DirectX11笔记(五)--Direct3D渲染1--VERTICES AND INPUT LAYOUTS
原文:DirectX11笔记(五)--Direct3D渲染1--VERTICES AND INPUT LAYOUTS
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u010333737/article/details/78682213
前言
在前几篇文章中我们主要学习了概念上的渲染管线, 那时我们更加注重说明渲染管线的含义和作用, 现在我们会转换方向, 开始学习使用API来配置渲染管线, 定义shader, 并把几何体提交到渲染管线渲染.
我们将重点学习以下几点:
- 定义, 存储, 渲染图形数据的接口.
- 编写基础的顶点shader和像素shader.
- 学习如何使用渲染状态来配置渲染管线.
- 了解 Effect 框架如何将 shader 和渲染状态封装到一个Render Technique里, 并学习如何把效果框架作为一个shader生成器来使用.
顶点结构与描述
之前我们提到过, 顶点可以是包含除了位置以外的很多数据, 所以为了定义我们自己的顶点, 可以借助结构体来保存我们的顶点信息. 比如下面这两种:
struct Vertex1
{
XMFLOAT3 Pos; // 位置
XMFLOAT4 Color; // 颜色
};
struct Vertex2
{
XMFLOAT3 Pos; // 位置
XMFLOAT3 Normal; // 法线
XMFLOAT2 Tex0; // 纹理坐标1
XMFLOAT2 Tex1; // 纹理坐标2
};
当我们确定顶点格式之后, 我们会通过一个D3D11_INPUT_ELEMENT_DESC类型的数组来描述每一个分量, 这样才能让显卡知道我们传给他的数字要代表怎样的含义. 这个数组也就是输入布局(Input Layout)的描述.
typedef struct D3D11_INPUT_ELEMENT_DESC {
LPCSTR SemanticName;
UINT SemanticIndex;
DXGI_FORMAT Format;
UINT InputSlot;
UINT AlignedByteOffset;
D3D11_INPUT_CLASSIFICATION InputSlotClass;
UINT InstanceDataStepRate;
} D3D11_INPUT_ELEMENT_DESC;
- SemanticName和SemanticIndex: 作用如图所示, 他们与顶点shader的输入标记相映射, index的作用主要是在由相同含义的成员时不必重新定义一个名字, 比如上面顶点的两个纹理就可以用index来区分.
- Format: 用来告诉显卡顶点结构中的数字的格式, 是一维的标量还是三维的向量, 是浮点数还是整数.
- InputSlot: 指定元素来源的slot的索引, D3D支持16条slot, 你可以在这16条slot中填充顶点数据, D3D会整合所有的slot来装配一个顶点, 但是在例子中我们都只会使用一条slot.
- AlignedByteOffset: 对于一条slot来说, 他是从顶点结构第一元素开始计算的byte偏移, 还是之前Vertex2的例子, Pos的偏移是0, Pos是一个三维浮点数向量, 每一个float是32bits, 也就是4bytes, 所以Normal的偏移量就是12.
- InputSlotClass和InstanceDataStepRate: 例子中暂时都会指定为 D3D11_INPUT_PER_VERTEX_DATA , 其他的格式会在以后更高级的应用场景里说明使用.
//Vertex1和Vertex2的输入描述
D3D11_INPUT_ELEMENT_DESC desc1[] =
{
{"POSITION", 0, DXGI_FORMAT_R32G32B32_FLOAT, 0, 0,
D3D11_INPUT_PER_VERTEX_DATA, 0},
{"COLOR", 0, DXGI_FORMAT_R32G32B32A32_FLOAT, 0, 12,
D3D11_INPUT_PER_VERTEX_DATA, 0}
};
D3D11_INPUT_ELEMENT_DESC desc2[] =
{
{"POSITION", 0, DXGI_FORMAT_R32G32B32_FLOAT, 0, 0,
D3D11_INPUT_PER_VERTEX_DATA, 0},
{"NORMAL", 0, DXGI_FORMAT_R32G32B32_FLOAT, 0, 12,
D3D11_INPUT_PER_VERTEX_DATA, 0},
{"TEXCOORD", 0, DXGI_FORMAT_R32G32_FLOAT, 0, 24,
D3D11_INPUT_PER_VERTEX_DATA, 0},
{"TEXCOORD", 1, DXGI_FORMAT_R32G32_FLOAT, 0, 32,
D3D11_INPUT_PER_VERTEX_DATA, 0}
};
创建并绑定输入布局
当定义了输入元素的描述之后, 我们就可以通过 ID3D11Device::CreateInputLayout 方法来创建输入布局( ID3D11InputLayout )了.
HRESULT ID3D11Device::CreateInputLayout(
const D3D11_INPUT_ELEMENT_DESC *pInputElementDescs,
UINT NumElements,
const void *pShaderBytecodeWithInputSignature,
SIZE_T BytecodeLength,
ID3D11InputLayout **ppInputLayout);
- pInputElementDescs: 之前定义的D3D11_INPUT_ELEMENT_DESC数组.
- NumElements: D3D11_INPUT_ELEMENT_DESC数组的长度.
- pShaderBytecodeWithInputSignature: 一个带有顶点shader输入签名的shader字节码的指针.
- BytecodeLength: 前一个参数指明的顶点shader的bytes大小.
这里进一步解释一下第三个参数. 顶点shader将一个名为 Input Signature 的列表作为输入参数. 用户自定义定点格式元素在传递给顶点shader时需要一一对应. 通过这个签名D3D可以验证这个对应关系并在创建的时候就完成顶点结构到shader输入的映射.
// 一种没有对应的定点结构和shader输入
VertexOut VS(
float3 Pos : POSITION,
float4 Color : COLOR,
float3 Normal : NORMAL) { }
struct Vertex
{
XMFLOAT3 Pos;
XMFLOAT4 Color;
};
接下来说明如何使用 ID3D11Device::CreateInputLayout , 这里用到了一些还没讨论过的东西, 但是最终我们的目的是拿到之前所说的输入签名.
ID3DX11Effect* mFX;
ID3DX11EffectTechnique* mTech;
ID3D11InputLayout* mInputLayout;
// 创建 effect
mTech = mFX->GetTechniqueByName("Tech");
D3DX11_PASS_DESC passDesc;
mTech->GetPassByIndex(0)->GetDesc(&passDesc);
HR(md3dDevice->CreateInputLayout(
vertexDesc, 4,
passDesc.pIAInputSignature,
passDesc.IAInputSignatureSize,
&mInputLayout));
这时InputLayout已经创建出来了, 但是我们还需要将他与我们用来渲染的设备进行绑定, 这里用到的是:
md3dImmediateContext->IASetInputLayout(mInputLayout);
需要注意一点是: 输入布局与设备绑定之后直到你自己手动修改它之前都不会发生改变, 当你有不止一个输入布局时需要自己重新设置.
DirectX11笔记(五)--Direct3D渲染1--VERTICES AND INPUT LAYOUTS的更多相关文章
- DirectX11笔记(八)--Direct3D渲染4--VERTEX SHADER
原文:DirectX11笔记(八)--Direct3D渲染4--VERTEX SHADER 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/u0103 ...
- DirectX11笔记(六)--Direct3D渲染2--VERTEX BUFFER
原文:DirectX11笔记(六)--Direct3D渲染2--VERTEX BUFFER 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/u0103 ...
- DirectX11笔记(十一)--Direct3D渲染7--RENDER STATES
原文:DirectX11笔记(十一)--Direct3D渲染7--RENDER STATES 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/u010 ...
- DirectX11笔记(十)--Direct3D渲染6--PIXEL SHADER
原文:DirectX11笔记(十)--Direct3D渲染6--PIXEL SHADER 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/u01033 ...
- DirectX11笔记(九)--Direct3D渲染5--CONSTANT BUFFERS
原文:DirectX11笔记(九)--Direct3D渲染5--CONSTANT BUFFERS 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/u0 ...
- DirectX11笔记(七)--Direct3D渲染3--INDICES AND INDEX BUFFERS
原文:DirectX11笔记(七)--Direct3D渲染3--INDICES AND INDEX BUFFERS 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.cs ...
- DirectX11笔记(三)--Direct3D初始化2
原文:DirectX11笔记(三)--Direct3D初始化2 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/u010333737/article/ ...
- DirectX11笔记(二)--Direct3D初始化1之基本概念
原文:DirectX11笔记(二)--Direct3D初始化1之基本概念 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/u010333737/art ...
- DirectX11笔记(三)--Direct3D初始化代码
原文:DirectX11笔记(三)--Direct3D初始化代码 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/u010333737/article ...
随机推荐
- logcat日志文件
android日志系统提供了记录和查看系统调试信息的功能,日志都是从各个软件和一些系统的缓冲区中记录下来的,缓冲区可以通过logcat命令来进行查看和使用 开发者选项,有个选项叫做“日志记录器缓冲区大 ...
- ES6之主要知识点(四)数值
引自:http://es6.ruanyifeng.com/#docs/number 1.Number.isFinite(),Number.isNaN() Number.isFinite(); // t ...
- Activiti数据库
数据库 Activiti的后台是有数据库的支持,所有的表都以ACT_开头. 第二部分是表示表的用途的两个字母标识. 用途也和服务的API对应. 1) ACT_RE_*: 'RE'表示repos ...
- Python PIL 怎么知道写入图片格式的kb大小
把图片数据写入一个IO,读这个IO的长度大小: #-*-coding:utf-8-*- from PIL import Image import io img = Image.open("1 ...
- 怎么对C++枚举(不是类)里面的东西进行随机
把枚举里面的东西取到一个数组如: enum 枚举类型 a[]={ 枚举元素 }; 变成了一个数组,然后把随机结果当成枚举数组的索引,就可以得到随机的枚举元素了.
- BaseController 的使用
为了提现代码的高可用性,我们可以常见的把dao层进行抽取,service ,但是很少看见有controller的抽取,其实dao层也是可以被抽取的. 首先我们定义一个BaseController接口 ...
- 廖雪峰Java10加密与安全-5签名算法-2DSA签名算法
DSA DSA:Digital Signature Algorithm,使用EIGamal数字签名算法,和RSA数字签名相比,DSA更快. DSA只能配合SHA使用: SHA1withDSA SHA2 ...
- Autoware显示用户界面细节
https://blog.csdn.net/jianxuezixuan/article/details/86015224
- Cesium实现背景透明的方法
前言 今天有人在Cesium实验室QQ群里问如何把地球背景做成透明的,当时我以为Cesium比较复杂的渲染机制可能即使context设置了alpha属性也未必能透明,所以和同学说可能得改Cesium代 ...
- [code]图像亮度调整enhancement
//draft 2013.9 //F=X2/u; ////远处细节被淹没. 亮的地方增亮明显,暗的地方更暗. 不可取. // CvScalar rgb; // rgb=cvAvg(src); //fo ...