冒死总结!有些地方不知道怎么描述,自己动手感受一番吧。
我只总结了前面五分多钟讲的快捷方式。后面的高级技巧我还在学习中,坑慢慢填。
已将 Tor Norbye 演讲的编辑技巧补充完。
昨天@陈启超同学发了 Android Studio for Experts (Android Dev Summit 2015) 的视频,我也跟着学习了一下。这个视频讲的非常好!做点小结,分享交流。
使用 Tab 补全,会自动编辑光标之后的字符串,如下,你在光标处键入 c 然后选择 contentEquals
然后回车,magic!
c.png
使用 ctrl + shift + space 智能补全,比如下图,按下组合键,magic!可以按两次哦!
c2.png
补充一个,尝试在编辑器中输入: new Bitmap().var
ctrl+ w 选中,继续操作会扩大选中范围,相反的操作是 ctrl + shift + w
选中后可以使用 Extra 快捷键重构为变量、方法等,这个可以在 Refactor -> Extra 下看到。
ctrl+ alt+ v:变量
ctrl+ alt+ c:常量
ctrl+ alt+ f:域值
ctrl+ alt+ p:参数
ctrl+ alt+ m:方法
这里我有一个快捷键没有听出来,就是从构造函数提取 parameters 为 fields,
public static class Init { public Init(String first, boolean second, int third) { } }
这个内容极度丰富,我以前发过微博,可以在 Setting -> Editor -> Live Templates 下查看。举几个例子:
fori
和 foreach
,在需要使用 for
循环时,尝试输入这两种 for
试试;
你还可以在数据集合变量后输入 .for
,例如 list.for
,这时候你看一下补全,会列出三种 for
循环形式让你选择;
logt
, logd
, logm
,在方法外输入 logt
,在方法内输入 logd
试试;
另外还有 fbc
, gone
, iter
等等,感兴趣的话可以在 Setting -> Editor -> Live Templates 下看看。
接下来可以说是牛哄哄的技巧了,同时也说明 Android Studio 真是强大!
这里就不得不贴上很多代码了。比如以下资源文件,现在你想去掉所有的 translation_description
,技巧是使用 双击 shift 或者 ctrl + shift + a 调出搜索框然后搜索并选择 replace structurally ,编辑规则,选择 find,然后就可以十分便捷的批量修改了。
<resources> <string name="a_fragment" translation_description="false">Hello blank fragment</string> <string name="s_fragment" translation_description="false">Hello blank fragment</string> <string name="d_fragment" translation_description="false">Hello blank fragment</string> <string name="f_fragment" translation_description="false">Hello blank fragment</string> </resources>
rs.png
另外你还可以把这个加入设置中,由编辑器自动检查,不符合规则的代码就会变黄,alt + enter 组合键进行修改。
ssi.png
这个方法对 java 源码同样适用,只需要修改 file type。
这个和 Replace Structurally 大同小异,不再赘述,请自行尝试一下吧,^_^。
在写好布局文件后,我们可能想要直接看一下 preview 效果,但是不想在编译时还预设这些属性和值,这个时候可以使用 tools 这个强大的工具。
首先我们要在布局文件中声明 xmlns:tools="http://schemas.android.com/tools"
,放在最外层的 layout 就好。
<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" ...
使用起来跟 xmlns:android
没有什么差别。
<TextView android:id="@+id/tv" android:text="Hello World!" android:layout_width="wrap_content" android:layout_height="wrap_content" tools:visibility="visible" tools:text="tools" />
这里面比较逆天的是 tools:listitem
,看下面这段代码!
<GridView android:id="@android:id/list" android:layout_width="match_parent" android:layout_height="match_parent" tools:numColumns="4" tools:listitem="@android:layout/simple_list_item_2" />
猜到了吗?它可以直接让我们 preview GridView的效果!
tools.png
如果你够细心的话一定会发现异常:那就是那个ToolBar 和 FAB 哪来的?!因为有 tools:showIn
。这个属性声明在最顶层的 layout,值是 include 了本布局的一个父布局,它使得预览本布局时同时会渲染该父布局。
更多的 tools attributes 可以访问官方文档 Android Tools Project Site: Tools Attributes
Android studio 默认 library 的所有 resource 为 public,如果想保护某些 resources 不被外部访问,可以创建 res/values/public.xml,因为 public 是关键词,所以需要用 new file 的方式创建。至少要添加一行,未添加的则视为 private。
<resources> <public name="mylib_app_name" type="string"/> </resources>
参考: Public and Private Resources
另外,如果在 library 的 build.gradle 中添加 resourcePrefix
,则所有资源必须以此 prefix 开头,否则会报错。
android { ... buildTypes { ... } resourcePrefix 'my_prefix_' }
这一段讲解了一个减少未使用的资源文件的技巧,可以参考官方文档: Android Tools Project Site: Resource Shrinking ,我就不做二次消化了。