View 的 duplicateParentState 属性

View 的 duplicateParentState 属性

duplicateParentState 属性可应用于 View 及其子类,对应的 xml 属性和方法如下:

xml 属性对应的方法
android:duplicateParentStatesetDuplicateParentStateEnabled(boolean)

Google 官方文档对其说明:

When this attribute is set to true, the view gets its drawable state (focused, pressed, etc.) from its direct parent rather than from itself.

Must be a boolean value, either “true” or “false”.

简言之,将此属性设置为 true 时,这个 View 将从其父容器而非自身获取绘制状态(焦点、点击等)。解释略显笼统,举个例子,有如下 xml:

    <LinearLayout
        android:id="@+id/ll_test"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="@drawable/ll_bg"
        android:gravity="center"
        android:orientation="horizontal"
        android:padding="10dp">

        <Button
            android:id="@+id/btn_test"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:background="@drawable/btn_bg"
            android:duplicateParentState="true"
            android:text="test"
            android:textColor="#ffffff" />
    </LinearLayout>

其中 LinearLayout 和 Button 均设置了点击事件,二者不同状态下的背景颜色和点击后显示的 Toast 信息设置如下:

ColorTable

  • 未点击时显示效果如下图:

Normal

  • 占击 LinearLayout (灰色内蓝色外) 后显示效果如下图:

Pressed

显示 Toast 信息:点击了 LinearLayout

  • 点击 Button (蓝色内) 后显示效果如下图:

Normal

显示 Toast 信息:点击了 Button

对比以上可以发现,将 Button 的 duplicateParentState 属性设置为 true 后反馈如下:

点击 LinearLayout 时:

  1. 触发了 LinearLayout 的点击事件,但未触发 Button 的点击事件;
  2. LinearLayout 由灰变绿,即显示效果由未点击的灰色 ——> 点击时的绿色;
  3. Button 由蓝变红,即显示效果由未点击的蓝色 ——> 点击时的红色。

点击 Button 时:

  1. 触发了 Button 的点击事件,但未触发 LinearLayout 的点击事件;
  2. LinearLayout 显示效果无变化;
  3. Button 显示效果无变化。

以上加粗的“未点击”和“点击时”即为绘制状态,View 处于不同绘制状态时会有不同的显示效果。回顾上文:

将此属性设置为 true 时,这个 View 将从其父容器而非自身获取绘制状态(焦点、点击等)。

本例中,Button 即为上述所指“View”, LinearLayout 即为上述所指“父容器”。对比分析可以得出如下结论:

无论点击 LinearLayout 还是点击 Button, 对于将 duplicateParentState 属性设置为 true 的 Button 而言,其绘制状态始终与 LinearLayout 的绘制状态保持一致,但点击事件相互独立。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值