View 的 duplicateParentState 属性

来源:互联网 发布:php模拟get提交数据 编辑:程序博客网 时间:2024/05/19 05:33

View 的 duplicateParentState 属性

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

xml 属性 对应的方法 android:duplicateParentState setDuplicateParentStateEnabled(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 的绘制状态保持一致,但点击事件相互独立。

1 0
原创粉丝点击