本系列目錄
- 使用Data Binding(一)介紹
- 使用Data Binding(二)集成與配置
- 使用Data Binding(三)在Activity中的使用
- 使用Data Binding(四)在Fragment中的使用
- 使用Data Binding(五)數(shù)據(jù)綁定
- 使用Data Binding(六)RecyclerView Adapter中的使用
- 使用Data Binding(七)使用BindingAdapter簡(jiǎn)化圖片加載
- 使用Data Binding(八)使用自定義Interface
- 使用Data Binding Android Studio不能正常生成相關(guān)類/方法的解決辦法
什么是BindingAdapter
BindingAdapter用來(lái)設(shè)置布局中View的自定義屬性破婆,當(dāng)使用該屬性時(shí)币喧,可以自定義其行為。
下面是一個(gè)簡(jiǎn)單的例子:
@BindingAdapter("android:bufferType")
public static void setBufferType(TextView view, TextView.BufferType bufferType) {
view.setText(view.getText(), bufferType);
}
當(dāng)一個(gè)方法加上@BindingAdapter注解后确垫,就定義了一個(gè)BindingAdapter吟宦,注意方法的第一個(gè)參數(shù)是需要綁定到的View篮洁,第二個(gè)參數(shù)是綁定的屬性值。
當(dāng)定義完成后殃姓,此時(shí)我們就可以在布局的View中使用該屬性袁波,舉例如下:
<TextView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:bufferType="normal"
/>
當(dāng)TextView中加入了android:bufferType="normal"后,setBufferType()方法就會(huì)被調(diào)用蜗侈。
當(dāng)自定義其它一些屬性時(shí)篷牌,也遵循一樣的規(guī)則。
自定義圖片加載的BindingAdapter
由于BindingAdapter的特性踏幻,我們就可以為ImageView自定義一個(gè)BindingAdapter枷颊,從而大幅簡(jiǎn)化圖片加載的過(guò)程。
第一步该面,我們先新建一個(gè)ImageBindingAdapter的類夭苗,圖片相關(guān)的BindingAdapter可以都定義在這個(gè)類里面:
public class ImageBindingAdapter {
@BindingAdapter("imageUrl")
public static void bindImageUrl(ImageView view, String imageUrl){
RequestOptions options =
new RequestOptions()
.centerCrop()
.dontAnimate();
Glide.with(view)
.load(imageUrl)
.apply(options)
.into(view);
}
}
定義好后,我們就可以直接在布局中使用這個(gè)屬性了:
<ImageView
android:layout_width="180dp"
android:layout_height="180dp"
app:imageUrl="@{user.photo}"
/>
僅僅簡(jiǎn)單的一行代碼隔缀,就可以進(jìn)行網(wǎng)絡(luò)圖片的加載了题造,是不是感覺(jué)這個(gè)世界簡(jiǎn)單了很多?
除了這種單個(gè)參數(shù)的BindingAdapter猾瘸,它也支持多個(gè)參數(shù)界赔,這也是BindingAdapter強(qiáng)大的地方。
總結(jié)
使用BindingAdapter可以大大簡(jiǎn)化一些重復(fù)代碼牵触,本文主要介紹了加載圖片上的使用淮悼,你可以舉一反三,用在更多的場(chǎng)景中使用揽思,比如加載列表的數(shù)據(jù)等袜腥,這樣做以后也可以使您的代碼更加清晰高效。