|  |  | 
|  | /* | 
|  | * Copyright 2011 Google Inc. | 
|  | * | 
|  | * Use of this source code is governed by a BSD-style license that can be | 
|  | * found in the LICENSE file. | 
|  | */ | 
|  |  | 
|  | #include "SkRefCnt.h" | 
|  |  | 
|  | #ifndef SkWGL_DEFINED | 
|  | #define SkWGL_DEFINED | 
|  |  | 
|  | /** | 
|  | * Working with WGL extensions can be a pain. Among the reasons is that You must | 
|  | * have a GL context to get the proc addresses, but you want to use the procs to | 
|  | * create a context in the first place. So you have to create a dummy GL ctx to | 
|  | * get the proc addresses. | 
|  | * | 
|  | * This file helps by providing SkCreateWGLInterface(). It returns a struct of | 
|  | * function pointers that it initializes. It also has a helper function to query | 
|  | * for WGL extensions. It handles the fact that wglGetExtensionsString is itself | 
|  | * an extension. | 
|  | */ | 
|  |  | 
|  | #if !defined(WIN32_LEAN_AND_MEAN) | 
|  | #define WIN32_LEAN_AND_MEAN | 
|  | #define SK_LOCAL_LEAN_AND_MEAN | 
|  | #endif | 
|  | #include <windows.h> | 
|  | #if defined(SK_LOCAL_LEAN_AND_MEAN) | 
|  | #undef WIN32_LEAN_AND_MEAN | 
|  | #undef SK_LOCAL_LEAN_AND_MEAN | 
|  | #endif | 
|  |  | 
|  | #define SK_WGL_DRAW_TO_WINDOW                       0x2001 | 
|  | #define SK_WGL_ACCELERATION                         0x2003 | 
|  | #define SK_WGL_SUPPORT_OPENGL                       0x2010 | 
|  | #define SK_WGL_DOUBLE_BUFFER                        0x2011 | 
|  | #define SK_WGL_COLOR_BITS                           0x2014 | 
|  | #define SK_WGL_ALPHA_BITS                           0x201B | 
|  | #define SK_WGL_STENCIL_BITS                         0x2023 | 
|  | #define SK_WGL_FULL_ACCELERATION                    0x2027 | 
|  | #define SK_WGL_SAMPLE_BUFFERS                       0x2041 | 
|  | #define SK_WGL_SAMPLES                              0x2042 | 
|  | #define SK_WGL_CONTEXT_MAJOR_VERSION                0x2091 | 
|  | #define SK_WGL_CONTEXT_MINOR_VERSION                0x2092 | 
|  | #define SK_WGL_CONTEXT_LAYER_PLANE                  0x2093 | 
|  | #define SK_WGL_CONTEXT_FLAGS                        0x2094 | 
|  | #define SK_WGL_CONTEXT_PROFILE_MASK                 0x9126 | 
|  | #define SK_WGL_CONTEXT_DEBUG_BIT                    0x0001 | 
|  | #define SK_WGL_CONTEXT_FORWARD_COMPATIBLE_BIT       0x0002 | 
|  | #define SK_WGL_CONTEXT_CORE_PROFILE_BIT             0x00000001 | 
|  | #define SK_WGL_CONTEXT_COMPATIBILITY_PROFILE_BIT    0x00000002 | 
|  | #define SK_WGL_CONTEXT_ES2_PROFILE_BIT              0x00000004 | 
|  | #define SK_ERROR_INVALID_VERSION                    0x2095 | 
|  | #define SK_ERROR_INVALID_PROFILE                    0x2096 | 
|  |  | 
|  | DECLARE_HANDLE(HPBUFFER); | 
|  |  | 
|  | class SkWGLExtensions { | 
|  | public: | 
|  | SkWGLExtensions(); | 
|  | /** | 
|  | * Determines if an extensions is available for a given DC. | 
|  | * WGL_extensions_string is considered a prerequisite for all other | 
|  | * extensions. It is necessary to check this before calling other class | 
|  | * functions. | 
|  | */ | 
|  | bool hasExtension(HDC dc, const char* ext) const; | 
|  |  | 
|  | const char* getExtensionsString(HDC hdc) const; | 
|  | BOOL choosePixelFormat(HDC hdc, const int*, const FLOAT*, UINT, int*, UINT*) const; | 
|  | BOOL getPixelFormatAttribiv(HDC, int, int, UINT, const int*, int*) const; | 
|  | BOOL getPixelFormatAttribfv(HDC hdc, int, int, UINT, const int*, FLOAT*) const; | 
|  | HGLRC createContextAttribs(HDC, HGLRC, const int *) const; | 
|  |  | 
|  | BOOL swapInterval(int interval) const; | 
|  |  | 
|  | HPBUFFER createPbuffer(HDC, int , int, int, const int*) const; | 
|  | HDC getPbufferDC(HPBUFFER) const; | 
|  | int releasePbufferDC(HPBUFFER, HDC) const; | 
|  | BOOL destroyPbuffer(HPBUFFER) const; | 
|  |  | 
|  | /** | 
|  | * WGL doesn't have precise rules for the ordering of formats returned | 
|  | * by wglChoosePixelFormat. This function helps choose among the set of | 
|  | * formats returned by wglChoosePixelFormat. The rules in decreasing | 
|  | * priority are: | 
|  | *     * Choose formats with the smallest sample count that is >= | 
|  | *       desiredSampleCount (or the largest sample count if all formats have | 
|  | *       fewer samples than desiredSampleCount.) | 
|  | *     * Choose formats with the fewest color samples when coverage sampling | 
|  | *       is available. | 
|  | *     * If the above rules leave multiple formats, choose the one that | 
|  | *       appears first in the formats array parameter. | 
|  | */ | 
|  | int selectFormat(const int formats[], | 
|  | int formatCount, | 
|  | HDC dc, | 
|  | int desiredSampleCount) const; | 
|  | private: | 
|  | typedef const char* (WINAPI *GetExtensionsStringProc)(HDC); | 
|  | typedef BOOL (WINAPI *ChoosePixelFormatProc)(HDC, const int *, const FLOAT *, UINT, int *, UINT *); | 
|  | typedef BOOL (WINAPI *GetPixelFormatAttribivProc)(HDC, int, int, UINT, const int*, int*); | 
|  | typedef BOOL (WINAPI *GetPixelFormatAttribfvProc)(HDC, int, int, UINT, const int*, FLOAT*); | 
|  | typedef HGLRC (WINAPI *CreateContextAttribsProc)(HDC, HGLRC, const int *); | 
|  | typedef BOOL (WINAPI* SwapIntervalProc)(int); | 
|  | typedef HPBUFFER (WINAPI* CreatePbufferProc)(HDC, int , int, int, const int*); | 
|  | typedef HDC (WINAPI* GetPbufferDCProc)(HPBUFFER); | 
|  | typedef int (WINAPI* ReleasePbufferDCProc)(HPBUFFER, HDC); | 
|  | typedef BOOL (WINAPI* DestroyPbufferProc)(HPBUFFER); | 
|  |  | 
|  | GetExtensionsStringProc fGetExtensionsString; | 
|  | ChoosePixelFormatProc fChoosePixelFormat; | 
|  | GetPixelFormatAttribfvProc fGetPixelFormatAttribfv; | 
|  | GetPixelFormatAttribivProc fGetPixelFormatAttribiv; | 
|  | CreateContextAttribsProc fCreateContextAttribs; | 
|  | SwapIntervalProc fSwapInterval; | 
|  | CreatePbufferProc fCreatePbuffer; | 
|  | GetPbufferDCProc fGetPbufferDC; | 
|  | ReleasePbufferDCProc fReleasePbufferDC; | 
|  | DestroyPbufferProc fDestroyPbuffer; | 
|  | }; | 
|  |  | 
|  | enum SkWGLContextRequest { | 
|  | /** Requests to create core profile context if possible, otherwise | 
|  | compatibility profile. */ | 
|  | kGLPreferCoreProfile_SkWGLContextRequest, | 
|  | /** Requests to create compatibility profile context if possible, otherwise | 
|  | core profile. */ | 
|  | kGLPreferCompatibilityProfile_SkWGLContextRequest, | 
|  | /** Requests to create GL ES profile context. */ | 
|  | kGLES_SkWGLContextRequest | 
|  | }; | 
|  | /** | 
|  | * Helper to create an OpenGL context for a DC using WGL. Configs with a sample count >= to | 
|  | * msaaSampleCount are preferred but if none is available then a context with a lower sample count | 
|  | * (including non-MSAA) will be created. If preferCoreProfile is true but a core profile cannot be | 
|  | * created then a compatible profile context will be created. | 
|  | */ | 
|  | HGLRC SkCreateWGLContext(HDC dc, int msaaSampleCount, SkWGLContextRequest context); | 
|  |  | 
|  | /** | 
|  | * Helper class for creating a pbuffer context and deleting all the handles when finished. This | 
|  | * requires that a device context has been created. However, the pbuffer gets its own device | 
|  | * context. The original device context can be released once the pbuffer context is created. | 
|  | */ | 
|  | class SkWGLPbufferContext : public SkRefCnt { | 
|  | public: | 
|  | static SkWGLPbufferContext* Create(HDC parentDC, int msaaSampleCount, | 
|  | SkWGLContextRequest contextType); | 
|  |  | 
|  | virtual ~SkWGLPbufferContext(); | 
|  |  | 
|  | HDC getDC() const { return fDC; } | 
|  | HGLRC getGLRC() const { return fGLRC; } | 
|  |  | 
|  | private: | 
|  | SkWGLPbufferContext(HPBUFFER pbuffer, HDC dc, HGLRC glrc); | 
|  |  | 
|  | HPBUFFER        fPbuffer; | 
|  | HDC             fDC; | 
|  | HGLRC           fGLRC; | 
|  | SkWGLExtensions fExtensions; | 
|  | }; | 
|  |  | 
|  | #endif |