当前位置:   article > 正文

初探ViewBinding_viewbinding 初始化

viewbinding 初始化

视图访问的方式有常用的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

  1. buildscript {
  2. ……
  3. dependencies {
  4. classpath "com.android.tools.build:gradle:3.6.0-beta01"
  5. }
  6. }

然后在app中开启viewbinding

  1. apply plugin: 'com.android.application'
  2. android {
  3. ……
  4. defaultConfig {
  5. ……
  6. viewBinding {
  7. enabled = true
  8. }
  9. }
  10. ……
  11. }

接下来新建一个布局文件activity_view_binding,内容如下

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. xmlns:app="http://schemas.android.com/apk/res-auto"
  4. xmlns:tools="http://schemas.android.com/tools"
  5. android:layout_width="match_parent"
  6. android:layout_height="match_parent">
  7. <TextView
  8. android:id="@+id/text"
  9. android:layout_width="wrap_content"
  10. android:layout_height="wrap_content"
  11. android:layout_margin="10dp"
  12. app:layout_constraintStart_toStartOf="parent"
  13. app:layout_constraintTop_toTopOf="parent"
  14. tools:text="111" />
  15. <android.support.v7.widget.AppCompatImageView
  16. android:id="@+id/image"
  17. android:layout_width="0dp"
  18. android:layout_height="0dp"
  19. android:layout_margin="10dp"
  20. app:layout_constraintDimensionRatio="1:1"
  21. app:layout_constraintStart_toStartOf="parent"
  22. app:layout_constraintTop_toBottomOf="@id/text"
  23. app:layout_constraintWidth_percent="0.4" />
  24. </android.support.constraint.ConstraintLayout>

然后在Activity等需要使用布局的类中进行ViewBinding的初始化及使用,如下

  1. public class ViewBindingActivity extends AppCompatActivity {
  2. private ActivityViewBindingBinding viewBinding;
  3. @Override
  4. protected void onCreate(@Nullable Bundle savedInstanceState) {
  5. super.onCreate(savedInstanceState);
  6. viewBinding = ActivityViewBindingBinding.inflate(LayoutInflater.from(this));
  7. setContentView(viewBinding.getRoot());
  8. viewBinding.text.setText("view binding");
  9. viewBinding.image.setImageResource(R.color.black);
  10. }
  11. }

ViewBinding的初始化有三种方式,

  1. inflate(@NonNull LayoutInflater inflater);
  2. inflate(@NonNull LayoutInflater inflater, @Nullable ViewGroup parent, boolean attachToParent);
  3. 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也会越来越强大。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/从前慢现在也慢/article/detail/319964
推荐阅读
相关标签
  

闽ICP备14008679号