当前位置: 首页 > article >正文

SDF!这特效牛不牛?

什么是SDF

SDF(Signed Distance Field),有向距离场 ,用于表示空间中各点距离物体表面的距离。SDF技术已经被应用于字体渲染、Ray Marching、物理引擎等领域。

在 ShaderToy 上可以找到大量用 SDF 渲染的作品,ShaderToy 创办人 Inigo Quilez 大神是运用SDF的专家,本文封面就摘自他的博客,用 SDF 和 Ray Marching 技术渲染的基本几何图形。

SDF 如何运用在 2D 游戏渲染?在 2D 图像里,SDF 表示的是图片中每个像素距离图片轮廓的距离,通过 SDF 可以很方便地对图片的轮廓施加特效。

如何生成SDF

目前有线性时间生成 SDF 的算法,这里使用了开源的TinySDF。
TinySDF计算SDF纹理完全在CPU上运行,对于小图可以直接运行时生成对应SDF纹理。考虑到苹果手机某些场合无法开启 JIT,对于大图可以采用离线生成的方式或者分帧计算的方式获取 SDF 纹理。

外发光之类的特效可能会超出原图的边缘,在计算 SDF 纹理前需要对原图进行扩边。SDF 信息生成后是一个和扩边后图片大小相同的二维数据,可以用该数组生成内存纹理,赋值给材质进行渲染。

简单起见,本文 Demo 直接将 SDF 纹理作为alpha通道和原图合并,不适合原图里本身有较大区域半透明像素的图片。

基于SDF的shader

轮廓Bloom

外发光

用 SDF 实现 2D 外发光的优势是 SDF 纹理计算是一次性的,之后通过 shader 渲染的成本非常低。实现原理和 Bloom 类似,加上原图的混合即可。


变形

在两个SDF纹理之间插值,可以实现轮廓的变形

代码 & Demo

代码已经上架 Cocos Store 先免费放几天,欢迎大家白漂!感谢支持

源码地址:http://store.cocos.com/app/detail/2875

[论坛讨论帖]
https://forum.cocos.org/t/topic/110559

这是我的公众号,关注有更多精彩,一起交个朋友吧!

  • Creator全平台游戏开发教程 PDF 免费下载(800+页)

  • 编写高效 TS 的一些建议

  • Creator 3.0 折纸效果!超赞

  • 隔壁老王,带你入坑腾讯联机对战引擎!

  • 更新!Creator最佳文字书写解决方案!

http://www.lryc.cn/news/2414140.html

相关文章:

  • dwmapi.dll文件丢失导致程序无法运行问题
  • 华三交换机基本配置命令
  • setAttribute、getAttribute、getParameter方法的用法 /// Session的getSession()方法的使用小结
  • 开源人脸识别项目 —— face_recognition
  • rx 文件管理器_免费开源资源管理器——RX 文件管理器
  • asp毕业设计——基于asp+access的教师信息管理系统设计与实现(毕业论文+程序源码)——教师信息管理系统
  • 通过JavaEye2.0网站看ruby on rails性能
  • QQ快速登录协议分析
  • 【RDMA】技术详解(一):RDMA概述
  • 面试专区|【60道计算机网络高频题整理(附答案背诵版)】
  • Codeigniter 框架开启PDO查询方式、多库连接实现、多语言网站开发配置、以及捕获页面最后报错
  • java语言技术_Java语言四大核心技术详解
  • WEB前端开发准备-Atom编辑器使用说明 Atom常用插件推荐 Atom快捷键
  • GUI Design Studio 4.5.151.0原型设计工具的使用
  • DOM4J 知识详解
  • 简单了解cms(内容管理系统)
  • [Visual Studio 2022 C#]设置splitContainer拆分器中间分隔条splitter的颜色和宽度
  • 【reverse】通俗易懂的gcc内联汇编入门+示例:实现花指令
  • C#窗体应用程序之CheckListBox复选列表与ListBox列表框控件
  • netframework有什么用_C#初学者教程系列1:什么是.NET Framework?
  • 使用fastdb的感受
  • 对SHFileOperation函数的一点研究
  • Java(API)——正则表达式
  • FieldTrip toolbox教程系列(0)-安装、配置与测试
  • linux 升级 java 8,生产环境 JDK6 升级至 JDK8
  • ExcuteReader详解
  • CImage拷贝到另一个CImage,两个方法
  • 备战数学建模4-MATLAB绘制三维图形
  • MatchPuppy:狗狗相亲网站
  • Request.QueryString