0

0

Android vector path fillType nonZero XML填充规则详解

月夜之吻

月夜之吻

发布时间:2026-03-08 11:42:11

|

829人浏览过

|

来源于php中文网

原创

nonzero填充规则基于环绕数:从点引射线,顺时针边+1、逆时针边−1,和非零则填充;重叠反向路径导致镂空,自相交或复合形状易出意外,需用evenodd验证或工具查看路径方向。

android vector path filltype nonzero xml填充规则详解

nonZero 填充规则到底怎么算?

Android 的 android:fillType="nonZero" 是默认值,但它不是“画哪儿填哪儿”那么简单——它靠**环绕数(winding number)** 判断是否填充:从某点往任意方向画一条射线,每遇到一条**顺时针路径边**就 +1,遇到**逆时针路径边**就 −1;最终和不为 0,该点就被认为在“内部”,会被填充。

这意味着:如果你画了两个重叠的三角形,一个顺时针、一个逆时针,它们重叠区域的环绕数是 0,那块就会“透明”——哪怕你没写 evenOdd,也会出现镂空效果。

  • 顺时针闭合路径(如 M0,0 L10,0 L5,10 Z)→ 贡献 +1
  • 逆时针闭合路径(如 M0,0 L5,10 L10,0 Z)→ 贡献 −1
  • 单个路径里混用顺/逆向子路径(比如先 M-L-L-Z 再 M-L-L-Z)→ 各自独立计算环绕数
  • nonZero 对「自相交路径」(如五角星)填充结果可能反直觉,建议用 evenOdd 验证对比

pathData 方向怎么控制顺/逆时针?

Android 不检查 pathData 的几何朝向,只忠实地按你写的坐标顺序连线并闭合。所以“顺时针”完全取决于你写点的顺序——就像手动画多边形:从左上→右上→右下→左下→Z,大概率是顺时针;反过来就是逆时针。

实操中别靠肉眼猜,用工具辅助:

Veed AI Voice Generator
Veed AI Voice Generator

Veed推出的AI语音生成器

下载
  • 在 Android Studio 中预览 vector asset,开启「Show Path Direction」(小齿轮图标 → Show Path Direction),箭头会标出每段走向
  • 用在线 SVG 编辑器(如 svgviewer.dev)粘贴 pathData,它会高亮显示填充区域,快速验证
  • 简单测试法:画一个矩形 M0,0 H10 V10 H0 Z → 顺时针;改成 M0,0 V10 H10 V0 Z → 逆时针(Y 增大向下)

fillType="nonZero" 在哪些场景容易翻车?

最常踩坑的是「复合形状」和「描边+填充混用」——nonZero 会把 stroke 和 fill 当作同一路径参与环绕数计算,但 stroke 本身不闭合,不会改变环绕数;真正影响的是 fill 区域的拓扑结构。

  • CL 拼出带内孔的形状(比如圆环),只写一个 path → nonZero 很可能填满整个外轮廓,内孔不空(因为没定义“逆向内圈”)
  • 多个 <path></path> 叠加时,各自独立计算环绕数,但渲染层会叠加 alpha,造成颜色变深或边缘发虚(尤其配合 android:fillAlpha
  • 从 SVG 导入时,某些工具导出的 path 默认用逆时针绘制 logo 文字,导入后文字被“挖空”,实际只是 nonZero 把它判为外部
  • targetSdkVersion 嵌套在 <path></path> 内且设了 fillType,可能直接 crash 或静默失效(错误提示类似 android:endX attribute not found

要不要主动写 android:fillType="nonZero"?

不用。它本来就是默认值,显式声明纯属冗余,还可能误导协作者以为“这里必须是非零填充”。真正该写的是 evenOdd——当你需要明确支持镂空、奇偶穿插、或兼容设计师给的 SVG 逻辑时。

另外注意:fillType 只作用于当前 <path></path>,不影响同级其他 path,也不继承 group;如果你有旋转/缩放 group,填充规则仍按原始 pathData 计算,不受 transform 影响。

复杂图标里路径方向难肉眼判断,又不想反复试错?老老实实拆成多个 <path></path>,每个单独配 fillType,比硬刚一个 giant pathData 更可靠。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

1944

2024.04.01

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

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

2118

2024.08.01

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

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

1162

2024.11.28

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

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

334

2023.08.14

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

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

1819

2023.08.22

android权限限制怎么解开
android权限限制怎么解开

android权限限制可以使用Root权限、第三方权限管理应用程序、ADB命令和Xposed框架解开。详细介绍:1、Root权限,通过获取Root权限,用户可以解锁所有权限,并对系统进行自定义和修改;2、第三方权限管理应用程序,用户可以轻松地控制和管理应用程序的权限;3、ADB命令,用户可以在设备上执行各种操作,包括解锁权限;4、Xposed框架,用户可以在不修改系统文件的情况下修改应用程序的行为和权限。

2126

2023.09.19

android重启应用的方法有哪些
android重启应用的方法有哪些

android重启应用有通过Intent、PendingIntent、系统服务、Runtime等方法。本专题为大家提供Android相关的文章、下载、课程内容,供大家免费下载体验。

284

2023.10.18

Android语音播放功能实现方法
Android语音播放功能实现方法

实现方法有使用MediaPlayer实现、使用SoundPool实现两种。可以根据具体的需求选择适合的方法进行实现。想了解更多语音播放的相关内容,可以阅读本专题下面的文章。

379

2024.03.01

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

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

23

2026.03.06

热门下载

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

精品课程

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

共162课时 | 20.4万人学习

Java 教程
Java 教程

共578课时 | 78.3万人学习

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

共64课时 | 6.9万人学习

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

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