android 开发 写一个有点击效果的正方形按钮背景(点击状态属性解析)

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">

    <item android:state_pressed="false">
        <shape android:shape="rectangle">
            <solid android:color="@color/colorBlue"></solid>
            <corners android:radius="5dp"/>
            <padding android:bottom="10dp"
                android:left="10dp"
                android:right="10dp"
                android:top="10dp"/>
        </shape>
    </item>
    <item
        android:state_pressed="true">
        <shape android:shape="rectangle">
            <solid android:color="@color/colorDownBlue"></solid>
            <corners android:radius="5dp"/>
            <padding android:bottom="10dp"
                android:left="10dp"
                android:right="10dp"
                android:top="10dp"/>
        </shape>
    </item>





</selector>

实现效果:



全部点击效果解析:


状态 说明
VIEW_STATE_WINDOW_FOCUSED window处在前台状态,比如通知栏拖下时,window就不再是前台状态
VIEW_STATE_SELECTED 选中状态,比如CheckBox或者RadioButton的选中
VIEW_STATE_FOCUSED 是否取得焦点,轨迹球和方向键可以触发该状态,手机现在一般看不到该状态,机顶盒上比较常见
VIEW_STATE_ENABLED 正常状态
VIEW_STATE_PRESSED 按下状态
VIEW_STATE_ACTIVATED 表示用户选中了自己感兴趣的项目,比如勾选了ListView里的item中的CheckBox
VIEW_STATE_ACCELERATED 表示设置了硬件加速,如果有该标记,则colorBackgroundCacheHint会被忽略
VIEW_STATE_HOVERED 表示当有一个指针悬浮在该View之上
VIEW_STATE_DRAG_CAN_ACCEPT 表示此View有能力接受用户拖拽的其他View
VIEW_STATE_DRAG_HOVERED 表示在拖拽操作中, 有View正在位于自己的上方

接下来便是这些状态与Android.R.attr里的属性的对应:

static final int[] VIEW_STATE_IDS = new int[] {
  R.attr.state_window_focused,	VIEW_STATE_WINDOW_FOCUSED ,
  R.attr.state_selected,		  VIEW_STATE_SELECTED,
  R.attr.state_focused,		   VIEW_STATE_FOCUSED,
  R.attr.state_enabled,		   VIEW_STATE_ENABLED,
  R.attr.state_pressed,		   VIEW_STATE_PRESSED,
  R.attr.state_activated,		 VIEW_STATE_ACTIVATED,
  R.attr.state_accelerated,	   VIEW_STATE_ACCELERATED,
  R.attr.state_hovered,		   VIEW_STATE_HOVERED,
  R.attr.state_drag_can_accept,   VIEW_STATE_DRAG_CAN_ACCEPT ,
  R.attr.state_drag_hovered,	  VIEW_STATE_DRAG_HOVERED
};


猜你喜欢

转载自blog.csdn.net/qq_37217804/article/details/80321193