溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何解決android顯示內(nèi)容被底部導(dǎo)航欄遮擋的問題

發(fā)布時(shí)間:2021-07-14 09:32:22 來源:億速云 閱讀:393 作者:小新 欄目:移動(dòng)開發(fā)

這篇文章將為大家詳細(xì)講解有關(guān)如何解決android顯示內(nèi)容被底部導(dǎo)航欄遮擋的問題,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

描述:

由于產(chǎn)品需求,要求含有EditText的界面全屏顯示,最好的解決方式是使用AndroidBug5497Workaround.assistActivity(this)

的方式來解決,但是華為和魅族手機(jī)系統(tǒng)自帶的有底部導(dǎo)航欄,會(huì)造成一些布局被遮擋。

解決方案:在values-21的style.xml中添加android:windowDrawsSystemBarBackgrounds”并將值設(shè)置為false,方式如下

在style引用的主題里面加入android:windowDrawsSystemBarBackgrounds”并將值設(shè)置為false,會(huì)自動(dòng)提醒點(diǎn)擊alt+Enter會(huì)新建values-21的文件夾并生成styles.xml的文件。

也可以自己忽略的,直接新建values-21的文件夾然后新建一個(gè)styles.xml的文件,將主題里面的內(nèi)容復(fù)制到styles.xml里面然后加上加入android:windowDrawsSystemBarBackgrounds”并將值設(shè)置為false即可解決。

例外:附上(網(wǎng)上找到的)

public class AndroidBug5497Workaround {
 
 // For more information, see https://code.google.com/p/android/issues/detail?id=5497
 // To use this class, simply invoke assistActivity() on an Activity that already has its content 
 
view set.
 
 public static void assistActivity (Activity activity) {
 new AndroidBug5497Workaround(activity);
 }
 private Activity activity;
 private View mChildOfContent;
 private int usableHeightPrevious;
 private FrameLayout.LayoutParams frameLayoutParams;
 
 private AndroidBug5497Workaround(Activity activity) {
 this.activity = activity;
 FrameLayout content = (FrameLayout) activity.findViewById(android.R.id.content);
 mChildOfContent = content.getChildAt(0);
 mChildOfContent.getViewTreeObserver().addOnGlobalLayoutListener(new 
 
ViewTreeObserver.OnGlobalLayoutListener() {
  public void onGlobalLayout() {
  possiblyResizeChildOfContent();
  }
 });
 frameLayoutParams = (FrameLayout.LayoutParams) mChildOfContent.getLayoutParams();
 }
 
 private void possiblyResizeChildOfContent() {
 int usableHeightNow = computeUsableHeight();
 LogUtils.e("possiblyResizeChildOfContent","usableHeightNow:"+usableHeightNow);
 LogUtils.e("possiblyResizeChildOfContent","usableHeightPrevious:"+usableHeightPrevious);
 if (usableHeightNow != usableHeightPrevious) {
  int usableHeightSansKeyboard = mChildOfContent.getRootView().getHeight();
 
  //這個(gè)判斷是為了解決19之前的版本不支持沉浸式狀態(tài)欄導(dǎo)致布局顯示不完全的問題
  if(Build.VERSION.SDK_INT < Build.VERSION_CODES.KITKAT){
  Rect frame = new Rect();
  activity.getWindow().getDecorView().getWindowVisibleDisplayFrame(frame);
  int statusBarHeight = frame.top;
  usableHeightSansKeyboard -= statusBarHeight;
  }
  int heightDifference = usableHeightSansKeyboard - usableHeightNow;
  if (heightDifference > (usableHeightSansKeyboard/4)) {
  // keyboard probably just became visible
  frameLayoutParams.height = usableHeightSansKeyboard - heightDifference;
  } else {
  // keyboard probably just became hidden
  frameLayoutParams.height = usableHeightSansKeyboard;
  }
  mChildOfContent.requestLayout();
  usableHeightPrevious = usableHeightNow;
 }
 }
 
 private int computeUsableHeight() {
 Rect frame = new Rect();
 activity.getWindow().getDecorView().getWindowVisibleDisplayFrame(frame);
 int statusBarHeight = frame.top;
 
 Rect r = new Rect();
 mChildOfContent.getWindowVisibleDisplayFrame(r);
 
 //這個(gè)判斷是為了解決19之后的版本在彈出軟鍵盤時(shí),鍵盤和推上去的布局(adjustResize)之間有黑色區(qū)域
 
的問題
 if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT){
  return (r.bottom - r.top)+statusBarHeight;
 }
 
 return (r.bottom - r.top);
 }
 
}

關(guān)于“如何解決android顯示內(nèi)容被底部導(dǎo)航欄遮擋的問題”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI