当前位置:编程学习 > VC++ >>

[Visual C++]游戏开发笔记三十 DirectX11 2D纹理映射知识全攻略

 

本节知识先是对DirectX11关于2D纹理映射方面基础知识的一个讲解,然后通过一个demo的创建过程来将学到的理论知识付诸实践。

 

 

 

一、引言

 

 

在之前我们提到过,纹理实际上就是映射到物体表面的数据。其实,纹理也可能是其他的一些信息片段,比如用于映射的常规映射值,用于控制透明度的alpha值,等等。

通常情况下,纹理是通过一个叫做纹理映射的过程来映射一幅图像到表面上的颜色值,这种功能能显著地增加所绘制场景的细腻感和真实感。

纹理和游戏开发中需要的其他数据一样,通常都是在运行时加载的。由于纹理是Direct3D重要的组成的部分,微软为我们提供了众多功能强大而丰富的Direct3D内建的函数,来处理纹理相关的操作。

 

 

 

 

二、基础知识讲解

 

 

 

 

1.纹理的加载

 

在Direct3D11中,我们通常使用D3DX11CreateTextureFromFile函数用于从硬盘文件中加载纹理。这个函数支持非常丰富的图像格式,比如BMP,PNG,以及DDS。D3DX11CreateTextureFromFile函数拥有六个变量,具有以下的函数原型:

 

 

[cpp]
HRESULT D3DX11CreateTextureFromFile( 
 
ID3D11Device* pDevice, 
 
LPCTSTR pSrcFile, 
 
D3DX11_IMAGE_LOAD_INFO* pLoadInfo, 
 
ID3DX11ThreadPump* pPump, 
 
ID3D11Resource** ppTexture, 
 
HRESULT* pHResult 
 
); 

HRESULT D3DX11CreateTextureFromFile(

ID3D11Device* pDevice,

LPCTSTR pSrcFile,

D3DX11_IMAGE_LOAD_INFO* pLoadInfo,

ID3DX11ThreadPump* pPump,

ID3D11Resource** ppTexture,

HRESULT* pHResult

);


 

 

 

D3DX11CreateTextureFromFile函数的第一个的参数为ID3D11Device类型的指针变量。

第二个参数pSrcFile为被加载文件的文件路径和文件名。

第三个参数pLoadInfo为一个图形信息结构体。它为一个可选的参数,并允许我们通过指定CPU访问的标识、内部格式、宽度和高度来控制图像纹理的加载方式。

第四个参数pPump用于多线程加载纹理时的异步处理。

第五个参数ppTexture用是纹理对象被调用时这个函数创建出的地址。如果D3DX11CreateTextureFromFile函数调用成功,这个变量就会拥有一个现成的纹理供使用。

最后一个参数pHResult是指向线程返回值的指针。

 

 

若此线程的参数不为空,pHResult必须为一个有效的内存地址。在Direct3D中我们能够使用很多函数载入各种琳琅满目的图

像文件格式,下面我们对他们进行一个详细的列举:

 

Windows Bitmap (BMP)

Joint Photographic Expert Group—i.e., JPEG (JPG)

Portable Network Graphics (PNG)

Tagged Image Format (TIFF)

Graphics Interchange Format (GIF)

DirectDraw Surface (DDS)

Windows Media Player (WMP)

 

 

2.纹理接口

 

纹理接口通常用于管理一个特定类型的图像数据。目前Direct3D纹理接口主要有三种类型,他们分别是:

ID3D11Texture1D——用于1D或者条形的纹理

ID3D11Texture2D——用于2D数据,这也是最常用的纹理资源类型、

ID3D11Texture3D——用于表示3D数据的纹理资源类型

上述3种纹理资源类型都包含一个或者多个子资源。

而游戏开发中使用的大多数纹理类型基本上都为二维的,他们都需要转化为ID3D11Texture2D型资源后再使用。而这些子资源代表了纹理中不同的    MIP等级。

譬如Adobe’s Photoshop这类的图像编辑器是创造2D纹理的最得力帮手。

 

 

3. 纹理细节

 

在游戏开发的过程中,常常我们需要从加载的纹理中得到一些特定的信息,比如说维度或者像素格式。这时候隶属于ID3D11Texture2D中的GetDesc函数就可以派上用场了。这个函数的功能是为我们填充D3D11_TEXTURE2D_DESC结构体中的各种细节,从而通过这个结构体作为载体,有关的各类数据就一目了然了。

 

D3D11_TEXTURE2D_DESC是专用于2D纹理的纹理描述结构体家族中的一员。

对于其他的两个维度,Direct3D11为我们准备了D3D11_TEXTURE1D_DESC用于1D纹理,D3D11_TEXTURE3D_DESC用于3D纹理。

 

作为最常见的纹理,二维的D3D11_TEXTURE2D_DESC声明形式如下:

 

[cpp]
typedef struct D3D11_TEXTURE2D_DESC { 
 
UINT Width; 
 
UINT Height; 
 
UINT MipLevels; 
 
UINT ArraySize; 
 
DXGI_FORMAT Format; 
 
DXGI_SAMPLE_DESC SampleDesc; 
 
D3D11_USAGE Usage; 
 
UINT BindFlags; 
 
UINT CPUAccessFlags; 
 
UINT MiscFlags; 
 
} D3D11_TEXTURE2D_DESC; 

typedef struct D3D11_TEXTURE2D_DESC {

UINT Width;

UINT Height;

UINT MipLevels;

UINT ArraySize;

DXGI_FORMAT Format;

DXGI_SAMPLE_DESC SampleDesc;

D3D11_USAGE Usage;

UINT BindFlags;

UINT CPUAccessFlags;

UINT MiscFlags;

} D3D11_TEXTURE2D_DESC;


 

 

 

 

 

三、DirectX11 2D纹理映射demo的创建

 

 

 

 

这里,我们先介绍一下这个demo的组成结构:

如图,头文件有Dx11DemoBase.h以及Texture2DDemo.h

源文件有 Dx11DemoBase.cpp,Texture2DDemo.h以及main.cpp

 


 

 

 

 

 

在之前的TriangleDemo的基础上,我们再添加一个叫做TextureDemo的类,以及添加一个叫做colorMap_的D3D11ShaderResourceView类型的着色器资源视图和一个D3D11SamplerState类型的唤做colorMapSampler_ 的采样状态。

着色资源视图简单的来说是一个用于访问资源的对象。当我们加载纹理到内存中的时候,必须创建一个着色器资源视图来通过着色器获取数据,而这些数据会被绑定到输出程序集当中。着色器资源视图也有其他的作用,比如为DirectCompute提供异步运算时需要的数据,本节我们主要是介绍其在纹理方面的运用。ID3D11Texture2D代表数据的缓存,而着色器资源视图允许我们在着色器中查看这个缓存的各项数据。

采样器声明(sampler state)允许我们访问的纹理采样的状态信息。后面将对其做更多更详细的讲解。

TextureDemo类的头文件代码书写风格如下:

 

 

代码段一  TextureDemo.h 对TextureDemo类的轮廓书写

 

[cpp]
#ifndef _TEXTURE_2D_DEMO_H_  
#define _TEXTURE_2D_DEMO_H_  
 
#include"Dx11DemoBase.h"  
 
 
class TextureDemo : public Dx11DemoBase 

    public: 
        TextureDemo( ); 
        virtual ~TextureDemo( ); 
 
        bool LoadContent( ); 
        void UnloadContent( ); 
 
        void Update( float dt ); 
        void Render( ); 
 
    private: 
        ID3D11VertexShader* solidColorVS_; 
        ID3D11PixelShader* solidColorPS_; 
 
        ID3D11InputLayout* inputLayout_; 
        ID3D11Buffer* vertexBuffer_; 
 
        ID3D11ShaderResourceView* colorMap_; 
        ID3D11SamplerState* colorMapSampler_; 
}; 
 
#endif 

#ifndef _TEXTURE_2D_DEMO_H_
#define _TEXTURE_2D_DEMO_H_

#include"Dx11DemoBase.h"


class TextureDemo : public Dx11DemoBase
{
    public:
        TextureDemo( );
        virtual ~Tex

补充:软件开发 , Vc ,
CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,