位置: 编程技术 - 正文

Android开发:shape和selector和layer-list的(详细说明)(qt Android开发)

编辑:rootadmin

推荐整理分享Android开发:shape和selector和layer-list的(详细说明)(qt Android开发),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:Android开发工具,Android开发者网站,Android开发者网站,qt Android开发,qt Android开发,Android开发者网站,qt Android开发,Android开发者,内容如对您有帮助,希望把文章链接给更多的朋友!

<shape>和<selector>在Android UI设计中经常用到。比如我们要自定义一个圆角Button,点击Button有些效果的变化,就要用到<shape>和<selector>。可以这样说,<shape>和<selector>在美化控件中的作用是至关重要。

在看这篇文章之前,可以看下这个小例子:镂空按钮的实现

1.Shape简介

作用:XML中定义的几何形状

位置:res/drawable/文件的名称.xml

使用的方法:

Java代码中:R.drawable.文件的名称

XML中:Android:background="@drawable/文件的名称"

属性:

<shape> Android:shape=["rectangle" | "oval" | "line" | "ring"]

其中rectagle矩形,oval椭圆,line水平直线,ring环形

<shape>中子节点的常用属性:

<gradient> 渐变

Android:startColor

起始颜色

Android:endColor

结束颜色

Android:angle

渐变角度,0从左到右,表示从下到上,数&#;为的整数倍,默认为0;

Android:type

渐变的样式 liner线性渐变 radial环形渐变 sweep

<solid > 填充

Android:color

填充的颜色

<stroke >描边

Android:width

描边的宽度

Android:color

描边的颜色

Android:dashWidth

表示'-'横线的宽度

Android:dashGap

表示'-'横线之间的距离

<corners >圆角

Android:radius

圆角的半径 &#;越大角越圆

Android开发:shape和selector和layer-list的(详细说明)(qt Android开发)

Android:topRightRadius

右上圆角半径

Android:bottomLeftRadius

右下圆角角半径

Android:topLeftRadius

左上圆角半径

Android:bottomRightRadius

左下圆角半径

<padding >填充

android:bottom="1.0dip"

底部填充

android:left="1.0dip"

左边填充

android:right="1.0dip"

右边填充

android:top="0.0dip"

上面填充

2.Selector简介

根据不同的选定状态来定义不同的现实效果

分为四大属性:

android:state_selected 是选中

android:state_focused 是获得焦点

android:state_pressed 是点击

android:state_enabled 是设置是否响应事件,指所有事件

另:

android:state_window_focused 默认时的背景图片

引用位置:res/drawable/文件的名称.xml

使用的方法:Java代码中:R.drawable.文件的名称

XML中:Android:background="@drawable/文件的名称"

[html] view plaincopy<?xml version="1.0" encoding="utf-8" ?> <selector xmlns:Android=" <!-- 默认时的背景图片--> <item Android:drawable="@drawable/pic1" /> <!-- 没有焦点时的背景图片 --> <item Android:state_window_focused="false" android:drawable="@drawable/pic_blue" /> <!-- 非触摸模式下获得焦点并单击时的背景图片 --> <item Android:state_focused="true" android:state_pressed="true" android:drawable= "@drawable/pic_red" /> <!-- 触摸模式下单击时的背景图片--> <item Android:state_focused="false" Android:state_pressed="true" Android:drawable="@drawable/pic_pink" /> <!--选中时的图片背景--> <item Android:state_selected="true" android:drawable="@drawable/pic_orange" /> <!--获得焦点时的图片背景--> <item Android:state_focused="true" Android:drawable="@drawable/pic_green" /> </selector> 3.layer-list 简介:将多个图片或上面两种效果按照顺序层叠起来例子:[html] view plaincopy<?xml version="1.0" encoding="utf-8"?> <layer-list xmlns:android=" <item> <bitmap android:src="@drawable/android_red" android:gravity="center" /> </item> <item android:top="dp" android:left="dp"> <bitmap android:src="@drawable/android_green" android:gravity="center" /> </item> <item android:top="dp" android:left="dp"> <bitmap android:src="@drawable/android_blue" android:gravity="center" /> </item> </layer-list> [html] view plaincopy<ImageView android:layout_height="wrap_content" android:layout_width="wrap_content" android:src="@drawable/layers" /> 效果图:

4.最后

以上三个标签可以揉合到一块儿来使用,所要实现的效果就是上面三种标签的说明,比如下面这个例子:

[html] view plaincopy<selector xmlns:android=" <item android:state_pressed="true"> <layer-list> <item android:bottom="8.0dip"> <shape> <solid android:color="#ffaaaaaa" /> </shape> </item> <item> <shape> <corners android:bottomLeftRadius="4.0dip" android:bottomRightRadius="4.0dip" android:topLeftRadius="1.0dip" android:topRightRadius="1.0dip" /> <solid android:color="#ffaaaaaa" /> <padding android:bottom="1.0dip" android:left="1.0dip" android:right="1.0dip" android:top="0.0dip" /> </shape> </item> <item> <shape> <corners android:bottomLeftRadius="3.0dip" android:bottomRightRadius="3.0dip" android:topLeftRadius="1.0dip" android:topRightRadius="1.0dip" /> <solid android:color="@color/setting_item_bgcolor_press" /> </shape> </item> </layer-list> </item> <item> <layer-list> <item android:bottom="8.0dip"> <shape> <solid android:color="#ffaaaaaa" /> </shape> </item> <item> <shape> <corners android:bottomLeftRadius="4.0dip" android:bottomRightRadius="4.0dip" android:topLeftRadius="1.0dip" android:topRightRadius="1.0dip" /> <solid android:color="#ffaaaaaa" /> <padding android:bottom="1.0dip" android:left="1.0dip" android:right="1.0dip" android:top="0.0dip" /> </shape> </item> <item> <shape> <corners android:bottomLeftRadius="3.0dip" android:bottomRightRadius="3.0dip" android:topLeftRadius="1.0dip" android:topRightRadius="1.0dip" /> <solid android:color="@color/setting_item_bgcolor" /> </shape> </item> </layer-list> </item> </selector>

Android Path和PathMeasure类的使用之获取圆弧上的坐标值 问题:已知图中的中心圆点在屏幕上的坐标为(x,y),分别求出点1、2、3、4的坐标!解决方法:可以利用Android的SDK自带类android.graphics.Path和android.graphics.Pa

EditText获取焦点不自动弹出键盘设置 EditText获取焦点不自动弹出键盘设置带有EditText控件的在第一次显示的时候会自动获得focus,并弹出键盘如果不想自动弹出键盘,有两种方法:方法一:

Android Volley完全解析(一),初识Volley的基本用法 1.Volley简介我们平时在开发Android应用的时候不可避免地都需要用到网络技术,而多数情况下应用程序都会使用HTTP协议来发送和接收网络数据。Android系统

标签: qt Android开发

本文链接地址:https://www.jiuchutong.com/biancheng/386754.html 转载请保留说明!

上一篇:android上开源项目、酷炫的交互动画和视觉效果(android开源小项目)

下一篇:Android Path和PathMeasure类的使用之获取圆弧上的坐标值

  • 如何申请成为一名党员
  • 企业交的增值税怎么做账
  • 未达起征点附加税还需要扣税嘛
  • 公司对公账户给员工发工资税是谁扣
  • 投资性房地产转为非投资性房地产
  • 公益性捐赠的税收优惠政策
  • 合同负债与预计负责区别
  • 企业资产重组是不定期清查吗
  • 融资融券与普通证券交易的区别体现在
  • 公司投资控股其他公司如何做账务处理
  • 参与工会职工应享受哪些福利待遇
  • 结转已到期未兑付怎么办
  • 住房补贴是现金还是转账
  • 酒店会务费发票税率
  • 在途物资的入账价值
  • 500万以下固定资产最新政策
  • 产权交易费用
  • 当无法取得对应报价时,将以即时现价报单
  • 委外开发费用可以加计扣除吗
  • 建筑行业项目部会计要做什么
  • 补记以前年度收入分录
  • 收到的增值税专用发票如何认证
  • 如何限制某台设备上网
  • 文字转换表格怎么设置行列
  • 一次性支付一年租金怎么做账
  • 摊销租赁费属于什么费用
  • win7纯净版系统 9代
  • windows 查询进程
  • 和平之城
  • php登录注册页面完整代码
  • 间接人工费用预算工时分配率将提高10%
  • ci框架如何做api
  • elementui怎么样
  • python怎样学
  • win11右键没了
  • laravel 实例
  • 融资租赁设备所有权归谁
  • 企业进行清算
  • 非成品油发票为什么不能抵扣
  • 购入固定资产怎么做账务处理
  • 资产负债表中应付账款项目应根据什么填制
  • 公司转让注册海外公司
  • 微擎最新破解版
  • centos7.1
  • jsp连接数据库的步骤
  • php增删改查语句
  • 城建税要计入税金及附加吗
  • 公司买手表可以抵扣增值税吗
  • 增值税进项发票是什么意思
  • 税务局核定税种流程
  • 财税人员岗位职责
  • 企业现金购货限额
  • 出口收入没有及时申报怎么处罚
  • 税金及附加如何预测
  • 内账收入如何确认
  • 社保金额不对到不了账
  • 外贸退税是算利润吗
  • 印花税滞纳金怎么处理
  • 捐赠支出表怎么填
  • win8系统怎么重置
  • 加入跨子网路由什么协议
  • 晨枫U盘启动工具哪个版本好用
  • xp系统与win7系统的电脑怎么组成局域网
  • ttf字体怎么转itz
  • windows10周年更新
  • javascript零基础
  • linux基本命令的使用方法
  • 常用的git操作
  • glslpe
  • Intermediate Unity 3D for iOS: Part 2/3
  • js获取表单元素
  • python基础入门教程
  • python如何编写
  • javascript五种数据类型
  • python爬虫类
  • python中创建类对象
  • 百旺金赋天津客服电话
  • 湖南省五一劳动奖章
  • 国家税务总局公告2017年第21号
  • 境外个人税务备案登记表
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设