Android: How to float a row above the soft keyboard
Last time, I explained how to fix resizing and scrolling on Android, see blog post here.
Now, I wanted to have a fixed “menu” row on the screen at all times, similar to how the contacts app works:
data:image/s3,"s3://crabby-images/eb125/eb1257f43f8221cab338339931a1bc8c49695e25" alt="Android Contacts App Android Contacts App"
Not too hard. I knew that I would want a RelativeLayout
with a ScrollView
inside as well as another view which would contain my buttons.
When the soft keyboard is closed, I want the app to look like this:
data:image/s3,"s3://crabby-images/668a7/668a7dd53875f0618a3f62523ba0e45b94744d01" alt="My App Good Closed My App Good Closed"
And when an EditText
is selected, I want it to look like this:
data:image/s3,"s3://crabby-images/7ea10/7ea10db703dbd39ead1afe5a068e7c8782f027db" alt="My App Good Open My App Good Open"
Well, with my code as it currently is suggested, I would have a RelativeLayout
containing a ScrollView
and a TableLayout
. So far so good. However, this is what it ends up looking like:
data:image/s3,"s3://crabby-images/4db8c/4db8cde3ae9cf71d586afa911c5556f13692a9bf" alt="My App Bad My App Bad"
Searching around, I ultimately discovered that I needed to add two different tags. The first to my ScrollView
was android:layout_above="@+id/myID"
. The other, on the TableLayout
was android:layout_alignParentBottom="true"
. Using both of these, you get the correct effect. However, if either are missing, you can end up with some stuff you don’t want.
No layout_above
:
data:image/s3,"s3://crabby-images/fb885/fb885abce88005ddf9bd934207e8856f34b113cd" alt="No layout above No layout above"
No align_parentBottom
:
data:image/s3,"s3://crabby-images/9551f/9551f9c878e1dba686b6cb39a53e6b2285f144f4" alt="No align parent bottom No align parent bottom"
Hope this helps.