之前有人问过这个问题,但没有一个对我有用的答案(显然是另一个给出了对接受/唯一答案的评论)。
我有一个ListView
并且我已经为列表中的每个项目实现了长按复制。我正在用我自己的适配器填写列表,它设置了OnLongClickListener
并且它运行良好,除了当我触摸并按住一个项目时,它根本不会突出显示并且不会褪色。我没有设置任何事件,也没有设置我从适配器返回的ListView
其他事件。View
我已经阅读了一些修复,例如不使用wrap_content
、将 clickable 设置为 false 或将其完全从 XML 中删除。没有任何影响。我注意到,如果我删除了我的 Long Click Listener,它会为点击设置动画,但不会为褪色的长点击设置动画。
我可以做些什么来保留我的 ListView 项目上的长点击褪色动画?
仅供参考:该应用程序针对 Gingerbread (2.3.3)
编辑:
我正在写一个简单的哈希计算器。它有一项活动如下:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent">
<EditText
android:id="@+id/Input"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_alignParentRight="true"
android:layout_alignParentTop="true"
android:ems="10"
android:inputType="text">
<requestFocus/>
</EditText>
<Button
android:id="@+id/Hash"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_alignParentRight="true"
android:layout_below="@id/Input"
android:onClick="StartHashes"
android:text="@string/HashButtonText"/>
<ListView
android:id="@+id/HashList"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_alignParentBottom="true"
android:layout_alignParentLeft="true"
android:layout_alignParentRight="true"
android:layout_below="@id/Hash">
</ListView>
</RelativeLayout>
我的 onCreate 方法中的相关代码:
Adapter = new HashEntryAdapter(this, Entries);// Entries is Vector<HashEntry>
ListView list = (ListView)findViewById(R.id.HashList);
list.setAdapter(Adapter);
HashEntry
只是一个包含 2 个字符串的类:散列的名称和散列的结果输出,分别称为Name
和Value
。HashEntryAdapter
如下:
public class HashEntryAdapter extends ArrayAdapter<HashEntry> {
private Context context;
public HashEntryAdapter(Context context, List<HashEntry> objects) {
super(context, R.layout.hashitem, objects);
this.context = context;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
//data from your adapter
HashEntry entry = getItem(position);
//we want to reuse already constructed row views...
if(convertView == null) {
convertView = LayoutInflater.from(context).inflate(R.layout.hashitem, null);
convertView.setOnLongClickListener(new OnLongClickListener() {
@Override
public boolean onLongClick(View v) {
HashEntry entry = (HashEntry)v.getTag();
ClipboardManager clipboard = (ClipboardManager)v.getContext().getSystemService(Context.CLIPBOARD_SERVICE);
clipboard.setText(entry.Value);
Toast.makeText(context, entry.Name + " copied to clipboard", Toast.LENGTH_SHORT).show();
return true;
}
});
}
convertView.setTag(entry);
TextView Name = (TextView)convertView.findViewById(R.id.HashName);
TextView Value = (TextView)convertView.findViewById(R.id.HashValue);
Name.setText(entry.Name);
Value.setText(entry.Value);
return convertView;
}
}
最后是 hashitem.xml,一个简单的布局,将灰色的哈希名称放在黑色的哈希值上:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:id="@+id/HashName"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_alignParentRight="true"
android:layout_alignParentTop="true"
android:text="@string/HashNameFiller"
android:textAppearance="?android:attr/textAppearanceLarge"
android:textColor="@color/DarkGray"/>
<TextView
android:id="@+id/HashValue"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_below="@id/HashName"
android:layout_centerHorizontal="true"
android:text="@string/HashValueFiller"
android:textAppearance="?android:attr/textAppearanceMedium"/>
</RelativeLayout>
vikki 的 OnCreateContextMenu:
list.setOnCreateContextMenuListener(new OnCreateContextMenuListener() {
@Override
public void onCreateContextMenu(ContextMenu menu, View v, ContextMenuInfo menuInfo) {
}
});