前言

最近开发的一个产品需要涉及到订单,订单页涉及到了一个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实现分割线
# 种颜色
# 两种
# 自定义
# 第一个
# 可以看到
# 一处
# 成了
# 也就
# 基础上
# 有多少个
# 好了
# 多个
# 说了
# 不多
# 而成
# 第二个
# 这样一个
# 然后再
# 作为一个
相关文章:
php json中文编码为null的解决办法
如何高效完成独享虚拟主机建站?
如何在腾讯云免费申请建站?
网页制作模板网站推荐,网页设计海报之类的素材哪里好?
宁波自助建站系统如何快速打造专业企业网站?
如何在沈阳梯子盘古建站优化SEO排名与功能模块?
如何在阿里云部署织梦网站?
如何配置FTP站点权限与安全设置?
免费视频制作网站,更新又快又好的免费电影网站?
Python路径拼接规范_跨平台处理说明【指导】
如何正确选择百度移动适配建站域名?
详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)
智能起名网站制作软件有哪些,制作logo的软件?
香港服务器网站卡顿?如何解决网络延迟与负载问题?
如何选择适配移动端的WAP自助建站平台?
昆明网站制作哪家好,昆明公租房申请网上登录入口?
Java解压缩zip - 解压缩多个文件或文件夹实例
建站主机系统SEO优化与智能配置核心关键词操作指南
桂林网站制作公司有哪些,桂林马拉松怎么报名?
建站之星IIS配置教程:代码生成技巧与站点搭建指南
如何快速搭建高效WAP手机网站吸引移动用户?
定制建站模板如何实现SEO优化与智能系统配置?18字教程
如何在云主机快速搭建网站站点?
制作营销网站公司,淘特是干什么用的?
宝塔新建站点报错如何解决?
C#怎么创建控制台应用 C# Console App项目创建方法
教育培训网站制作流程,请问edu教育网站的域名怎么申请?
网站制作哪家好,cc、.co、.cm哪个域名更适合做网站?
如何快速生成高效建站系统源代码?
网站制作的软件有哪些,制作微信公众号除了秀米还有哪些比较好用的平台?
网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?
C#如何序列化对象为XML XmlSerializer用法
济南网站制作的价格,历城一职专官方网站?
深圳企业网站制作设计,在深圳如何网上全流程注册公司?
建站之星24小时客服电话如何获取?
如何生成腾讯云建站专用兑换码?
网站网页制作电话怎么打,怎样安装和使用钉钉软件免费打电话?
如何在Golang中实现微服务服务拆分_Golang微服务拆分与接口管理方法
如何选择适合PHP云建站的开源框架?
如何在Windows服务器上快速搭建网站?
如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?
北京制作网站的公司,北京铁路集团官方网站?
如何快速搭建高效香港服务器网站?
建站主机与服务器功能差异如何区分?
免费制作小说封面的网站有哪些,怎么接网站批量的封面单?
建站主机默认首页配置指南:核心功能与访问路径优化
建站三合一如何选?哪家性价比更高?
如何选择服务器才能高效搭建专属网站?
如何在阿里云服务器自主搭建网站?
高端建站如何打造兼具美学与转化的品牌官网?
*请认真填写需求信息,我们会在24小时内与您取得联系。