Stefano
Stefano

Reputation: 307

Android keyboard hides input in web view

In an Android webview, when a text/password field is touched, the keyboard appears but covers the field, forcing the user to scroll to see what they are typing.

Is there a way to solve this issue or a way to have an auto-focus in web view ? (as seen in iOS).

Manifest

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.dedalos.amb">

    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />

    <application
        android:name=".MyApplication"
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:usesCleartextTraffic="true"
        android:windowSoftInputMode="adjustPan"
        android:theme="@style/AppTheme">
        <activity android:name=".SplashScreen" android:theme="@style/SplashTheme">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity android:name=".MainActivity">
        </activity>
    </application>

</manifest>

Layout

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical"
    android:background="@color/splash_background"
    tools:context=".MainActivity">

    <WebView
        android:id="@+id/ambWebViewLayout"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:background="@color/splash_background" />

</LinearLayout>

I also paste styles and colors here:

colors.xml

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <color name="colorPrimary">#008577</color>
    <color name="colorPrimaryDark">#00574B</color>
    <color name="colorAccent">#D81B60</color>

    <color name="splash_background">#e11020</color>
</resources>

styles.xml

<resources>

    <!-- Base application theme. -->
    <style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
        <!-- Customize your theme here. -->
        <item name="colorPrimary">#e11020</item>
        <item name="colorPrimaryDark">#e11020</item>
        <item name="colorAccent">#e11020</item>
        <item name="android:statusBarColor">@android:color/transparent</item>
        <item name="windowNoTitle">true</item>
        <item name="android:windowDrawsSystemBarBackgrounds">true</item>
        <item name="android:windowTranslucentNavigation">true</item>

    </style>

    <!-- SplashTheme -->
    <style name="SplashTheme" parent="AppTheme">
        <item name="android:windowBackground">@drawable/splash_theme</item>
    </style>

</resources>

Upvotes: 9

Views: 19221

Answers (7)

Ashley
Ashley

Reputation: 31

I resolved this issue by following answers

android:fitsSystemWindows="true" in root LinearLayout @animeshk

<item name="android:windowFullscreen">false</item> in theme style @Nawin

In my case, it worked well without adding android:windowSoftInputMode="adjustResize"

Upvotes: 1

Nawin
Nawin

Reputation: 616

Android keyboard hides when the app use full screen mode.

This issue can be resolved if you use

<item name="android:windowFullscreen">false</item> in your styles.

then use <activity android:name=".MainActivity" android:windowSoftInputMode="adjustResize">

in your manifest.

Upvotes: 3

Rohit Mandiwal
Rohit Mandiwal

Reputation: 10462

Try this one.

webView.getSettings().setJavaScriptEnabled(true);

webView.setWebViewClient(new WebViewClient() {
    @Override
    public void onPageFinished(WebView view, String url) {
        view.loadUrl("javascript:document.getElementsByName('[your view name without square brackets]')[0].focus();");
        super.onPageFinished(view, url);
    }
});

InputMethodManager imm = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
imm.toggleSoftInput(InputMethodManager.SHOW_IMPLICIT, 0);

Upvotes: 0

Viral Patel
Viral Patel

Reputation: 1316

There are two Alternatives:

Alternative 1 :

For single line to focus then use this:

webView.requestFocus(View.FOCUS_DOWN);

Alternative 2 :

webView.setOnTouchListener(new View.OnTouchListener() {
    @Override
    public boolean onTouch(View view, MotionEvent event) {
        switch (event.getAction()) {
            case MotionEvent.ACTION_DOWN:
            case MotionEvent.ACTION_UP:
                view.requestFocusFromTouch();  
                break;
        }               
        return false;
    }

});

I hope it'll help you...!

Upvotes: 0

Nidhi Savaliya
Nidhi Savaliya

Reputation: 179

You can try this following property:

  • In manifest file where you register your activity :

    <activity android:name="yourActivity"
       android:windowSoftInputMode="stateHidden"/>
    

Upvotes: 0

animeshk
animeshk

Reputation: 396

Try adding the following property:

android:fitsSystemWindows="true"

in the root LinearLayout of the .xml layout.

Upvotes: 9

Sebastian M
Sebastian M

Reputation: 659

You might want to check this article: https://developer.android.com/training/keyboard-input/visibility

Maybe this will help you.

android:windowSoftInputMode="adjustResize"

Upvotes: 1

Related Questions