0

0

Android shape stroke dashWidth XML绘制虚线的实线长度

畫卷琴夢

畫卷琴夢

发布时间:2026-03-07 11:57:35

|

362人浏览过

|

来源于php中文网

原创

dashwidth 控制虚线中实线段的像素宽度,必须与 dashgap 同时大于 0 才生效,且依赖 android:strokewidth;xml 中使用需注意单位统一为 dp,代码中须用 dashpatheffect 实现。

android shape stroke dashwidth xml绘制虚线的实线长度

dashWidth 控制的是虚线中“实线段”的长度

很多人以为 dashWidth 是“空隙长度”或“整个虚线周期”,其实它明确指每一段实线的像素宽度。比如 dashWidth="4" 就是画 4px 长的实线,再画 dashGap="2" 的空白,循环下去。

常见错误现象:stroke 看起来像实线、断断续续不均匀、甚至完全不显示虚线——多数是因为 dashWidthdashGap 同时为 0(默认值),或只设了其中一个。

  • dashWidthdashGap 必须**同时大于 0** 才能生效,缺一不可
  • 若只写 android:dashWidth="4"dashGap 仍为 0,结果仍是实线
  • Android 4.0+ 才支持 dashWidth/dashGap;低于 API 14 会静默忽略,无报错

XML 中必须配合 android:strokeWidth 使用

虚线本质是描边,所以 android:strokeWidth 是前提。没有它,哪怕 dashWidth 设得再准,也不会渲染出任何线条。

使用场景:自定义 shape 作背景、分隔线、按钮边框等。注意:不能直接用在 Viewbackground 属性里就指望自动虚化——必须确保该 shape 是 layer-list 或独立 drawable,且被正确引用。

  • android:strokeWidth 决定整体线宽,dashWidth 只控制其中实线部分的长度
  • 例如 strokeWidth="2" + dashWidth="6" + dashGap="2":每 8px 周期里,画 6px 实线 + 2px 空白,整条线粗 2px
  • 如果 strokeWidth 太小(如 1),在高密度屏上可能因抗锯齿导致虚线模糊或断点粘连

实际 XML 示例与关键参数组合

下面是一个能稳定生效的虚线 shape 定义:

光子AI
光子AI

AI电商服饰商拍平台

下载
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="line">
    <stroke
        android:width="2dp"
        android:color="#666"
        android:dashWidth="6dp"
        android:dashGap="4dp" />
</shape>

说明:dashWidth="6dp" → 每段实线长 6dp;dashGap="4dp" → 空白段长 4dp;周期为 10dp。注意单位统一用 dp,避免在不同屏幕密度下缩放失真。

  • 不要混用 pxdp,尤其 dashWidthpx 会导致高密度屏上虚线过密甚至糊成实线
  • 若用于 Viewandroid:background,需确认该 View 高度足够(对 line shape,至少设 android:layout_height="2dp"
  • rectangle shape 中用虚线边框时,dashWidth 从左上角起始绘制,四个边共用同一相位,不会自动对齐拐角

Canvas drawLine 绘制虚线时,dashWidth 不适用

这是最容易混淆的点:dashWidth 是 XML shape 的专属属性,**纯代码中调用 canvas.drawLine()Paint.setPathEffect() 时完全无效**。

如果你在自定义 View 里动态画虚线,必须用 DashPathEffect

Paint paint = new Paint();
paint.setStyle(Paint.Style.STROKE);
paint.setStrokeWidth(2f);
float[] intervals = {6f, 4f}; // 实线6px、空隙4px
paint.setPathEffect(new DashPathEffect(intervals, 0));

注意:DashPathEffect 的数组是交替的实/空长度,第二个参数是 phase(偏移),不是 dashGap

  • XML 的 dashWidth/dashGap 和代码里的 DashPathEffect 是两套机制,不能互相替换或混用
  • PathEffect 在硬件加速开启时部分机型可能不生效(尤其是旧 Android 版本),可临时加 setLayerType(LAYER_TYPE_SOFTWARE, null)
  • XML 虚线无法做旋转或缩放动画,而代码绘制的虚线可通过矩阵实时调整,灵活性更高

虚线的“实线长度”由 dashWidth 直接决定,但它永远不是孤立参数——它依赖 dashGap 的配合、受 strokeWidth 的物理约束、在不同载体(XML vs Canvas)中完全不互通。最常被忽略的是:没设 dashGap 就等于没设虚线。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

252

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

1049

2024.03.01

pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1943

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2117

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

1159

2024.11.28

html5动画制作有哪些制作方法
html5动画制作有哪些制作方法

html5动画制作方法有使用CSS3动画、使用JavaScript动画库、使用HTML5 Canvas等。想了解更多html5动画制作方法相关内容,可以阅读本专题下面的文章。

547

2023.10.23

android开发三大框架
android开发三大框架

android开发三大框架是XUtil框架、volley框架、ImageLoader框架。本专题为大家提供android开发三大框架相关的各种文章、以及下载和课程。

334

2023.08.14

android是什么系统
android是什么系统

Android是一种功能强大、灵活可定制、应用丰富、多任务处理能力强、兼容性好、网络连接能力强的操作系统。本专题为大家提供android相关的文章、下载、课程内容,供大家免费下载体验。

1819

2023.08.22

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

1

2026.03.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Excel 教程
Excel 教程

共162课时 | 20.2万人学习

Java 教程
Java 教程

共578课时 | 77.8万人学习

Uniapp从零开始实现新闻资讯应用
Uniapp从零开始实现新闻资讯应用

共64课时 | 6.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号