創作內容

0 GP

解決 VueCLI3 + Cordova 全屏時輸入鍵盤擋住輸入框的坑

作者:Majitoo│2019-10-24 22:44:22│巴幣:0│人氣:332
前言:
最近在做Vue+Cordova做WebApp的專案
在全屏時會有輸入鍵盤擋住輸入框的問題
查詢並且測試了許久似乎是android1.x 到現在android版本
都仍然存在的bug
參考文章:

不過網路上找到的資料很少針對cordova去做修改
以下是我測試了許久才解決的問題
特此紀錄此坑

解法:
在src-cordova/platforms/android/CordovaLib/src/org/apache/cordova下
新增檔案AndroidBug5497Workaround.java
內容如下

package org.apache.cordova;
import android.graphics.Rect;
import android.app.Activity;
import android.view.ViewTreeObserver;
import android.view.View;
import android.widget.FrameLayout;
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) {
        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();
        if (usableHeightNow != usableHeightPrevious) {
            int usableHeightSansKeyboard = mChildOfContent.getRootView().getHeight();
            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 r = new Rect();
        mChildOfContent.getWindowVisibleDisplayFrame(r);
        return (r.bottom - r.top);// 全屏模式下: return r.bottom
    }

}


接著在CordovaActivity.java中搜尋
setContentView(appView.getView());
並在下一行貼上
AndroidBug5497Workaround.assistActivity(this);

並且確保src-cordova/plarforms/android/app/src/main/AndroidManifest.xml
<activity> 的 android:windowSoftInputMode="adjustResize"
是adjustResize屬性
預設值就是adjustResize

接著App.Vue的mounted中貼上
document.body.style.height = document.body.clientHeight + 'px';

以上這些步驟就能解決
VueCLI3 搭配cordova 開啟強制全屏時
彈出鍵盤擋住輸入框的問題

引用網址:https://home.gamer.com.tw/TrackBack.php?sn=4570460
All rights reserved. 版權所有,保留一切權利

相關創作

同標籤作品搜尋:Vue|Cordova|Vue Cordova|WebAPP|採坑|Vue js坑|Cordova 全屏時輸入|全屏時輸入鍵盤擋住

留言共 0 篇留言

我要留言提醒:您尚未登入,請先登入再留言

喜歡★jimmyy512 可決定是否刪除您的留言,請勿發表違反站規文字。

前一篇:網頁下雪效果套件 ( e... 後一篇:Cocos Creato...

追蹤私訊切換新版閱覽

作品資料夾

airsky00大家
與一個罪犯談判的方式,就他媽誰理他!看更多我要大聲說4小時前


face基於日前微軟官方表示 Internet Explorer 不再支援新的網路標準,可能無法使用新的應用程式來呈現網站內容,在瀏覽器支援度及網站安全性的雙重考量下,為了讓巴友們有更好的使用體驗,巴哈姆特即將於 2019年9月2日 停止支援 Internet Explorer 瀏覽器的頁面呈現和功能。
屆時建議您使用下述瀏覽器來瀏覽巴哈姆特:
。Google Chrome(推薦)
。Mozilla Firefox
。Microsoft Edge(Windows10以上的作業系統版本才可使用)

face我們了解您不想看到廣告的心情⋯ 若您願意支持巴哈姆特永續經營,請將 gamer.com.tw 加入廣告阻擋工具的白名單中,謝謝 !【教學】