6

編集:これは最終的に機能しました。以前にこれを試していましたが、実際には JavaScript でスコーピングの問題が発生していました。document.onready で appBack() を定義しました。その関数のスコープを *window.*appBack = function() に変更するだけです。ビジネスを完了しました。これが誰かに役立つことを願っています。

public boolean onKeyDown(int keyCode, KeyEvent event) {
    if (keyCode == KeyEvent.KEYCODE_BACK) {
        WebView.loadUrl("javascript:appBack()");
        return true;
    }
    return super.onKeyDown(keyCode, event);
}

Webview アプリケーション内では、戻るナビゲーションはカスタム JS 関数appBack()で処理されます。Androidの物理的な戻るボタンをインターセプトし、代わりにその JavaScript 関数を呼び出す方法を見つけようとしています。これが私の活動ファイルです。その非常に基本的な、webview を設定し、戻るボタンのクリックをリッスンします。現在、ユーザーがこの物理的な戻るボタンをクリックすると、mWebView.goBack() が実行されます。javascript:appBack() を実行したい場所

package com.stgeorgeplc.app;

import android.app.Activity;
import android.os.Bundle;
import android.view.KeyEvent;
import android.webkit.WebView;


public class StGeorgePLCliteActivity extends Activity {
    /** Called when the activity is first created. */
    WebView mWebView;
    @Override

    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        mWebView = (WebView) findViewById(R.id.webview);
        mWebView.getSettings().setJavaScriptEnabled(true);
        mWebView.getSettings().setBuiltInZoomControls(true);

        mWebView.loadUrl("file:///android_asset/www/index.html");
    }

    public boolean onKeyDown(int keyCode, KeyEvent event) {
        if (keyCode == KeyEvent.KEYCODE_BACK) {
            mWebView.goBack();
            return true;
        }
        return super.onKeyDown(keyCode, event);
    } 
}
4

0 に答える 0