android studio 3.6.0 綁定視圖新特性

Android studio 3.6.0 綁定視圖使用方法

1.確保你的 build gradle 最低爲3.6.0

​
dependencies {

        classpath 'com.android.tools.build:gradle:3.6.0'
        
   
    }

​

2、在你的項目裏的build gradle配置以下代碼,注意 是在 android { } 裏面配置 

android{

     viewBinding{

           enabled = true;  }

      }


android {
    
   //.........

    viewBinding { 

        enabled = true;
    }

}

dependencies {
   //.......
}

3、代碼使用方法

如果你的 MainActivity 加載的是 activity_main.xml 文件,那麼你在 MainActivity 就可以使用 ActivityMainBinding

來綁定,注意ActivityMainBinding 是根據你的xml文件名生成的 如果你是login_activity.xml 那麼會對應的來生成

LoginActivityBinding。

原來的onCreate方法是這樣的

public class MainActivity extends Activity {
    
  
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        
         setContentView(R.layout.activity_main);
        
    }

使用綁定視圖之後是這樣的

public class MainActivity extends Activity {
    
    ActivityMainBinding binding;//這個是你對用的XML文件生成的
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        
        binding = ActivityMainBinding.inflate(getLayoutInflater());
        setContentView(binding.getRoot());
        
    }

假如你的佈局裏有 TextView 和 Button 兩個組件 id 分別爲 text 和 button  如下

 <LinearLayout
        android:orientation="vertical"
        android:layout_width="match_parent"
        android:layout_height="match_parent">
        
        <TextView
            android:id="@+id/text"
            android:layout_width="match_parent"
            android:layout_height="wrap_content">
        </TextView>

        <Button
            android:id="@+id/button"
            android:layout_width="match_parent"
            android:layout_height="wrap_content">
        </Button>
        
    </LinearLayout>

那麼視圖綁定功能的使用時這樣的,省去了findViewById的過程

​
public class MainActivity extends Activity {
    
    ActivityMainBinding binding;//這個是你對用的XML文件生成的
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        
        binding = ActivityMainBinding.inflate(getLayoutInflater());
        setContentView(binding.getRoot());
        
    }

        
    protected void initView() {

        binding.text.setText("視圖綁定練習");
        binding.button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                //按鈕點擊事件
            }
        });
    }

​}

簡單的使用記錄下,適配器,Fragment等綁定基本差不太多,歡迎自行探索


public class FragmentOne extends BaseFragment{
    FragmentOneBinding binding;
   
    @Override
    public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup 
                              container, @Nullable Bundle savedInstanceState) {

        View view = inflater.inflate(R.layout.fragment_one,container,false);
        binding = FragmentOneBinding.bind(view);
        return view;

    }
}

 

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