gpt4 book ai didi

android - 为 ListView 的特定子项应用 android 选择器,并在同一列表项中的其他子项上禁用选择器

转载 作者:塔克拉玛干 更新时间:2023-11-03 00:05:52 26 4
gpt4 key购买 nike

我有一个 ListView ,每个项目包含 2 个 View (这个 ListView 看起来像一个有 2 列的 GridView)。我需要页眉和页脚,但它们在 GridView 中不可用,所以我转而使用 ListView 。

我想要一个用于每个列表项的单独 subview 的选择器,列表选择器不起作用,它将选择器应用于两个 subview 。

到目前为止我尝试了什么????

我将每个元素的 Root View 设为 FrameLayout 并使用 android:foreground="@drawable/some_selector" 属性,这样我就可以模拟 drawSelectorOnTop 属性。

我的问题:

如何才能将选择器仅应用于 listview 项目 中按下的子项。

ListView 布局

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

<ListView
android:id="@+id/episode_list"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:divider="@android:color/black"
android:dividerHeight="5dp"
android:listSelector="@null"
android:descendantFocusability="afterDescendants" />

</RelativeLayout>

剧集项目

<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:clickable="true"
android:foreground="@drawable/all_show_cell_background_selector" >

<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/llEpisode"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#282828"
android:paddingBottom="5dp" >

<ImageView
android:id="@+id/episodeImage"
android:layout_width="160dp"
android:layout_height="90dp"
android:layout_alignParentLeft="true"
android:layout_alignParentRight="true"
android:layout_gravity="center_vertical|center_horizontal"
android:adjustViewBounds="true"
android:contentDescription="@string/app_name"
android:scaleType="centerCrop"
android:src="@drawable/video_blank" />

<TextView
android:id="@+id/episodeDuration"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignBottom="@id/episodeImage"
android:layout_alignLeft="@id/episodeImage"
android:background="@android:color/black"
android:gravity="right"
android:padding="2dp"
android:textColor="#FFFFFF"
android:textSize="11sp" />
<!-- android:textColor="#b5b4b4" -->

<TextView
android:layout_marginTop="2dp"
android:id="@+id/episodeTitle"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_below="@+id/episodeImage"
android:gravity="right"
android:paddingRight="5dp"
android:singleLine="true"
android:text="hdgsagafasfsdafsdfsdfasddfsad"
android:textColor="#ffffff"
android:textSize="14sp" >

</TextView>

<TextView
android:id="@+id/showName"
android:layout_marginTop="2dp"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_below="@+id/episodeTitle"
android:clickable="true"
android:gravity="right"
android:paddingRight="5dp"
android:text="hdgsagafasfsdafsdfsdfasddfsad"
android:textColor="#A8A8A8"
android:textSize="13sp" >

</TextView>

<TextView
android:layout_marginTop="2dp"
android:id="@+id/noOfViewsText"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:layout_below="@+id/showName"
android:layout_alignParentBottom="true"
android:gravity="right"
android:paddingRight="5dp"
android:text="@string/number_of_views_text"
android:textColor="#A8A8A8"
android:textSize="11sp" />

<TextView
android:id="@+id/episodeNumberOfViews"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignBottom="@+id/noOfViewsText"
android:layout_toLeftOf="@+id/noOfViewsText"
android:layout_toRightOf="@+id/fav_img"
android:ellipsize="none"
android:gravity="right"
android:paddingRight="5dp"
android:singleLine="true"
android:text="fsdafasdfsad"
android:textColor="#A8A8A8"
android:textSize="11sp" />

<ImageView
android:id="@+id/fav_img"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignBottom="@+id/episodeNumberOfViews"
android:layout_alignParentLeft="true"
android:layout_marginLeft="4dp"
android:contentDescription="@string/favourite_title_show"
android:src="@drawable/fav_episode" />
</RelativeLayout>

</FrameLayout>

单个列表项包含 2 个剧集项

这是装有 2 集元素的容器

 <?xml version="1.0" encoding="utf-8"?>
<!-- This container to help emulate a GridView in each ListView item -->
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:descendantFocusability="afterDescendants"
android:orientation="horizontal" >

</LinearLayout>

最佳答案

我不太确定前景,但我实际上做的是使用 ListView 。然后在适配器中我为列表中的每一行设置了两个相对布局,这是我的列表属性:

<ListView
android:id="@+id/seccion_list"
android:layout_height="wrap_content"
android:layout_width="fill_parent"
android:divider="@null"
android:dividerHeight="0dp"/>

在我的适配器中,我将布局设置为为每一行加载,这是该行中第一帧的第一个相对布局:

 <RelativeLayout
android:id="@+id/primerContenedor"
android:layout_width="wrap_content"
android:layout_height="@dimen/seccion_3_imagen_height"
android:layout_marginLeft="3dip"
android:layout_marginRight="3dip"
android:layout_marginTop="5dip"
android:layout_weight="1"
android:clickable="true"
android:focusable="true"
android:background="@drawable/layout_selector">

基本上我所做的是将相对布局的可点击和可聚焦属性设置为 true 并定义一个选择器:

    <?xml version="1.0" encoding="utf-8"?> 
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_focused="true" android:drawable="@color/blue"/>
<item android:state_pressed="true" android:drawable="@color/blue"/>
<item android:drawable="@color/grey" />
</selector>

关于android - 为 ListView 的特定子项应用 android 选择器,并在同一列表项中的其他子项上禁用选择器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13022230/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com