[基础] Unity Shader:顶点着色器(vert)函数

顶点着色器(Vertex Shader)是图形渲染的第一个阶段,它的输入来自于CPU。顶点着色器的处理单位是顶点,CPU输入进来的每个顶点都会调用一次顶点着色器函数,也就是我们在Shader代码里所定义的vert函数。本篇我们将会通过顶点的颜色变换、顶点位移、顶点扭曲来介绍顶点着色器(vert)函数。

1. 基于模型空间的顶点颜色变换

3D模型中的每个顶点都有一个处于模型空间里的顶点坐标,顶点坐标通常在经过顶点着色器处理后会被转换到规范化设备坐标(NDC)空间,这个空间中的x、y、z坐标范围通常是[-1, 1],在vert函数中,我们就可以利用这些坐标来对顶点的颜色进行变换。我们在场景里创建一个立方体,它的坐标值一般为0.5或-0.5,例如,我们要将坐标为(0.5, 0.5, 0.5)的顶点渲染成红色,其它顶点为白色,则Cg代码如下:

if (appData.vertex.x == 0.5 && appData.vertex.y == 0.5 && appData.vertex.z == 0.5)
    outData.color = fixed4(1, 0, 0, 1);
else
    outData.color = fixed4(1, 1, 1, 1);

实现效果如下图所示:

我们发现,靠近立方体顶点(0.5, 0.5, 0.5)的部分呈现出红色,且不管我们如何移动或旋转立方体,该顶点区域依然保持为红色,这是因为我们使用的是基于模型空间的固定顶点坐标。

2. 基于世界空间的顶点颜色变换

倘若我们要让模型的顶点接近世界空间的某个位置时才让颜色发生改变,我们则需要将模型顶点变为世界顶点。要这么做,我们先要让顶点进行物体到世界的矩阵变换:

// 将顶点进行物体到世界的矩阵变换
float4 wpos = mul(unity_ObjectToWorld, appData.vertex);

接下来,例如我们要实现当模型顶点大于世界x坐标 0 时,则变为红色,反之为白色,Cg代码如下:

if (wpos.x > 0)
    outData.color = fixed4(1, 0, 0, 1);
else
    outData.color = fixed4(1, 1, 1, 1);

实现效果如下图所示:

 3. 顶点位移

当然,我们也可以在vert函数里修改每个顶点的位置,例如,我们让越靠近模型圆心的顶点,它的y值越高:

Properties
{
    _R("Range", range(0, 5)) = 1
}
float2 xy = appData.vertex.xz;
float d = _R - length(xy); // R - 计算原点到顶点的长度
d = d < 0 ? 0 : d;
float baseHeight = 1;
float4 uppos = float4(appData.vertex.x, baseHeight * d, appData.vertex.z, appData.vertex.w);
outData.pos = UnityObjectToClipPos(uppos);

我们在编辑器中拖动 Range 的值,效果如下:

 4. 顶点扭曲

我们也可以通过让每个顶点通过旋转矩阵变换来实现模型的扭曲,Cg代码如下:

// 旋转角度
float angle = length(appData.vertex) * _SinTime.w;
// 定义旋转矩阵
float4x4 m = {
    float4(cos(angle), 0, sin(angle), 0),
    float4(0, 1, 0, 0),
    float4(-sin(angle), 0, cos(angle), 0),
    float4(0, 0, 0, 1)
};
// 与MVP矩阵相乘
appData.vertex = mul(m, appData.vertex);
outData.pos = UnityObjectToClipPos(appData.vertex);

效果如下图所示:

相关推荐

  1. 11.1 OpenGL可编程顶点处理:顶点着色

    2024-05-03 09:56:05       38 阅读
  2. 11.3 OpenGL可编程顶点处理:几何着色

    2024-05-03 09:56:05       35 阅读
  3. 11.2 OpenGL可编程顶点处理:细分着色

    2024-05-03 09:56:05       33 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-05-03 09:56:05       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-05-03 09:56:05       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-05-03 09:56:05       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-05-03 09:56:05       20 阅读

热门阅读

  1. 揭秘FastStone Capture

    2024-05-03 09:56:05       17 阅读
  2. Nacos在微服务架构中如何支持服务发现和注册

    2024-05-03 09:56:05       16 阅读
  3. 区分Vue2和Vue3的配置读取(附Demo)

    2024-05-03 09:56:05       12 阅读
  4. 高可用系列四:loadbalancer 负载均衡

    2024-05-03 09:56:05       15 阅读
  5. 愚安科技安全工程师面经:

    2024-05-03 09:56:05       12 阅读
  6. Windows 系统运维常用命令

    2024-05-03 09:56:05       13 阅读
  7. 什么是Vuex它的作用是什么怎么用

    2024-05-03 09:56:05       14 阅读
  8. 新人天上下凡尘

    2024-05-03 09:56:05       15 阅读
  9. redis

    redis

    2024-05-03 09:56:05      12 阅读
  10. 孩子学编程,考级和竞赛二者间的比较

    2024-05-03 09:56:05       10 阅读
  11. Qt绘图与图形视图之Graphics View坐标系的简单介绍

    2024-05-03 09:56:05       13 阅读