Текстовое поле 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);
}
}

person Sana    schedule 11.08.2010    source источник
comment
Вы имеете в виду, что клавиатура не появляется, когда вы находитесь на веб-странице или когда вы щелкаете внутри текстового поля?   -  person Sephy    schedule 11.08.2010
comment
может быть, он имеет в виду поле ввода html на веб-сайте, которое отображается в веб-просмотре?   -  person Mathias Conradt    schedule 11.08.2010
comment
@Sephny: Когда я нажимаю на текстовую область, клавиатура не появляется, и жесткая клавиатура, доступная на Motorola Milestone, не работает!   -  person Sana    schedule 11.08.2010
comment
мм, это действительно странно. Я провел несколько тестов и без проблем открыл клавиатуру с помощью простейшего веб-просмотра. Можете ли вы добавить код, который вы используете для своего веб-просмотра?   -  person Sephy    schedule 11.08.2010
comment
У меня тоже была эта проблема, и она специфична для веб-страницы. Я не смог справиться с этим. Возможно, попробуйте установить фокус на веб-просмотр с помощью кода или использовать трекбол для навигации. Если вы найдете решение, пожалуйста, поделитесь с нами.   -  person Pentium10    schedule 11.08.2010


Ответы (11)


Полное решение немного больше, чем то, что было у Саны. Это задокументировано как ошибка на сайте 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;
    }
});
person Jeff Peiffer    schedule 26.07.2011
comment
У меня сработало без этой строки: webView.requestFocus(View.FOCUS_DOWN);. - person Tae; 08.08.2013

Проблема заключалась в том, что веб-просмотр не получал фокуса при загрузке, поэтому использовал

webView.requestFocus(View.FOCUS_DOWN);

решил проблему.

person Sana    schedule 24.11.2010
comment
это решение не помогло для Nexus 7 с Jelly Bean, у кого-нибудь есть другие идеи? - person user1159819; 16.09.2012
comment
У меня была эта проблема на устройствах ‹ HONEYCOMB. Само по себе это исправление не сработало. Но добавление кода OnTouchListener, предложенного Джеффом Пейффером (см. выше), помогло. - person andude; 16.02.2013

Я удивлен, что даже на 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);
    }
}
person RuslanK    schedule 16.11.2012
comment
В Jelly Bean+ ни одно из других решений не сработало. Это должен быть принятый ответ! - person Eric Lange; 12.08.2014
comment
@RuslanK Спасибо за решение, но я не вижу, где используется MyWebView? Я использую веб-просмотр следующим образом. Это дает мне ошибку, если я заменяю MyWebview вместо Webview mWebView = (WebView) findViewById (R.id.webview); - person Manisha; 10.11.2015
comment
@Manisha: сначала вы должны заменить «WebView» на «com.mypackage.MyWebview» в xml-файле с вашим макетом. - person RuslanK; 18.11.2015

однострочный ответ, и он работает хорошо

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

где wb - мой объект webView

person rahul    schedule 03.04.2013

Была та же проблема, и ни одно из вышеперечисленных решений не сработало. Это разбудило меня

    <CustomWebView
    android:id="@+id/webView"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:focusable="true"
    android:focusableInTouchMode="true" />
person Panzenbaby    schedule 24.10.2013
comment
Грустно, что я попробовал ваш вариант после того, как попробовал все вышеперечисленные ответы! - person amalBit; 04.02.2014
comment
Для меня то же самое, единственный ответ, который сработал. Я установил его во время выполнения --› setFocusable(true); установитьFocusableInTouchMode (истина); - person luckyhandler; 24.05.2016

Для тех из вас, кто ищет решение, когда WebView находится в AlertDialog, ответ здесь решил эту проблему для меня: Показать виртуальную клавиатуру в AlertDialog с WebView внутри (Android)

person datu-puti    schedule 09.12.2012

У меня была такая же проблема с Jelly Bean, но ни одно из вышеперечисленных решений не помогло мне. Это решение сработало для меня на JellyBean

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

Иногда android.R.attr.webViewStyle не применяется по умолчанию. Это гарантирует, что стиль всегда применяется.

person Kevin Grant    schedule 20.11.2012

У меня была аналогичная проблема .... и позже я обнаружил, что текстовое поле на веб-странице, которое отображалось в моем веб-представлении, было отключено.

Проверьте это, если на странице такая же проблема в браузере?

person Prasham    schedule 12.11.2010

У меня была точно такая же проблема, ни одно из вышеперечисленных решений не помогло мне. После долгих попыток я наконец нашел проблему.

Некоторые из различных веб-страниц, которые я отображал с помощью WebView, не вписывались должным образом в веб-представление, и в результате div (или какой-либо другой компонент html) невидимо накладывался на поля ввода. Хотя поля ввода казались выбранными при прикосновении, они не позволяли вводить текст (даже если мне удалось поднять программную клавиатуру с помощью трекбола).

Итак, решение.

WebView.getSettings().setUseWideViewPort(true);

Это не решит проблему полностью, но сделает представление более похожим на браузер ПК, для которого предназначены сайты. Меньше изменения наложения.

Надеюсь, это поможет вам.

person gumbercules    schedule 13.10.2011

попробуйте это -> имя - это имя поля и убедитесь, что оно не имеет атрибута автофокуса.

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

Чтобы упростить задачу, а также, поскольку другие решения имеют проблемы с работой на всех устройствах или во всех условиях, я всегда использую небольшой хак, чтобы решить эту проблему, не касаясь кода, просто добавьте любой скрытый editText в макет, содержащий webView, который автоматически предоставит фокус всему представлению, и вам больше не придется беспокоиться о webView текстовых полях:

<EditText
    android:id="@+id/kb_holder"
    android:layout_width="wrap_content"
    android:layout_height="match_parent"
    android:inputType="text"
    android:maxLines="1"
    android:visibility="gone" /> 

Итак, весь макет будет выглядеть так:

<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <EditText
        android:id="@+id/kb_holder"
        android:layout_width="wrap_content"
        android:layout_height="match_parent"
        android:inputType="text"
        android:maxLines="1"
        android:visibility="gone" />

    <WebView
        android:id="@+id/webView"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />

</FrameLayout>
person Muhammed Refaat    schedule 25.09.2017