Android基礎入門之dataBinding的簡單使用教程
前言
dataBinding是實現(xiàn) view 和 data 綁定的工具,把數(shù)據(jù)映射到 view 的 xml中,可以在 xml 布局文件中實現(xiàn) view 的賦值,方法調用。使用 DataBinding 后,我們不用再寫 findViewById,不用再獲取控件對象,不用再設置監(jiān)聽,可以節(jié)省我們 activity 中的很多獲取控件,賦值,添加監(jiān)聽所需要的代碼。
可以說MVP + DataBinding就是MVVC(關于MVC,MVP,MVVC的區(qū)別可看往期文章)
1.前期準備
1.1打開dataBinding

1.2修改布局文件
選中布局文件的第一行,按alter+enter就會彈出提示,默認選中data binding layout


改造好的的新的布局文件里最大的變化就是多了一對<data></data>標簽;很容易想到這是為了實現(xiàn)布局文件里數(shù)據(jù)和布局的分離,以及更好的實現(xiàn)數(shù)據(jù)與視圖的雙向綁定(這里文章后面會慢慢介紹)

1.3修改Activity方法
修改好布局文件之后,還需要對Activity文件做修改
使用了dataBinding之后,編譯器會自動幫我們生成一個類名+Binding的新類,這其實是編譯器幫我們把布局文件轉換成了一個java文件,可以看到我們通過ctrl+鼠標左鍵點擊這個類可以直接訪問到布局文件


除此之外還需要為mainBinding這個對象賦初值,同樣是通過setContentView方法,不過要傳入兩個參數(shù),前者是Activity類,后者是布局文件的id
mainBinding=DataBindingUtil.setContentView(this,R.layout.activity_main);


2.DataBinding的使用
2.1屬性更新
那么如何使用dataBingding呢?
我們先在布局文件中新建幾個控件,這里我的兩個控件:文本控件的id是textview,按鈕控件的id是button

回到Activity中,我們通過mainBInding對象可以看到,其下有兩個值,textView和button,這正是我們剛剛兩個組件的id,所以通過mainBinding對象我們可以輕松的取到我們布局文件里的組件,不再需要findViewById了

通過mainBinding獲取到組件同樣的可以設置這些控件的各種屬性

2.2<data>標簽
之前有提到在<data></data>標簽中定義數(shù)據(jù)
在<androidx.constraintlayout.widget.ConstraintLayout>中定義布局并且綁定數(shù)據(jù),這類似于前端vue框架中的數(shù)據(jù)視圖雙向綁定
2.2.1簡單數(shù)據(jù)的定義與綁定
那么如何在data標簽中定義數(shù)據(jù)呢?
通過標簽,定義數(shù)據(jù)的名字name和類型type,這個類型可以是java中的所有基本類型

然后到布局中,用插值表達式將數(shù)據(jù)替代掉

不過現(xiàn)在什么也不會顯示,因為這兩個變量只定義了,沒有賦值

看到這,我們也明白data標簽的好處之一了,數(shù)據(jù)的定義都在data標簽中,而constraint中就只管布局,通過插值表達式來綁定數(shù)據(jù),不會出現(xiàn)數(shù)據(jù)。
那么data標簽里的數(shù)據(jù)又如何初始化賦值呢?
這部分邏輯操作就交給Activity了。每定義一個varible,在布局的Binding類中都會生成此變量的get和set方法,通過這兩個方法我們對數(shù)據(jù)進行初始化和更新。


所以有了dataBinding我們極大的減輕了Activity所要做的操作,Activity可以更專注于對數(shù)據(jù)與邏輯的處理,而UI的獲取與數(shù)據(jù)和UI的綁定都交給了布局文件。
2.2.2復雜數(shù)據(jù)的定義與綁定
我們嘗試一下類類型的數(shù)據(jù)的定義與綁定
先定義一個簡單的實體類,簡單的寫兩個屬性

在data中定義一個類變量,name屬性的同樣是這個變量的名字,type屬性就是這個包名.類名

數(shù)據(jù)的綁定也是一樣的,通過類變量的名字.屬性,所以我們可以把類變量person看成Person類new 出來的一個對象

回到Activity中對類變量進行初始化,運行可以看到UI上的數(shù)據(jù)已經(jīng)更新了

2.3事件綁定
dataBinding可以把事件以數(shù)據(jù)的形式綁定到布局文件中
2.3.1點擊事件綁定
首先我們在Activity中定義一個內(nèi)部類

然后在data標簽中定義這個內(nèi)部類的變量

通過onClick屬性實現(xiàn)事件的綁定,值得注意的是myclick.onClick方法后沒有括號;這樣簡單的幾行代碼就實現(xiàn)了事件的綁定。用戶每點擊一次按鈕都會調用MyClick類中的onClick()方法
android:onClick="@{myclick.onClick}"

而Activity只需要做的事情就是初始化這個點擊事件。因為此時事件已經(jīng)被當成數(shù)據(jù)在使用了,通過set方法設置Myclick的值即可。然后打印日志查看運行效果
mainBinding.setMyclick(new MyClick());

可以看到每點擊一次按鈕都會打印一次日志,說明調用成功

2.3.2點擊事件回傳數(shù)據(jù)
我們看到onClick()方法中,我們傳入的是view參數(shù),那可以傳其他參數(shù)嗎?
public class MyClick{
public void onClick(View view){
Log.i("myclick", "onClick: 點贊成功!");
}
}
當然是可以的而且我們是通過這一種方法事件點擊回傳數(shù)據(jù)。如我們把Person作為參數(shù)傳入,并綁定點擊事件,那么用戶點擊按鈕,又可以將數(shù)據(jù)傳回到Activity中。
改造一下onClick()方法,傳入?yún)?shù)改為Person

并在布局文件中重新綁定,這里綁定事件也有點不同了,需要用到lambda表達式
android:onClick="@{()->myclick.onClick(person)}"

點擊按鈕,可以看到把person中的數(shù)據(jù)傳了回來;

2.3.3動態(tài)改變對象數(shù)據(jù)在控件上顯示
默認情況下,在點擊事件監(jiān)聽方法中修改person對象的值并不會修改數(shù)據(jù)在控件上的顯示

如果我們要實現(xiàn)事件監(jiān)聽動態(tài)去改變控件上的數(shù)據(jù)的話,我們需要對Person類動一動手腳
讓Person類繼承BaseObservable類,并為每個屬性生成get和set方法

在點擊事件監(jiān)聽方法中通過調用set方法設置新的值,來修改person對象的值并在控件上的顯示

2.3.4動態(tài)改變基本數(shù)據(jù)在控件上顯示
首先在Activity中定義一個name變量,不過需要使用ObservableField類包裝

其后在data標簽中定義一個name變量,并將其綁定在一個新的文本控件上。
這里值得注意的是在<>符號里不能再出現(xiàn)<>,所以我們使用轉義符<和>

最后在單擊事件方法中更新name的值,這個值就會動態(tài)的更新在界面上


2.4與輸入控件結合
首先在界面中添加一個新的輸入控件,并為其綁定一個變量,這里我就綁定name變量。那么我們剛剛把name變量綁定在一個文本控件上,現(xiàn)在又把name綁定在一個輸入控件上。那么我們在輸入控件中對name變量的改變會及時更新顯示在文本控件上嗎?


當然是可以的不夠我們的數(shù)據(jù)綁定要做一個小小的修改,僅僅添加了一個等于符號,那這個實時輸入顯示的功能就實現(xiàn)啦?。?!
android:text="@={name}"

動圖看一下效果

2.5與圖片控件結合
通過dataBinding和imageView和Glide的結合使用,可以很方便的加載一張網(wǎng)絡圖片
第一步我們還是先在布局文件中添加一個圖片控件

然后添加Glide依賴和網(wǎng)絡請求權限
//引入第三方庫glide
implementation 'com.github.bumptech.glide:glide:4.13.0'
annotationProcessor 'com.github.bumptech.glide:compiler:4.13.0'


然后再Activity中創(chuàng)建一個靜態(tài)的公共的方法,傳入imageView和網(wǎng)絡圖片的url兩個參數(shù);并為其添加一個注解BindingAdapter()
@BindingAdapter("imageUrl")
public static void bindImageUrl(ImageView view,String url){
Glide.with(view)
.load(url)
.into(view);
}

然后在布局文件中就出現(xiàn)了一個imageUrl的屬性,通過這個屬性我們?yōu)槲覀兊膱D片組件動態(tài)的添加網(wǎng)絡圖片。這里為了方便我還是綁定@{name},在Activity中將name初始化為一個圖片的url



這其實是我們為控件自定義了一個屬性,名字叫imageUrl,(其實就是注解里的那個參數(shù),你取這個自定義的屬性叫什么它就叫什么)
總結
到此這篇關于Android基礎入門之dataBinding的簡單使用的文章就介紹到這了,更多相關Android dataBinding使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
解析Android開發(fā)優(yōu)化之:對界面UI的優(yōu)化詳解(二)
在一個應用程序中,一般都會存在多個Activity,每個Activity對應著一個UI布局文件。一般來說,為了保持不同窗口之間的風格統(tǒng)一,在這些UI布局文件中,幾乎肯定會用到很多相同的布局2013-05-05
Android中Activity啟動默認不顯示輸入法解決方法
這篇文章主要介紹了Android中Activity啟動默認不顯示輸入法解決方法,一般是因為包含checkbox控件導致Activity啟動默認不顯示輸入法,本文給出了正確解決方法,需要的朋友可以參考下2015-06-06
Android簡單的利用MediaRecorder進行錄音的實例代碼
MediaRecorder可以進行簡單的錄音,由于操作簡單所以可以用來進行基本的錄音。下面提供一個簡單的例子,記得在Mainfest文件中添加權限2013-08-08
Android編程實現(xiàn)下載時主界面與詳細界面一致更新的方法
這篇文章主要介紹了Android編程實現(xiàn)下載時主界面與詳細界面一致更新的方法,涉及Android事件監(jiān)聽及界面動態(tài)更新相關操作技巧,需要的朋友可以參考下2017-11-11

