最近被吐槽界面太丑,还是很尴尬的,全公司就一个UI设计师,所以很多事情还是不忍直视,一个同事问我,背景可不可以使用渐变的感觉,然后我就有种突然感觉眼前一亮的感觉。还真的没有做过这方面的东西,单纯使用渐变说真的,并不是很让人感兴趣,所以就思考着能不能在自定义视图里面直接定义一个xml参数,在xml中可以直接指定渐变的颜色,感觉还真的挺容易实现,唯一卡的一下子就是平常不太遇到的自定义字段reference/color也就是通过R.color.xxx来指定颜色而不是单纯使用字符串#111111来指定颜色,这个了解一下对应的用法其实也很快。整个过程1个小时吧,就实现了渐变颜色的标题,但是当前的情况只能指定起始渐变颜色和终结渐变颜色,如果想弄更加奇葩的颜色就需要继续研究了= =说真的,当前的公司感觉什么东西都缺,有点心有余而力不足的感觉呢。

转载于/感谢:https://www.cnblogs.com/popfisher/p/5606690.html

Android GradientDrawable(shape标签定义) 静态使用和动态使用(圆角,渐变实现)

Android GradientDrawable使用优势:

  1. 快速实现一些基本图形(线,矩形,圆,椭圆,圆环)

  2. 快速实现一些圆角,渐变,阴影等效果

  3. 代替图片设置为View的背景

  4. 可以减少apk大小,提升用户下载意愿

  5. 还可以减少内存占用

  6. 方便修改与维护

  基于上面几种优势,我们很多时候都会选择使用android的shape,下面分别介绍shape的静态使用和动态使用

1. GradientDrawable的静态使用(xml中使用shape标签定义)

  在drawable中创建一个xml文件,在布局文件中直接引用这个xml文件即可

<?xml version="1.0" encoding="utf-8"?><!-- android:shape=["rectangle" | "oval" | "line" | "ring"]shape的形状,默认为矩形,可以设置为矩形(rectangle)、椭圆形(oval)、线(line)、环形(ring)下面的属性只有在android:shape="ring时可用:android:innerRadius           内环的半径。android:innerRadiusRatio    浮点型,以环的宽度比率来表示内环的半径,例如,如果android:innerRadiusRatio,表示内环半径等于环的宽度除以5,这个值是可以被覆盖的,默认为9.android:thickness              环的厚度android:thicknessRatio      浮点型,以环的宽度比率来表示环的厚度,例如,如果android:thicknessRatio="2",那么环的厚度就等于环的宽度除以2。这个值是可以被android:thickness覆盖的,默认值是3.android:useLevel            boolean值,如果当做是LevelListDrawable使用时值为true,否则为false.-->
<shape xmlns:android="http://schemas.android.com/apk/res/android"android:shape="rectangle" ><!--宽度和高度 android:width   整型 宽度android:height  整型 高度--><sizeandroid:width="50dp"android:height="50dp"/><!--圆角android:radius                    整型 半径android:topLeftRadius           整型 左上角半径android:topRightRadius               整型 右上角半径android:bottomLeftRadius           整型 左下角半径android:bottomRightRadius         整型 右下角半径--><cornersandroid:radius="10dp"/><!-- 设置圆角半径,可以分别设置4个角 --><!--渐变,这个设置之后一般就不要设置solid填充色了android:startColor  颜色值     起始颜色android:endColor    颜色值     结束颜色android:centerColor 整型       渐变中间颜色,即开始颜色与结束颜色之间的颜色android:angle       整型       渐变角度(PS:当angle=0时,渐变色是从左向右。 然后逆时针方向转,当angle=90时为从下往上。angle必须为45的整数倍)android:type        ["linear" | "radial" | "sweep"] 渐变类型(取值:linear、radial、sweep)linear 线性渐变,这是默认设置radial 放射性渐变,以开始色为中心。sweep 扫描线式的渐变。android:useLevel     ["true" | "false"]              如果要使用LevelListDrawable对象,就要设置为true。设置为true无渐变。false有渐变色android:gradientRadius 整型   渐变色半径.当 android:type="radial" 时才使用。单独使用 android:type="radial"会报错。android:centerX      整型     渐变中心X点坐标的相对位置android:centerY      整型     渐变中心Y点坐标的相对位置--><gradientandroid:startColor="@android:color/white"android:centerColor="@android:color/black"android:endColor="@android:color/black"android:useLevel="true"android:angle="45"android:type="radial"android:centerX="0"android:centerY="0"android:gradientRadius="90"/><!-- 间隔内边距,即内容与边的距离 android:left        整型 左内边距android:top        整型 上内边距android:right      整型 右内边距android:bottom   整型 下内边距--><paddingandroid:left="5dp"android:top="5dp"android:right="5dp"android:bottom="5dp"/><!--填充 android:color   颜色值 填充颜色--><solidandroid:color="@android:color/white"/><!-- 填充的颜色 --><!--描边 android:width          整型      描边的宽度android:color           颜色值    描边的颜色android:dashWidth   整型      表示描边的样式是虚线的宽度, 值为0时,表示为实线。值大于0则为虚线。android:dashGap     整型      表示描边为虚线时,虚线之间的间隔 即“ - - - - ”--><strokeandroid:width="1dp" <!-- 边框宽度 -->android:color="@android:color/black"android:dashWidth="1dp"android:dashGap="2dp"/></shape>

2. 动态创建GradientDrawable并使用

  用shape标签定义的xml,最终都是转化为GradientDrawable对象,而不是ShapeDrawable, 也不是起类型对应的 OvalShape,RoundRectShape等。

  GradientDrawable可以动态设置类型如下图所示,跟xml文件中类型android:shape的值一一对应。

View view = null;    // 这个view是你需要设置背景的view
int strokeWidth = 1;     // 1dp 边框宽度
int roundRadius = 5;     // 5dp 圆角半径
int strokeColor = Color.parseColor("#FFFF0000");//边框颜色
int fillColor = Color.parseColor("#FF00FF00"); //内部填充颜色GradientDrawable gd = new GradientDrawable();//创建drawable
gd.setColor(fillColor);
gd.setCornerRadius(roundRadius);
gd.setStroke(strokeWidth, strokeColor);
gd.setGradientType(GradientDrawable.RECTANGLE);
view.setBackgroundDrawable(gd);// 创建渐变的shape drawable
int colors[] = { 0xff255779 , 0xff3e7492, 0xffa6c0cd };//分别为开始颜色,中间夜色,结束颜色
GradientDrawable gradientDrawable = new GradientDrawable(GradientDrawable.Orientation.TOP_BOTTOM, colors);
view.setBackgroundDrawable(gd);

3. 动态改变GradientDrawable的属性

  既然GradientDrawable都能动态创建,那么肯定能过动态修改,我们可以通过先获取view上设置的background drawable

  如果是GradientDrawable则强制转换为GradientDrawable,这个时候就可以修改里面的属性,像动态创建时一样设置,设置好之后重新设置给view.

GradientDrawable drawable =(GradientDrawable)view.getBackground();
drawable.setColor(fillColor); // 设置填充色
drawable.gd.setStroke(strokeWidth, strokeColor); // 设置边框宽度和颜色
gd.setColors(colors);    // 设置渐变颜色数组

总结:

  请注意区分 GradientDrawable 和 ShapeDrawable,这两个 Drawable 官方文档解释都是可以使用 shape 标签来定义,但实际使用过程却发现使用 shape 标签定义的 Drawable 属于 GradientDrawabl。使用 shape 标签能定义多种多样的 Drawable,能够方便实现圆角,渐变等效果,更多 shape 标签定义请参考 Drawable实战解析:Android XML shape 标签使用详解 。

(转载)Android GradientDrawable(shape标签定义) 静态使用和动态使用(圆角,渐变实现)相关推荐

  1. Android NDK生成及连接静态库与动态库

    对于Android应用开发,大部分情况下我们使用Java就能完整地实现一个应用.但是在某些情况下,我们需要借助C/C++来写JNI本地代码.比如,在使用跨平台的第三方库的时候:为了提升密集计算性能的时 ...

  2. android中shape资源定义,Android可绘制对象资源之shape和layer-list使用

    Code4Android.jpg 前言 文章中内容多来自谷歌官方文档详戳,一些示例代码详戳GitHub,不喜请轻喷. 可绘制对象资源 可绘制对象资源是一般概念,是指可在屏幕上绘制的图形,以及可以使用 ...

  3. android中shape资源定义,Android中drawable使用Shape资源

    本文实例为大家分享了drawable使用Shape资源的具体内容,供大家参考,具体内容如下 1.画一条水平方向的虚线 android:shape="line" > andro ...

  4. Android动态图文混排,Android控件TextView实现静态图与动态GIF图文混排

    最近做项目功能时,需要在TextView中展示图文,刚开始做的时候以为很简单,只需要用个ImageView跟TextView来展示就行了,可是发现这样做,不能实现我们需要的效果,这就需要涉及到富文本T ...

  5. Android控件TextView实现静态图与动态GIF图文混排

    最近做项目功能时,需要在TextView中展示图文,刚开始做的时候以为很简单,只需要用个ImageView跟TextView来展示就行了,可是发现这样做,不能实现我们需要的效果,这就需要涉及到富文本T ...

  6. android 背景描边,Android告别使用shape标签,自定义实现圆角、背景色、描边Button...

    为什么不使用shape标签 我想大家平常都用过shape标签来定义一个Drawable,来实现一些例如圆角.设置描边等一些需求.但是,最近发现项目中res/drawable/下的shape标签文件越来 ...

  7. android shape 底部线,android用shape给linearLayout设置边框,怎样只保留底部或顶部的边框,把其它三个方向的边框去掉呢?...

    http://bbs.csdn.net/topics/390485215 这种方法只是两个颜色块相减而已 android:top="1dp" android:left=" ...

  8. android shape 无边框颜色,Android 使用shape定义不同控件的的颜色、背景色、边框色...

    Android 使用shape定义不同控件的的颜色.背景色.边框色 设置按钮的右边框和底边框颜色为红色,边框大小为3dp: 在drawable新建一个 buttonstyle.xml的文件,内容如下: ...

  9. [转载]android 画虚线、实线,画圆角矩形,一半圆角

    [转载]android 画虚线.实线,画圆角矩形,一半圆角 (2013-03-19 12:38:12) 转载▼ 标签: 转载 分类: android 原文地址:android 画虚线.实线,画圆角矩形 ...

最新文章

  1. markdown语法十步学习 图文并茂
  2. C语言实现数组Array(附完整源码)
  3. 从一道面试题说起—js隐式转换踩坑合集
  4. 启动weblogic需要账号密码问题
  5. windows2019迁移FSMO
  6. Vista初级使用技巧及故障总结
  7. spring mvc使用html页面,Spring MVC静态页面
  8. SQL从入门到入魔之初入门
  9. 2021-秋招你准备好了吗?软件测试面试题
  10. 关于Excel的最大行数和列数。
  11. 金字塔原理(Pyramid Principle)
  12. access和filemaker_四个替代微软Access的开源产品
  13. linux打开dwg格式文件怎么打开软件,DWG 文件扩展名: 它是什么以及如何打开它?...
  14. 分式怎么开根号_如何开根号
  15. 民进自强进修学院 计算机,#民进自强#中复班学生周记摘录
  16. 大疆前端校招面试指北,各路英雄来相会!
  17. 使用watermark.js给HTML、Word、PPT、Excel等添加水印
  18. Mac 调节鼠标移速
  19. 微信公众号开发 - 开发环境搭建
  20. eclipse配置python解析器_Eclipse中配置Python环境

热门文章

  1. iwconfig 安装_iwconfig linux 命令行配置无线网卡
  2. Linux下覆盖目录的方法
  3. linux之sed命令n,N,d,D,p,P,h,H,g,G,x解析
  4. Selenium3自动化测试——4. 获取百度备案信息
  5. 2014江苏省职称计算机,2014年江苏省职称计算机office多选题.doc
  6. python类库丰富吗_Rich库:丰富你的Python程序终端输出
  7. python中编写函数素数_如何用Python编写素数程序?
  8. gzencode php demo,8个必备的PHP功能实例代码
  9. 计算机科学CSTA,学编程,搞懂CSTA K-12计算机科学学习标准
  10. s1200 博图高速脉冲计数值没有变化_赤峰发泡硅胶板,高速公路橡胶垫橡胶厂-京品吉...