4

それぞれ2つのビューを保持するアイテムを含むリストビューがあります(これは2つの列を持つListViewのように見えGridViewます)。ヘッダーとフッターが必要でしたが、では使用できないGridViewため、リストビューを使用することにしました。

各リストアイテムの個々の子ビューのセレクターが必要ですが、リストセレクターが機能しませんでした。セレクターは、両方の子ビューに適用されます。

私がこれまでに試したことは????

各単一要素のルートビューをaにし、属性FrameLayoutを使用してandroid:foreground="@drawable/some_selector"属性をシミュレートできるようにしdrawSelectorOnTopます。

私の問題 :

リストビューアイテムで押された子にのみセレクターを適用するにはどうすればよいですか。

リストビューのレイアウト

<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>

1つのリストアイテムには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>
4

4 に答える 4

4

フォアグラウンドについてはよくわかりませんが、実際に行うのはリストビューを使用することです。次に、アダプターで、リストのすべての行に2つの相対レイアウトを設定しました。これが、リストの属性です。

<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>
于 2012-10-29T18:07:07.747 に答える
2

リストビューのを設定@android:listSelector="@null"します。次に、リストアイテムの個々の子ビューのセレクターを設定します。

またandroid:descendantFocusability="afterDescendants"、リストアイテムとandroid:duplicateParentState="false"エピソードアイテムに設定します。

于 2012-10-26T12:50:03.697 に答える
2

私は前にこの問題に直面しました、そしてサンプルコードのためにここで良い解決策を見てください

于 2012-11-01T12:25:37.087 に答える
0

ListViewアダプターを使用していると仮定します。このアダプターでは、左右のレイアウトのIDが異なる2つのFrameLayoutを保持するカスタムレイアウトを拡張します。そうでない場合-これは1つの解決策です。

ListView Adapter内に、グローバルint selectedRowId=-1およびshortleftRight= -1を追加します(0は左を意味し、1は右を意味します)。getViewメソッドで、convertViewを作成するときに、postition==selectedRowIdかどうかを確認します。はいの場合-左が0または1であるかどうかを確認します。これにより、選択したアイテムが表示され、操作できるようになります。次に、各FrameLayoutにonClickListenerを追加します。ここで、selectedRowId = position、leftRight = 0または1を選択に基づいて格納し、notifyDataSetChanged()を呼び出します。

于 2012-10-26T08:27:09.730 に答える