package comexmythandroid;
public class ListEditorAdapter extends BaseAdapter {
private LayoutInflater mInflater;
private List<Map<String, Object>> mData;// 存储的EditText值
public Map<String, String> editorValue = new HashMap<String, String>();//
public ListEditorAdapter(Context context, List<Map<String, Object>> data) {
mData = data;
mInflater = LayoutInflaterfrom(context);
init();
}
// 初始化
private void init() {
editorValueclear();
}
@Override
public int getCount() {
return mDatasize();
}
@Override
public Object getItem(int position) {
return null;
}
@Override
public long getItemId(int position) {
return 0;
}
private Integer index = -1;
@Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder = null;
// convertView为null的时候初始化convertView。
if (convertView == null) {
holder = new ViewHolder();
convertView = mInflaterinflate(Rlayoutlistview_item, null);
holdername = (TextView) convertView
findViewById(Ridlist_item_name);
holdertitle = (TextView) convertView
findViewById(Ridlist_item_title);
holdervalue = (EditText) convertView
findViewById(Ridlist_item_inputvalue);
holdervaluesetTag(position);
holderuserkey = (TextView) convertViewfindViewById(Riduser_key);
holdervaluesetOnTouchListener(new OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
if (eventgetAction() == MotionEventACTION_UP) {
index = (Integer) vgetTag();
}
return false;
}
});
class MyTextWatcher implements TextWatcher {
public MyTextWatcher(ViewHolder holder) {
mHolder = holder;
}
private ViewHolder mHolder;
@Override
public void onTextChanged(CharSequence s, int start,
int before, int count) {
}
@Override
public void beforeTextChanged(CharSequence s, int start,
int count, int after) {
}
@Override
public void afterTextChanged(Editable s) {
if (s != null && !""equals(stoString())) {
int position = (Integer) mHoldervaluegetTag();
mDataget(position)put("list_item_inputvalue",
stoString());// 当EditText数据发生改变的时候存到data变量中
}
}
}
holdervalueaddTextChangedListener(new MyTextWatcher(holder));
convertViewsetTag(holder);
} else {
holder = (ViewHolder) convertViewgetTag();
holdervaluesetTag(position);
}
Object value = mDataget(position)get("list_item_name");
if (value != null) {
holdernamesetText((String) value);
}
value = mDataget(position)get("list_item_title");
if (value != null) {
holdertitlesetText(valuetoString());
}
value = mDataget(position)get("user_key");
if (value != null) {
holderuserkeysetText(valuetoString());
} else {
holderuserkeysetText("-1");
}
value = mDataget(position)get("list_item_inputvalue");
if (value != null && !""equals(value)) {
holdervaluesetText(valuetoString());
} else {
String key = mDataget(position)get("user_key")toString();
String inputValue = editorValueget(key);
holdervaluesetText(inputValue);
}
holdervalueclearFocus();
if (index != -1 && index == position) {
holdervaluerequestFocus();
}
return convertView;
}
public final class ViewHolder {
public TextView name;
public TextView title;
public EditText value;// ListView中的输入
public TextView userkey;// 用来定义的标志性主键,可不用关心
}
}不如这样
onClick中获得字符串后,
If(==&&=){
setText("匹配成功");
}
连续给同一个组件设置文本系统也许没能通知更新UI。
基于Android9x
Window和Session创建成功后,窗口的下一步流程为获取焦点
我们看下焦点获取过程,跟输入法相关的流程
两个Activity切换时,对应的状态变化过程为:
以下是Activity窗口初次获取焦点的流程
当两个activity 切换时,失去焦点的窗口调用过程如下:
对应的,获取焦点的额窗口的调用过程如下:
当B窗口的状态切换到RESUMED时,当窗口的focus可能变化时,会调用updateFocusedWindowLocked
在该方法中,判断,如果还没有执行startInputInner方法,则执行startInputInner方法,否则,直接执行startInputOrWindowGainedFocus方法
主要流程:
1:设置controlFlags的flag为CONTROL_WINDOW_FIRST
2:检查是否已经执行过startInputInner,没有的话执行startInputInner-->startInputOrWindowGainedFocus;否则,直接执行startInputOrWindowGainedFocus
两条路径,携带的startInputReason参数不一样
主要流程:
1:检查要启动和退出的ServedView是否为同一个,如果为同一个,则表示已经执行过startInputInner,则返回false,表示不再执行startInputInner
2:如果获取焦点的是EditorText,会创建跟IMS通信的mServedInputConnectionWrapper对象
主要流程:
1:创建EditorInfo对象tba,这个参数对TextView布局才有意义,它的初始化是在mServedView的onCreateInputConnection完成实例化的
2:根据EditorInfo创建一个InputConnection对象,输入法应用通过该对象,完成输入内容到输入框的传递;ACTIVITY获取焦点场景,该对象
为null,因为没有要输入的对象
startInputOrWindowGainedFocus携带的参数
startInputReason = 1
表示,该流程是窗口获取焦点过程
mClient
应用层创建的IInputMethodClient对象,为服务层提供应用层的各个回调方法
该方法跟应用进程首次创建时Session时,传递到IMMS的对象是同一个对象
windowGainingFocus:
应用层的ViewRootImpl$W对象
controlFlags |= CONTROL_START_INITIAL;
表示window窗口刚开始获取焦点
softInputMode = SOFT_INPUT_ADJUST_RESIZE , 允许调整输入法窗口,避免被其他窗口遮挡
tba , EditorInfo对象
servedContext
null
missingMethodFlags
ic等于null的情况下,为0
当应用层传递的W对象windowToken不为null的时候,则创建windowGainedFocus对象,返回给app
结果返回后,会对IMM的对象进行赋值
如此,进入一个窗口,获取窗口焦点过程,窗口与输入法相关的流程,就结束了。
下一篇:输入法在输入框d出流程
Android输入法(3),d出流程
package nbesense7vinciedittext;
import androidappActivity;
import androidosBundle;
import androidviewKeyEvent;
import androidviewView;
import androidwidgetEditText;
import androidwidgetTextView;
public class EditTextDemoActivity extends Activity {
private EditText editText;
private TextView textView;
/ Called when the activity is first created /
@Override
public void onCreate(Bundle savedInstanceState) {
superonCreate(savedInstanceState);
setContentView(Rlayoutmain);
editText = (EditText)findViewById(Ridinput);
textView = (TextView)findViewById(Ridoutput);
//设置EditText按键输入时的事件
editTextsetOnKeyListener(new EditTextOnKeyListener(){
@Override
public boolean onKey(View arg0, int arg1, KeyEvent arg2) {
// TODO Auto-generated method stub
textViewsetText(editTextgetText());//获取edittext的内容
return false;
}
});
}
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)