Java 按钮未显示在自定义列表视图实现中

Java 按钮未显示在自定义列表视图实现中,java,android,xml,listview,Java,Android,Xml,Listview,我无法让我的按钮显示在我的ListView中,除了按钮之外,其他一切都显示得很好 <Button android:id="@+id/button1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Button" /> <LinearLayout android:layou

我无法让我的按钮显示在我的ListView中,除了按钮之外,其他一切都显示得很好

    <Button
        android:id="@+id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button" />

<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="155dp"
    android:orientation="vertical" >

    <TextView
        android:id="@+id/color_number"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="left|center_vertical"
        android:textSize="20sp"
        android:textStyle="bold"
        android:text="dfasd"
        android:textIsSelectable="false"/>
    <TextView
        android:id="@+id/color_name"
        android:text="dfas11111d"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="left|center_vertical"
        android:textSize="15sp"
        android:textStyle="italic"
        android:textIsSelectable="false"/>


</LinearLayout>
我的自定义行文件:custom\u list\u view\u row.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="horizontal" >

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical">
        <TextView
            android:id="@+id/color_number"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="left|center_vertical"
            android:textSize="20sp"
            android:textStyle="bold"
            android:textIsSelectable="false"/>
        <TextView
            android:id="@+id/color_name"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="left|center_vertical"
            android:textSize="15sp"
            android:textStyle="italic"
            android:textIsSelectable="false"/>
    </LinearLayout>
    <Button
        android:id="@+id/btnColor"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/Hello"
        android:background="#ff005500"/>

</LinearLayout>
    <Button
        android:id="@+id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button" />

<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="155dp"
    android:orientation="vertical" >

    <TextView
        android:id="@+id/color_number"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="left|center_vertical"
        android:textSize="20sp"
        android:textStyle="bold"
        android:text="dfasd"
        android:textIsSelectable="false"/>
    <TextView
        android:id="@+id/color_name"
        android:text="dfas11111d"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="left|center_vertical"
        android:textSize="15sp"
        android:textStyle="italic"
        android:textIsSelectable="false"/>


</LinearLayout>

以下是我的主要活动:活动\u颜色\u选择器:

<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center_horizontal"
        android:textSize="26sp"
        android:text="@string/choose_color"
        android:textColor="@android:color/holo_blue_bright"/>
    <ListView
        android:id="@android:id/list"
        android:layout_height="wrap_content"
        android:layout_width="match_parent"/>

</LinearLayout>
    <Button
        android:id="@+id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button" />

<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="155dp"
    android:orientation="vertical" >

    <TextView
        android:id="@+id/color_number"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="left|center_vertical"
        android:textSize="20sp"
        android:textStyle="bold"
        android:text="dfasd"
        android:textIsSelectable="false"/>
    <TextView
        android:id="@+id/color_name"
        android:text="dfas11111d"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="left|center_vertical"
        android:textSize="15sp"
        android:textStyle="italic"
        android:textIsSelectable="false"/>


</LinearLayout>

下面是我扩展ListActivity的activity类:

public class ColorSelector extends ListActivity {

    private final String[] items = {
        "Color #1",
        "Color #2",
        "Color #3",
        "Color #4",
        "Color #5",
        "Color #6"
    };

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_color_selector);
        setListAdapter(new CustomListViewAdapter());
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.color_selector, menu);
        return true;
    }

    class CustomListViewAdapter extends ArrayAdapter<String>{

        public CustomListViewAdapter(){
            super(
                ColorSelector.this,
                R.layout.custom_list_view_row,
                R.id.color_number,
                items);
        }
        @Override
        public View getView(int position, View convertView, ViewGroup parent){
            // Call the super class' getView method
            View row = super.getView(position, convertView, parent);

            // Get all of the widgets in the row template
            TextView colorNumber = (TextView)row.findViewById(R.id.color_number);
            TextView colorName = (TextView)row.findViewById(R.id.color_name);
            Button colorButton = (Button)row.findViewById(R.id.btnColor);
            String[] colorArray = getResources().getStringArray(R.array.color_array);

            // Set the widgets appropriate values
            colorNumber.setText("Color #" + (position + 1));
            colorName.setText(colorArray[position]);
            colorButton.setVisibility(View.VISIBLE);
            colorButton.setBackgroundColor(Color.parseColor(colorArray[position]));

            return row;
        }
    }
}
    <Button
        android:id="@+id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button" />

<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="155dp"
    android:orientation="vertical" >

    <TextView
        android:id="@+id/color_number"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="left|center_vertical"
        android:textSize="20sp"
        android:textStyle="bold"
        android:text="dfasd"
        android:textIsSelectable="false"/>
    <TextView
        android:id="@+id/color_name"
        android:text="dfas11111d"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="left|center_vertical"
        android:textSize="15sp"
        android:textStyle="italic"
        android:textIsSelectable="false"/>


</LinearLayout>
公共类ColorSelector扩展ListActivity{
私有最终字符串[]项={
“颜色#1”,
“颜色#2”,
“颜色#3”,
“颜色#4”,
“颜色#5”,
“颜色#6”
};
@凌驾
创建时受保护的void(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.activity\u color\u选择器);
setListAdapter(新的CustomListViewAdapter());
}
@凌驾
公共布尔onCreateOptions菜单(菜单){
//为菜单充气;这会将项目添加到操作栏(如果存在)。
getMenuInflater().充气(R.menu.color\u选择器,菜单);
返回true;
}
类CustomListViewAdapter扩展了ArrayAdapter{
公共CustomListViewAdapter(){
超级(
这个,,
R.layout.custom\u list\u view\u行,
R.id.color\U编号,
项目);
}
@凌驾
公共视图getView(int位置、视图转换视图、视图组父视图){
//调用超类的getView方法
视图行=super.getView(位置、转换视图、父级);
//获取行模板中的所有小部件
TextView colorNumber=(TextView)row.findViewById(R.id.color\u编号);
TextView colorName=(TextView)row.findViewById(R.id.color\u name);
按钮颜色按钮=(按钮)行。findViewById(R.id.btnColor);
String[]colorArray=getResources().getStringArray(R.array.color\u数组);
//将窗口小部件设置为适当的值
colorNumber.setText(“颜色”+(位置+1));
setText(colorArray[position]);
colorButton.setVisibility(View.VISIBLE);
colorButton.setBackgroundColor(Color.parseColor(colorArray[position]));
返回行;
}
}
}

您的代码中按钮上方的线性布局的宽度设置为与父项匹配,因此它填充了屏幕的宽度,没有为按钮留出空间:

    <LinearLayout
    android:layout_width="match_parent"
    <Button
        android:id="@+id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button" />

<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="155dp"
    android:orientation="vertical" >

    <TextView
        android:id="@+id/color_number"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="left|center_vertical"
        android:textSize="20sp"
        android:textStyle="bold"
        android:text="dfasd"
        android:textIsSelectable="false"/>
    <TextView
        android:id="@+id/color_name"
        android:text="dfas11111d"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="left|center_vertical"
        android:textSize="15sp"
        android:textStyle="italic"
        android:textIsSelectable="false"/>


</LinearLayout>

由于布局宽度,您的按钮在视图中隐藏。在开始第二个线性布局之前添加按钮。但这肯定会改变你的设计

    <Button
        android:id="@+id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button" />

<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="155dp"
    android:orientation="vertical" >

    <TextView
        android:id="@+id/color_number"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="left|center_vertical"
        android:textSize="20sp"
        android:textStyle="bold"
        android:text="dfasd"
        android:textIsSelectable="false"/>
    <TextView
        android:id="@+id/color_name"
        android:text="dfas11111d"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="left|center_vertical"
        android:textSize="15sp"
        android:textStyle="italic"
        android:textIsSelectable="false"/>


</LinearLayout>
以下是带有按钮的布局:

    <Button
        android:id="@+id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button" />

<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="155dp"
    android:orientation="vertical" >

    <TextView
        android:id="@+id/color_number"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="left|center_vertical"
        android:textSize="20sp"
        android:textStyle="bold"
        android:text="dfasd"
        android:textIsSelectable="false"/>
    <TextView
        android:id="@+id/color_name"
        android:text="dfas11111d"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="left|center_vertical"
        android:textSize="15sp"
        android:textStyle="italic"
        android:textIsSelectable="false"/>


</LinearLayout>

    <Button
        android:id="@+id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button" />

<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="155dp"
    android:orientation="vertical" >

    <TextView
        android:id="@+id/color_number"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="left|center_vertical"
        android:textSize="20sp"
        android:textStyle="bold"
        android:text="dfasd"
        android:textIsSelectable="false"/>
    <TextView
        android:id="@+id/color_name"
        android:text="dfas11111d"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="left|center_vertical"
        android:textSize="15sp"
        android:textStyle="italic"
        android:textIsSelectable="false"/>


</LinearLayout>