Android軟鍵盤彈起遮擋h5頁面解決方法

所謂人在家中坐鍋從天上來灌具。
項目里有個客服系統(tǒng)是接入的h5摹察,最近收到反饋用戶在客服系統(tǒng)輸入時奶躯,輸入框被Android彈起的軟件盤遮擋,從而看不到輸入框內(nèi)容的問題特漩。


正常界面

軟鍵盤擋住

一開始想到的就是應(yīng)該是沒設(shè)置鍵盤自適應(yīng)的屬性吧雹,打開manifest找到相應(yīng)的Activity,果然沒有設(shè)置涂身。不多說一頓操作猛如虎雄卷,設(shè)置

android:windowSoftInputMode="adjustResize"  

打開調(diào)試,如果你的當(dāng)前Activity不是全屏模式蛤售,那么恭喜你丁鹉,成功了。但是不幸的是我這個項目里Activity是全屏模式悴能。結(jié)果還是被軟鍵盤擋住揣钦。一臉懵逼~什么鬼。網(wǎng)上一搜搜骡,除了這個屬性拂盯,全是讓h5改屬性的。把鍋甩給h5记靡?h5同學(xué)一臉懵逼谈竿,我這個客服模塊在集團(tuán)其他項目也用团驱,該設(shè)置的position,fixed等屬性都設(shè)置了空凸,人家沒報問題嚎花,你們自己想想辦法。得呀洲,搞到最后鍋還是回來了紊选。那只能自己想辦法了。道逗。兵罢。
最終發(fā)現(xiàn)是設(shè)置Activity全屏模式引起的問題。要解決軟件盤彈起遮擋問題滓窍,一版如下兩種方式
(1)Native Activity非全屏模式下卖词,要適應(yīng)軟鍵盤彈起一般可設(shè)置如下兩種屬性中的一種。

android:windowSoftInputMode="adjustResize|adjustSpan"  

有人說h5在這種模式下會失效吏夯。親測adjustSpan確實是會在h5頁面失效此蜈。

android:windowSoftInputMode="adjustSpan"  

(2)但是在h5全屏模式下以上兩種方法都是失效的。這是Android系統(tǒng)目前存在的一個bug噪生,編號5497裆赵。若需要在h5全屏模式下解決該問題,需要自己手動添加一個類跺嗽,如下:

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;

    private AndroidBug5497Workaround(Activity activity) {
        //Decorview里分為title和content战授,content即是承載我們setContentView方法的布局的根布局
        FrameLayout content = (FrameLayout) activity.findViewById(android.R.id.content);
        //mChildOfContent我們setContentView方法的布局
        mChildOfContent = content.getChildAt(0);
        //監(jiān)聽布局變化,任何界面變化都會觸發(fā)該監(jiān)聽
        //軟鍵盤彈起同樣也會觸發(fā)該監(jiān)聽
        mChildOfContent.getViewTreeObserver().addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() {
            public void onGlobalLayout() {
                possiblyResizeChildOfContent();
            }
        });
        frameLayoutParams = (FrameLayout.LayoutParams) mChildOfContent.getLayoutParams();
    }

    private void possiblyResizeChildOfContent() {
        int usableHeightNow = computeUsableHeight();
        if (usableHeightNow != usableHeightPrevious) {
            int usableHeightSansKeyboard = mChildOfContent.getRootView().getHeight();
            //計算布局變化的高度
            int heightDifference = usableHeightSansKeyboard - usableHeightNow;
            if (heightDifference > (usableHeightSansKeyboard / 4)) {
                // keyboard probably just became visible
                //如果布局變化的高度大于全屏高度的4分之一桨嫁,則認(rèn)為可能是鍵盤彈出陈醒,需要改變我們setContentView的布局高度
                frameLayoutParams.height = usableHeightSansKeyboard - heightDifference;
            } else {
                // keyboard probably just became hidden
                frameLayoutParams.height = usableHeightSansKeyboard;
            }
            //布局改變后重繪
            mChildOfContent.requestLayout();
            usableHeightPrevious = usableHeightNow;
        }
    }

    //計算去掉鍵盤高度后的可用高度
    private int computeUsableHeight() {
        Rect r = new Rect();
        mChildOfContent.getWindowVisibleDisplayFrame(r);
        return (r.bottom - r.top);// 全屏模式下: return r.bottom
//        return r.bottom;
    }

}
20180824233819.png

該類原理已添加在注釋當(dāng)中。
使用方式是引入該類后瞧甩,在所需要設(shè)置的Activity oncreat()中添加如下一行代碼

AndroidBug5497Workaround.assistActivity(this);

綜上所述,解決軟鍵盤彈起遮擋問題方法如下:

(1)Native頁面:可設(shè)置adjustResize或adjustSpan屬性弥鹦。
(2)h5頁面下:

  • h5非全屏模式肚逸,可設(shè)置adjustResize
  • h5全屏模式,可設(shè)置AndroidBug5497Workaround

參考資料:
https://code.google.com/p/android/issues/detail?id=5497
https://www.diycode.cc/topics/383

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末彬坏,一起剝皮案震驚了整個濱河市朦促,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌栓始,老刑警劉巖务冕,帶你破解...
    沈念sama閱讀 212,454評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異幻赚,居然都是意外死亡禀忆,警方通過查閱死者的電腦和手機(jī)臊旭,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,553評論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來箩退,“玉大人离熏,你說我怎么就攤上這事〈骼裕” “怎么了滋戳?”我有些...
    開封第一講書人閱讀 157,921評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長啥刻。 經(jīng)常有香客問我奸鸯,道長,這世上最難降的妖魔是什么可帽? 我笑而不...
    開封第一講書人閱讀 56,648評論 1 284
  • 正文 為了忘掉前任娄涩,我火速辦了婚禮,結(jié)果婚禮上蘑拯,老公的妹妹穿的比我還像新娘钝满。我一直安慰自己,他們只是感情好申窘,可當(dāng)我...
    茶點故事閱讀 65,770評論 6 386
  • 文/花漫 我一把揭開白布弯蚜。 她就那樣靜靜地躺著,像睡著了一般剃法。 火紅的嫁衣襯著肌膚如雪碎捺。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,950評論 1 291
  • 那天贷洲,我揣著相機(jī)與錄音收厨,去河邊找鬼。 笑死优构,一個胖子當(dāng)著我的面吹牛诵叁,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播钦椭,決...
    沈念sama閱讀 39,090評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼拧额,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了彪腔?” 一聲冷哼從身側(cè)響起侥锦,我...
    開封第一講書人閱讀 37,817評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎德挣,沒想到半個月后恭垦,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,275評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,592評論 2 327
  • 正文 我和宋清朗相戀三年番挺,在試婚紗的時候發(fā)現(xiàn)自己被綠了唠帝。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,724評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡建芙,死狀恐怖没隘,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情禁荸,我是刑警寧澤右蒲,帶...
    沈念sama閱讀 34,409評論 4 333
  • 正文 年R本政府宣布,位于F島的核電站赶熟,受9級特大地震影響瑰妄,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜映砖,卻給世界環(huán)境...
    茶點故事閱讀 40,052評論 3 316
  • 文/蒙蒙 一间坐、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧邑退,春花似錦竹宋、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,815評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至莫矗,卻和暖如春飒硅,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背作谚。 一陣腳步聲響...
    開封第一講書人閱讀 32,043評論 1 266
  • 我被黑心中介騙來泰國打工三娩, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人妹懒。 一個月前我還...
    沈念sama閱讀 46,503評論 2 361
  • 正文 我出身青樓雀监,卻偏偏與公主長得像,于是被迫代替她去往敵國和親眨唬。 傳聞我的和親對象是個殘疾皇子滔悉,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,627評論 2 350

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