沉浸式主題下軟鍵盤問題


版權聲明:本文為xing_star原創文章,轉載請注明出處!

本文同步自http://javaexception.com/archives/150

沉浸式主題下軟鍵盤問題

項目中,對沉浸式的處理用的是https://github.com/gyf-dev/ImmersionBar 這個開源項目,項目還算可以的,處理了不少疑難雜症。剛好這幾天碰到了這個問題,所以這里做個簡單的總結。

我們的登錄頁面就是個沉浸式的主題,布局中有兩個EditText。對於屏幕比較窄的手機,最下面的EditText會被軟鍵盤給遮住,這樣體驗太差,只能想辦法解決了。

ImmersionBar對軟鍵盤這塊有處理,理解它的用法,按照它的api操作,可以解決問題。

ImmersionBar上幾個很常見的問題 https://github.com/gyf-dev/ImmersionBar/issues/288 https://github.com/gyf-dev/ImmersionBar/issues/79 這兩個問題中,設置keyboardEnable(true)后,底部的控件會被頂上去,這個應該是由於ImmersionBar做的處理,是它的鍋,對於這種,我們可以獲取到底部的控件,在軟鍵盤彈起的時候,將bottomLayout設置為View.GONE,收攏的時候,恢復bottomLayout的顯示。

解決方案

簡易的代碼為:

ImmersionBar.with(this).keyboardEnable(true).setOnKeyboardListener((isPopup, keyboardHeight) -> {
if (isPopup) {
bottomLayout.setVisibility(View.GONE);
} else {
bottomLayout.setVisibility(View.VISIBLE);
}
}).statusBarDarkFont(true).titleBar(R.id.tv_status).init();

 

keyboardEnable(true) 這個方法設置了當前Activity軟鍵盤彈出的模式,默認是AdjustResize。

那么單純這種就可行么,可能不一定可行,這個就需要結合自己的頁面布局來看了。

如果沒有使用ScrollView作為跟節點容器,那么當軟鍵盤彈起的時候,為了避免軟鍵盤遮住EditText,可以將EditText等上面的一些控件給隱藏起來,或者是修改在上面的view的padding或者是margin。這樣可以解決問題。
代碼可以是這樣子的。

ImmersionBar.with(this).keyboardEnable(true).setOnKeyboardListener((isPopup, keyboardHeight) -> {
if (isPopup) {
ViewGroup.MarginLayoutParams layoutParams = (ViewGroup.MarginLayoutParams) mTvStatus.getLayoutParams();
layoutParams.topMargin = DisplayUtils.dip2px(20);
mTvStatus.setLayoutParams(layoutParams);
bottomLayout.setVisibility(View.GONE);
} else {
ViewGroup.MarginLayoutParams layoutParams = (ViewGroup.MarginLayoutParams) mTvStatus.getLayoutParams();
layoutParams.topMargin = DisplayUtils.dip2px(50);
mTvStatus.setLayoutParams(layoutParams);
bottomLayout.setVisibility(View.VISIBLE);
}
}).statusBarDarkFont(true).titleBar(R.id.tv_status).init();

 

到此問題解決, 用ImmersionBar的api處理軟鍵盤問題還是很方便的。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM