Android之viewBing(視圖綁定)

首先我們需要從Android studio模塊編譯腳本中加入依賴:

    viewBinding {
        enabled = true

    }
  • 如圖
    在這裏插入圖片描述

佈局文件

在這裏插入圖片描述

放置了三個button

 <Button
     android:layout_below="@+id/id_text01"
     android:text="@string/view_binding"
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:id="@+id/id_button_1"
     ></Button>
 <Button
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:id="@+id/id_button_2"
     android:layout_below="@id/id_button_1"
     />

 <Button
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:id="@+id/id_button_3"
     android:layout_below="@id/id_button_2"
     android:text="@string/there_"
     />

加載佈局

  • 以前加載佈局
// 老辦法
setContentView(R.layout.activity_main);
  • 現在加載佈局
 // 新辦法
 ActivityMainBinding binding = ActivityMainBinding.inflate(getLayoutInflater());
 setContentView(binding.getRoot());
  • 對比
 // 老辦法
 setContentView(R.layout.activity_main);
 // 新辦法
 ActivityMainBinding binding = ActivityMainBinding.inflate(getLayoutInflater());
 setContentView(binding.getRoot());

獲得控件

  • 以前

findViewById(R.id.id_button_3).setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View v) {
        Toast.makeText(MainActivity.this, "我是傳統發放除法的", Toast.LENGTH_SHORT).show();
    }
});
  • 現在
binding.idButton2.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View v) {
        Toast.makeText(MainActivity.this,"2222", Toast.LENGTH_SHORT).show();
    }
});
  • 對比
binding.idButton2.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View v) {
        Toast.makeText(MainActivity.this,"2222", Toast.LENGTH_SHORT).show();
    }
});

findViewById(R.id.id_button_3).setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View v) {
        Toast.makeText(MainActivity.this, "我是傳統發放除法的", Toast.LENGTH_SHORT).show();
    }
});

需要說明的

首先可以注意到在xml的佈局文件裏面,控件id的名命都是依靠下劃線來進行分割的。
在這裏插入圖片描述
但是在java代碼中調用的時候,卻丟失了下劃線轉化成了駝峯命名。
在這裏插入圖片描述
這是因爲Android view的優化機制導致的。
如果想要細看的話可以打開自己編譯生成的文件。會多出來一個文件就是viewbinding自動生成的文件。
在這裏插入圖片描述

// Generated by view binder compiler. Do not edit!
package com.example.learnandroidfromgoogle.databinding;

import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Button;
import android.widget.RelativeLayout;
import android.widget.TextView;
import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.constraintlayout.widget.ConstraintLayout;
import androidx.viewbinding.ViewBinding;
import com.example.learnandroidfromgoogle.R;
import java.lang.NullPointerException;
import java.lang.Override;
import java.lang.String;

public final class ActivityMainBinding implements ViewBinding {
  @NonNull
  private final ConstraintLayout rootView;

  @NonNull
  public final Button idButton1;

  @NonNull
  public final Button idButton2;

  @NonNull
  public final RelativeLayout idRelative;

  @NonNull
  public final TextView idText01;

  private ActivityMainBinding(@NonNull ConstraintLayout rootView, @NonNull Button idButton1,
      @NonNull Button idButton2, @NonNull RelativeLayout idRelative, @NonNull TextView idText01) {
    this.rootView = rootView;
    this.idButton1 = idButton1;
    this.idButton2 = idButton2;
    this.idRelative = idRelative;
    this.idText01 = idText01;
  }

  @Override
  @NonNull
  public ConstraintLayout getRoot() {
    return rootView;
  }

  @NonNull
  public static ActivityMainBinding inflate(@NonNull LayoutInflater inflater) {
    return inflate(inflater, null, false);
  }

  @NonNull
  public static ActivityMainBinding inflate(@NonNull LayoutInflater inflater,
      @Nullable ViewGroup parent, boolean attachToParent) {
    View root = inflater.inflate(R.layout.activity_main, parent, false);
    if (attachToParent) {
      parent.addView(root);
    }
    return bind(root);
  }

  @NonNull
  public static ActivityMainBinding bind(@NonNull View rootView) {
    // The body of this method is generated in a way you would not otherwise write.
    // This is done to optimize the compiled bytecode for size and performance.
    String missingId;
    missingId: {
      Button idButton1 = rootView.findViewById(R.id.id_button_1);
      if (idButton1 == null) {
        missingId = "idButton1";
        break missingId;
      }
      Button idButton2 = rootView.findViewById(R.id.id_button_2);
      if (idButton2 == null) {
        missingId = "idButton2";
        break missingId;
      }
      RelativeLayout idRelative = rootView.findViewById(R.id.id_relative);
      if (idRelative == null) {
        missingId = "idRelative";
        break missingId;
      }
      TextView idText01 = rootView.findViewById(R.id.id_text01);
      if (idText01 == null) {
        missingId = "idText01";
        break missingId;
      }
      return new ActivityMainBinding((ConstraintLayout) rootView, idButton1, idButton2, idRelative,
          idText01);
    }
    throw new NullPointerException("Missing required view with ID: ".concat(missingId));
  }
}

本文參考了以下內容:

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章