Android绘制竖直虚线完美解决方案—自定义View
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相关推荐
- android xml中设置水平虚线及竖直虚线
水平线背景 <?xml version="1.0" encoding="utf-8"?> <shape xmlns:android=" ...
- android 横向虚线,Android实现水平虚线和竖直虚线
水平虚线 android:shape="line"> android:width="1dp" android:color="#747474&qu ...
- 用xml画水平虚线和竖直虚线.md
1.画水平虚线 直接建一个shape,设置stroke属性就行了,再将这个属性直接作为background的drawable属性引入就行了 注意在4.0以上的真机加一句 <?xml versio ...
- Winform中设置ZedGraph因设置小刻度导致的竖直虚线显示过多
场景 Winforn中设置ZedGraph曲线图的属性.坐标轴属性.刻度属性: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/10 ...
- android 自定义view xml ,Android实现在xml文件中引用自定义View的方法分析
本文实例讲述了Android实现在xml文件中引用自定义View的方法.分享给大家供大家参考,具体如下: 在xml中引用自定义view 方法一: android:layout_width=" ...
- Android TextView竖直滚动文字广告效果
项目需要 TextView 单行竖直滚动文字广告效果,很简单的功能在网上找了很多没有想要的效果.开始找到的<android TextView 垂直自动滚动>,歌词效果,对代码处理一下变成单 ...
- 安卓/Android 模仿支付宝/微信 支付密码输入框的自定义View
类似这个密码输入框相信在博客上已经不少了,但是我稍微看了一下,大都是通过XML布局,然后组合成的一个自定义View.但是我想只用一个java文件,拿来就用该怎么办呢? 那就需要自己画出来了.水平有限, ...
- Android 仿微信刷新旋转小风车 自定义view
不太会录像,没办法,智能截图了 不多说了,直接上代码 package com.shipneg.demoysp.demo;import android.content.Context; import a ...
- android刷新时的圆形动画_Android自定义view渐变圆形动画
本文实例为大家分享了Android自定义view渐变圆形动画的具体代码,供大家参考,具体内容如下 直接上效果图 自定义属性 attrs.xml文件 创建一个类 ProgressRing继承自 view ...
最新文章
- 使用openpyxl处理表格数据
- 聊聊Synchronized
- NAT(修改IP包的IP或者Port) NAT穿越 keepalive包(IP包),保持映射关系
- 转载 vue的基础使用
- P5283-[十二省联考2019]异或粽子【可持久化Trie,堆】
- 数据结构上机实践第四周项目6- 循环双链表应用
- spark 数据倾斜之两阶段聚合(局部聚合+全局聚合)
- 单纯学python能干啥_如何高效学习Python编程,转行的朋友可以过来看看,单纯的经验分享...
- 硅谷新传奇Kevin Systrom
- 鸡啄米VS2010/MFC编程入门教程——学习3(安装VS2010)
- Hive教程(05)- Hive命令汇总
- 蒙特卡罗 Monte Carlo 模拟
- 【AHP】层次分析法 | 过程解读 案例实践
- 那些年啊,那些事——一个程序员的奋斗史 ——16
- iPhone - 不能读取文件 iTunes.Library.itl 因为它是由更高级别的 iTunes 所创建
- OpenWrt之DNS 测试工具(nslookup、dig)
- 语言栏删除已经卸载了的输入法
- cs字体样式和盒子模型学习1
- 从 KPI 到 OKR,高阶产品人如何推动业务高速增长
- PDF如何在线翻译?PDF在线翻译的方法