桌面 透明 三角形 分层窗口 DX

  1 //桌面 透明 三角形 分层窗口 DX
  2 //IDirect3DSurface9 GetDC  UpdateLayeredWindow
  3
  4 #include <Windows.h>
  5 #include <mmsystem.h>
  6 #include <d3dx9.h>
  7 #pragma warning( disable : 4996 )
  8 #include <strsafe.h>
  9 #pragma warning( default : 4996 )
 10
 11 //include path $(DXSDK_DIR)Include;
 12 //library path $(DXSDK_DIR)Lib\x86
 13 //library d3dx9.lib d3d9.lib Winmm.lib
 14
 15
 16 LPDIRECT3D9             g_pD3D = NULL;
 17 LPDIRECT3DDEVICE9       g_pd3dDevice = NULL;
 18 LPDIRECT3DVERTEXBUFFER9 g_pVB = NULL;
 19
 20 HWND g_hWnd = NULL;
 21 IDirect3DSurface9*        g_pkRenderTarget = NULL;
 22 IDirect3DSurface9*        g_pkOffscreenPlainSurface = NULL;
 23
 24 struct CUSTOMVERTEX
 25 {
 26     FLOAT x, y, z;
 27     DWORD color;
 28 };
 29
 30 #define D3DFVF_CUSTOMVERTEX (D3DFVF_XYZ|D3DFVF_DIFFUSE)
 31
 32 HRESULT InitD3D(HWND hWnd)
 33 {
 34     if (NULL == (g_pD3D = Direct3DCreate9(D3D_SDK_VERSION)))
 35     {
 36         return E_FAIL;
 37     }
 38
 39     D3DPRESENT_PARAMETERS d3dpp;
 40     ZeroMemory(&d3dpp, sizeof(d3dpp));
 41     d3dpp.Windowed = TRUE;
 42     d3dpp.SwapEffect = D3DSWAPEFFECT_DISCARD;
 43     d3dpp.BackBufferFormat = D3DFMT_UNKNOWN;
 44
 45     if (FAILED(g_pD3D->CreateDevice(D3DADAPTER_DEFAULT, D3DDEVTYPE_HAL, hWnd, D3DCREATE_SOFTWARE_VERTEXPROCESSING, &d3dpp, &g_pd3dDevice)))
 46     {
 47         return E_FAIL;
 48     }
 49
 50     g_pd3dDevice->SetRenderState(D3DRS_CULLMODE, D3DCULL_NONE);
 51     g_pd3dDevice->SetRenderState(D3DRS_LIGHTING, FALSE);
 52
 53     return S_OK;
 54 }
 55
 56 HRESULT InitGeometry()
 57 {
 58     CUSTOMVERTEX g_Vertices[] =
 59     {
 60         { -1.0f, -1.0f, 0.0f, 0xffff0000, },
 61         { 1.0f, -1.0f, 0.0f, 0xff0000ff, },
 62         { 0.0f, 1.0f, 0.0f, 0xffffffff, },
 63     };
 64
 65     if (FAILED(g_pd3dDevice->CreateVertexBuffer(3 * sizeof(CUSTOMVERTEX), 0, D3DFVF_CUSTOMVERTEX, D3DPOOL_DEFAULT, &g_pVB, NULL)))
 66     {
 67         return E_FAIL;
 68     }
 69
 70     VOID* pVertices;
 71     if (FAILED(g_pVB->Lock(0, sizeof(g_Vertices), (void**)&pVertices, 0)))
 72     {
 73         return E_FAIL;
 74     }
 75     memcpy(pVertices, g_Vertices, sizeof(g_Vertices));
 76     g_pVB->Unlock();
 77
 78     return S_OK;
 79 }
 80
 81 VOID Cleanup()
 82 {
 83     if (g_pVB != NULL)
 84     {
 85         g_pVB->Release();
 86     }
 87     if (g_pd3dDevice != NULL)
 88     {
 89         g_pd3dDevice->Release();
 90     }
 91     if (g_pD3D != NULL)
 92     {
 93         g_pD3D->Release();
 94     }
 95 }
 96
 97 VOID SetupMatrices()
 98 {
 99     D3DXMATRIXA16 matWorld;
100     UINT iTime = timeGetTime() % 1000;
101     FLOAT fAngle = iTime * (2.0f * D3DX_PI) / 1000.0f;
102     D3DXMatrixRotationY(&matWorld, fAngle);
103     g_pd3dDevice->SetTransform(D3DTS_WORLD, &matWorld);
104
105     D3DXVECTOR3 vEyePt(0.0f, 3.0f, -5.0f);
106     D3DXVECTOR3 vLookatPt(0.0f, 0.0f, 0.0f);
107     D3DXVECTOR3 vUpVec(0.0f, 1.0f, 0.0f);
108     D3DXMATRIXA16 matView;
109     D3DXMatrixLookAtLH(&matView, &vEyePt, &vLookatPt, &vUpVec);
110     g_pd3dDevice->SetTransform(D3DTS_VIEW, &matView);
111
112     D3DXMATRIXA16 matProj;
113     D3DXMatrixPerspectiveFovLH(&matProj, D3DX_PI / 4, 1.0f, 1.0f, 100.0f);
114     g_pd3dDevice->SetTransform(D3DTS_PROJECTION, &matProj);
115
116 }
117
118 VOID Render()
119 {
120
121     RECT kRect;
122     GetWindowRect(g_hWnd, &kRect);
123
124     UINT uiWndWidth = kRect.right - kRect.left;
125     UINT uiWndHeight = kRect.bottom - kRect.top;
126
127     if (!g_pkOffscreenPlainSurface)
128     {
129         g_pd3dDevice->CreateOffscreenPlainSurface(uiWndWidth, uiWndHeight, D3DFMT_X8R8G8B8, D3DPOOL_SYSTEMMEM, &g_pkOffscreenPlainSurface, 0);
130         g_pd3dDevice->CreateRenderTarget(uiWndWidth, uiWndHeight, D3DFMT_X8R8G8B8, D3DMULTISAMPLE_NONE, 0, true, &g_pkRenderTarget, 0);
131     }
132     else
133     {
134         D3DSURFACE_DESC kDesc;
135         g_pkOffscreenPlainSurface->GetDesc(&kDesc);
136
137         if (kDesc.Width != uiWndWidth || kDesc.Width != uiWndHeight)
138         {
139             g_pkOffscreenPlainSurface->Release();
140             g_pkRenderTarget->Release();
141             g_pd3dDevice->CreateOffscreenPlainSurface(uiWndWidth, uiWndHeight, D3DFMT_X8R8G8B8, D3DPOOL_SYSTEMMEM, &g_pkOffscreenPlainSurface, 0);
142             g_pd3dDevice->CreateRenderTarget(uiWndWidth, uiWndHeight, D3DFMT_X8R8G8B8, D3DMULTISAMPLE_NONE, 0, true, &g_pkRenderTarget, 0);
143         }
144     }
145
146     if (!g_pkOffscreenPlainSurface || !g_pkRenderTarget)
147     {
148         return;
149     }
150
151     HRESULT hr = g_pd3dDevice->SetRenderTarget(0, g_pkRenderTarget);
152     g_pd3dDevice->Clear(0, NULL, D3DCLEAR_TARGET, D3DCOLOR_XRGB(0, 0, 0), 1.0f, 0);
153
154     if (SUCCEEDED(g_pd3dDevice->BeginScene()))
155     {
156         SetupMatrices();
157
158         g_pd3dDevice->SetStreamSource(0, g_pVB, 0, sizeof(CUSTOMVERTEX));
159         g_pd3dDevice->SetFVF(D3DFVF_CUSTOMVERTEX);
160         g_pd3dDevice->DrawPrimitive(D3DPT_TRIANGLESTRIP, 0, 1);
161
162         g_pd3dDevice->EndScene();
163     }
164
165     g_pd3dDevice->Present(NULL, NULL, NULL, NULL);
166
167     hr = g_pd3dDevice->GetRenderTargetData(g_pkRenderTarget, g_pkOffscreenPlainSurface);
168
169     HDC hDC = 0;
170     //g_pkRenderTarget->GetDC(&hDC);
171     g_pkOffscreenPlainSurface->GetDC(&hDC);
172
173     POINT kPoint = { 0, 0 };
174     SIZE kSize = { uiWndWidth, uiWndHeight };
175
176     BLENDFUNCTION kBlend;
177     kBlend.AlphaFormat = AC_SRC_ALPHA;
178     kBlend.SourceConstantAlpha = 255;
179     kBlend.BlendFlags = 0;
180     kBlend.BlendOp = AC_SRC_OVER;
181
182     UpdateLayeredWindow(g_hWnd, 0, &kPoint, &kSize, hDC, &kPoint, 0, &kBlend, ULW_ALPHA);
183
184     g_pkOffscreenPlainSurface->ReleaseDC(hDC);
185     //g_pkRenderTarget->ReleaseDC(hDC);
186 }
187
188 LRESULT WINAPI MsgProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam)
189 {
190     switch (msg)
191     {
192     case WM_DESTROY:
193         Cleanup();
194         PostQuitMessage(0);
195         return 0;
196     }
197
198     return DefWindowProc(hWnd, msg, wParam, lParam);
199 }
200
201 INT WINAPI wWinMain(HINSTANCE hInst, HINSTANCE, LPWSTR, INT)
202 {
203     UNREFERENCED_PARAMETER(hInst);
204
205     WNDCLASSEX wc =
206     {
207         sizeof(WNDCLASSEX), CS_CLASSDC, MsgProc, 0L, 0L, GetModuleHandle(NULL), NULL, NULL, NULL, NULL, L"D3D Tutorial", NULL
208     };
209     RegisterClassEx(&wc);
210
211     g_hWnd = CreateWindowEx(WS_EX_LAYERED, L"D3D Tutorial", L"D3D Tutorial 03: Matrices", WS_POPUP | WS_THICKFRAME, 100, 100, 512, 512, NULL, NULL, wc.hInstance, NULL);
212
213     if (SUCCEEDED(InitD3D(g_hWnd)))
214     {
215         if (SUCCEEDED(InitGeometry()))
216         {
217             ShowWindow(g_hWnd, SW_SHOWDEFAULT);
218             UpdateWindow(g_hWnd);
219
220             MSG msg;
221             ZeroMemory(&msg, sizeof(msg));
222             while (msg.message != WM_QUIT)
223             {
224                 if (PeekMessage(&msg, NULL, 0U, 0U, PM_REMOVE))
225                 {
226                     TranslateMessage(&msg);
227                     DispatchMessage(&msg);
228                 }
229                 else
230                 {
231                     Render();
232                 }
233             }
234         }
235     }
236
237     UnregisterClass(L"D3D Tutorial", wc.hInstance);
238     return 0;
239 }
时间: 2024-10-03 15:33:11

桌面 透明 三角形 分层窗口 DX的相关文章

点击弹出居中带有透明遮罩层窗口

点击弹出居中带有透明遮罩层窗口:本章节介绍一下如何点击一个按钮实现弹出一个居中窗口,并且此窗口带有半透明的遮罩层效果,此效果在当下比较流行,当然还有更为复杂的实现方式,当然效果也更为绚丽,下面介绍的代码能够简单实现此效果.代码如下: <!DOCTYPE html> <html> <head> <meta charset=" utf-8"> <meta name="author" content="htt

第二十篇:在SOUI中使用分层窗口

从Windows 2K开始,MS为UI开发引入了分层窗口这一窗口风格.使用分层窗口,应用程序的主窗口可以是半透明,也可以是逐点半透明(即每一个像素点的透明度可以不同). 可以说,正是因为有了分层窗口,在Windows上开发的应用程序的UI才真正炫起来. 在UI的主窗口上加一个分层窗口的风格对于一个稍有点UI开发经验的程序员来说是非常简单的,本篇要说的是在SOUI的窗口系统中实现SOUI的分层窗口. 正如使用系统的窗口已经可以实现很漂亮的UI,我们还是会需要DirectUI这样的UI开发技术:有了

android 桌面透明

目录(?)[-] public void setWallpaperOffsetSteps float xStep float yStep Parameters public void setWallpaperOffsets IBinder windowToken float xOffset float yOffset Parameters 在Android应用开发中,使用系统桌面背景作为应用的背景,需要把应用的背景设置为透明背景,然后设置窗口的属性为FLAG_SHOW_WALLPAPER即可显示

Ubuntu启用3D桌面和更多的窗口动画

Ubuntu(确切的说是Ubuntu天朝定制版简称优麒麟)才是我最早接触的一个Linux发行,比较搞笑的是,那个时候我还坐在网吧玩星际2. 刚开始玩的时候,尤其喜欢优麒麟那个窗口动画以及在切换的时候那些特效和3D桌面还有像苹果机上的Docky,切来换去的骚包得很.当然,现在也还是喜欢Docky. 要启用3D桌面,过程是很简单的. 注: 无论是3D桌面还是窗口扭曲的动画特效,kde桌面环境都已提供.而在unity桌面环境还需要手动配置才行.为了更好的折腾这些,切换到闭源显卡驱动(闭源驱动可以在设置

Windows 10设置桌面图标间距、窗口的背景颜色、选中文字的背景颜色

Windows 10取消了“高级外观设置”(或者叫“窗口颜色和外观”设置),想调整一些参数只能进注册表了. 按Win+R,然后输入regedit进入注册表编辑器. 桌面图标间距 找到这里:HKEY_CURRENT_USER\Control Panel\Desktop\WindowMetrics 桌面图标水平间距: IconSpacing,默认值大概是-1125,想缩小间距就改大一些,比如-800. 桌面图标垂直间距: IconVerticalSpacing,同上. 窗口的背景颜色 找到这里:HK

css实现的透明三角形

css实现下图样式,具体像素值记不住了,很好设置,html code (2014百度秋招面试题): <div id="demo"></div>   分析:这个样式的关键就在三角形和三角形实现了之后的变成只有个边框的三角形.利用元素的:after和:before伪元素(请自动忽略低版本IE). 思想:先实现个正方形,在实现个三角形层,放在右上角,然后再实现一个透明的三角形覆盖黑色三角形的内部,只留边框. 1 <!DOCTYPE html> 2 <

给kalilinux桌面添加系统监视窗口

其实原理很简单就是用到conky manager Conky是一种自由软件,用于X视窗系统的系统监视器,可以在FreeBSD.OpenBSD和各种Linux发布上使用的自由软件[2].Conky具有很高的可配置性,可以监视许多系统参数,如:CPU.内存.标签页.硬盘使用情况等状态:各种硬件的温度:系统的进程(top):网络状态:电池电量:系统信息和邮件收发:各种音乐播放器MPD.XMMS2.BMPx.Audacious)的控制 先下载conky manager 32位dl.dropbox.com

Win7远程桌面全屏及窗口模式切换

以下整理常规的切换组合键,不同的电脑可能有不同的快捷键(有些笔记本电脑甚至没有相应的键值):①台式机:ctrl+alt+break 组合键.②CTRL+ALT+PAGEDOWN 组合键.③有的笔记本没有break键,可以尝试加载Fn键.Ctrl + Alt + Fn + P 组合键.④也有的笔记本电脑可以使用 Fn+Ctrl+Alt+END 组合键.⑤比如联想Y系列笔记本可以用Fn+Alt+Break(其中Break键在F10功能键上)⑥也可以尝试使用Ctrl + Alt + Pause(Pau

winserver2012远程桌面进入只有CMD窗口,无桌面解决方法

原因:.net framework4.5是Windows server图形化界面的基础,系统还原时只装了核心模式core,系统没有了图形界面当然只有cmd了 解决方法:使用dism命令需要将核心模式core 变回完整模式 Full,命令如下↓↓↓ Dism /online /enable-feature /all /featurename:Server-Gui-Mgmt /featurename:Server-Gui-Shell /featurename:ServerCore-FullServe