我有一个列表项,里面有一个按钮。
显示按钮时,列表项不再可点击。 为了使其再次可点击,我已用视图替换了该按钮。问题是,当单击列表项时,按钮会更改背景图像(就像单击它一样)。如何避免这种不良行为?
由于
答案 0 :(得分:20)
实际上我刚刚找到了一个很好的解释:http://android.cyrilmottier.com/?p=525
问题和解决方案在那里得到了很好的解释。
答案 1 :(得分:18)
为您设置以下属性按钮
android:focusable="false"
android:focusableInTouchMode="false"
对于ImageButton,还要将以下内容添加到父视图
android:descendantFocusability="blocksDescendants"
答案 2 :(得分:12)
@Matroska提供的链接部分回答了问题:
你必须添加
android:descendantFocusability="blocksDescendants"
到定义ListView项目布局的父ViewGroup。
注意:这将不再允许您使用硬件按钮专注于内部按钮。 (对不起,我还不能发表评论)
答案 3 :(得分:2)
你可以试试这个:
yourButton.setFocusable(false);
yourButton.setFocusableInTouchMode(false);
答案 4 :(得分:0)
以下是ListView中可点击按钮的示例。如果要下载项目,可以从我的网站下载IntelliJ Gradle项目: http://developersfound.com/ListButtonClickExample.zip
此示例中的自定义适配器具有单击侦听器,而不是位于Fragment或Activity内的侦听器。它的完成方式是只有侦听器对象和所有按钮都绑定到它们以提高效率。
这是ListItem布局:
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout 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"
tools:context="com.jc_systems.listbuttonclickexample.app.ItemFragment">
<LinearLayout
android:id="@+id/test_container"
android:orientation="horizontal"
android:layout_width="fill_parent"
android:layout_height="wrap_content">
<ImageView
android:id="@+id/image_list_image"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/exaple_icon"
android:layout_weight=".1"
android:layout_gravity="left|top"/>
<TextView
android:id="@+id/lbl_list_item"
android:layout_width="168dp"
android:layout_height="wrap_content"
android:text="I think this should take up two lines..."
android:layout_marginLeft="5dp"
android:layout_marginRight="5dp"
android:gravity="center_vertical|center_horizontal"
android:layout_gravity="center_vertical"/>
<Button
android:id="@+id/cmd_list_button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Hello"
android:layout_weight="0.2"
android:paddingLeft="0dp"
android:paddingRight="0dp"
android:paddingTop="0dp"
android:paddingBottom="0dp"
android:layout_gravity="right|top"/>
</LinearLayout>
</FrameLayout>
这是CustomAdapter:
import android.app.Activity;
import android.app.AlertDialog;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.TextView;
import java.util.ArrayList;
public class MyCustomAdapter extends ArrayAdapter {
private final ArrayList<FragmentItems> list;
private static Activity context;
private View.OnClickListener adaptrDynaListener = null;
public MyCustomAdapter(Activity context, ArrayList<FragmentItems> list) {
super(context, R.layout.fragment_items, list);
this.context = context;
this.list = list;
adaptrDynaListener = new View.OnClickListener() {
@Override
public void onClick(View v) {
String buttonText = ((Button) v).getText().toString();
new AlertDialog.Builder(MyCustomAdapter.context).setTitle("Alert").setMessage(buttonText).setNeutralButton("OK", null).show();
}
};
}
static class ViewHolder {
protected ImageView image_list_image;
protected TextView lbl_list_item;
protected Button cmd_list_button;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
View view = null;
ViewHolder viewHolder = new ViewHolder();
if (convertView == null) {
LayoutInflater inflator = context.getLayoutInflater();
view = inflator.inflate(R.layout.fragment_items, null);
viewHolder.image_list_image = (ImageView) view.findViewById(R.id.image_list_image);
viewHolder.lbl_list_item = (TextView) view.findViewById(R.id.lbl_list_item);
viewHolder.cmd_list_button = (Button) view.findViewById(R.id.cmd_list_button);
viewHolder.cmd_list_button.setTag(viewHolder);
view.setTag(viewHolder);
}
else {
view = convertView;
viewHolder = (ViewHolder) view.getTag();
}
ViewHolder holder = (ViewHolder) view.getTag();
holder.lbl_list_item.setText(list.get(position).getMessage());
holder.cmd_list_button.setText(list.get(position).getButtonText());
holder.cmd_list_button.setOnClickListener(adaptrDynaListener);
return view;
}//public View getView(int position, View convertView, ViewGroup parent)
public int getCount() {
if(list.size() <= 0) {
return 1;
}
return list.size();
}
public Object getItem(int position) {
return position;
}
public long getItemId(int position) {
return position;
}
}
我已经非常广泛地测试了这个适配器模式,它在ListView,ListActivities和ListFragments中似乎非常稳定。
答案 5 :(得分:-1)
您可以创建一个包含所查看视图行为的xml文件。创建一个xml文件custom_button.xml(或任何你想要调用的文件)并用以下代码填充它:
<?xml version="1.0" encoding="UTF-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<!-- Focused -->
<item android:state_focused="true" android:state_pressed="false" android:color="@color/black"/>
<!-- Pressed -->
<item android:state_focused="false" android:state_pressed="true" android:color="@color/black"/>
<!-- Focused+Pressed -->
<item android:state_focused="true" android:state_pressed="true" android:color="@color/black"/>
<!-- Disabled -->
<item android:state_enabled="false" android:color="@color/dark_grey_text"/>
<!-- Default -->
<item android:color="@color/white"/>
</selector>
然后您可以更改
android:color=""
要
android:drawable=""
并将它们分配给drawable文件夹中的任何可绘制资源。然后在包含视图的布局的xml文件中,添加:
android:background="custom_button"