大家都知道在listView中使用editText,在输入过程中是有冲突的。今天稍微研究了一下这个问题,有一点点小小的心得和大家一起分享下。
首先建立一个最简单的demo,主界面就是一个ListView,其中list_item的布局代码如下:
01 |
<?xml version= "1.0" encoding= "utf-8" ?>
|
02 |
<LinearLayout xmlns:android= "http://schemas.android.com/apk/res/android"
|
03 |
android:orientation= "vertical" android:layout_width= "match_parent"
|
04 |
android:layout_height= "match_parent" >
|
05 |
<TextView android:layout_width= "wrap_content"
|
06 |
android:layout_height= "wrap_content" android:text= "TextView"
|
07 |
android:id= "@+id/textView1" android:textSize= "20sp" ></TextView>
|
08 |
<EditText android:layout_width= "match_parent"
|
09 |
android:layout_height= "wrap_content" android:id= "@+id/editText1" >
|
很简单list_item包含一个TextView,还有一个就是EditText。
运行后在某一项EditText进行输入,点击返回键隐藏输入法键盘时会遇到一个问题即所有项的EditText内容都被清空了。
解决办法:在Manifest中Activity标签下加入android:windowSoftInputMode="adjustPan"。
这个问题是解决了,但是还有其他的问题。
当你点击最后一项时,没有问题,此时最后一项的EditText拥有焦点。然后,点击系统返回键,再点击最后一项,此时你会发现输入法将最后一项完全挡住了(这样很影响用户体验)。
解决方法:当点击系统返回键时,让其释放焦点。
有人肯定会先这样处理:
2 |
public boolean onKeyDown( int keyCode, KeyEvent event) {
|
3 |
// TODO Auto-generated method stub
|
4 |
if (keyCode == KeyEvent.KEYCODE_BACK) {
|
7 |
return super .onKeyDown(keyCode, event);
|
但是很遗憾,当输入法键盘显示的时候,你点击系统的返回键事件被捕获了,而不会在onKeyDown里执行。
02 |
public boolean dispatchKeyEventPreIme(KeyEvent event) {
|
03 |
if (context != null ) {
|
04 |
InputMethodManager imm = (InputMethodManager) context
|
05 |
.getSystemService(Context.INPUT_METHOD_SERVICE);
|
06 |
if (imm.isActive() && event.getKeyCode() == KeyEvent.KEYCODE_BACK) {
|
08 |
for ( int i = 0 ; i < getChildCount(); i++) {
|
09 |
View view = getChildAt(i);
|
10 |
EditText editText1 = (EditText) view
|
11 |
.findViewById(R.id.editText1);
|
12 |
editText1.clearFocus();
|
16 |
return super .dispatchKeyEventPreIme(event);
|
自定义控件重写dispatchKeyEventPreIme方法判断软键处于活动状态,并且用户按下了返回键盘。
说到这里提一下,自定义adapter的getView方法中view不要复用
2 |
public View getView( int position, View convertView, ViewGroup parent) {
|
3 |
convertView = mLayoutInflater.inflate(R.layout.list_item, null );
|
写到这里觉得这种实现方式和ScrollView+LinearLayout本质差不多
顺便提一下怎么保存数据:
01 |
editText1.addTextChangedListener( new TextWatcher() {
|
04 |
public void onTextChanged(CharSequence s, int start, int before,
|
09 |
public void beforeTextChanged(CharSequence s, int start, int count,
|
14 |
public void afterTextChanged(Editable s) {
|
最后,附demo下载 http://www.oschina.net/code/snippet_132911_14137