如何在我的应用程序中添加展开/关闭图标?

时间:2017-02-10 20:13:58

标签: android xml android-studio

在Android Studio中关注我的应用教程后,我创建了一个可扩展/可折叠列表,但是我想添加一个按标题左边对齐的按钮,当标题为时,该按钮会变为向上/向下按钮展开/折叠。我该如何添加?

可扩展和可折叠列表的我的活动文件如下:

list_main.xml:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical"
android:background="#f4f4f4" >

<ExpandableListView
    android:id="@+id/lvExp"
    android:layout_height="match_parent"
    android:layout_width="match_parent"/>

</LinearLayout>

list_group.xml:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
android:padding="8dp"
android:background="#000000">


<TextView
    android:id="@+id/lblListHeader"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:paddingLeft="?android:attr/expandableListPreferredItemPaddingLeft"
    android:textSize="17dp"
    android:textColor="#f9f93d" />

</LinearLayout>

list_item.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="55dip"
android:orientation="vertical" >

<TextView
    android:id="@+id/lblListItem"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:textSize="17dip"
    android:paddingTop="5dp"
    android:paddingBottom="5dp"
    android:paddingLeft="?android:attr/expandableListPreferredChildPaddingLeft" />

</LinearLayout>

我尝试通过将list_group.xml的布局文件更改为:

来实现它
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
android:padding="8dp"
android:background="#000000">


<selector xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content">
    <item android:drawable="@drawable/down_squared"  android:state_checked="true"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />
    <item android:drawable="@drawable/up_squared"  android:state_checked="false"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />
</selector>

<TextView
    android:id="@+id/lblListHeader"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
          android:paddingLeft="?android:attr/expandableListPreferredItemPaddingLeft"
    android:textSize="17dp"
    android:textColor="#f9f93d" />

</LinearLayout>

然而,页面现在仍然崩溃,设计选项卡显示存在渲染错误,这些错误是:

找不到以下类: - item(修复构建路径,编辑XML) - 选择器(修复构建路径,编辑XML)

1 个答案:

答案 0 :(得分:1)

使用带有背景设置的复选框作为可绘制的

<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:drawable="@drawable/play_icon" android:state_checked="true" />
<item android:drawable="@drawable/pause_icon" android:state_checked="false" />
</selector>

然后在您的代码中设置复选框setOnCheckedChangeListener

的回调

并在onCheckedChanged内置expandGroupcollapseGroup来电,具体取决于检查状态