溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Android控件怎么設置寬高比

發(fā)布時間:2022-04-18 11:09:33 來源:億速云 閱讀:401 作者:iii 欄目:開發(fā)技術

本篇內容主要講解“Android控件怎么設置寬高比”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Android控件怎么設置寬高比”吧!

0. 困擾很久的問題

Android控件的寬和高保持比例,這是從我接觸Android以來,一直不斷會遇到的需求。以前,要么就是在代碼里直接設置寬和高,要么就是自定義控件。網上也有開源的自定義ViewGroup,可以讓其子View比較方便的設置寬和高的比例。但這些實現(xiàn)方式,還是比較麻煩,也不夠直觀。直到有了DataBinding,我們可以很方便地給控件加上自定義的屬性,也就可以很方便的在布局文件中設置控件的寬高比了。

1. 如何實現(xiàn)

通過BinderAdapter為所有View綁定下面的方法,當設置widthHeightRatio屬性時,會調用下面這個方法。這個有點AOP的意思,我們針對所有的View做了處理。

public class DataBindingAdapters {
  // 根據View的高度和寬高比,設置高度
  @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);
        }
      }
    });
  }
}

我們在獲取到控件的高度后,根據比例計算寬度,然后設置給控件。這里注冊了OnGlobalLayoutListener,是因為控件的高度有可能還沒計算完成。在獲取到高度之后,移除監(jiān)聽,避免多余的調用。

<ImageView
  android:layout_width="120dp"
  android:layout_height="match_parent"
  app:widthHeightRatio="@{1}"/>

然后我們就可以在布局文件中直接設置寬高比了。這個布局文件必須使用DataBinding,也就是最外層要用layout標簽。屬性值必須加上@{},不然是按普通屬性處理的,不會調用我們的方法,編譯時會因為找不到屬性報錯。當然,這個屬性只能根據高度計算寬度,如果要根據寬度計算高度,可以用同樣的方式再加一個屬性。

2. 原理簡析

其實在編譯后的layout文件中是沒有我們加的屬性的(編譯后的layout文件在build/intermediates/data-binding-layout-out下面可以看到)。真正設置這個屬性,還是在Java代碼中直接調用了我們綁定的方法。在DataBinding自動生成的Binding類中,可以發(fā)現(xiàn)有類似下面這樣的調用。

復制代碼 代碼如下:


DataBindingAdapters.setWidthHeightRatio(this.mboundView0, cardWidthHeightRatio);

這里只是做一個簡單的解釋,至于在什么時機會觸發(fā)這行代碼,敬請期待我后續(xù)的文章。

3. BinderAdapter的其他妙用

ImageView自動加載網絡圖片

@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);
  }
}

直接在布局文件中設置要加載的圖片的url,和加載失敗時顯示的默認圖。

到此,相信大家對“Android控件怎么設置寬高比”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續(xù)學習!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI