【问题标题】:Focusable EditText in the ListView and onItemClickListView 和 onItemClick 中的可聚焦 EditText
【发布时间】:2012-08-18 20:52:23
【问题描述】:

在每个ListView 项目中我都有EditText

当我将android:focusable="false" 设置为EditText 时,ListView 项目上的onItemClick 工作正常,但是当我在内部clickEditText 没有光标。

如果我将android:focusable="true" 设置为EditText,那么EditText 是可聚焦的,但是当我单击它时,ListViewonItemClick 不起作用。

如何在这个项目中分离onItemClick和可聚焦的EditText

【问题讨论】:

  • 如果您从 EditText 中删除 android:focusable 属性会怎样?
  • 我认为这是因为当您将 android:focusable="true" 应用于 EditText 时,ListItem 的 onItemClick 仅调度到 EditText。并且事件没有传递给它父列表项视图。
  • @user370305 行为与 android:focusable="true" 相同。即EditText 是可聚焦的,但是当我点击它时,ListViewonItemClick 不起作用。
  • @user370305 我是这么认为的:) 但是如何克服呢?
  • 你可以试试这个,setOnTouchListener()EditText 并在 onTouch 中覆盖 onTouch() 只是 return false...?让我知道发生了什么......

标签: android android-listview onitemclick focusable


【解决方案1】:

感谢 @user370305 提出 OnTouchListener 的想法。 现在它正在使用setOnTouchListener()为我工作:

public class AdapterListCards extends CursorAdapter implements View.OnTouchListener {
 public AdapterListCards(Context context) {
    super(context, null, true);
 }

 @Override
 public boolean onTouch(View view, MotionEvent motionEvent) {
    if (view instanceof EditText) {
        EditText editText = (EditText) view;
        editText.setFocusable(true);
        editText.setFocusableInTouchMode(true);
    } else {
        ViewHolder holder = (ViewHolder) view.getTag();
        holder.edtCode.setFocusable(false);
        holder.edtCode.setFocusableInTouchMode(false);
    }
    return false;
 }

 private class ViewHolder {
    TextView txtName;
    EditText edtCode;
}

 @Override
 public View newView(final Context context, Cursor cursor, ViewGroup parent) {
    View convertView = LayoutInflater.from(context).inflate(R.layout.list_item, parent, false);
    final ViewHolder holder = new ViewHolder();
    holder.txtName = (TextView) convertView.findViewById(R.id.txt_name);
    holder.edtCode = (EditText) convertView.findViewById(R.id.pass);
    holder.edtCode.setOnTouchListener(this);
    convertView.setOnTouchListener(this);
    convertView.setTag(holder);

    return convertView;
 }

@Override
public void bindView(View view, Context context, Cursor cur) {
    ViewHolder holder = (ViewHolder) view.getTag();
    if (cur!=null) holder.txtName.setText(cur.getString(cur.getColumnIndex("name")));
 }
}

当然还有:android:windowSoftInputMode="adjustPan" 用于清单中的活动。

【讨论】:

  • 好。现在你可以接受你自己的答案了。并且我 +1 用于实施我的建议并将其作为解决方案发布,以便其他用户也可以发现这很有帮助。
【解决方案2】:

我的解决方案:

@Override
public boolean onTouch(View view, MotionEvent motionEvent) {
    ViewHolder vh = (ViewHolder) view.getTag();
    //vh.row is the convertView in getView or you may call it the row item itself
    ((ViewGroup)vh.row).setDescendantFocusability(view instanceof EditText?ViewGroup.FOCUS_AFTER_DESCENDANTS:ViewGroup.FOCUS_BLOCK_DESCENDANTS);
    return false;
}

并添加

android:descendantFocusability="blocksDescendants"

到列表行项目的布局 xml 文件中的视图组。

【讨论】:

    【解决方案3】:

    对我有用的解决方案是使用带有 TextView 的 EditText 和 adater 中指示编辑模式启用/禁用的标志。

    我在相对布局中的相同位置添加了 TextView 和 EditText,这意味着它们将相互重叠。默认情况下,EditText 将被隐藏,而 TextView 将被显示。在此列表视图的项目单击工作完美。

    然后我为 TextView 和 onTouch 分配了触摸侦听器,我隐藏了 textview 并显示了 EditText 和 requestfocus 以启用输入。甚至整个视图的点击都会请求 EditText 的焦点。因此,不应启用任何项目单击。

    我在操作栏中有一个按钮“完成”。单击它后,我会在适配器中更新我的标志,说“modeEdit = false”并调用 notifydatasetchanges。

    在 GetView 中,我们检查了标志,如果 modeEdit = false,则显示 TextView。

    这是我工作的唯一最佳解决方案!!!

    希望这会有所帮助。如果有人对源代码的工作副本感兴趣,请告诉我。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2013-01-12
      • 1970-01-01
      • 1970-01-01
      • 2016-08-27
      • 1970-01-01
      • 2021-04-24
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多