沉浸式+虛擬鍵盤遮擋輸入框+底部導(dǎo)航條被虛擬按鍵遮擋

今天遇到了個(gè)問題...
之前設(shè)置APP為沉浸式躬厌,同時(shí)解決了軟鍵盤彈出遮擋輸入框的問題。
先說之前的解決方式:
加入AndroidBug5497Workaround操作類,這種方式網(wǎng)上很多人都提到。

一開始使用并沒有問題焕参。
有一天拿一個(gè)帶虛擬按鍵的手機(jī)測(cè)試,發(fā)現(xiàn)了底部的導(dǎo)航欄完全被虛擬按鍵遮擋了。

先說解決方式:

修改AndroidBug5497Workaround類:代碼中無(wú)法加粗甘磨,修改的兩個(gè)地方用【此處】標(biāo)記了。

import android.app.Activity;
import android.graphics.Rect;
import android.os.Build;
import android.view.View;
import android.view.ViewTreeObserver;
import android.widget.FrameLayout;

/**
 * Created by bhj on 2018/1/30.
 */

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 View mChildOfContent;
    private int usableHeightPrevious;
    private FrameLayout.LayoutParams frameLayoutParams;
    //為適應(yīng)華為小米等手機(jī)鍵盤上方出現(xiàn)黑條或不適配
    private int contentHeight;//獲取setContentView本來(lái)view的高度
    private boolean isfirst = true;//只用獲取一次

    private AndroidBug5497Workaround(final Activity activity) {
        final Activity activity1 = activity;
        FrameLayout content = (FrameLayout) activity.findViewById(android.R.id.content);
        mChildOfContent = content.getChildAt(0);
        mChildOfContent.getViewTreeObserver().addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() {
            public void onGlobalLayout() {
                if (isfirst) {
                    contentHeight = mChildOfContent.getHeight();//【此處】獲取布局的高度(不包括底部虛擬按鍵的高度)
                    isfirst = false;
                }
                possiblyResizeChildOfContent(activity1);
            }
        });
        frameLayoutParams = (FrameLayout.LayoutParams) mChildOfContent.getLayoutParams();
    }


    // 獲取界面可用高度眯停,如果軟鍵盤彈起后济舆,Activity的xml布局可用高度需要減去鍵盤高度
    private void possiblyResizeChildOfContent(Activity activity) {
        //1?獲取當(dāng)前界面可用高度,鍵盤彈起后莺债,當(dāng)前界面可用布局會(huì)減少鍵盤的高度
        int usableHeightNow = computeUsableHeight(activity);
        if (usableHeightNow != usableHeightPrevious) {
            //3?獲取Activity中xml中布局在當(dāng)前界面顯示的高度
            int usableHeightSansKeyboard = mChildOfContent.getRootView().getHeight();
            //4?Activity中xml布局的高度-當(dāng)前可用高度
            int heightDifference = usableHeightSansKeyboard - usableHeightNow;
            //5?高度差大于屏幕1/4時(shí)滋觉,說明鍵盤彈出
            if (heightDifference > (usableHeightSansKeyboard/4)) {
                // 6?鍵盤彈出了,Activity的xml布局高度應(yīng)當(dāng)減去鍵盤高度
                // keyboard probably just became visible
                    frameLayoutParams.height = usableHeightSansKeyboard - heightDifference;
            } else {
                // keyboard probably just became hidden
                frameLayoutParams.height = contentHeight;//【此處】當(dāng)鍵盤隱藏時(shí)設(shè)置的高度是之前獲取的contentHeight
            }
            mChildOfContent.requestLayout();
            usableHeightPrevious = usableHeightNow;
        }
    }

    private int computeUsableHeight(Activity activity) {
        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);
    }

}

解釋下原因:

之前的操作方式(鏈接里的代碼)是在隱藏鍵盤時(shí)椎侠,設(shè)置的高度為 usableHeightSansKeyboard ,
也就是mChildOfContent.getRootView().getHeight(),
獲取的是rootView的高度措拇,包含了底部的虛擬按鍵 高度我纪。
所以設(shè)置我們的布局高度大了,
所以會(huì)被遮住。

設(shè)置為contentHeight宣羊,即當(dāng)前view的getHeight()獲取的高度璧诵,
不包括底部虛擬按鍵高度,
所以不被遮擋仇冯。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末之宿,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子苛坚,更是在濱河造成了極大的恐慌比被,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,729評(píng)論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件泼舱,死亡現(xiàn)場(chǎng)離奇詭異等缀,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)娇昙,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,226評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門尺迂,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人冒掌,你說我怎么就攤上這事噪裕。” “怎么了股毫?”我有些...
    開封第一講書人閱讀 169,461評(píng)論 0 362
  • 文/不壞的土叔 我叫張陵膳音,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我铃诬,道長(zhǎng)祭陷,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 60,135評(píng)論 1 300
  • 正文 為了忘掉前任趣席,我火速辦了婚禮兵志,結(jié)果婚禮上吩坝,老公的妹妹穿的比我還像新娘毒姨。我一直安慰自己钉寝,他們只是感情好闸迷,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,130評(píng)論 6 398
  • 文/花漫 我一把揭開白布嵌纲。 她就那樣靜靜地躺著,像睡著了一般腥沽。 火紅的嫁衣襯著肌膚如雪逮走。 梳的紋絲不亂的頭發(fā)上今阳,一...
    開封第一講書人閱讀 52,736評(píng)論 1 312
  • 那天茅信,我揣著相機(jī)與錄音,去河邊找鬼墓臭。 笑死蘸鲸,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的窿锉。 我是一名探鬼主播酌摇,決...
    沈念sama閱讀 41,179評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼嗡载,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了洼滚?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 40,124評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤耿芹,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后吧秕,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,657評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡砸彬,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,723評(píng)論 3 342
  • 正文 我和宋清朗相戀三年斯入,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片刻两。...
    茶點(diǎn)故事閱讀 40,872評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖滋迈,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情饼灿,我是刑警寧澤,帶...
    沈念sama閱讀 36,533評(píng)論 5 351
  • 正文 年R本政府宣布碍彭,位于F島的核電站,受9級(jí)特大地震影響庇忌,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜皆疹,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,213評(píng)論 3 336
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望墙基。 院中可真熱鬧软族,春花似錦残制、人聲如沸立砸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,700評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)恼布。三九已至,卻和暖如春倔幼,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背损同。 一陣腳步聲響...
    開封第一講書人閱讀 33,819評(píng)論 1 274
  • 我被黑心中介騙來(lái)泰國(guó)打工鸟款, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留膏燃,地道東北人何什。 一個(gè)月前我還...
    沈念sama閱讀 49,304評(píng)論 3 379
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像伶贰,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子幕袱,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,876評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容