【UE】SDF - 使用有向距离场(Signed Distance Fields)整各种活-4-将图片制作为距离场图

关于"如何使用函数制作 SDF(有符号距离场)",之前已经做过详细讲解,这里就不再赘述。

今天这篇文章,解决另一个需求

如何使用 Photoshop,将普通的图像资产,制作为距离场图像资产


第一步:在 PS 中搭建工作环境

最简单的距离场,就是从图像的轮廓开始向外,带有一个随距离变化的渐变效果。

例如一个三角形2D距离场基元

这是它的渐变方向

布置工作环境
  • 导入图片,放到文件夹里,后续操作这个文件夹
  • 创建纯白色背景
缩放图像
  • 缩放图像,使其最远边,距离整体边缘250px左右(原因稍后提到)

第二步:进阶制作近似的 SDF(有符号距离场)

在真正的 SDF 中,0 代表边界,负值代表内部,正值代表外部。

但是,因为普通的图像数据无法存储负值,所以我们在 PS 中采用将 0.5(中性灰)视为 0的方式来进行映射和伪造。

制作思路:

我们在 Photoshop 中调整图层样式或绘制渐变时,需要使其满足以下灰度条件:

灰色(0.5 / RGB127)代表形状边界
  • 右键文件夹,选择混合选项

  • 覆盖颜色为50%

大于 0.5 的值(从0.5渐变到1)代表形状外部距离
  • 继续添加效果 外发光 注意图中:
  1. 灰色
  2. 选择精确
  3. 扩展50% (参数居中)
  4. 大小250px作为距离单位,(这也是为什么前面要缩放尺寸)
小于 0.5 的值(0.5渐变到0)代表形状内部
  • 现在调整颜色叠加为纯黑 0%
    (之前为50%只是为了方便教学,正式生成可直接为0%)
  • 启用内发光,设置如下

通过这种手法,我们就可以在图像上生成重现 SDF 效果的"伪 SDF"。

补充说明:

这种处理思路其实和法线贴图(Normal Map)中以 0.5 为基准记录法线的方法非常相似。在法线贴图的切线空间中,各通道的值原本应该在 -1 到 +1 之间,但由于纹理无法保存负值,因此也是转换到了 0 到 1(0.5为基准)的范围内进行保存。
工作环境搭建好了,在这里切换新图就可以直接生成了

记得缩放图像到250距离


第三步:导入 UE5 的资产设置

导出
  • 选择导出为

  • 使用精度高的PNG,但丢弃Alpha通道

  • 取消勾选sRGB,作为线性图导出

导入 Unreal Engine
  • 导入图片,将压缩设置改为遮罩,或者灰度
  • 视情况,可以更改MIP设置以提升图片清晰度

延伸应用

列举一些常见应用

拿回边缘

首先,通过Step0.5可以取边缘

还原为SDF
发光
线性插值
其他

既然是SDF,那以前见过的SDF玩法都可以

相关推荐
laowangpython13 天前
Photoshop 2025 下载安装全攻略
其他·ui·photoshop
CG_MAGIC14 天前
3ds Max材质编辑器:精简模式与Slate模式对比
3d·编辑器·材质·贴图·uv·建模教程
玉夏14 天前
【Shader基础】UV 与纹理采样 Part1
unity·着色器·uv
魔士于安15 天前
Shader forge技术美术专用
游戏·unity·游戏引擎·贴图·技术美术·模型
四代水门15 天前
UE5实现客户端与服务器时间同步
ue5
魔士于安16 天前
unity 音乐会场景 unity2022
游戏·unity·游戏引擎·贴图·模型
智海深蓝17 天前
海上平行战场:态势模拟三维可视化平台
3d·ue5
auccy17 天前
Unity Sprite 添加法线贴图
unity·贴图·normal
mxwin17 天前
次世代角色 PBR 贴图制作 + Unity URP 接入 极简流程图
unity·流程图·贴图·shader
mxwin17 天前
Unity URP 法线贴图如何生成 用什么工具创建
unity·游戏引擎·贴图