華為等申請 “聲紋識別”專利:解決聲紋識別魯棒性低的問題
技術標籤: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("友情提示");
}
}