diff options
author | Wolfgang Draxinger <Wolfgang.Draxinger@draxit.de> | 2015-01-24 23:20:28 +0100 |
---|---|---|
committer | Wolfgang Draxinger <Wolfgang.Draxinger@draxit.de> | 2015-01-24 23:20:28 +0100 |
commit | 6521285ecab5529adbf716f21bc867a64a224779 (patch) | |
tree | 5affb3f09cc5014a73d74c3d6ff4a9e2c32f64c4 /test | |
parent | b8a7bb6d6b75ab708a9b0834183c91cc1c054b6c (diff) | |
download | wglarb-6521285ecab5529adbf716f21bc867a64a224779.tar.gz wglarb-6521285ecab5529adbf716f21bc867a64a224779.tar.bz2 |
rewrote mutex creation to not use goto
Diffstat (limited to 'test')
-rw-r--r-- | test/Makefile | 2 | ||||
-rw-r--r-- | test/layered.c | 34 |
2 files changed, 33 insertions, 3 deletions
diff --git a/test/Makefile b/test/Makefile index 2b5a0b7..94f3058 100644 --- a/test/Makefile +++ b/test/Makefile @@ -1,5 +1,5 @@ TARGET64=x86_64-w64-mingw32 -TARGET32=i686-w64-mingw32 +TARGET32=mingw32 CC64=-$(TARGET64)-gcc CC32=-$(TARGET32)-gcc CFLAGS=-static-libgcc -static-libstdc++ -I.. diff --git a/test/layered.c b/test/layered.c index f28c677..3c359e1 100644 --- a/test/layered.c +++ b/test/layered.c @@ -24,6 +24,11 @@ procp_DwmEnableBlurBehindWindow impl_DwmEnableBlurBehindWindow = NULL; typedef HRESULT (WINAPI *procp_DwmExtendFrameIntoClientArea)(HWND, MARGINS const*);
procp_DwmExtendFrameIntoClientArea impl_DwmExtendFrameIntoClientArea = NULL;
+typedef HRESULT (WINAPI *procp_DwmGetColorizationColor)(DWORD*,BOOL*);
+procp_DwmGetColorizationColor impl_DwmGetColorizationColor = NULL;
+
+float bg_color[3];
+
int win_width;
int win_height;
@@ -199,8 +204,27 @@ BOOL cursor_needs_setting = TRUE; LRESULT CALLBACK ViewProc(HWND hWnd,UINT uMsg,WPARAM wParam,LPARAM lParam)
{
+ DWORD bgcol;
+ BOOL opaque;
switch(uMsg)
{
+ case WM_CREATE:
+ case WM_DWMNCRENDERINGCHANGED:
+ if( impl_DwmGetColorizationColor ) {
+ impl_DwmGetColorizationColor(&bgcol, &opaque);
+ if( opaque ) {
+ bg_color[0] = (float)GetRValue(bgcol)/255.f;
+ bg_color[1] = (float)GetGValue(bgcol)/255.f;
+ bg_color[2] = (float)GetBValue(bgcol)/255.f;
+ }
+ else {
+ bg_color[0] = 0.f;
+ bg_color[1] = 0.f;
+ bg_color[2] = 0.f;
+ }
+ }
+ break;
+
case WM_MOUSELEAVE:
cursor_needs_setting = TRUE;
break;
@@ -227,7 +251,6 @@ LRESULT CALLBACK ViewProc(HWND hWnd,UINT uMsg,WPARAM wParam,LPARAM lParam) return DefWindowProc(hWnd,uMsg,wParam,lParam);
}
-
void display(HWND hWnd)
{
HDC hDC = GetDC(hWnd);
@@ -243,7 +266,11 @@ void display(HWND hWnd) rect.right,
rect.bottom);
- glClearColor(0., 0., 0., 0.);
+ glClearColor(
+ bg_color[0],
+ bg_color[1],
+ bg_color[2],
+ 0.);
glClearDepth(1.);
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
@@ -309,6 +336,9 @@ int main(int argc, char *argv[]) *(PROC*)(&impl_DwmExtendFrameIntoClientArea) =
GetProcAddress(hDwmAPI_DLL, "DwmExtendFrameIntoClientArea");
+
+ *(PROC*)(&impl_DwmGetColorizationColor) =
+ GetProcAddress(hDwmAPI_DLL, "DwmGetColorizationColor");
}
}
|