Android绘制竖直虚线完美解决方案—自定义View

开发中我们经常会遇到绘制虚线的需求,一般我们使用一个drawable文件即可实现,下面我会先列举常规drawable文件的实现方式。

使用drawable绘制水平虚线

水平方向的虚线最好绘制,drawable文件如下所示:

drawable/imaginary_line.xml:<?xml version="1.0" encoding="utf-8"?>
<shapexmlns:android="http://schemas.android.com/apk/res/android"android:shape="line"><strokeandroid:width="1dp"android:color="#000"android:dashWidth="5dp"android:dashGap="2dp" /></shape>

在布局中使用如下:

<!-- 这里的高度必须大于drawable中设置的虚线宽度 -->
<Viewandroid:layout_width="match_parent"android:layout_height="2dp"android:layout_marginTop="50dp"android:background="@drawable/imaginary_line"android:layerType="software" />

这里我们需要注意一下几点,第一最好设置android:layerType="software"属性,第二View的高度,最好大于drawable中设置的虚线高度。不然都可能导致虚线不显示。

使用drawable绘制竖直方向虚线

与水平方向虚线相比,竖直方向虚线就麻烦的多了,而且有很多缺陷。

drawable代码如下所示:

drawable/vertical_imaginary_line.xml:<?xml version="1.0" encoding="utf-8"?>
<rotate xmlns:android="http://schemas.android.com/apk/res/android"android:fromDegrees="90"android:toDegrees="90"><shape android:shape="line"><strokeandroid:width="1dp"android:color="#000"android:dashWidth="5dp"android:dashGap="2dp" /></shape>
</rotate>

可以看出,实质上是通过View动画,对水平方向的View进行了旋转操作。

具体使用如下:跟水平方向使用方式一样。

 <Viewandroid:layout_width="200dp"android:layout_height="200dp"android:layout_alignParentRight="true"android:background="@drawable/vertical_imaginary_line"android:layerType="software" />

因为View是先绘制水平方向的虚线,然后进行旋转,所以竖直虚线默认就会有偏移量,我们需要手动的去调整位置。

实现效果如下所示:

单个虚线还好说,如果需要绘制图表的网格线之类的需求,那就要欲哭无泪了。

自定义DividerView

接下来祭出我们的大杀器自定义View。

先定义下需求,我们的虚线需要支持自定义背景色,支持自定义虚线宽度,支持水平和竖直方向,支持虚线的dash宽度和dash间隔,所以我们的自定义属性就如下所示:

attrs.xml:<?xml version="1.0" encoding="utf-8"?>
<resources><!-- 垂直方向的虚线 --><declare-styleable name="DividerView"><!-- 虚线颜色 --><attr name="divider_line_color" format="color"/><!-- 虚线宽度 --><attr name="dashThickness" format="dimension"/><!-- 虚线dash宽度 --><attr name="dashLength" format="dimension"/><!-- 虚线dash间隔 --><attr name="dashGap" format="dimension"/><!-- 虚线朝向 --><attr name="divider_orientation" format="enum"><enum name="horizontal" value="0"/><enum name="vertical" value="1"/></attr></declare-styleable>
</resources>

接下来我们看下DividerView的具体实现:
自定义View的第一步,通常是获取自定义的属性值,具体如下所示:

public DividerView(Context context, AttributeSet attrs) {super(context, attrs);int dashGap, dashLength, dashThickness;int color;TypedArray a = context.getTheme().obtainStyledAttributes(attrs, R.styleable.DividerView, 0, 0);try {dashGap = a.getDimensionPixelSize(R.styleable.DividerView_dashGap, 5);dashLength = a.getDimensionPixelSize(R.styleable.DividerView_dashLength, 5);dashThickness = a.getDimensionPixelSize(R.styleable.DividerView_dashThickness, 3);color = a.getColor(R.styleable.DividerView_divider_line_color, 0xff000000);orientation = a.getInt(R.styleable.DividerView_divider_orientation, ORIENTATION_HORIZONTAL);} finally {a.recycle();}mPaint = new Paint();mPaint.setAntiAlias(true);mPaint.setColor(color);mPaint.setStyle(Paint.Style.STROKE);mPaint.setStrokeWidth(dashThickness);mPaint.setPathEffect(new DashPathEffect(new float[]{dashGap, dashLength,}, 0));
}

我们通过TypedArray获取到我们设置的自定义属性值,并给各个属性设置默认值;接着初始化我们的画笔paint。

初始化工作完毕后,就是绘制工作了,代码如下所示:

@Override
protected void onDraw(Canvas canvas) {if (orientation == ORIENTATION_HORIZONTAL) {float center = getHeight() * 0.5f;canvas.drawLine(0, center, getWidth(), center, mPaint);} else {float center = getWidth() * 0.5f;canvas.drawLine(center, 0, center, getHeight(), mPaint);}
}

具体使用如下所示:

横向虚线:

<com.tinytongtong.dividerviewdemo.DividerViewandroid:layout_width="match_parent"android:layout_height="1dp"android:layout_marginTop="50dp"android:layerType="software"custom:dashGap="4dp"custom:dashLength="1dp"custom:dashThickness="1dp"custom:divider_line_color="#ef5350"custom:divider_orientation="horizontal" />

竖向虚线:

<com.tinytongtong.dividerviewdemo.DividerViewandroid:layout_width="1dp"android:layout_height="match_parent"android:layout_alignParentRight="true"android:layout_marginRight="50dp"android:layerType="software"custom:dashGap="4dp"custom:dashLength="1dp"custom:dashThickness="1dp"custom:divider_line_color="#ef5350"custom:divider_orientation="vertical" />

效果图如下所示:

DividerView项目地址

参考:
Android竖虚线绘制

Android绘制竖直虚线完美解决方案—自定义View相关推荐

  1. android xml中设置水平虚线及竖直虚线

    水平线背景 <?xml version="1.0" encoding="utf-8"?> <shape xmlns:android=" ...

  2. android 横向虚线,Android实现水平虚线和竖直虚线

    水平虚线 android:shape="line"> android:width="1dp" android:color="#747474&qu ...

  3. 用xml画水平虚线和竖直虚线.md

    1.画水平虚线 直接建一个shape,设置stroke属性就行了,再将这个属性直接作为background的drawable属性引入就行了 注意在4.0以上的真机加一句 <?xml versio ...

  4. Winform中设置ZedGraph因设置小刻度导致的竖直虚线显示过多

    场景 Winforn中设置ZedGraph曲线图的属性.坐标轴属性.刻度属性: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/10 ...

  5. android 自定义view xml ,Android实现在xml文件中引用自定义View的方法分析

    本文实例讲述了Android实现在xml文件中引用自定义View的方法.分享给大家供大家参考,具体如下: 在xml中引用自定义view 方法一: android:layout_width=" ...

  6. Android TextView竖直滚动文字广告效果

    项目需要 TextView 单行竖直滚动文字广告效果,很简单的功能在网上找了很多没有想要的效果.开始找到的<android TextView 垂直自动滚动>,歌词效果,对代码处理一下变成单 ...

  7. 安卓/Android 模仿支付宝/微信 支付密码输入框的自定义View

    类似这个密码输入框相信在博客上已经不少了,但是我稍微看了一下,大都是通过XML布局,然后组合成的一个自定义View.但是我想只用一个java文件,拿来就用该怎么办呢? 那就需要自己画出来了.水平有限, ...

  8. Android 仿微信刷新旋转小风车 自定义view

    不太会录像,没办法,智能截图了 不多说了,直接上代码 package com.shipneg.demoysp.demo;import android.content.Context; import a ...

  9. android刷新时的圆形动画_Android自定义view渐变圆形动画

    本文实例为大家分享了Android自定义view渐变圆形动画的具体代码,供大家参考,具体内容如下 直接上效果图 自定义属性 attrs.xml文件 创建一个类 ProgressRing继承自 view ...

最新文章

  1. 使用openpyxl处理表格数据
  2. 聊聊Synchronized
  3. NAT(修改IP包的IP或者Port) NAT穿越 keepalive包(IP包),保持映射关系
  4. 转载 vue的基础使用
  5. P5283-[十二省联考2019]异或粽子【可持久化Trie,堆】
  6. 数据结构上机实践第四周项目6- 循环双链表应用
  7. spark 数据倾斜之两阶段聚合(局部聚合+全局聚合)
  8. 单纯学python能干啥_如何高效学习Python编程,转行的朋友可以过来看看,单纯的经验分享...
  9. 硅谷新传奇Kevin Systrom
  10. 鸡啄米VS2010/MFC编程入门教程——学习3(安装VS2010)
  11. Hive教程(05)- Hive命令汇总
  12. 蒙特卡罗 Monte Carlo 模拟
  13. 【AHP】层次分析法 | 过程解读 案例实践
  14. 那些年啊,那些事——一个程序员的奋斗史 ——16
  15. iPhone - 不能读取文件 iTunes.Library.itl 因为它是由更高级别的 iTunes 所创建
  16. OpenWrt之DNS 测试工具(nslookup、dig)
  17. 语言栏删除已经卸载了的输入法
  18. cs字体样式和盒子模型学习1
  19. 从 KPI 到 OKR,高阶产品人如何推动业务高速增长
  20. PDF如何在线翻译?PDF在线翻译的方法

热门文章

  1. 全世界的计算机是怎样连在一起的?
  2. 价值营销:让中高端品牌成为信仰
  3. 易数一键还原备份--系统休眠状态,无法备份
  4. ESP8285、ESP8266 和 FPM10光学指纹模块做指纹锁协议 爆光
  5. 影驰 H610M 光影 评测
  6. C#实现RPC(远程过程调用)
  7. 计算机室的校规英语翻译,我们学校的校规英语作文含翻译(通用5篇)
  8. arma自回归matlab,基于MATLAB的自回归移动平均模型_ARMA_在股票预测中的应用
  9. iOS图片合成————(拍照换发)
  10. wps word内表格与上面文字距离大