» cn.Tutorial Effects - Vertex Data
This site relies heavily on Javascript. You should enable it if you want the full experience. Learn more.

cn.Tutorial Effects - Vertex Data

English | Italian | Spanish | Japanese

TOC: Of Effects and Shaders
Back: Function Printing
Next: Normals


当然在程序片中你也可以定义你自己的的顶点数据。使用Mesh join/split和VertexBuffer join/split节点创建一个新的程序片,像下面这样:

你可以从这里.拷贝最基本的顶点着色器。

VertexBuffer (Join)

那么让我使用VertexBuffer join节点在网格上的z坐标值输入自定义的值,我们用Perlin (2d)这个节点生成这个自定义的值。

你可以尝试一下用LineatSpreads作为输入值来改变网格的样子..

如果你打开属性编辑器,选择VertexBuffer (EX9.Geometry Join)你可以看到所有的通道,它们把每个顶点的数据从程序片传送到顶点着色器:

为了在顶点着色器中获取另外的数据你需要给顶点着色器的输入参数加入数据字段和类型。例如法线和第二材质坐标:

vs2ps VS(
    float4 PosO  : POSITION,
    float3 NormO : NORMAL,
    float4 TexCd : TEXCOORD0,
    float4 TexCd2 : TEXCOORD1)
{
    ...
}

顶点着色器中的材质数据

大多数新的显卡都能够在顶点着色器中获取材质。可以通过tex2Dlod函数来实现:

为了使用tex2Dlod函数你必须使用shader-profile vs_3_0作为顶点着色器的编译器。
//texture
texture Tex <string uiname="Texture";>;
sampler Samp = sampler_state    //sampler for doing the texture-lookup
{
    Texture   = (Tex);          //apply a texture to the sampler
    MipFilter = LINEAR;         //set the sampler states
    MinFilter = LINEAR;
    MagFilter = LINEAR;
};
 
//texture transformation marked with semantic TEXTUREMATRIX 
//to achieve symmetric transformations
float4x4 tTex: TEXTUREMATRIX <string uiname="Texture Transform";>;
 
//the data structure: "vertexshader to pixelshader"
//used as output data of the VS function
//and as input data of the PS function
struct vs2ps
{
    float4 Pos  : POSITION;
    float2 TexCd : TEXCOORD0;
};
 
float Amount = 0.1;
 
vs2ps VS(
    float4 PosO  : POSITION,
    float4 TexCd : TEXCOORD0)
{
    //declare output struct
    vs2ps Out;
 
    //get the color in the texture
    float4 texColor = tex2Dlod(Samp, TexCd);
 
    //offset the z coordinate
    PosO.z += texColor.r * Amount;
 
    //transform position
    Out.Pos = mul(PosO, tWVP);
 
    //transform texturecoordinates
    Out.TexCd = mul(TexCd, tTex);
 
    return Out;
}

这个程序片非常简单如下:

数组

直接的从程序片中把数组传递到着色器也是可以的。你可以使用材质坐标或其它的可变的值获取数组输入的值:

float Amount = 0.1;
 
#define ArrSize 20
float2 Noise[ArrSize];
 
vs2ps VS(
    float4 PosO  : POSITION,
    float4 TexCd : TEXCOORD0)
{
    //declare output struct
    vs2ps Out;
 
    //get the color in the texture
    float4 texColor = tex2Dlod(Samp, TexCd);
 
    //offset the z coordinate
    PosO.z += texColor.r * Amount;
 
    PosO.xy += Noise[TexCd.x * (ArrSize-1)];
 
    //transform position
    Out.Pos = mul(PosO, tWVP);
 
    //transform texturecoordinates
    Out.TexCd = mul(TexCd, tTex);
 
    return Out;
}

我们可以使用前面的那个程序片:


Next: Normals
Back: Function Printing
TOC: Of Effects and Shaders

anonymous user login

Shoutbox

~2d ago

tonfilm: even more #GPU #debugging with #renderdoc and #vvvv #dx11: debug-dx11-frames-with-renderdoc

~3d ago

lev: Heyy. Any vvvv guys in Amsterdam now?

~3d ago

StiX: @vnm there is contrib, just search forums and page

~4d ago

vnm: Hi! How can I get PC-name in VVVV?

~4d ago

mediadog: @fleg Yes, will be premiering a new public work at Times Square the 25th - drop a line!