selector 选择器基础用法

   

一.创建xml文件,位置:drawable/xxx.xml,同目录下记得要放相关图片

<?xml version="1.0" encoding="utf-8" ?>   
<selector xmlns:android="http://schemas.android.com/apk/res/android"> 
<!--
 默认时的背景图片-->  
  <item android:drawable="@drawable/pic1" />    
<!--
 没有焦点时的背景图片 -->  
  <item android:state_window_focused="false"  android:drawable="@drawable/pic1" />   
<!--
 摸模式下获得焦点并单击时的背景图片 -->  
  <item android:state_focused="true" 
android:state_pressed="true"android:drawable= "@drawable/pic2" /> 

<!--选中时的图片背景-->  

  <item android:state_selected="true"   android:drawable="@drawable/pic4" />   

<!--获得焦点时的图片背景-->  

  <item android:state_focused="true"   android:drawable="@drawable/pic5" />   
</selector>
.使用xml文件:

1.方法一:listview中配置android:listSelector="@drawable/xxx
或者在listviewitem中添加属性android
background="@drawable/xxx"

2.方法二:Drawable drawable = getResources().getDrawable(R.drawable.xxx);  
       ListView.setSelector(drawable);
但是这样会出现列表有时候为黑的情况,需要加上:android:cacheColorHint="@android:color/transparent"
使其透明。

相关属性:

android:state_selected是选中
android:state_focused
是获得焦点
android:state_pressed
是点击
android:state_enabled
是设置是否响应事件,指所有事件

根据这些状态同样可以设置buttonselector效果。也可以设置selector改变button中的文字状态。

  

通过selector,Button还可以实现更复杂的效果,例如渐变
drawable/button_color.xml
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">        
   <item android:state_pressed="true">//
定义当button 处于pressed 状态时的形态。 
                <shape>

                      <gradient  android:startColor="#8600ff" /> 

                      <stroke   android:width="2dp" android:color="#000000" /> 
                      <corners  android:radius="5dp" />  
                      <padding  android:left="10dp"   android:top="10dp" 
                                android:bottom="10dp" android:right="10dp"/>  
                 </shape> 
   </item> 
   <item android:state_focused="true">//
定义当button获得 focus时的形态 
                 <shape> 
                        <gradient android:startColor="#eac100"/> 
                        <stroke android:width="2dp" android:color="#333333"  color="#ffffff"/> 
                        <corners android:radius="8dp" />   
                        <padding android:left="10dp"   android:top="10dp" 
                                 android:bottom="10dp" android:right="10dp"/>                   
                </shape> 
   </item>
</selector> 
最后,需要在包含 buttonxml文件里添加两项。例如main.xml 文件,需要在<Button />里加两项android
focusable="true" android:background="@drawable/button_color"
   在Activity 中改变选中状态:
        状态名称
含义
 enable
是否处于可以点击状态,可以 调用setEnable()方法改变其状态
 focused 
是否处于聚焦(获得焦点)状态,一个窗口只能有一个视图拥有焦点,一般 由用户交互导致,不需要应用程序直接改变
pressed 
是否处于按下状态,一般由 用户交互导致
selected
是否处于被选中状态,应用程序可以 调用setSelected()改变状态
window_focused
视图所在窗口是否是当前交互窗口,即前台窗口。该状态值由系统自动决定,应用程序不能改变其状态


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python的CSS选择器是一种用于在网页中定位元素的方法。CSS选择器可以将CSS样式中的选择器转换为XPath表达式,并用于在Python中使用cssselect库进行元素定位。这个库是Python中的一个组件,它是CSS选择器的一个端口,可以根据选择器来查找元素。使用CSS选择器,你可以根据元素的类名、标签名、属性等来定位元素。比如,你可以通过"table.table-model tbody tr td:nth-child(5) a"这个CSS选择器来定位一个网页中所有table元素中第五个td元素下的a标签。你可以使用find_elements方法来获取所有匹配的元素,并将它们放入一个列表中。请注意,如果要找到的是多个元素,则find_elements方法的最后一个参数需要加上"s",否则会返回单个元素,导致后面的遍历时出现报错找不到标签的情况。如果你想了解更多关于CSS选择器的内容,可以参考CSS选择器的文档。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [css-selector:CssSelector组件将CSS选择器转换为XPath表达式](https://download.csdn.net/download/weixin_42100971/15059499)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Python使用selenium中的CSS_SELECTOR进行搞定复杂多标签定位](https://blog.csdn.net/qq_16519957/article/details/125999441)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值