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

来源:互联网 发布:c4d mac破解版下载 编辑:程序博客网 时间:2024/06/06 12:51

  

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

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

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

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

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

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

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

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

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

有人肯定会先这样处理:

?
1
2
3
4
5
6
7
8
@Override
    publicboolean onKeyDown(intkeyCode, KeyEvent event) {
        // TODO Auto-generated method stub
        if(keyCode == KeyEvent.KEYCODE_BACK) {
             //释放焦点
        }
        returnsuper.onKeyDown(keyCode, event);
    }

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

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

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

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

?
1
2
3
4
5
@Override
    publicView getView(intposition, View convertView, ViewGroup parent) {
        convertView = mLayoutInflater.inflate(R.layout.list_item, null);
        returnconvertView;
    }

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

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
editText1.addTextChangedListener(newTextWatcher() {
 
            @Override
            publicvoid onTextChanged(CharSequence s, intstart, intbefore,
                    intcount) {
            }
 
            @Override
            publicvoid beforeTextChanged(CharSequence s, intstart, intcount,
                    intafter) {
            }
 
            @Override
            publicvoid afterTextChanged(Editable s) {
                //保存数据
            }
        });


最后,附demo下载 http://www.oschina.net/code/snippet_132911_14137
0 0
原创粉丝点击