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,底色为白色,两个颜色块使用两种不同的颜色,效果如下:

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

(0)

相关推荐

  • Android中RecyclerView上拉下拉,分割线,多条目的实例代码

    //activity的xml <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/activity

  • Android中控件GridView实现设置行列分割线的方法示例

    前言 虽然Aandroid目前已经有RecyclerView了.非常强大的一个View.可以直接控制成ListView以及GridView等.而且画框线也比较方便.但是呢在很多情况下我们不得不仍然使用GridView来实现布局.那么在这个时候我们又要怎么来对GridViw进行画框线呢.下面将提供两种实现方式.大家可以选择一下 一.设置垂直.横向间距.通过GRIDVIEW和ITEM的背景色来实现 1.设置GridView背景色 2.设置水平和竖直方向间隔:android:horizontalSpa

  • android利用xml实现分割线

    因为没有美工, 所以只能自己动手了. 在layout文件夹里的xml 写 方法1:在layout里面的布局xml 文件里加上面的代码 <View android:layout_width="match_parent" android:layout_height="1dp" android:background="@color/orange_normal" /> 效果图 在drawable文件夹里用 shape line 或 recta

  • 详解Android中ListView实现图文并列并且自定义分割线(完善仿微信APP)

    昨天的(今天凌晨)的博文<Android中Fragment和ViewPager那点事儿>中,我们通过使用Fragment和ViewPager模仿实现了微信的布局框架.今天我们来通过使用ListView实现其中联系人一栏的基本视图,效果如下: 要实现上图的效果,我们要用到两个知识点: 1.这里我们使用自定义适配实现图文列表(当然也可以用SimpleAdapter) 通过继承BaseAdapter(抽象类)自定义适配器可以实现更灵活更复杂的列表. 自定义适配器ListView的优化: (1)使用固

  • Android 关于ExpandableListView去掉里头分割线的方法

    关于ExpandableListView, 自己写了个类继承自BaseExpandableListAdapter groups,childs 都弄好了,显示出来的效果跟网上很多demo一样,我现在就是想去掉那个组下面各item间的分割线 有知道的么? ------解决方案-------------------- expandableList.setDivider(null); up,还不行就设置一个透明的颜色. ------解决方案-------------------- 可以的, androi

  • Android自定义彩色织带分割线

    前言 最近开发的一个产品需要涉及到订单,订单页涉及到了一个UI元素,类似饿了么的订单页以及支付宝口碑外卖订单页的彩带(通俗点讲就是一条两种颜色相间而成的分割线):           可以看到,风格基本都是以两种颜色为主相间拼接,至于长度则完全由屏幕宽度来决定,因此如果想要通过设计成图片素材来作为ImageView的背景的方式实现的话,效果并不理想,因为图片的宽度完全无法确定.所以本文通过自定义View的方式,绘制出这样一个彩带的效果. 实现 1.Android中如何绘制四边形 public c

  • Android自定义View绘制彩色圆弧

    本文实例为大家分享了Android自定义View绘制彩色圆弧的具体代码,供大家参考,具体内容如下 效果如下: 自定义View代码如下: package com.example.yan; import android.content.Context; import android.graphics.Canvas; import android.graphics.Paint; import android.graphics.Rect; import android.graphics.RectF; i

  • Android 自定义View 密码框实例代码

    暴露您view中所有影响可见外观的属性或者行为. •通过XML添加和设置样式 •通过元素的属性来控制其外观和行为,支持和重要事件交流的事件监听器 详细步骤见:Android 自定义View步骤 效果图展示: 支持的样式 可以通过XML定义影响外边和行为的属性如下 边框圆角值,边框颜色,分割线颜色,边框宽度,密码长度,密码大小,密码颜色 <declare-styleable name="PasswordInputView"> <attr name="borde

  • Android实现RecyclerView添加分割线的简便方法

    1.前言 刚开始学习RecyclerView的时候我跟着一个视频学的,当时添加分割线是从外面导入一个Java类,然后使用里面的函数来创建分割线的,所以一直以来我都是这样做的.直到前几天才无意中发现,原来v7包中提供了一个DividerItemDecoration类,利用它,我们可以很简单地实现RecyclerView的分割线!那还等什么呢?赶紧用起来. 2.创建一个简单的RecyclerView 首先当然应该来一个RecyclerView,这里就不再赘述了,随便造点数据就好.直接上代码: pub

  • Android 自定义输入支付密码的软键盘实例代码

    Android 自定义输入支付密码的软键盘 有项目需求需要做一个密码锁功能,还有自己的软键盘,类似与支付宝那种,这里是整理的资料,大家可以看下,如有错误,欢迎留言指正 需求:要实现类似支付宝的输入支付密码的功能,效果图如下: 软键盘效果图 使用 android.inputmethodservice.KeyboardView 这个类自定义软键盘 软键盘的实现 1. 自定义只输入数字的软键盘 PasswordKeyboardView 类,继承自 android.inputmethodservice.

  • Android 自定义AlertDialog对话框样式

    实际的项目开发当中,经常需要根据实际的需求来自定义AlertDialog.最近在开发一个WIFI连接的功能,点击WIFI需要弹出自定义密码输入框.在此权当记录 效果图 点击首页的Button即跳出对话框,显示WIFI信息(TextView),密码输入框(EditText),取消和连接按钮(Button) 实现 根据自己实际的需求,为AlertDialog创建一个布局,在此我需要定义一个如图所示的WIFI密码输入框,故在 res/layout 目录下建立一个 dialog_layout.xml 文

  • Android自定义ListView实现仿QQ可拖拽列表功能

    我们大致的思路,其实是这样子的,也是我的设想,我们可以先去实现一个简单的ListView的数据,但是他的Adapter,我们可以用系统封装好的,然后传递进去一个实体类,最后自定义一个listview去操作,所以我们先把准备的工作做好,比如? list_item.xml <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.a

  • Android自定义ActionBar实例

    本文实例讲述了Android自定义ActionBar的实现方法.分享给大家供大家参考.具体实现方法如下: Android 3.0及以上已经有了ActionBar的API,可以通过引入support package在3.0以下的平台引用这些API,但这儿呢,完全自定义一个ActionBar,不用引入额外jar包,参照的是开源的UI组件GreeenDroid,项目主页:https://github.com/cyrilmottier/GreenDroid .提取出关于ActionBar的相关文件,你可

  • Android自定义指示器时间轴效果实例代码详解

    指示器时间轴在外卖.购物类的APP里会经常用到,效果大概就像下面这样,看了网上很多文章,大都是自己绘制,太麻烦,其实通过ListView就可以实现. 在Activity关联的布局文件activity_main.xml中放置一个ListView,代码如下.由于这个列表只是用于展示信息,并不需要用户去点击,所以将其clickable属性置为false:为了消除ListView点击产生的波纹效果,我们设置其listSelector属性的值为透明:我们不需要列表项之间的分割线,所以设置其divider属

  • Android自定义上下左右间隔线

    本文实例为大家分享了Android自定义SpaceItemDecoration分割线的具体代码,供大家参考,具体内容如下 此线是在RecyclerView中的GridlayoutManager中使用的 效果图如下: /** * author: Y_Qing * date: 2018/5/7 */ public class SpaceItemDecoration extends RecyclerView.ItemDecoration { private int space; Paint mPain

随机推荐