D3D渲染到纹理

  1 #include <d3dx9.h>
2
3 //-----------------------------------------------------------------------------
4 // Desc: 全局变量
5 //-----------------------------------------------------------------------------
6 LPDIRECT3D9 g_pD3D = NULL; //Direct3D对象
7 LPDIRECT3DDEVICE9 g_pd3dDevice = NULL; //Direct3D设备对象
8 LPDIRECT3DVERTEXBUFFER9 g_pVB = NULL; //顶点缓冲区对象
9 LPDIRECT3DTEXTURE9 g_pTexture = NULL; //纹理对象
10
11 LPDIRECT3DTEXTURE9 g_pRender2Tex = NULL;
12 LPDIRECT3DSURFACE9 g_pRenderSur = NULL;
13 LPDIRECT3DSURFACE9 g_pBackupSur = NULL;
14
15 //-----------------------------------------------------------------------------
16 // Desc: 顶点结构
17 //-----------------------------------------------------------------------------
18 struct CUSTOMVERTEX
19 {
20 FLOAT x, y, z; //顶点位置
21 FLOAT u,v ; //顶点纹理坐标
22 };
23 #define D3DFVF_CUSTOMVERTEX (D3DFVF_XYZ|D3DFVF_TEX1)
24
25
26 //-----------------------------------------------------------------------------
27 // Desc: 设置变换矩阵
28 //-----------------------------------------------------------------------------
29 VOID SetupMatrices()
30 {
31 //创建并设置世界矩阵
32 D3DXMATRIXA16 matWorld;
33 D3DXMatrixIdentity( &matWorld );
34 g_pd3dDevice->SetTransform( D3DTS_WORLD, &matWorld );
35
36 //创建并设置观察矩阵
37 D3DXVECTOR3 vEyePt( 0.0f, 0.0f, -10 );
38 D3DXVECTOR3 vLookatPt( 0.0f, 0.0f, 0.0f );
39 D3DXVECTOR3 vUpVec( 0.0f, 1.0f, 0.0f );
40 D3DXMATRIXA16 matView;
41 D3DXMatrixLookAtLH( &matView, &vEyePt, &vLookatPt, &vUpVec );
42 g_pd3dDevice->SetTransform( D3DTS_VIEW, &matView );
43
44 //创建并设置投影矩阵
45 D3DXMATRIXA16 matProj;
46 D3DXMatrixPerspectiveFovLH( &matProj, D3DX_PI/4, 1.0f, 1.0f, 100.0f );
47 g_pd3dDevice->SetTransform( D3DTS_PROJECTION, &matProj );
48 }
49
50
51 //-----------------------------------------------------------------------------
52 // Desc: 初始化Direct3D
53 //-----------------------------------------------------------------------------
54 HRESULT InitD3D( HWND hWnd )
55 {
56 //创建Direct3D对象, 该对象用于创建Direct3D设备对象
57 if( NULL == ( g_pD3D = Direct3DCreate9( D3D_SDK_VERSION ) ) )
58 return E_FAIL;
59
60 //设置D3DPRESENT_PARAMETERS结构, 准备创建Direct3D设备对象
61 D3DPRESENT_PARAMETERS d3dpp;
62 ZeroMemory( &d3dpp, sizeof(d3dpp) );
63 d3dpp.Windowed = TRUE;
64 d3dpp.SwapEffect = D3DSWAPEFFECT_DISCARD;
65 d3dpp.BackBufferFormat = D3DFMT_X8R8G8B8;
66
67 //创建Direct3D设备对象
68 if( FAILED( g_pD3D->CreateDevice( D3DADAPTER_DEFAULT, D3DDEVTYPE_HAL, hWnd,
69 D3DCREATE_SOFTWARE_VERTEXPROCESSING,
70 &d3dpp, &g_pd3dDevice ) ) )
71 {
72 return E_FAIL;
73 }
74
75 //禁用照明效果
76 g_pd3dDevice->SetRenderState( D3DRS_LIGHTING, FALSE );
77
78 //设置变换矩阵
79 SetupMatrices();
80
81 HRESULT hr = g_pd3dDevice->CreateTexture(256,256,1,D3DUSAGE_RENDERTARGET,
82 D3DFMT_X8R8G8B8, D3DPOOL_DEFAULT, &g_pRender2Tex, NULL);
83 if (FAILED(hr))
84 {
85 return E_FAIL;
86 }
87 g_pRender2Tex->GetSurfaceLevel(0, &g_pRenderSur);
88
89 return S_OK;
90 }
91
92
93 //-----------------------------------------------------------------------------
94 // Desc: 创建场景图形
95 //-----------------------------------------------------------------------------
96 HRESULT InitGriphics()
97 {
98 //创建纹理对象
99 if( FAILED( D3DXCreateTextureFromFile( g_pd3dDevice, L"texture.jpg", &g_pTexture ) ) )
100 {
101 MessageBox(NULL, L"创建纹理失败", L"Texture.exe", MB_OK);
102 return E_FAIL;
103 }
104
105 //顶点数据
106 CUSTOMVERTEX g_Vertices[] =
107 {
108 { -3, -3, 0.0f, 0.0f, 1.0f},
109 { -3, 3, 0.0f, 0.0f, 0.0f},
110 { 3, -3, 0.0f, 1.0f, 1.0f},
111 { 3, 3, 0.0f, 1.0f, 0.0f }
112
113 };
114
115 //创建顶点缓冲区
116 if( FAILED( g_pd3dDevice->CreateVertexBuffer( 4*sizeof(CUSTOMVERTEX),
117 0, D3DFVF_CUSTOMVERTEX,
118 D3DPOOL_MANAGED, &g_pVB,NULL ) ) )
119 {
120 return E_FAIL;
121 }
122
123 //填充顶点缓冲区
124 VOID* pVertices;
125 if( FAILED( g_pVB->Lock( 0, sizeof(g_Vertices), (void**)&pVertices, 0 ) ) )
126 return E_FAIL;
127 memcpy( pVertices, g_Vertices, sizeof(g_Vertices) );
128 g_pVB->Unlock();
129
130 return S_OK;
131 }
132
133
134 //-----------------------------------------------------------------------------
135 // Desc: 释放创建的对象
136 //-----------------------------------------------------------------------------
137 VOID Cleanup()
138 {
139 //释放纹理对象
140 if( g_pTexture != NULL )
141 g_pTexture->Release();
142
143 //释放顶点缓冲区对象
144 if( g_pVB != NULL )
145 g_pVB->Release();
146
147 //释放Direct3D设备对象
148 if( g_pd3dDevice != NULL )
149 g_pd3dDevice->Release();
150
151 //释放Direct3D对象
152 if( g_pD3D != NULL )
153 g_pD3D->Release();
154 }
155
156
157 //-----------------------------------------------------------------------------
158 // Desc: 渲染图形
159 //-----------------------------------------------------------------------------
160 VOID Render()
161 {
162 //清空后台缓冲区
163 g_pd3dDevice->Clear( 0, NULL, D3DCLEAR_TARGET, D3DCOLOR_XRGB(45, 50, 170), 1.0f, 0 );
164
165 //开始在后台缓冲区绘制图形
166 if( SUCCEEDED( g_pd3dDevice->BeginScene() ) )
167 {
168 g_pd3dDevice->GetRenderTarget(0, &g_pBackupSur);
169 g_pd3dDevice->SetRenderTarget(0, g_pRenderSur);
170
171 /*RTT*/
172 g_pd3dDevice->Clear( 0, NULL, D3DCLEAR_TARGET, D3DCOLOR_XRGB(0, 0, 0), 1.0f, 0 );
173 g_pd3dDevice->SetTexture( 0, g_pTexture ); //设置纹理
174 g_pd3dDevice->SetStreamSource( 0, g_pVB, 0, sizeof(CUSTOMVERTEX) );
175 g_pd3dDevice->SetFVF( D3DFVF_CUSTOMVERTEX );
176 g_pd3dDevice->DrawPrimitive( D3DPT_TRIANGLESTRIP, 0, 2);
177
178 D3DXSaveTextureToFileA("tt.tga", D3DXIFF_TGA, g_pRender2Tex, NULL);
179
180 /*真是场景*/
181 g_pd3dDevice->SetRenderTarget(0, g_pBackupSur);
182
183 g_pd3dDevice->SetTexture( 0, g_pTexture ); //设置纹理
184 g_pd3dDevice->SetStreamSource( 0, g_pVB, 0, sizeof(CUSTOMVERTEX) );
185 g_pd3dDevice->SetFVF( D3DFVF_CUSTOMVERTEX );
186 g_pd3dDevice->DrawPrimitive( D3DPT_TRIANGLESTRIP, 0, 2);
187
188
189 //结束在后台缓冲区绘制图形
190 g_pd3dDevice->EndScene();
191 }
192
193 //将在后台缓冲区绘制的图形提交到前台缓冲区显示
194 g_pd3dDevice->Present( NULL, NULL, NULL, NULL );
195 }
196
197
198 //-----------------------------------------------------------------------------
199 // Desc: 消息处理
200 //-----------------------------------------------------------------------------
201 LRESULT WINAPI MsgProc( HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam )
202 {
203 switch( msg )
204 {
205 case WM_DESTROY:
206 Cleanup();
207 PostQuitMessage( 0 );
208 return 0;
209 }
210
211 return DefWindowProc( hWnd, msg, wParam, lParam );
212 }
213
214
215
216 //-----------------------------------------------------------------------------
217 // Desc: 入口函数
218 //-----------------------------------------------------------------------------
219 INT WINAPI WinMain( HINSTANCE hInst, HINSTANCE, LPSTR, INT )
220 {
221
222 //注册窗口类
223 WNDCLASSEX wc = { sizeof(WNDCLASSEX), CS_CLASSDC, MsgProc, 0L, 0L,
224 GetModuleHandle(NULL), NULL, NULL, NULL, NULL,
225 L"ClassName", NULL };
226 RegisterClassEx( &wc );
227
228 //创建窗口
229 HWND hWnd = CreateWindow( L"ClassName", L"纹理影射基础",
230 WS_OVERLAPPEDWINDOW, 200, 100, 800, 600,
231 GetDesktopWindow(), NULL, wc.hInstance, NULL );
232
233 //初始化Direct3D
234 if( SUCCEEDED( InitD3D( hWnd ) ) )
235 {
236 //创建场景图形
237 if( SUCCEEDED( InitGriphics() ) )
238 {
239 //显示窗口
240 ShowWindow( hWnd, SW_SHOWDEFAULT );
241 UpdateWindow( hWnd );
242
243 //进入消息循环
244 MSG msg;
245 ZeroMemory( &msg, sizeof(msg) );
246 while( msg.message!=WM_QUIT )
247 {
248 if( PeekMessage( &msg, NULL, 0U, 0U, PM_REMOVE ) )
249 {
250 TranslateMessage( &msg );
251 DispatchMessage( &msg );
252 }
253 else
254 {
255 Render(); //渲染图形
256 }
257 }
258 }
259 }
260
261 UnregisterClass( L"ClassName", wc.hInstance );
262 return 0;
263 }

Windows D3D渲染到纹理的更多相关文章

  1. 使用D3D渲染YUV视频数据

    源代码下载 在PC机上,对于YUV格式的视频如YV12,YUY2等的显示方法,一般是采用DIRECTDRAW,使用显卡的OVERLAY表面显示.OVERLAY技术主要是为了解决在PC上播放VCD而在显 ...

  2. 什么是渲染目标(render target)&& 渲染到纹理(Render To Texture, RTT)详解

    渲染到纹理(Render To Texture, RTT)详解 RTT是现在很多特效里面都会用到的一项很基本的技术,实现起来很简单,也很重要.但是让人不解的是网上搜索了半天只找到很少的文章说这个事儿, ...

  3. 使用D3D渲染YUV视频数据<转>

    源代码下载 转载地址:http://blog.csdn.net/dengzikun/article/details/5824874 源码地址:http://download.csdn.net/down ...

  4. NeHe OpenGL教程 第三十六课:从渲染到纹理

    转自[翻译]NeHe OpenGL 教程 前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线 ...

  5. CSharpGL(42)借助帧缓存实现渲染到纹理(RenderToTexture)

    CSharpGL(42)借助帧缓存实现渲染到纹理(RenderToTexture) 渲染到纹理(Render To Texture)是实现很多OpenGL高级效果的一个基础.本文记录了如何用CShar ...

  6. 一步一步学RenderMonkey(5)--渲染到纹理(RTT) 【转】

    转载请注明出处:  http://blog.csdn.net/tianhai110 渲染到纹理: 新建一个空effect; 添加渲染目标纹理, Add Texture-> Add Render ...

  7. Directx11教程(65) 渲染到纹理

    原文:Directx11教程(65) 渲染到纹理     通常情况下,我们的render target都是后缓冲,但也可以把render target设置为一个2d 纹理,然后再通过贴图的方式,把这个 ...

  8. D3D三层Texture纹理经像素着色器实现渲染YUV420P

    简单记录一下这两天用Texture实现渲染YUV420P的一些要点. 在视频播放的过程中,有的时候解码出来的数据是YUV420P的.表面(surface)通过设置参数是可以渲染YUV420P的,但Te ...

  9. D3D渲染流程--转载

    http://www.cnblogs.com/ixnehc/articles/1282350.html 先从最基础的写起吧,关于Device的渲染流程. D3D9的Device就是D3D给我们提供的一 ...

  10. m3u8编码视频webgl、threejs渲染视频纹理demo

    <!DOCTYPE html> <html> <head> <meta charset=utf-8 /> <title>fz-live< ...

随机推荐

  1. selenium定位元素不稳定的解决方式

    1 显示的进行时间上的等待 2 能够查到元素的时候可以使用js注入,单击 element = driver.find_element(*loc) driver.execute_script(" ...

  2. Spring基本概述

    Spring是一个开源框架,官方网站是http://spring.io/,Spring是2003年兴起的一个轻量级的Java开发框架,由lnterface21公司的JavaEE专家RodJohnson ...

  3. airtest截图后放在allure报告里面。

    #需要导入的包 from airtest.aircv import * from airtest.aircv.utils import cv2_2_pil screen1 = G.DEVICE.sna ...

  4. HIVE- concat方法

    (1)concat_ws() select user ,concat_ws(';' , collect_set(cast(amt as string))) as amt from table grou ...

  5. 教你如何自己搭环境部署华为FusionCompute虚拟化系统

    https://www.bilibili.com/video/BV1iy4y177f4?p=10 实用的干货快先码起来,说不定以后会用到哟

  6. Selenium私房菜系列4 -- Selenium IDE的使用【QQ】

    前面说过,Selenium IDE是Firefox的一个插件,是可以进行脚本录制以及案例转换,所以Selenium IDE+Firebug会成为你日后写测试案例的两大助手(IE下可以使用Seleniu ...

  7. 快速傅里叶变换详解(FFT)

    自己也看了几篇博客,但是对我这种不擅长推导小白来说还是有一点困难,所以自己也写一篇博客也为像我一样的小白提供思路.以下内容包含各种LaTeX渲染,如果哪里有错误欢迎大家评论留言,或者添加本人qq:14 ...

  8. day11 事件相关笔记

    day11 事件上 事件的概述 事件是指代一个东西的操作被另外一个东西监听以后的一个过程(事件),这个过程可以完成对应的操作(处理函数)事件监听器是一个标准的观察者模式(observer)也被称为订阅 ...

  9. Mac 启动转换助理 安装 win10

    Mac 启动转换助理 安装 win10 Mac的处理器 是Inter芯 才有该功能 打开启动转换助理/Bootcamp 设置分区大小 win10安装完成后 在左侧的此电脑中找到咱们的Boot Camp ...

  10. Raize

    Raize.v5和Raize.v6 本人在windows10下装有delphi7和delphi2010,安装好Raize.v6后,两个版本delphi的控件页都找不到Raize控件,即使想编译相应的D ...