Reputation: 307
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
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
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
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
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
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
Reputation: 396
Try adding the following property:
android:fitsSystemWindows="true"
in the root LinearLayout of the .xml layout.
Upvotes: 9
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