让预览 RecyclerView 效果更方便的一个小技巧

简评:使用 "@tools:sample/*" 资源来让 RecyclerView(或 ListView)的效果预览更方便。

相信在大多数的 Android 开发中都会和 RecyclerView(或者 ListView)打交道。常有的一个问题就是在编码时,怎么方便的看到和调整每个 item 的显示效果。

当然啦,有经验一的开发者肯定都知道用 tools:namespace 来帮忙,今天要介绍的当然不只是这么简单。

首先,假设我们要实现的效果类似下面这样(每个 item 左边还有个头像):

这里就是通过* tools:text* 来在 Android Studio 的 Preview 视图中直接显示一些简单内容(ImageView 也可以使用 tools:src)。

 <TextView
    android:id="@+id/name"
    ...
    tools:text="Mark Allison"/>

现在,在 Android Studio 3.0 或以上版本中我们有了更好的方法来在开发时直接显示一些示例数据 - 那就是使用 "tools:sample/" 中提供的数据。*

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout
  ...>

  <ImageView
    android:id="@+id/avatar"
    ...
    tools:src="@tools:sample/avatars" />

  <TextView
    android:id="@+id/name"
    ...
    tools:text="@tools:sample/full_names" />

  <TextView
    android:id="@+id/city"
    ...
    tools:text="@tools:sample/cities" />

  <TextView
    android:id="@+id/date"
    ...
    tools:text="@tools:sample/date/ddmmyy" />

  <TextView
    android:id="@+id/description"
    ...
    tools:text="@tools:sample/lorem/random" />

</android.support.constraint.ConstraintLayout>

效果:

当然,这些自带的数据很可能没办法满足你的需求(比如只有英文),我们还可以自己创建 Sample 数据:

点击之后,文件实际所在的位置:

添加头像图片(这里用的是 Android 矢量图,也可以是其他格式的图片):

 <ImageView
    android:id="@+id/avatar"
    ...
    tools:src="@sample/avatars" />

更棒的地方在于,我们还可以通过 JSON 文件的方式来组织我们的数据。比如,创建一个名为 users.json 的文件:

{
  "data": [
    {
      "city": "北京",
      "avatar": "@sample/avatars",
    },
    {
      "city": "上海",
      "avatar": "@sample/avatars"
    },
    {
      "city": "广州",
      "avatar": "@sample/avatars"
    },
    {
      "city": "深圳",
      "avatar": "@sample/avatars"
    }
  ]
}

item 的部分布局代码:

<ImageView
  android:id="@+id/avatar"
  ...
  tools:src="@sample/users.json/data/avatar" />

<TextView
  android:id="@+id/city"
  ...
  tools:text="@sample/users.json/data/city" />
...

此外,定义的这些 sample data 不会被打包到 APK 中,因此不必担心会增加应用的体积。

官方文档:https://developer.android.com/studio/write/tool-attributes.html#toolssample_resources
英文原文:Tool Time – Part 1 & Tool Time – Part 2
推荐阅读:在 Android 中实现 Redux 的一点经验

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 173,523评论 25 708
  • 这个女生,是一个大学里的校友。 今天用了谢依霖姐姐的图片,只想表达,像谢依霖这样直率的女神才能收拾今天这个没有人喜...
    紫柴子阅读 397评论 0 1
  • 我一直在思考,思考我为什么睡不着,为什么不开心,为什么这世上有形形色色的人和事,甚至是为什么我们会存在。 后来才发...
    人若无心会如何阅读 410评论 1 1
  • 1.看到他妳的心情怎樣?身體有什麽感覺? 一般吧,身體沒啥反應。 回答第二題時看幾次圖後,心情開始變陰鬱,喉嚨開始...
    秀ShirleyZ阅读 185评论 0 1
  • 8、Love & faith,爱和信仰同在 来丽江三年,差不多每年会去一次梅里雪山。跟不同的人去,走不同的路,许同...
    岁亦莫止阅读 243评论 0 2