全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Android自定义彩色织带分割线

前言

最近开发的一个产品需要涉及到订单,订单页涉及到了一个UI元素,类似饿了么的订单页以及支付宝口碑外卖订单页的彩带(通俗点讲就是一条两种颜色相间而成的分割线):        

         

可以看到,风格基本都是以两种颜色为主相间拼接,至于长度则完全由屏幕宽度来决定,因此如果想要通过设计成图片素材来作为ImageView的背景的方式实现的话,效果并不理想,因为图片的宽度完全无法确定。所以本文通过自定义View的方式,绘制出这样一个彩带的效果。

实现

1.Android中如何绘制四边形

public class ColourLineView extends View{ 
 
 public ColourLineView(Context context) { 
 super(context, null); 
 } 
 
 public ColourLineView(Context context, AttributeSet attrs) { 
 super(context, attrs, 0); 
 } 
 
 public ColourLineView(Context context, AttributeSet attrs, int defStyleAttr) { 
 super(context, attrs, defStyleAttr); 
 } 
 
 @Override 
 protected void onDraw(Canvas canvas) { 
 super.onDraw(canvas); 
 int width = getWidth(); 
 int height = getHeight(); 
 Path path = new Path(); 
 canvas.save(); 
 path.reset();//重置路径 
 path.moveTo(width/2, 0);//左上点 
 path.lineTo(0, height);//左下点 
 path.lineTo(width-width/2, height);//右下点 
 path.lineTo(width, 0);//右上点 
 canvas.clipPath(path);//截取路径所绘制的图形 
 canvas.drawColor(Color.RED); 
 path.reset();//重置路径,准备绘制第三种颜色的平行四边形 
 canvas.restore(); 
 } 
} 

主要看onDraw方法,可以看到首先获取View的宽和高,然后建立路径对象path,接着先将path的起点移动到(控件宽的二分之一处,0)处:


接着由该点向(0, 控件高)处绘制一条直线:


接着由(0, 控件高)向(控件宽的二分之一处,高度)绘制一条直线:


接着由(控件宽的二分之一处,高度)向(控件宽, 0)绘制一条直线:


路径绘制完毕,调用clipPath将路径的图形剪出来,便成了一个平行四边形,再给它填充个颜色。

在布局文件中使用一下:

<com.example.yang.statubardemo.ColourLineView 
 android:layout_width="80dp" 
 android:layout_height="80dp" 
 android:background="#000"/> 

效果如图:


平行四边形的效果就出来了,了解了如何绘制平行四边形,也就相当于写好了砖块,砌成墙自然就不是事了。

2.绘制彩色分割线

首先,我们这个View可以定义的东西应该有如下这几点:
1.可以自定义每个颜色块的大小
2.可以自定义两种颜色
3.可以自定义颜色块之间的间隔
4.平行四边形颜色块倾斜的程度
5.背景色

下面着手来实现这个效果
首先定义一下属性,在attrs.xml中加入如下:

<declare-styleable name="ColourLineView"> 
 <!--线条高度--> 
 <attr name="line_height" format="dimension"/> 
 <!--第一种颜色块的宽度--> 
 <attr name="item_width" format="dimension"/> 
 <!--第二种颜色块的宽度--> 
 <attr name="separation_width" format="dimension"/> 
 <!--平行四边形倾斜的程度--> 
 <attr name="lean_degree" format="dimension"/> 
 <!--第一种颜色--> 
 <attr name="first_color" format="color"/> 
 <!--第二种颜色--> 
 <attr name="second_color" format="color"/> 
 <!--线条底色--> 
 <attr name="canvas_color" format="color"/> 
</declare-styleable> 

自定义View代码:

** 
 * Created by IT_ZJYANG on 2017/2/9. 
 */ 
public class ColourLineView extends View{ 
 
 //线条高度 
 private float line_height; 
 //每个颜色块的宽度 
 private float item_width; 
 //每两个颜色快之间的间距 
 private float separation_width; 
 //平行四边形倾斜的程度 
 private float lean_degree; 
 //第一种颜色块的颜色 
 private int first_color; 
 //第二种颜色块的颜色 
 private int second_color; 
 //线条底色 
 private int canvas_color; 
 
 public ColourLineView(Context context) { 
 super(context, null); 
 } 
 
 public ColourLineView(Context context, AttributeSet attrs) { 
 super(context, attrs); 
 initAttr(context, attrs); 
 } 
 
 public ColourLineView(Context context, AttributeSet attrs, int defStyleAttr) { 
 super(context, attrs, defStyleAttr); 
 initAttr(context, attrs); 
 } 
 
 public void initAttr(Context context, AttributeSet attrs){ 
 TypedArray typedArray = context.obtainStyledAttributes(attrs, R.styleable.ColourLineView); 
 line_height = typedArray.getDimension(R.styleable.ColourLineView_line_height, 20); 
 item_width = typedArray.getDimension(R.styleable.ColourLineView_item_width, 20); 
 separation_width = typedArray.getDimension(R.styleable.ColourLineView_separation_width, 20); 
 lean_degree = typedArray.getDimension(R.styleable.ColourLineView_lean_degree, 5); 
 first_color = typedArray.getColor(R.styleable.ColourLineView_first_color, Color.RED); 
 second_color = typedArray.getColor(R.styleable.ColourLineView_second_color, Color.GREEN); 
 canvas_color = typedArray.getColor(R.styleable.ColourLineView_canvas_color, Color.WHITE); 
 typedArray.recycle(); 
 } 
 
 @Override 
 protected void onDraw(Canvas canvas) { 
 super.onDraw(canvas); 
 Path path = new Path(); 
 int lineWidth = getWidth(); 
 int lineHeight = getHeight(); 
 int count = (item_width + separation_width == 0) ? 0 : lineWidth / (int) (item_width + separation_width) + 1; 
 for(int i=0; i < count; i++){ 
  canvas.save(); 
  path.reset();//重置路径 
  path.moveTo(lean_degree + (item_width + separation_width) * i, 0);//左上点 
  path.lineTo((item_width + separation_width) * i, lineHeight);//左下点 
  path.lineTo(item_width * (i + 1) + separation_width * i, lineHeight);//右下点 
  path.lineTo(lean_degree + item_width * (i + 1) + separation_width * i, 0);//右上点 
  canvas.clipPath(path);//截取路径所绘制的图形 
  if(i % 2 == 0){ 
  canvas.drawColor(first_color); 
  }else{ 
  canvas.drawColor(second_color); 
  } 
  canvas.restore(); 
 } 
 } 
} 

其中,initAttr方法就不多说了,就是单纯的获取attr里面的属性值,关键看onDraw中的代码,我们要实现多个平行四边形间隔着绘制,那首先需要计算出有多少个平行四边形,将每一个【颜色块+间距】作为一个小部分,然后以整体的宽度/【颜色块+间距】得出有多少个,然后通过for循环绘制出每一个Item,关键在于如何定位平行四边形的四个端点,下面举个例子说明一下思路:

       当i = 0,也就是第一个颜色块,那么其左上角一定是(lean_degree,0),左下角为(0,line_height),右上角肯定是左上角+颜色块宽度,所以为(lean_degree+item_width, 0),同理右下角肯定是左下角+颜色块宽度,所以为(item_width, line_height)。
       当i = 1,也就是第二个颜色块,此时需要注意,左上角需要在刚才第一个的基础上加上第一个【颜色块+间距】的值,也就是(lean_degree+ (item_width + separation_width) *1,0),左下角则为((item_width + separation_width) *1,line_height),右下和右上同理只是在左上左下的基础上加上item_width。
.............
.............
.............
当i = i时,四个点也就成了:
(lean_degree + (item_width + separation_width) * i  ,  0)
((item_width + separation_width) * i  ,  lineHeight)
(item_width * (i + 1) + separation_width * i  ,  lineHeight)
(lean_degree + item_width * (i + 1) + separation_width * i  ,  0)

然后再根据奇偶性判断,让两种颜色间隔绘制,完成。

使用

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
 xmlns:tools="http://schemas.android.com/tools" 
 android:layout_width="match_parent" 
 android:layout_height="match_parent" 
 xmlns:app="http://schemas.android.com/apk/res-auto" 
 android:orientation="vertical" 
 android:gravity="center" 
 tools:context="com.example.zjyang.statubardemo.MainActivity"> 
 
 <com.example.zjyang.statubardemo.ColourLineView 
 android:layout_width="match_parent" 
 android:layout_height="5dp" 
 android:background="#fff" 
 app:first_color="@color/colorAccent" 
 app:second_color="@color/colorPrimary" 
 app:item_width="15dp" 
 /> 
 
</LinearLayout> 

可以看到高度设置为5dp,每个颜色块宽度为15dp,底色为白色,两个颜色块使用两种不同的颜色,效果如下:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# Android自定义View  # Android彩色虚线  # Android彩色织带分割线  # Android中控件GridView实现设置行列分割线的方法示例  # Android中RecyclerView上拉下拉  # 分割线  # 多条目的实例代码  # 详解Android中ListView实现图文并列并且自定义分割线(完善仿微信APP)  # Android 关于ExpandableListView去掉里头分割线的方法  # android利用xml实现分割线  # 种颜色  # 两种  # 自定义  # 第一个  # 可以看到  # 一处  # 成了  # 也就  # 基础上  # 有多少个  # 好了  # 多个  # 说了  # 不多  # 而成  # 第二个  # 这样一个  # 然后再  # 作为一个 


相关文章: 网站制作的软件有哪些,制作微信公众号除了秀米还有哪些比较好用的平台?  如何安全更换建站之星模板并保留数据?  微信推文制作网站有哪些,怎么做微信推文,急?  北京营销型网站制作公司,可以用python做一个营销推广网站吗?  网站制作培训多少钱一个月,网站优化seo培训课程有哪些?  怎么用手机制作网站链接,dw怎么把手机适应页面变成网页?  建站之星备案流程有哪些注意事项?  linux top下的 minerd 木马清除方法  如何挑选最适合建站的高性能VPS主机?  如何在企业微信快速生成手机电脑官网?  制作网站的网址是什么,请问后缀为.com和.com.cn还有.cn的这三种网站是分别是什么类型的网站?  网站制作报价单模板图片,小松挖机官方网站报价?  网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?  如何通过宝塔面板实现本地网站访问?  广州网站建站公司选择指南:建站流程与SEO优化关键词解析  如何处理“XML格式不正确”错误 常见XML well-formed问题解决方法  c# Task.Yield 的作用是什么 它和Task.Delay(1)有区别吗  如何选择适合PHP云建站的开源框架?  网站视频制作书签怎么做,ie浏览器怎么将网站固定在书签工具栏?  北京企业网站设计制作公司,北京铁路集团官方网站?  建站之星手机一键生成:多端自适应+小程序开发快速建站指南  国美网站制作流程,国美电器蒸汽鍋怎么用官方网站?  网站制作与设计教程,如何制作一个企业网站,建设网站的基本步骤有哪些?  建站之星如何实现PC+手机+微信网站五合一建站?  如何快速生成可下载的建站源码工具?  杭州银行网站设计制作流程,杭州银行怎么开通认证方式?  C++时间戳转换成日期时间的步骤和示例代码  攀枝花网站建设,攀枝花营业执照网上怎么年审?  广德云建站网站建设方案与建站流程优化指南  关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)  建站之星3.0如何解决常见操作问题?  如何快速重置建站主机并恢复默认配置?  邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?  如何高效配置IIS服务器搭建网站?  如何在Golang中处理模块冲突_解决依赖版本不兼容问题  单页制作网站有哪些,朋友给我发了一个单页网站,我应该怎么修改才能把他变成自己的呢,请求高手指点迷津?  公司网站的制作公司,企业网站制作基本流程有哪些?  在线教育网站制作平台,山西立德教育官网?  平台云上自主建站:模板化设计与智能工具打造高效网站  C#如何在一个XML文件中查找并替换文本内容  如何登录建站主机?访问步骤全解析  合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?  Java解压缩zip - 解压缩多个文件或文件夹实例  一键网站制作软件,义乌购一件代发流程?  导航网站建站方案与优化指南:一站式高效搭建技巧解析  武汉网站制作费用多少,在武汉武昌,建面100平方左右的房子,想装暖气片,费用大概是多少啊?  公众号网站制作网页,微信公众号怎么制作?  建站主机如何选?高性价比方案全解析  湖北网站制作公司有哪些,湖北清能集团官网?  建站之星安装后如何自定义网站颜色与字体? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。