dx9学习2

简介:
#include <d3d9.h> 
 
LPDIRECT3D9 g_pD3D = NULL; 
LPDIRECT3DDEVICE9 g_pD3DDevice = NULL; 
LPDIRECT3DVERTEXBUFFER9 g_pVertexBuffer = NULL;  // 顶点buffer  
 
 
struct  CUSTOMVERTEX 

  FLOAT x, y, z, rhw;     // 顶点变换位置.  
  DWORD colour;       // 顶点颜色.  
}; 
 
#define D3DFVF_CUSTOMVERTEX (D3DFVF_XYZRHW|D3DFVF_DIFFUSE) 
 
#define SafeRelease(pObject)  if (pObject != NULL) {pObject->Release(); pObject=NULL;} 
 
HRESULT InitialiseD3D(HWND hWnd) 

   //首先创建主要的D3D对象.如果创建成功我们将会得到一个指向IDirect3D9接口的指针  
  g_pD3D = Direct3DCreate9(D3D_SDK_VERSION); 
   if (g_pD3D == NULL) 
  { 
     return  E_FAIL; 
  } 
 
   //获取当前的显示模式  
  D3DDISPLAYMODE d3ddm; 
   if (FAILED(g_pD3D->GetAdapterDisplayMode(D3DADAPTER_DEFAULT, &d3ddm))) 
  { 
     return  E_FAIL; 
  } 
 
   //创建一个结构来保存我们设备的设置  
  D3DPRESENT_PARAMETERS d3dpp;    
  ZeroMemory(&d3dpp,  sizeof (d3dpp)); 
 
   //设置该结构体属性值  
   //我们想让我们的程序窗口化,并且设置了后缓冲的格式以匹配我们当前的显示模式  
  d3dpp.Windowed = TRUE; 
  d3dpp.SwapEffect    = D3DSWAPEFFECT_COPY; 
  d3dpp.PresentationInterval=D3DPRESENT_INTERVAL_DEFAULT; 
  d3dpp.BackBufferFormat = d3ddm.Format; 
 
   //创建一个Direct3D设备.  
   if (FAILED(g_pD3D->CreateDevice(D3DADAPTER_DEFAULT, D3DDEVTYPE_HAL, hWnd,    
    D3DCREATE_SOFTWARE_VERTEXPROCESSING, &d3dpp, &g_pD3DDevice))) 
  { 
     return  E_FAIL; 
  } 
 
   return  S_OK; 

 
HRESULT InitialiseVertexBuffer() 

  VOID* pVertices; 
 
   //存储矩形的每一个顶点和它的颜色  
  CUSTOMVERTEX cvVertices[] = 
  { 
    {250.0f, 100.0f, 0.5f, 1.0f, D3DCOLOR_XRGB(255, 0, 0),},   //顶点 1 - 红色  (250, 100)  
    {400.0f, 350.0f, 0.5f, 1.0f, D3DCOLOR_XRGB(0, 255, 0),},   //顶点 2 - 绿色  (400, 350)  
    {100.0f, 350.0f, 0.5f, 1.0f, D3DCOLOR_XRGB(0, 0, 255),},   //顶点 3 - 蓝色  (100, 350)  
  }; 
 
   //由设备创建顶点缓冲  
   if (FAILED(g_pD3DDevice->CreateVertexBuffer(3 *  sizeof (CUSTOMVERTEX), 
    0, D3DFVF_CUSTOMVERTEX, 
    D3DPOOL_DEFAULT, &g_pVertexBuffer,NULL))) 
  { 
     return  E_FAIL; 
  } 
 
   //得到一个指向顶点缓冲顶点的指针并锁定顶点缓冲  
   if (FAILED(g_pVertexBuffer->Lock(0,  sizeof (cvVertices), ( void **)&pVertices, 0))) 
  { 
     return  E_FAIL; 
  } 
 
   //将我们存储的顶点值拷贝到顶点缓冲  
  memcpy(pVertices, cvVertices,  sizeof (cvVertices)); 
 
   //解锁顶点缓冲  
  g_pVertexBuffer->Unlock(); 
 
   return  S_OK; 

 
void  Render() 

   if (g_pD3DDevice == NULL) 
  { 
     return
  } 
 
   //清除后缓冲为黑色  
  g_pD3DDevice->Clear(0, NULL, D3DCLEAR_TARGET, D3DCOLOR_XRGB(0, 0, 0), 1.0f, 0); 
 
   //场景开始  
  g_pD3DDevice->BeginScene(); 
 
 
   //渲染我们的矩形  
  g_pD3DDevice->SetStreamSource(0, g_pVertexBuffer,0,  sizeof (CUSTOMVERTEX)); 
  g_pD3DDevice->SetFVF(D3DFVF_CUSTOMVERTEX); 
  g_pD3DDevice->DrawPrimitive(D3DPT_TRIANGLELIST, 0, 1); 
 
 
   //场景结束  
  g_pD3DDevice->EndScene(); 
 
   //翻动前后缓冲以便后缓冲中渲染的一切能够显示在屏幕(前缓冲)上。  
  g_pD3DDevice->Present(NULL, NULL, NULL, NULL); 

 
void  CleanUp() 

  SafeRelease(g_pVertexBuffer); 
  SafeRelease(g_pD3DDevice); 
  SafeRelease(g_pD3D); 

 
void  GameLoop() 

   //进入游戏循环  
  MSG msg;    
  BOOL fMessage; 
 
  PeekMessage(&msg, NULL, 0U, 0U, PM_NOREMOVE); 
 
   while (msg.message != WM_QUIT) 
  { 
    fMessage = PeekMessage(&msg, NULL, 0U, 0U, PM_REMOVE); 
 
     if (fMessage) 
    { 
       //处理消息  
      TranslateMessage(&msg); 
      DispatchMessage(&msg); 
    } 
     else  
    { 
       //没有要处理的消息,所以渲染当前场景  
      Render(); 
    } 
 
  } 

 
//窗口消息处理  
LRESULT WINAPI WinProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam) 

   switch (msg) 
  { 
   case  WM_DESTROY: 
    PostQuitMessage(0); 
     return  0; 
     break
   case  WM_KEYUP:    
     switch  (wParam) 
    {    
     case  VK_ESCAPE: 
       //用户已经按了ESC键,所以退出  
      DestroyWindow(hWnd); 
       return  0; 
       break
    }    
     break
 
  } 
 
   return  DefWindowProc(hWnd, msg, wParam, lParam); 

 
//应用程序入口点  
INT WINAPI WinMain(HINSTANCE hInst, HINSTANCE, LPSTR, INT) 

   //注册窗口类  
  WNDCLASSEX wc = { sizeof (WNDCLASSEX), CS_CLASSDC, WinProc, 0L, 0L,    
    GetModuleHandle(NULL), NULL, NULL, NULL, NULL, 
     "DX Project 2" , NULL}; 
  RegisterClassEx(&wc); 
 
   //创建应用程序的窗口  
  HWND hWnd = CreateWindow( "DX Project 2" "www.andypike.com: Tutorial 2" ,    
    WS_OVERLAPPEDWINDOW, 50, 50, 500, 500, 
    GetDesktopWindow(), NULL, wc.hInstance, NULL); 
 
   //初始化 Direct3D  
   if (SUCCEEDED(InitialiseD3D(hWnd))) 
  {    
     //显示我们的窗体  
    ShowWindow(hWnd, SW_SHOWDEFAULT); 
    UpdateWindow(hWnd); 
 
     //初始化顶点缓冲  
     if (SUCCEEDED(InitialiseVertexBuffer())) 
    { 
       //启动游戏运行:进入游戏循环  
      GameLoop(); 
    } 
  } 
 
  CleanUp(); 
 
  UnregisterClass( "DX Project 2" , wc.hInstance); 
 
   return  0; 






 本文转自 xcf007 51CTO博客,原文链接: http://blog.51cto.com/xcf007/326024 ,如需转载请自行联系原作者
相关文章
|
机器学习/深度学习 人工智能 算法
【代数学作业1完整版-python实现GNFS一般数域筛】构造特定的整系数不可约多项式:涉及素数、模运算和优化问题
【代数学作业1完整版-python实现GNFS一般数域筛】构造特定的整系数不可约多项式:涉及素数、模运算和优化问题
454 0
|
编译器 Linux 数据库
【C进阶】文件操作(上)--(详解、非常适合基础入门学习)(上)
【C进阶】文件操作(上)--(详解、非常适合基础入门学习)(上)
139 0
|
11月前
|
缓存 负载均衡 应用服务中间件
Nginx七层(应用层)反向代理:HTTP反向代理proxy_pass篇
通过使用Nginx的反向代理功能,可以有效地提高Web应用的性能、安全性和可扩展性。配置过程中需要注意不同场景下的具体需求,如负载均衡、SSL终止和缓存策略等。正确配置和优化Nginx反向代理可以显著提升系统的整体表现。
1841 20
|
人工智能 编解码 算法
Stable Diffusion超详细教程!从0-1入门到进阶
本文提供了Stable Diffusion AI绘画工具的超详细入门到进阶教程,包括本地部署、界面基础、模型选择、ControlNet安装与使用,以及如何通过不断学习和调试提升使用效果。
Stable Diffusion超详细教程!从0-1入门到进阶
|
缓存 并行计算 算法
上帝视角看GPU(5):图形流水线里的不可编程单元
上帝视角看GPU(5):图形流水线里的不可编程单元
652 0
|
存储 安全 Java
Java一分钟之Java数据类型概览:基本类型与引用类型
【5月更文挑战第7天】本文概述了Java中的基本和引用数据类型,强调了理解它们对高效编程的重要性。基本类型包括数值、布尔和字符类型,而引用类型涉及类、接口、数组等。注意基本类型的精度损失和溢出问题,以及引用类型的空指针异常和内存泄漏。通过明确类型范围、使用包装类、空值检查和及时释放资源来避免这些问题。代码示例展示了基本类型和引用类型的使用。理解这些核心概念有助于编写更健壮的Java代码。
216 1
|
Linux 网络安全 数据库
openstack 部署单节点
在CentOS 7系统上,配置了一台拥有4核CPU、8GB内存和300GB磁盘的服务器,安装了OpenStack Trian版本。安装完成后,获取了OpenStack管理控制台的登录凭证(admin用户和密码),可访问IP地址192.168.200.249/dashboard进行登录。如果遇到问题,可能需要重新安装以确保纯净环境。
735 0
zookeeper应用场景二:分布式锁
zookeeper应用场景二:分布式锁
105 0
zookeeper应用场景二:分布式锁
|
存储 弹性计算 安全
OSS的网盘之路,最小化实现网盘分享
其实很多用户都知道OSS是非常适合用于作为网盘、附件系统的底层设施的,但是很多企业用户在沟通的过程中,其实没有很好的系统来支持OSS作为一个网盘去分发一些文件,例如企业像将介绍视频通过微信发布给有购买记录的客户,但是视频比较大也不方便直接通过微信发送视频,也不方便放到B站、优酷等视频平台中。 那么本文就介绍利用最小化资源实现OSS的网盘分享,让 ECS + OSS = 网盘。
1706 1
OSS的网盘之路,最小化实现网盘分享