Android解决ListView中使用EditText所遇到的一些冲突

本文介绍了解决在Android ListView中使用EditText时出现的焦点和键盘遮挡问题的方法。通过调整Activity配置并重写dispatchKeyEventPreIme方法来解决焦点丢失及输入法键盘遮挡问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

大家都知道在listView中使用editText,在输入过程中是有冲突的。今天稍微研究了一下这个问题,有一点点小小的心得和大家一起分享下。

  首先建立一个最简单的demo,主界面就是一个ListView,其中list_item的布局代码如下:

[java]  view plain copy
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:orientation="vertical" android:layout_width="match_parent"  
  4.     android:layout_height="match_parent">  
  5.     <TextView android:layout_width="wrap_content"  
  6.         android:layout_height="wrap_content" android:text="TextView"  
  7.         android:id="@+id/textView1" android:textSize="20sp"></TextView>  
  8.     <EditText android:layout_width="match_parent"  
  9.         android:layout_height="wrap_content" android:id="@+id/editText1">  
  10.     </EditText>  
  11.    
  12. </LinearLayout>  

很简单list_item包含一个TextView,还有一个就是EditText。

运行后在某一项EditText进行输入,点击返回键隐藏输入法键盘时会遇到一个问题即所有项的EditText内容都被清空了。

解决办法:在Manifest中Activity标签下加入android:windowSoftInputMode="adjustPan"。

这个问题是解决了,但是还有其他的问题。

当你点击最后一项时,没有问题,此时最后一项的EditText拥有焦点。然后,点击系统返回键,再点击最后一项,此时你会发现输入法将最后一项完全挡住了(这样很影响用户体验)。

解决方法:当点击系统返回键时,让其释放焦点。

有人肯定会先这样处理:

[java]  view plain copy
  1. @Override  
  2.     public boolean onKeyDown(int keyCode, KeyEvent event) {  
  3.         // TODO Auto-generated method stub  
  4.         if (keyCode == KeyEvent.KEYCODE_BACK) {  
  5.              //释放焦点  
  6.         }  
  7.         return super.onKeyDown(keyCode, event);  
  8.     }  

但是很遗憾,当输入法键盘显示的时候,你点击系统的返回键事件被捕获了,而不会在onKeyDown里执行。

[java]  view plain copy
  1. @Override  
  2. public boolean dispatchKeyEventPreIme(KeyEvent event) {  
  3.     if (context != null) {  
  4.         InputMethodManager imm = (InputMethodManager) context  
  5.                 .getSystemService(Context.INPUT_METHOD_SERVICE);  
  6.         if (imm.isActive() && event.getKeyCode() == KeyEvent.KEYCODE_BACK) {  
  7.             //释放焦点  
  8.             for (int i = 0; i < getChildCount(); i++) {  
  9.                 View view = getChildAt(i);  
  10.                 EditText editText1 = (EditText) view  
  11.                         .findViewById(R.id.editText1);  
  12.                 editText1.clearFocus();  
  13.             }  
  14.         }  
  15.     }  
  16.     return super.dispatchKeyEventPreIme(event);  
  17. }  

自定义控件重写dispatchKeyEventPreIme方法判断软键处于活动状态,并且用户按下了返回键盘。

说到这里提一下,自定义adapter的getView方法中view不要复用

[java]  view plain copy
  1. @Override  
  2.     public View getView(int position, View convertView, ViewGroup parent) {  
  3.         convertView = mLayoutInflater.inflate(R.layout.list_item, null);  
  4.         return convertView;  
  5.     }  

写到这里觉得这种实现方式和ScrollView+LinearLayout本质差不多

 顺便提一下怎么保存数据:

[java]  view plain copy
  1. editText1.addTextChangedListener(new TextWatcher() {  
  2.    
  3.             @Override  
  4.             public void onTextChanged(CharSequence s, int start, int before,  
  5.                     int count) {  
  6.             }  
  7.    
  8.             @Override  
  9.             public void beforeTextChanged(CharSequence s, int start, int count,  
  10.                     int after) {  
  11.             }  
  12.    
  13.             @Override  
  14.             public void afterTextChanged(Editable s) {  
  15.                 //保存数据  
  16.             }  
  17.         });  

最后,附demo下载  http://www.oschina.net/code/snippet_132911_14137
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值