本篇內(nèi)容主要講解“Android控件怎么設(shè)置寬高比”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學(xué)習(xí)“Android控件怎么設(shè)置寬高比”吧!
0. 困擾很久的問題
Android控件的寬和高保持比例,這是從我接觸Android以來,一直不斷會遇到的需求。以前,要么就是在代碼里直接設(shè)置寬和高,要么就是自定義控件。網(wǎng)上也有開源的自定義ViewGroup,可以讓其子View比較方便的設(shè)置寬和高的比例。但這些實現(xiàn)方式,還是比較麻煩,也不夠直觀。直到有了DataBinding,我們可以很方便地給控件加上自定義的屬性,也就可以很方便的在布局文件中設(shè)置控件的寬高比了。
1. 如何實現(xiàn)
通過BinderAdapter為所有View綁定下面的方法,當(dāng)設(shè)置widthHeightRatio屬性時,會調(diào)用下面這個方法。這個有點AOP的意思,我們針對所有的View做了處理。
public class DataBindingAdapters { // 根據(jù)View的高度和寬高比,設(shè)置高度 @BindingAdapter("widthHeightRatio") public static void setWidthHeightRatio(final View view, final float ratio) { view.getViewTreeObserver().addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() { @Override public void onGlobalLayout() { int height = view.getHeight(); if (height > 0) { view.getLayoutParams().width = (int) (height * ratio); view.invalidate(); view.getViewTreeObserver().removeGlobalOnLayoutListener(this); } } }); } }
我們在獲取到控件的高度后,根據(jù)比例計算寬度,然后設(shè)置給控件。這里注冊了OnGlobalLayoutListener,是因為控件的高度有可能還沒計算完成。在獲取到高度之后,移除監(jiān)聽,避免多余的調(diào)用。
<ImageView android:layout_width="120dp" android:layout_height="match_parent" app:widthHeightRatio="@{1}"/>
然后我們就可以在布局文件中直接設(shè)置寬高比了。這個布局文件必須使用DataBinding,也就是最外層要用layout標(biāo)簽。屬性值必須加上@{},不然是按普通屬性處理的,不會調(diào)用我們的方法,編譯時會因為找不到屬性報錯。當(dāng)然,這個屬性只能根據(jù)高度計算寬度,如果要根據(jù)寬度計算高度,可以用同樣的方式再加一個屬性。
2. 原理簡析
其實在編譯后的layout文件中是沒有我們加的屬性的(編譯后的layout文件在build/intermediates/data-binding-layout-out下面可以看到)。真正設(shè)置這個屬性,還是在Java代碼中直接調(diào)用了我們綁定的方法。在DataBinding自動生成的Binding類中,可以發(fā)現(xiàn)有類似下面這樣的調(diào)用。
復(fù)制代碼 代碼如下:
DataBindingAdapters.setWidthHeightRatio(this.mboundView0, cardWidthHeightRatio);
這里只是做一個簡單的解釋,至于在什么時機會觸發(fā)這行代碼,敬請期待我后續(xù)的文章。
3. BinderAdapter的其他妙用
ImageView自動加載網(wǎng)絡(luò)圖片
@BindingAdapter({"android:src", "error"}) public static void setImageUrl(ImageView view, String url, @DrawableRes int errorImage) { if (!TextUtils.isEmpty(url)) { // 封裝好的圖片加載工具 ImageManager.from(view.getContext()).displayImage(view, url, errorImage); } else { view.setImageResource(errorImage); } }
直接在布局文件中設(shè)置要加載的圖片的url,和加載失敗時顯示的默認(rèn)圖。
到此,相信大家對“Android控件怎么設(shè)置寬高比”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)建站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
名稱欄目:Android控件怎么設(shè)置寬高比-創(chuàng)新互聯(lián)
網(wǎng)頁鏈接:http://www.chinadenli.net/article36/dcihpg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、網(wǎng)站營銷、虛擬主機、網(wǎng)站設(shè)計公司、ChatGPT、動態(tài)網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容