UGUI源码解析——Outline
  gEMN1CQh1PXt 2023年11月02日 72 0


一:前言

Outline继承自Shadow,可以为图片或文字添加描边效果

它的实现原理是将原网格数据复制四份并向指定方向移动指定像素,然后再填充到顶点数据中,也可以理解成是四个Shadow,所以顶点数和三角面数会增加4倍


将Outline组件上的x偏移值和y偏移值调大可以看出来其实就是复制了四份原网格
UGUI源码解析——Outline_unity



二:源码解析

UGUI源码解析——Outline_unity_02

UGUI源码解析——Outline_实现原理_03 

首先在ModifyMesh方法中使用vh.GetUIVertexStream把当前的顶点信息提取到一个List<UIVertex>中(UIVertex是一个结构体),之后调用四次ApplyShadowZeroAlloc方法复制出四份,按照原顶点的顺序,从前至后,先添加一个相同的顶点,然后再修改原顶点的值(包括顶点的偏移、颜色)

先添加一个相同的顶点再修改原顶点的值是为了保证复制出来的Outline对象绘制在原对象的下边

最后使用vh.AddUIVertexTriangleStream将List<UIVertex>添加到当前VertexHelper对象中


三:使用Shader实现UI描边

Unity中实现UI描边


【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2023年11月08日 0

暂无评论