赞
踩
视图访问的方式有常用的findViewById,ButterKnife等多种方式,这些方式的各方面对比如下
如上图所示,在简明、编译安全和编译速度上都各有优势,那么有没有一种方式可以一石 "三" 鸟呢。谷歌在Android Studio 3.6 Canary 11版本中正式推出视图绑定(View Binding),来看下使用方法,
首先需要使用AS 3.6 Canary 11之上的版本,这里我们使用AS 3.6 Beta 1(也可以使用最新的AS 4.0 Canary 01),升级gradle plugin版本到3.6.0 beta01
- buildscript {
- ……
- dependencies {
- classpath "com.android.tools.build:gradle:3.6.0-beta01"
- }
- }
然后在app中开启viewbinding
- apply plugin: 'com.android.application'
-
- android {
- ……
- defaultConfig {
- ……
-
- viewBinding {
- enabled = true
- }
- }
- ……
- }
接下来新建一个布局文件activity_view_binding,内容如下
- <?xml version="1.0" encoding="utf-8"?>
- <android.support.constraint.ConstraintLayout 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"
- android:layout_width="match_parent"
- android:layout_height="match_parent">
-
- <TextView
- android:id="@+id/text"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:layout_margin="10dp"
- app:layout_constraintStart_toStartOf="parent"
- app:layout_constraintTop_toTopOf="parent"
- tools:text="111" />
-
- <android.support.v7.widget.AppCompatImageView
- android:id="@+id/image"
- android:layout_width="0dp"
- android:layout_height="0dp"
- android:layout_margin="10dp"
- app:layout_constraintDimensionRatio="1:1"
- app:layout_constraintStart_toStartOf="parent"
- app:layout_constraintTop_toBottomOf="@id/text"
- app:layout_constraintWidth_percent="0.4" />
- </android.support.constraint.ConstraintLayout>
然后在Activity等需要使用布局的类中进行ViewBinding的初始化及使用,如下
- public class ViewBindingActivity extends AppCompatActivity {
- private ActivityViewBindingBinding viewBinding;
-
- @Override
- protected void onCreate(@Nullable Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- viewBinding = ActivityViewBindingBinding.inflate(LayoutInflater.from(this));
- setContentView(viewBinding.getRoot());
- viewBinding.text.setText("view binding");
- viewBinding.image.setImageResource(R.color.black);
- }
- }
ViewBinding的初始化有三种方式,
- inflate(@NonNull LayoutInflater inflater);
- inflate(@NonNull LayoutInflater inflater, @Nullable ViewGroup parent, boolean attachToParent);
- bind(@NonNull View rootView);
ViewBinding不用再手动进行类型转换,也避免了空指针错误。如果不想生成ViewBinding,可以在布局的根视图上使用tools:viewBindingIgnore="true"。
当然ViewBinding现在还是测试阶段,也有很多问题,例如tools:viewBindingIgnore有时会无效;如果你的布局名称比较长的时候,生成的ViewBinding类也比较长,没有自定义生成ViewBinding类名称的方式;视图id比较长的时候,生成的对象名称也比较长。
在Butterknife的github主页上也有这样一段话,
Attention: Development on this tool is winding down. Please consider switching to view binding in the coming months.
看来JakeWharton还是比较推荐自家的ViewBinding,大家可以开始尝试使用,如果有问题可以进行反馈,相信ViewBinding也会越来越强大。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。