android shape 的使用

2023-11-05

Android中常常使用shape来定义控件的一些显示属性它可以作为一般图片使用,今天看了一些shape的使用,对shape有了大体的了解,稍作总结:

先看下面的代码:

XML/HTML代码
  1. <shape>  
  2.     <!-- 实心 -->  
  3.     <solid android:color="#ff9d77"/>  
  4.     <!-- 渐变 -->  
  5.     <gradient  
  6.         android:startColor="#ff8c00"  
  7.         android:endColor="#FFFFFF"  
  8.         android:angle="270" />  
  9.     <!-- 描边 -->  
  10.     <stroke  
  11.         android:width="2dp"  
  12.         android:color="#dcdcdc" />  
  13.     <!-- 圆角 -->  
  14.     <corners  
  15.         android:radius="2dp" />  
  16.     <padding  
  17.         android:left="10dp"  
  18.         android:top="10dp"  
  19.         android:right="10dp"  
  20.         android:bottom="10dp" />  
  21. </shape>  


solid:实心,就是填充的意思
android:color指定填充的颜色

gradient:渐变
android:startColor和android:endColor分别为起始和结束颜色,ndroid:angle是渐变角度,必须为45的整数倍。
另外渐变默认的模式为android:type="linear",即线性渐变,可以指定渐变为径向渐变,android:type="radial",径向渐变需要指定半径android:gradientRadius="50"。

stroke:描边
android:width="2dp" 描边的宽度,android:color 描边的颜色。
我们还可以把描边弄成虚线的形式,设置方式为:
android:dashWidth="5dp"

android:dashGap="3dp"
其中android:dashWidth表示'-'这样一个横线的宽度,android:dashGap表示之间隔开的距离。

corners:圆角
android:radius为角的弧度,值越大角越圆。
我们还可以把四个角设定成不同的角度,方法为:

XML/HTML代码
  1. <corners  
  2.   
  3.         android:topRightRadius="20dp"    右上角  
  4.         android:bottomLeftRadius="20dp"    右下角  
  5.         android:topLeftRadius="1dp"    左上角  
  6.         android:bottomRightRadius="0dp"    左下角  
  7. />  


这里有个地方需要注意,bottomLeftRadius是右下角,而不是左下角,这个有点郁闷,不过不影响使用,记得别搞错了就行。
还有网上看到有人说设置成0dp无效,不过我在测试中发现是可以的,我用的是2.2,可能修复了这个问题吧,如果无效的话那就只能设成1dp了。

padding:间隔
这个就不用多说了,XML布局文件中经常用到。


大体的就是这样,以下是一个使用的具体示例:用在Selector中作为Button的背景,分别定义了按钮的一般状态、获得焦点状态和按下时的状态,具体代码如下:

XML/HTML代码
  1. main.xml:  
  2. <Button  
  3.     android:layout_width="wrap_content"  
  4.     android:layout_height="wrap_content"  
  5.     android:text="TestShapeButton"  
  6.     android:background="@drawable/button_selector"  
  7.     />  
  8. >  



button_selector.xml:

XML/HTML代码
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <selector  
  3.     xmlns:android="http://schemas.android.com/apk/res/android">  
  4.     <item android:state_pressed="true" >  
  5.         <shape>  
  6.             <!-- 渐变 -->  
  7.             <gradient  
  8.                 android:startColor="#ff8c00"  
  9.                 android:endColor="#FFFFFF"  
  10.                 android:type="radial"  
  11.                 android:gradientRadius="50" />  
  12.             <!-- 描边 -->  
  13.             <stroke  
  14.                 android:width="2dp"  
  15.                 android:color="#dcdcdc"  
  16.                 android:dashWidth="5dp"  
  17.                 android:dashGap="3dp" />  
  18.             <!-- 圆角 -->  
  19.             <corners  
  20.                 android:radius="2dp" />  
  21.             <padding  
  22.                 android:left="10dp"  
  23.                 android:top="10dp"  
  24.                 android:right="10dp"  
  25.                 android:bottom="10dp" />  
  26.         </shape>  
  27.     </item>  
  28.     <item android:state_focused="true" >  
  29.         <shape>  
  30.             <gradient  
  31.                 android:startColor="#ffc2b7"  
  32.                 android:endColor="#ffc2b7"  
  33.                 android:angle="270" />  
  34.             <stroke  
  35.                 android:width="2dp"  
  36.                 android:color="#dcdcdc" />  
  37.             <corners  
  38.                 android:radius="2dp" />  
  39.             <padding  
  40.                 android:left="10dp"  
  41.                 android:top="10dp"  
  42.                 android:right="10dp"  
  43.                 android:bottom="10dp" />  
  44.         </shape>  
  45.     </item>  
  46.     <item>        
  47.         <shape>  
  48.             <solid android:color="#ff9d77"/>  
  49.             <stroke  
  50.                 android:width="2dp"  
  51.                 android:color="#fad3cf" />  
  52.             <corners  
  53.                 android:topRightRadius="5dp"  
  54.                 android:bottomLeftRadius="5dp"  
  55.                 android:topLeftRadius="0dp"  
  56.                 android:bottomRightRadius="0dp"  
  57.             />  
  58.             <padding  
  59.                 android:left="10dp"  
  60.                 android:top="10dp"  
  61.                 android:right="10dp"  
  62.                 android:bottom="10dp" />  
  63.         </shape>  
  64.     </item>  
  65. </selector>  


运行效果如下图:
一般状态:


获得焦点状态:


按下状态:

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

android shape 的使用 的相关文章

  • 使用匕首柄作为依赖注入来处理多个改造客户端?

    我想在我的 android 应用程序中使用两个不同的后端 具有不同的响应格式 我使用 hilt 作为依赖注入 并对网络调用进行改造 这非常适合工作 因为我已经添加了第二个服务器网络文件和应用程序模块 所以它给了我错误 该错误列在最后 我需要
  • Kotlin Android Firebase 数据库哈希映射转换为类

    我正在尝试从 firebase 数据库获取数据 断点显示它正在获取数据 但看起来我没有正确地将其分配给我的班级 这会导致此异常 java lang ClassCastException 无法将 java util HashMap 转换为 班
  • Android Studio Canary 3.4 Canary 4:错误:功能插件不支持variant.getApplicationId()

    自从我在新版本上更新了我的项目以来Android Studio 3 4 金丝雀 4 gradle 同步失败 因为 ERROR variant getApplicationId is not supported by feature plug
  • ndk-build error.opencv2/core/core.hpp:没有这样的文件或目录

    我在 Android 中使用 OpenCV Nonfree 模块时遇到问题 我读了这个教程https sites google com site wghsite technical notes sift surf opencv androi
  • 如何使用retrofit2动态设置超时?

    public class Router private static Retrofit retrofit null public Retrofit getRetrofit if retrofit null OkHttpClient clie
  • 与通用地图相比,MapView 的分辨率较差

    我刚刚收到 HTC Desire 进行测试 我注意到 残留在小于整个屏幕的框架中的地图视图不如通用地图应用程序那么清晰 有什么办法解决这个问题吗 您应该使用 API 级别 4 或更高级别编译应用程序 然后在 AndroidManifest
  • 不使用eclipse安装Android模拟器

    如何在没有eclipse的电脑上安装android模拟器 android模拟器无需安装eclipse 只需下载 android sdk 并安装即可 安装android SDK之前必须先安装JDK 完成后安装成功 您将获得两个应用程序 SDK
  • Android 中图像字节表示的每像素字节数

    我目前正在编写一个Android应用程序 需要在其中使用OCR 为了实现这一点 我将 Tesseract 与tesseract android tools 项目 http code google com p tesseract androi
  • 构建应用程序时出现 BufferOverflowException

    每次我想运行我的 Android 应用程序时 我都会收到错误 2013 11 02 13 05 36 Dex Loader Unable to execute dex java nio BufferOverflowException Che
  • 在活动启动期间优雅地处理屏幕方向变化

    我正在尝试找到一种方法来正确处理设置活动 其中活动的方向是根据启动它的意图中的数据确定的 这是一款用户可以选择关卡的游戏 其中一些是纵向的 一些是横向的 我面临的问题是setRequestedOrientation ActivityInfo
  • MediaPlayer.create() 始终返回 null

    我以前用过媒体播放器 从来没有遇到过这个问题 每当我尝试使用 MediaPlayer create 时 该方法都会给我 null 并且我无法播放声音 我有什么遗漏的吗 public class Game extends Activity p
  • Android - 使用 SAX 解析器解析大文件

    我正在尝试使用 SAX 解析器解析来自 webservice 的 xml 数据 当我尝试使用 URL 解析数据 大小 7 4MB 时 它工作正常 但是当我从 URL 复制 xml 数据并放置 xml 文件时 size 7 4MB 在raw文
  • 旋转 Google 地图中的两层标记图标

    在我的应用程序中 我向地图添加了一定数量的标记 如下所示 private fun addMarker googleMap GoogleMap location Location val options MarkerOptions optio
  • 如何防止应用程序被盗(针对Android应用程序)?

    我想知道防止人们窃取我的应用程序的最有效方法是什么 在线下载 apk 的副本而不是购买它 我已经花了一个lot特别是 Droidbox 上的时间 并且不会发布 Sync 直到我可以保证提供专业版本的非法副本的人无法发布 有人实施过这个吗 我
  • foo.setVisibility(View.GONE) 和parent.removeView(foo) 之间的区别

    如果 foo 是一个视图 那么有什么区别foo setVisibility View GONE and fooParent removeView foo 我对两个语句之前和之后视图的内存消耗特别感兴趣 可见性设置为 GONE 的视图是否会消
  • DialogFragment 关闭事件

    我需要处理 DialogFragment 的结尾 在调用 dismiss 之后 例如 我会在关闭后 包含 片段的活动内显示一个 toast 我该如何处理该事件 覆盖onDismiss 在你的DialogFragment中 或者使用setOn
  • 片段中的 SavedInstanceState 始终为 null

    我使用 XML 以及活动中的 setContentView 将片段附加到活动 A 有一个问题 因为我的片段中有非常动态的视图 所以当方向改变时 我必须恢复所有的观点状态 我有问题 因为我正在使用类似的东西 public void onSav
  • Android SDK WebView调用Activity

    我试图在单击 WebView 组件内的链接时启动活动 我的Webview已加载到里面Main java我想启动SubActivity java当点击网站内的链接时Main java 另外 如何将参数传递给此活动 Example inspec
  • 将主题应用到 v7 支持操作栏

    我正在使用support v7库来实现ActionBar在我的应用程序中 我的styles xml file
  • 使用 PDFBox 在 Android 中创建 PDF

    我正在尝试通过我的 Android 应用程序创建 PDFPDFBoxapi 但出现以下错误 java lang NoClassDefFoundError org apache pdfbox pdmodel PDDocument 我已经将以下

随机推荐

  • PyTorch 深度学习模型压缩开源库(含量化、剪枝、轻量化结构、BN融合)

    点击我爱计算机视觉标星 更快获取CVML新技术 本文为52CV群友666dzy666投稿 介绍了他最近开源的PyTorch模型压缩库 该库开源不到20天已经收获 219 颗星 是最近值得关注的模型压缩开源库 开源地址 https githu
  • FreeRTOS学习笔记 6 - 互斥量

    目录 1 创建 2 获取 3 释放 4 测试 FreeRTOS不支持调度方式的设置 所以下面2个宏定义可以随意设置值 define RTOS IPC FLAG FIFO 0x00 define RTOS IPC FLAG PRIO 0x01
  • 灰度重采样的方法分为_均值采样

    from skimage import datafrom matplotlib import pyplot as pltimport numpy as npimage data coffee print image shape 显示图像原始
  • Python连接Oracle数据库

    cx Oracle cx Oracle模块是Python连接Oracle数据库的模块 在Python中 如果要连接Oracle 必须先安装cx Oracle模块 cx Oracle的下载地址 https pypi python org py
  • 【 华为OD机试 2023】 最快到达医院的方法(C++ Java JavaScript Python)

    华为od机试题库 华为OD机试2022 2023 C Java JS Py https blog csdn net banxia frontend category 12225173 html 华为OD机试2023最新题库 更新中 C Ja
  • printk与内核日志打印优先级设置

    1 控制台的日志优先级 define KERN EMERG lt 0 gt 致命级 紧急事件消息 系统崩溃之前提示 表示系统不可用 define KERN ALERT lt 1 gt 警戒级 报告消息 表示必须采取措施 define KER
  • MySQL 数据库引擎

    引擎分类 InnoDB MyIsam 引擎对比 单位 ms 测试项 MyIsam InnoDb 结论 insert 100w 28825 123487 百万级插入性能 MyIsql 在30秒内完成性能优于 InnoDb 性能相差接近5倍 u
  • docker安装MongoDB

    base rootyx rootyx Default string sudo docker pull mongo 4 4 4 4 Pulling from library mongo 99803d4b97f3 Pull complete 6
  • NODE => CORS跨域资源共享学习

    1 CORS跨域资源共享 cors是Express的一个第三方中间件 通过安装和配置cors中间件 可以很方便地解决跨域问题 运行npm install cors 安装中间件 使用const cors require cors 导入中间件
  • Qt信号槽使用注意事项

    使用信号槽connect时 1 信号函数和槽函数都不能加形参 2 信号函数和槽函数形参列表要保持一致
  • 使用VS2010编译QT

    首先不要使用中文目录 发布QT程序时 为了使没有QT依赖库的环境中也能运行QT程序 这就需要静态编译你的QT程序 要达到这个目的 首先必须静态编译你的QT库文件 1 下载Qt的安装包和VS2010的Qt插件 2 安装Qt Library 注
  • maven模板freemarker引擎代码

    依次在src resource template 新建模板引擎mapper xml ftl
  • wvp-pro Java项目启动流程

    1 下载eclipse 下载 点击左边Download x86 64 下载 2 下载后解压 进入文件夹执行 eclipse inst 一路 next就可以安装完成了 记得给自己选择一个合适的安装路径 3 安装结束后 打开IDE 选择菜单he
  • 距离大决战777天——目前的进度

    最近看上了两款开发板 一是大名鼎鼎的合宙C3 看上他是因为9 9的无敌性价比 二是某黄厂的st7789s3 看上他是因为始终的大小和性价比 有着一块170 320的屏 S3处理起来刚好得心应手 58元的价位也是蛮能打 秒杀其他大厂的板子的配
  • OpenMMLab实训16班--第一节

    OpenMMLab实训16班 第一节 主讲人 张子豪 主题 计算机视觉与Openmmlab入门 内容 一 计算视觉基础 计算机视觉任务主要分为分类 检测 分割三类任务 计算机视觉基础问题都是对图像进行模式识别和数据挖掘 二 openmmla
  • 魔方游戏(附游戏开源代码)

    这个魔方游戏的前期的实现参考了许多教程 但全部代码逻辑都是本人写的 借鉴了的都会给出原贴链接 只讲实现的思路 已完成 魔方的转动和魔方的动画效果 支持魔方的cfop全部公式 按按钮可转动魔方 按键盘上的alt键可用移动鼠标360无死角观察魔
  • 二维数组与字符数组部分实验

    学习目标 1 掌握与数组有关的算法 2 掌握二维数组的定义 存储结构 初始化及输入 输出的方法 3 掌握字符数组的定义 初始化及输入 输出的方法 4 掌握字符串和字符串函数的使用 学习内容 1 编写程序实现 输出二维数组 数值型 每一行的最
  • 轨迹路线相似度计算

    概述 在日常生活中很多场景应用到了轨迹相似度的计算 如 地图路线匹配 发现新冠病毒易感人群等 目前主要使 的相似性分析 法可以分为基于规整的方法 包括动态时间规整 DTW 最 公共 序列 LCSS 和基于真实序列的编辑距离 EDR 等 和基
  • 内推几何建模与图形渲染职位

    最近 可能也会是长期的 公司在大力招兵买马 急缺几何 图形方面的人才 初级 高级 专家或有致力于图形领域方面开发都欢迎 当然其他方面的也有 包括BIM相关的开发 可直接内推 具体职位列表如下 薪资open可谈 坐标 上海 深圳 武汉三地均可
  • android shape 的使用

    Android中常常使用shape来定义控件的一些显示属性它可以作为一般图片使用 今天看了一些shape的使用 对shape有了大体的了解 稍作总结 先看下面的代码 复制到剪贴板 XML HTML代码