|
高级着色器语言(High-Level Shader Language) ——DirectX9XML:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" /> 译者:高超震 ——孤独一剑 你是不是厌倦了用汇编语言写着色器?可以试一下高级着色器语言(High-Level Shader Language——HLSH)。Microsoft DirectX9包含了可用于开发和调试着色器的类C语言HLSH。这种特性DirectX 8.0开始,是对汇编着色器的扩展,可用于顶点着色器(vertex shaders),像素着色器(pixel shaders),以及特效。 HLSH支持类C函数开发着色器,支持函数(fUCtions),表达式(eXPresstions),声明(statements),标准数据类型(standard date types),自定义数据类型(user-desighed date types),预处理指令(preprocessor directives)。 ******数据类型(date types)****** 数值类型(scalar types) bool true or false int 32位整数 half 16位浮点数 float 32位浮点数 doule 64位浮点数 不是所有的目标平台都支持整数型数据,整数型可能被浮点型硬件模拟。在这些平台上整数型操作超出整数位的部分会表达成浮点型,这种情况DirectX不保证执行期望的功能。 不是所有的目标平台都支持half和doule类型,如果不支持将用float类型模拟。 矢量类型(vector types) vector 由四个float类型组成的矢量 vector<type,size> 由size个数值类型组成的矢量 矢量的各个组成部分可以通过标量存取,通过数组存取语法,如下: vec[0] (same as vec.x) vec[3] (same as vec.w) 也可以通过名称存取,通过结构成员存取语法,以下矢量的名称设置如下: Default set x y z w Color set r g b a 通过名字存取的矢量(原文Vectors containing swizzled components of the vector)可以写成两个或以上组成部分名字连接在一起的形式。比如:yyzw或者bgr。连接起来的名字必须来自同一个名字设定。相同的部分被重复是无效的。 矩阵类型(matrix types) matrix 4*4矩阵,由float类型组成 matrix<type,rows,columns> row*col矩阵,由type类型组成 矩阵的各部分可以通过标量存取,通过数组存取语法如下: mat[2] (same as mat.mCSC="0" NumberType="1" Negative="False" HasSpace="False" SourceValue="20" UnitName="m">20m21m22m23) mat[2].w (same as mat.m23) ///原文如此 mat[2][3] (same as mat.m23) 也可以通过名称存取,通过结构成员存取语法,以下矩阵的名称设置如下: 基于1的设置 _11 _12 _13 _14 _21 _22 _23 _24 _31 _32 _33 _34 _41 _42 _43 _44 基于0的设置 _m00 _m01 _m02 _m03 _m10 _m11 _m12 _m13 _m20 _m21 _m22 _m23 _m30 _m31 _m32 _m33 通过名字存取的矩阵(原文Vectors containing swizzled components of the matrix)可以写成两个或以上组成部分名字连接在一起的形式。比如:_41_42_43 or _m01_m02_m03_m04。连接起来的名字必须来自同一个名字设定。相同的部分被重复是无效的。 ******对象类型****** 字符串(string) ASCII字符串类型,没有操作和状态接受字符串。字符串参数和注释可以通过ID3DXEffect界面被应用程序质问(query)。 像素着色器(pixelshader) 一个pixelshader对象表示Direct3D像素着色器对象。当着色器函数里没有操作直接接受像素着色器时,像素着色器可以在technique内部设置给设备。下例可以被一个pixelshader对象质问,通过结构成员存取语法。 const string version; 字面上的pixelshader值可以被表示成汇编块: pixelshader ps = asm { ps.2.0 mov oC0, c0 }; 或者一个compile调用: pixelshader ps = compile ps_2_0 psmain(); 取样器(sampler) 一个sampler对象表示Direct3D取样器层。其样器层被用来取样纹理。取样器被指定纹理和过滤类型。 纹理(texture) 一个texture对象表示Direct3D纹理对象。当着色器函数没有操作直接接受纹理时,纹理可以在technique中被设置给设备。下例可以被一个texture对象质问,通过结构成员存取语法。 const string type; const string format; const int width; const int height; const int depth; 顶点着色器(vertexshader) 一个vertexshader对象表示Direct3D顶点着色器对象。当着色器函数没有操作直接接受顶点着色器时,顶点着色器可以在technique中被设置给设备。下例可以被一个vertexshader对象质问,通过结构成员存取语法。 const string version; 字面上的pixelshader值可以被表示成汇编块: vertexshader vs = asm { vs.2.0 mov oPos, c0 };或者一个compile调用: vertexshader vs = compile vs_2_0 psmain(); 对象的结构存取方法还没有被完全贯彻。 ******结构类型(struct types) struct关键字被用来定义结构类型。一旦结构被定义,就可以通过其标识符(ID)被引用。 struct [id] { member_list }一个member_list由一个或多个成员声明(member declarations)组成。成员声明类似于变量声明(声明在下面),除非他们不能被初始化或者被单独地声明为static, extern, volatile, or const。 ******用户自定义类型****** typedef关键字被用来为一种类型定义一个名字。const关键字被用来标明其为常量类型。Array_suffix可以放在每一个ID后面。一旦自定义类型被定义,就可以通过其标识符(ID)被引用。 typedef [const] type id [array_suffix] [, id ...] ; 一个array_suffix由一个或多个int表达式,表示其维度(dimension)。 为了与Direct3D extensions(D3DX)8.0保持兼容,下列类型被自动定义了: typedef int DWord; typedef float FLOAT; typedef vector VECTOR; typedef matrix MATRIX; typedef string STRING; typedef texture TEXTURE; typedef pixelshader PIXELSHADER; typedef vertexshader VERTEXSHADER; 为了方便,下列类型被自动定义了(#表示1-4之间的数字) typedef vector bool#; typedef vector int#; typedef vector half#; typedef vector float#; typedef vector double#; typedef matrix bool#x#; typedef matrix int#x#; typedef matrix half#x#; typedef matrix float#x#; typedef matrix double#x#; ******类型转换****** Scalar-to-scalar | 总是有效的,当从bool型转化为整数型或浮点型时, false被认为是0,true为1。当整数型或浮点型转化为bool型时,0为true,非0为false。当从浮点型转化为整数型时,值被除余(the value is rounded toward zero) | Scalar-to-vector | 总是有效的,复制数值型填充vector | Scalar-to-matrix | 总是有效的,复制数值型填充matrix | Scalar-to-object | 无效的 | Scalar-to-structure | 如果结构的所有部分均为数值则有效,复制数值填充结构 | Vector-to-scalar | 总是有效的,选择向量的第一部分 | Vector-to-vector | 目标矢量必须大于资源矢量保持左值,去掉多余值。这样做的目的是行矩阵,列矩阵和数字结构可以看成是矢量 | Vector-to-matrix | 大小必须相等 | Vector-to-object | 无效的 | Vector-to-structure | 结构不大于矢量,且结构各部分均为数字则有效 | Matrix-to-scalar | 总是有效的,选择了矩阵的左上部分 | Matrix-to-vector | 大小必须相等 | Matrix-to-matrix | 目标矩阵在任何一维都不大于资源矩阵 ,这个操作保持左上值,去掉多余值。 | Matrix-to-object | 无效的 | Matrix-to-structure | 结构的大小等于矩阵的大小,结构的所有组成部分都是数字 | Object-to-scalar | 无效的 | Object-to-vector | 无效的 | Object-to-matrix | 无效的 | Object-to-object | 对象类型完全相同则有效 | Object-to-structure | 结构必须包含比成员更多的内容,此成员的类型必须与结构类型完全相同 | Structure-to-scalar | 结构必须包含至少一个数字型成员 | Structure-to-vector | 结构至少是矢量的大小,第一个组成部分必须是数字,直到矩阵的大小 | Structure-to-matrix | 结构必须至少是矩阵的大小。第一个组成部分必须是数字,直到矩阵的大小 | Structure-to-object | 结构至少包含一个对象的成员。这个成员的类型必须和对象类型完全相同。 | Structure-to-structure | 目标结构必须大于资源结构 |
累了,看反响如何决定是否继续。
|