1. 程式人生 > 遊戲 >《GTA6》海量細節洩露:可能在2023年10月發售 主線60個小時

《GTA6》海量細節洩露:可能在2023年10月發售 主線60個小時

技術標籤:Androidandroidjavaandroid studiokotlin

Android Jetpack ViewBinding的使用

1. ViewBinding概述

使用ViewBinding的目的是輕鬆地編寫可與檢視互動的程式碼。將view和程式碼繫結在一起有多種方法:

(1)findViewById:編譯不安全,出現大量模版,並且存在型別轉換問題。

(2)ButterKnife:編譯速度慢,不安全,存在型別轉換問題

(3)Kotlin Android Extensions:存在安全問題,谷歌已經不建議使用Kotlin Android擴充套件,這意味著不再支援使用Kotlin合成進行檢視繫結。

而ViewBinding中, 產生的binding類中的屬性是依據XML layout檔案生成的,所以Id不會錯,將繫結view的模板程式碼自動生成到了其他類中,使controlor類(Activity,Fragment)更加清晰了。

2. ViewBing的配置

注意:檢視繫結在Android Studio 3.6 Canary 11 及更高版本中可用

(1)檢視繫結功能可按模組啟用。要在某個模組中啟用檢視繫結,可在對應模組的 build.gradle檔案中配置如下:

android {
        ...
        viewBinding {
            enabled = true
        }
    }

(2)如果您希望在生成繫結類時忽略某個佈局檔案,請將tools:viewBindingIgnore="true"屬性新增到相應佈局檔案的根檢視中:

<LinearLayout
            ...
            tools:viewBindingIgnore="true" >
        ...
    </LinearLayout>

(3)在gradle檔案中開啟ViewBinding功能後,編譯器就會為此模組下的每個佈局檔案都產生一個對應的繫結類。

生成類的的命名規則為: XML 檔案的名稱轉換為駝峰式大小寫,在末尾加上Binding。例如您有一個佈局檔案activity_main.xml,那對應生成的類檔案為ActivityMainBinding.java

3. ViewBing的使用

(1) 在 Activity 中使用檢視繫結

public class MainActivity extends AppCompatActivity {
    private ActivityMainBinding mBinding;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        mBinding = ActivityMainBinding.inflate(getLayoutInflater());
        setContentView(mBinding.getRoot());
        mBinding.tvName.setText("ethan");
    }
}

(2) 在 Fragment 中使用檢視繫結

public class MainFragment extends Fragment {
    private FragmentMainBinding mBinding;

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
        mBinding = FragmentMainBinding.inflate(inflater, container, false);
        mBinding.tvAddress.setText("北京市");
        return mBinding.getRoot();
    }
}

(3) 在 Dialog中使用檢視繫結

Dialog dialog = new Dialog(getContext());
        DialogTipBinding dialogTipBinding = DialogTipBinding.inflate(LayoutInflater.from(getContext()));
        dialog.setContentView(dialogTipBinding.getRoot());
        dialogTipBinding.tvTip.setText("溫馨提示");
        dialog.show();

(4) 在 RecyclerView.Adapter中使用檢視繫結

public class MyAdapter extends RecyclerView.Adapter<MyAdapter.MyViewHolder> {

    private List<String> mDataList;

    public MyAdapter(List<String> mDataList) {
        this.mDataList = mDataList;
    }

    @NonNull
    @Override
    public MyViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
        RecyclerItemAdapterBinding binding = RecyclerItemAdapterBinding.inflate(LayoutInflater.from(parent.getContext()), parent, false);
        MyViewHolder myViewHolder = new MyViewHolder(binding);
        return myViewHolder;
    }

    @Override
    public void onBindViewHolder(@NonNull MyViewHolder holder, int position) {
        holder.mBinding.tvPrice.setText(mDataList.get(position));
    }

    @Override
    public int getItemCount() {
        return this.mDataList.size();
    }

    class MyViewHolder extends RecyclerView.ViewHolder {
        RecyclerItemAdapterBinding mBinding;
        public MyViewHolder(@NonNull RecyclerItemAdapterBinding binding ) {
            super(binding.getRoot());
            mBinding = binding;
        }
    }
}

(4) 在 Layout 檔案中有include使用檢視繫結

新建include_card_tip.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical" android:layout_width="match_parent"
    android:layout_height="match_parent">

    <TextView
        android:id="@+id/tvTip"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"/>
</LinearLayout>
public class MainActivity extends AppCompatActivity {
    private ActivityMainBinding mBinding;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        mBinding = ActivityMainBinding.inflate(getLayoutInflater());
        setContentView(mBinding.getRoot());
        IncludeCardTipBinding includeCardTipBinding = IncludeCardTipBinding.bind(mBinding.getRoot());
        includeCardTipBinding.tvTip.setText("友情提示");
    }
}