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 信息设置如下:
- 未点击时显示效果如下图:
- 占击 LinearLayout (灰色内蓝色外) 后显示效果如下图:
显示 Toast 信息:点击了 LinearLayout
- 点击 Button (蓝色内) 后显示效果如下图:
显示 Toast 信息:点击了 Button
对比以上可以发现,将 Button 的 duplicateParentState 属性设置为 true 后反馈如下:
点击 LinearLayout 时:
- 触发了 LinearLayout 的点击事件,但未触发 Button 的点击事件;
- LinearLayout 由灰变绿,即显示效果由未点击的灰色 ——> 点击时的绿色;
- Button 由蓝变红,即显示效果由未点击的蓝色 ——> 点击时的红色。
点击 Button 时:
- 触发了 Button 的点击事件,但未触发 LinearLayout 的点击事件;
- LinearLayout 显示效果无变化;
- Button 显示效果无变化。
以上加粗的“未点击”和“点击时”即为绘制状态,View 处于不同绘制状态时会有不同的显示效果。回顾上文:
将此属性设置为 true 时,这个 View 将从其父容器而非自身获取绘制状态(焦点、点击等)。
本例中,Button 即为上述所指“View”, LinearLayout 即为上述所指“父容器”。对比分析可以得出如下结论:
无论点击 LinearLayout 还是点击 Button, 对于将 duplicateParentState 属性设置为 true 的 Button 而言,其绘制状态始终与 LinearLayout 的绘制状态保持一致,但点击事件相互独立。