带有imageview的可点击布局的android选择器

Posted

技术标签:

【中文标题】带有imageview的可点击布局的android选择器【英文标题】:android selector for clickable layout with imageview 【发布时间】:2014-02-14 16:09:29 【问题描述】:

伙计们,如果我有这样的布局

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_
    android:layout_
    android:background="@drawable/deals_list_item_bckg"
    android:orientation="vertical" >

    <LinearLayout
        android:layout_
        android:layout_
        android:layout_margin="15dp"
        android:background="@drawable/deals_list_item_background"
        android:clickable="true"
        android:orientation="horizontal" >

        <ImageView
            android:id="@+id/imageView1"
            android:layout_
            android:layout_
            android:scaleType="fitXY"
            android:src="@drawable/btn_unpressed" />

        <LinearLayout
            android:layout_
            android:layout_
            android:gravity="center_vertical|right"
            android:orientation="vertical" >

            <TextView
                android:id="@+id/textView1"
                android:layout_
                android:layout_
                android:paddingRight="10dp"
                android:text="My Account"
                android:textSize="16sp" />
        </LinearLayout>
    </LinearLayout>

</LinearLayout>

结果是

有没有办法编写选择器,当按下状态时只改变 imageView 的 img

喜欢这个

或者请告诉我我该怎么做这样的按钮,因为问题是按钮的右侧部分也需要背景图像,而左侧部分是图像视图,当按下右侧部分(布局)时必须更改它的图像

【问题讨论】:

给ImageView的imageDrawable设置一个StateListDrawable 【参考方案1】:

除非您计划在运行时向该按钮布局添加大量视图......它对于您需要它执行的操作来说过于复杂。这是一个更简单的版本,应该适合您:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_
android:layout_
android:layout_margin="15dp"
android:clickable="true"
android:orientation="horizontal">

<ImageView
    android:layout_
    android:layout_
    android:scaleType="fitXY"
    android:duplicateParentState="true"
    android:src="@drawable/btn_background" />

<TextView
    android:layout_
    android:layout_
    android:gravity="center_vertical|right"
    android:background="@drawable/your_grey_bar"
    android:paddingRight="10dp"
    android:text="My Account"
    android:textSize="16sp" />
</LinearLayout>

然后在 res/drawable 中你需要定义 btn_background.xml 如下:

<selector xmlns:android="http://schemas.android.com/apk/res/android">

<item android:drawable="@drawable/btn_default_disabled_focused" android:state_focused="true" android:state_enabled="false"/>
<item android:drawable="@drawable/btn_default_focused" android:state_focused="true" android:state_enabled="true"/>
<item android:drawable="@drawable/btn_default_disabled" android:state_enabled="false"/>
<item android:drawable="@drawable/btn_default_pressed" android:state_pressed="true"/>
<item android:drawable="@drawable/btn_default_normal" />

</selector>

这里的诀窍是使 LinearLayout 可点击。这样,用户可以单击“按钮”上的任何位置。然后让ImageView 复制它的父状态。这意味着每当 LinearLayout 更改其状态(例如,启用、聚焦、按下等)时,ImageView 也会收到它。因此,选择器可绘制对象将为您完成它的工作并更新。

【讨论】:

工作得很好,但在设备上我的按钮是全屏的 =( 我该如何解决它 只需用另一个适当的布局围绕 LinearLayout。例如,线性、框架、相对等。取决于您是否真的添加了其他东西。它的高度/宽度需要为 match_parent【参考方案2】:

使用Android提供的样式如下

<ImageView
    android:src="@drawable/sky_image"
    style="@style/Widget.AppCompat.ActionButton"
    ...
/>

你会在点击时获得色调效果

source

【讨论】:

以上是关于带有imageview的可点击布局的android选择器的主要内容,如果未能解决你的问题,请参考以下文章

带有两个列表片段的可滚动布局

Android ImageView 点击更换头像

Android - 扩展 ImageView 的最佳实现

如何在特定的imageView上上传特定的图像点击来自android中的画廊和相机

带有setAdjustViewBounds的Android ImageView在ConstraintLayout中具有无法解释的行为

ImageView控件的使用