web-dev-qa-db-ja.com

WebViewテキストエリアがキーボードをポップアップしません

WebViewを表示すると、ソフトキーボードがポップアップ表示されません。ハードキーボードも機能しません!

通常の欠点は何ですか。

WebViewにアクセスするために使用するコードは次のとおりです。

package com.example.blahblah;

import Android.app.Activity;
import Android.content.Intent;
import Android.content.SharedPreferences;
import Android.os.Bundle;
import Android.os.Handler;
import Android.preference.PreferenceManager;
import Android.util.Log;
import Android.view.KeyEvent;
import Android.view.Window;
import Android.webkit.JsResult;
import Android.webkit.WebChromeClient;
import Android.webkit.WebSettings;
import Android.webkit.WebView;
import Android.webkit.WebViewClient;
import Android.widget.Toast;

public class createAccount extends Activity {

private static final String LOG_TAG = "Create Account";
private WebView mWebView;
private static final String URL = blah_app.urlSelected+"createAccount.html";    
private Handler mHandler = new Handler();

@Override
public void onCreate(Bundle icicle) {
    super.onCreate(icicle);
    Toast.makeText(createAccount.this, "URL = " +URL, Toast.LENGTH_SHORT).show();
    getWindow().requestFeature(Window.FEATURE_PROGRESS);
    setContentView(R.layout.webview);
    getWindow().setFeatureInt(Window.FEATURE_PROGRESS, Window.PROGRESS_VISIBILITY_ON);

    mWebView = (WebView) findViewById(R.id.webview);

    WebSettings webSettings = mWebView.getSettings();
    webSettings.setSavePassword(true);
    webSettings.setSaveFormData(true);
    webSettings.setJavaScriptEnabled(true);
    webSettings.setSupportZoom(true);


    final Activity activity = this;
    mWebView.setWebChromeClient(new WebChromeClient() {
    public void onProgressChanged(WebView view, int progress) {

        activity.setProgress(progress * 1000);
      }
    });

    mWebView.addJavascriptInterface(new DemoJavaScriptInterface(), "demo");
    mWebView.clearCache(true);
    setProgressBarVisibility(true);
    mWebView.setWebViewClient(new WebViewClient() {
          public void onReceivedError(WebView view, int errorCode, String description, String failingUrl) {
            Toast.makeText(activity, "Oh no! " + description, Toast.LENGTH_SHORT).show();
          }

           @Override  
           public void onPageFinished(WebView view, String url)  
           {  
               mWebView.loadUrl("javascript:(function () { " +
                       "setVariables("+blah_app.numberSelected+",'"+blah_app.urlSelected+"');" +
                       "})()");
           }
        });

    mWebView.loadUrl(URL);
}

final class DemoJavaScriptInterface {

    public void setData(String fname, String lname, String gacct, String phone) {

        SharedPreferences prefCreateAccount = PreferenceManager.getDefaultSharedPreferences(createAccount.this);
        SharedPreferences.Editor editor = prefCreateAccount.edit();
        editor.putString("FirstName", fname);
        editor.putString("LastName", lname);
        editor.putString("GmailAcct", gacct);
        editor.putString("Phone", phone);
        editor.commit();    

    }
    DemoJavaScriptInterface() {

    }

    /**
     * This is not called on the UI thread. Post a runnable to invoke
     * loadUrl on the UI thread.
     */
    public void clickOnAndroid() {
        mHandler.post(new Runnable() {
            public void run() {
                mWebView.loadUrl("javascript:wave()");
            }
        });
    }
}

/**
 * Provides a hook for calling "alert" from javascript. Useful for
 * debugging your javascript.
 */
final class MyWebChromeClient extends WebChromeClient {
    @Override
    public boolean onJsAlert(WebView view, String url, String message, JsResult result) {
        Log.d(LOG_TAG, message);
        result.confirm();
        return true;
    }
}

public boolean onKeyDown(int keyCode, KeyEvent event) {
    if ((keyCode == KeyEvent.KEYCODE_BACK) && mWebView.canGoBack()) {
        startActivity(new Intent(getApplication(), blah_app.class));
        return true;
    }
    return super.onKeyDown(keyCode, event);
}
}
40
Sana

問題は、webviewがロードされたときにフォーカスを取得していなかったため、

webView.requestFocus(View.FOCUS_DOWN);

問題を解決しました。

37
Sana

完全なソリューションは、Sanaが持っていたものよりも少し多くなっています。 Androidサイト( http://code.google.com/p/Android/issues/detail?id=7189 )でバグとして文書化されています:

webView.requestFocus(View.FOCUS_DOWN);
webView.setOnTouchListener(new View.OnTouchListener()
{
    @Override
    public boolean onTouch(View v, MotionEvent event)
    {
        switch (event.getAction())
        {
            case MotionEvent.ACTION_DOWN:
            case MotionEvent.ACTION_UP:
                if (!v.hasFocus())
                {
                    v.requestFocus();
                }
                break;
        }
        return false;
    }
});
46
Jeff Peiffer

Android 4.1(SGS3でテスト済み)でも問題がまだ存在していて、onTouch()をオーバーライドしても解決されないことに驚いています。

テストコード:

String HTML = "<html><head>TEST</head><body><form>";
HTML += "<INPUT TYPE=TEXT SIZE=40 NAME=user value=\"your name\">";
HTML += "</form></body></html>";

WebView wv = new WebView(getContext());
wv.loadData(HTML, "text/html", null);

final AlertDialog.Builder adb = new AlertDialog.Builder(getContext());
adb.setTitle("TEST").setView(wv).show();

私の複雑なソリューションは、WebViewをMyWebViewに置き換えることです。

private static class MyWebView extends WebView
{
    public MyWebView(Context context)
    {
        super(context);
    }

    // Note this!
    @Override
    public boolean onCheckIsTextEditor()
    {
        return true;
    }

    @Override
    public boolean onTouchEvent(MotionEvent ev)
    {
        switch (ev.getAction())
        {
            case MotionEvent.ACTION_DOWN:
            case MotionEvent.ACTION_UP:
                if (!hasFocus())
                    requestFocus();
            break;
        }

        return super.onTouchEvent(ev);
    }
}
8
RuslanK

1行の回答とそれはうまく機能しています

// define webview for browser
wb = (WebView) findViewById(R.id.webView1);
wb.requestFocusFromTouch();

wbはwebViewの私のオブジェクトです

6
rahul

同じ問題があり、上記の解決策が機能していなかった。これは私のために働いた

    <CustomWebView
    Android:id="@+id/webView"
    Android:layout_width="fill_parent"
    Android:layout_height="fill_parent"
    Android:focusable="true"
    Android:focusableInTouchMode="true" />
5
Panzenbaby

WebViewAlertDialogにあるときに解決策を探している人のために、ここの答えは私のためにこの問題を解決しました: WebView(Android )

4
elBradford

Jelly Beanでも同じ問題が発生しましたが、上記の解決策はどれも役に立ちませんでした。このソリューションはJellyBeanで私のために働いた

WebView webView = new WebView(getActivity(), null, Android.R.attr.webViewStyle);

Android.R.attr.webViewStyleはデフォルトで適用されない場合があります。これにより、スタイルが常に適用されます。

1
Kevin Grant

私はまったく同じ問題を抱えていましたが、上記の解決策はどれもうまくいきませんでした。試行錯誤の末、ようやく問題が見つかりました。

WebViewでレンダリングしていたさまざまなWebページの一部がWebビューに適切に収まらず、その結果、div(または他のhtmlコンポーネント)が入力フィールドに目に見えないように配置されていました。タッチすると入力フィールドが選択されているように見えますが、テキスト入力はできません(トラックボールを使用してソフトキーボードを起動できたとしても)。

解決策です。

WebView.getSettings().setUseWideViewPort(true);

これで問題が完全に停止するわけではありませんが、ビューは、サイトが設計されているPCブラウザーのようになります。オーバーレイの変化が少ない。

これがお役に立てば幸いです。

0
gumbercules

これを試してください-> firstnameはフィールドの名前であり、autofocus属性を持たないことを確認してください。

    mWebView.setWebViewClient(new WebViewClient() {
        @Override
        public void onPageFinished(WebView view, String url) {
            mWebView.loadUrl("javascript:document.getElementById(\"firstname\").focus();");
        }
    });
0
Manisha

私は同様の問題を抱えていた....そして、後で私は私のウェブビューが示したウェブページ上のテキストボックスが無効になっていることを発見した。

ページにブラウザで同じ問題がある場合、これを確認しますか?

0
Prasham