From 6edd2991f310efde0d4a4670f6f505d911e34c25 Mon Sep 17 00:00:00 2001 From: bkaradzic Date: Fri, 22 Feb 2013 22:34:55 -0800 Subject: [PATCH 1/4] Removed dxerr.h from DX11 build. --- src/renderer_d3d.h | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/renderer_d3d.h b/src/renderer_d3d.h index cd09969ab..ef0f587c8 100644 --- a/src/renderer_d3d.h +++ b/src/renderer_d3d.h @@ -6,7 +6,7 @@ #ifndef __RENDERER_D3D_H__ #define __RENDERER_D3D_H__ -#if BGFX_CONFIG_DEBUG && BX_PLATFORM_WINDOWS && BX_COMPILER_MSVC +#if BGFX_CONFIG_RENDERER_DIRECT3D9 # include # pragma comment(lib, "dxerr.lib") # define DX_CHECK_EXTRA_F " (%s): %s" @@ -14,7 +14,7 @@ #else # define DX_CHECK_EXTRA_F "" # define DX_CHECK_EXTRA_ARGS -#endif // BGFX_CONFIG_DEBUG && BX_PLATFORM_WINDOWS && BX_COMPILER_MSVC +#endif // BGFX_CONFIG_RENDERER_DIRECT3D9 namespace bgfx { From 074bf5a23232f7e525d61498cfa85b872c2f966a Mon Sep 17 00:00:00 2001 From: bkaradzic Date: Sat, 23 Feb 2013 00:15:54 -0800 Subject: [PATCH 2/4] Added dummy window to peek into WGL features. --- src/glcontext_wgl.cpp | 141 +++++++++++++++++++++++++---------------- src/renderer_d3d11.cpp | 2 +- src/renderer_d3d9.cpp | 2 +- src/renderer_gl.cpp | 19 +++--- 4 files changed, 100 insertions(+), 64 deletions(-) diff --git a/src/glcontext_wgl.cpp b/src/glcontext_wgl.cpp index 3d3cfaed5..7454a5cda 100644 --- a/src/glcontext_wgl.cpp +++ b/src/glcontext_wgl.cpp @@ -24,6 +24,51 @@ namespace bgfx # include "glimports.h" # undef GL_IMPORT + static HGLRC createContext(HDC _hdc) + { + PIXELFORMATDESCRIPTOR pfd; + memset(&pfd, 0, sizeof(pfd) ); + pfd.nSize = sizeof(PIXELFORMATDESCRIPTOR); + pfd.nVersion = 1; + pfd.dwFlags = PFD_DRAW_TO_WINDOW | PFD_SUPPORT_OPENGL | PFD_DOUBLEBUFFER; + pfd.iPixelType = PFD_TYPE_RGBA; + pfd.cColorBits = 32; + pfd.cAlphaBits = 8; + pfd.cDepthBits = 24; + pfd.cStencilBits = 8; + pfd.iLayerType = PFD_MAIN_PLANE; + + int pixelFormat = ChoosePixelFormat(_hdc, &pfd); + BGFX_FATAL(0 != pixelFormat, Fatal::UnableToInitialize, "ChoosePixelFormat failed!"); + + DescribePixelFormat(_hdc, pixelFormat, sizeof(PIXELFORMATDESCRIPTOR), &pfd); + + BX_TRACE("Pixel format:\n" + "\tiPixelType %d\n" + "\tcColorBits %d\n" + "\tcAlphaBits %d\n" + "\tcDepthBits %d\n" + "\tcStencilBits %d\n" + , pfd.iPixelType + , pfd.cColorBits + , pfd.cAlphaBits + , pfd.cDepthBits + , pfd.cStencilBits + ); + + int result; + result = SetPixelFormat(_hdc, pixelFormat, &pfd); + BGFX_FATAL(0 != result, Fatal::UnableToInitialize, "SetPixelFormat failed!"); + + HGLRC context = wglCreateContext(_hdc); + BGFX_FATAL(NULL != context, Fatal::UnableToInitialize, "wglCreateContext failed!"); + + result = wglMakeCurrent(_hdc, context); + BGFX_FATAL(0 != result, Fatal::UnableToInitialize, "wglMakeCurrent failed!"); + + return context; + } + void GlContext::create(uint32_t _width, uint32_t _height) { m_opengl32dll = LoadLibrary("opengl32.dll"); @@ -44,44 +89,28 @@ namespace bgfx m_hdc = GetDC(g_bgfxHwnd); BGFX_FATAL(NULL != m_hdc, Fatal::UnableToInitialize, "GetDC failed!"); - PIXELFORMATDESCRIPTOR pfd; - memset(&pfd, 0, sizeof(pfd) ); - pfd.nSize = sizeof(PIXELFORMATDESCRIPTOR); - pfd.nVersion = 1; - pfd.iPixelType = PFD_TYPE_RGBA; - pfd.cColorBits = 32; - pfd.cAlphaBits = 8; - pfd.cDepthBits = 24; - pfd.cStencilBits = 8; - pfd.iLayerType = PFD_MAIN_PLANE; - - int pixelFormat = ChoosePixelFormat(m_hdc, &pfd); - BGFX_FATAL(0 != pixelFormat, Fatal::UnableToInitialize, "ChoosePixelFormat failed!"); - - DescribePixelFormat(m_hdc, pixelFormat, sizeof(PIXELFORMATDESCRIPTOR), &pfd); - - BX_TRACE("Pixel format:\n" - "\tiPixelType %d\n" - "\tcColorBits %d\n" - "\tcAlphaBits %d\n" - "\tcDepthBits %d\n" - "\tcStencilBits %d\n" - , pfd.iPixelType - , pfd.cColorBits - , pfd.cAlphaBits - , pfd.cDepthBits - , pfd.cStencilBits + // Dummy window to peek into WGL functionality. + // + // An application can only set the pixel format of a window one time. + // Once a window's pixel format is set, it cannot be changed. + // MSDN: http://msdn.microsoft.com/en-us/library/windows/desktop/dd369049%28v=vs.85%29.aspx + HWND hwnd = CreateWindowA("STATIC" + , "" + , WS_POPUP|WS_DISABLED + , -32000 + , -32000 + , 0 + , 0 + , NULL + , NULL + , GetModuleHandle(NULL) + , 0 ); - int result; - result = SetPixelFormat(m_hdc, pixelFormat, &pfd); - BGFX_FATAL(0 != result, Fatal::UnableToInitialize, "SetPixelFormat failed!"); + HDC hdc = GetDC(hwnd); + BGFX_FATAL(NULL != hdc, Fatal::UnableToInitialize, "GetDC failed!"); - m_context = wglCreateContext(m_hdc); - BGFX_FATAL(NULL != m_context, Fatal::UnableToInitialize, "wglCreateContext failed!"); - - result = wglMakeCurrent(m_hdc, m_context); - BGFX_FATAL(0 != result, Fatal::UnableToInitialize, "wglMakeCurrent failed!"); + HGLRC context = createContext(hdc); wglGetExtensionsStringARB = (PFNWGLGETEXTENSIONSSTRINGARBPROC)wglGetProcAddress("wglGetExtensionsStringARB"); wglChoosePixelFormatARB = (PFNWGLCHOOSEPIXELFORMATARBPROC)wglGetProcAddress("wglChoosePixelFormatARB"); @@ -90,7 +119,7 @@ namespace bgfx if (NULL != wglGetExtensionsStringARB) { BX_TRACE("WGL extensions:"); - const char* extensions = (const char*)wglGetExtensionsStringARB(m_hdc); + const char* extensions = (const char*)wglGetExtensionsStringARB(hdc); if (NULL != extensions) { char name[1024]; @@ -119,10 +148,6 @@ namespace bgfx } } -#if 0 - // An application can only set the pixel format of a window one time. - // Once a window's pixel format is set, it cannot be changed. - // MSDN: http://msdn.microsoft.com/en-us/library/windows/desktop/dd369049%28v=vs.85%29.aspx if (NULL != wglChoosePixelFormatARB && NULL != wglCreateContextAttribsARB) { @@ -134,15 +159,14 @@ namespace bgfx WGL_PIXEL_TYPE_ARB, WGL_TYPE_RGBA_ARB, WGL_DRAW_TO_WINDOW_ARB, true, WGL_DOUBLE_BUFFER_ARB, true, - WGL_RED_BITS_ARB, 8, - WGL_BLUE_BITS_ARB, 8, - WGL_GREEN_BITS_ARB, 8, - WGL_ALPHA_BITS_ARB, 8, + WGL_COLOR_BITS_ARB, 32, WGL_DEPTH_BITS_ARB, 24, WGL_STENCIL_BITS_ARB, 8, 0 }; + int result; + int pixelFormat; uint32_t numFormats = 0; do { @@ -156,6 +180,7 @@ namespace bgfx } while (0 == numFormats); + PIXELFORMATDESCRIPTOR pfd; DescribePixelFormat(m_hdc, pixelFormat, sizeof(PIXELFORMATDESCRIPTOR), &pfd); BX_TRACE("Pixel format:\n" @@ -174,13 +199,16 @@ namespace bgfx result = SetPixelFormat(m_hdc, pixelFormat, &pfd); BGFX_FATAL(0 != result, Fatal::UnableToInitialize, "SetPixelFormat failed (last err: 0x%08x)!", GetLastError() ); - wglMakeCurrent(m_hdc, NULL); - wglDeleteContext(m_context); - const int32_t contextAttrs[] = { - WGL_CONTEXT_MAJOR_VERSION_ARB, 2, - WGL_CONTEXT_MINOR_VERSION_ARB, 1, +#if 1 + WGL_CONTEXT_MAJOR_VERSION_ARB, 2, + WGL_CONTEXT_MINOR_VERSION_ARB, 1, +#else + WGL_CONTEXT_MAJOR_VERSION_ARB, 3, + WGL_CONTEXT_MINOR_VERSION_ARB, 2, + WGL_CONTEXT_PROFILE_MASK_ARB, WGL_CONTEXT_CORE_PROFILE_BIT_ARB, +#endif // 1 #if BGFX_CONFIG_DEBUG WGL_CONTEXT_FLAGS_ARB, WGL_CONTEXT_DEBUG_BIT_ARB, #endif // BGFX_CONFIG_DEBUG @@ -188,12 +216,19 @@ namespace bgfx }; m_context = wglCreateContextAttribsARB(m_hdc, 0, contextAttrs); - - result = wglMakeCurrent(m_hdc, m_context); - BGFX_FATAL(0 != result, Fatal::UnableToInitialize, "wglMakeCurrent failed!"); } -#endif // 0 + wglMakeCurrent(NULL, NULL); + wglDeleteContext(context); + DestroyWindow(hwnd); + + if (NULL == m_context) + { + m_context = createContext(m_hdc); + } + + int result = wglMakeCurrent(m_hdc, m_context); + BGFX_FATAL(0 != result, Fatal::UnableToInitialize, "wglMakeCurrent failed!"); import(); } diff --git a/src/renderer_d3d11.cpp b/src/renderer_d3d11.cpp index a34ce49a4..01bd1e36a 100644 --- a/src/renderer_d3d11.cpp +++ b/src/renderer_d3d11.cpp @@ -2568,7 +2568,7 @@ namespace bgfx tvm.clear(); uint16_t pos = 10; - tvm.printf(0, 0, 0x8f, " " BGFX_RENDERER_NAME " "); + tvm.printf(0, 0, BGFX_CONFIG_DEBUG ? 0x89 : 0x8f, " " BGFX_RENDERER_NAME " "); tvm.printf(10, pos++, 0x8e, " Frame: %7.3f, % 7.3f \x1f, % 7.3f \x1e [ms] / % 6.2f FPS" , double(frameTime)*toMs , double(min)*toMs diff --git a/src/renderer_d3d9.cpp b/src/renderer_d3d9.cpp index da2b0e5fc..12f92932c 100644 --- a/src/renderer_d3d9.cpp +++ b/src/renderer_d3d9.cpp @@ -2671,7 +2671,7 @@ namespace bgfx tvm.clear(); uint16_t pos = 10; - tvm.printf(0, 0, 0x8f, " " BGFX_RENDERER_NAME " "); + tvm.printf(0, 0, BGFX_CONFIG_DEBUG ? 0x89 : 0x8f, " " BGFX_RENDERER_NAME " "); tvm.printf(10, pos++, 0x8e, " Frame: %7.3f, % 7.3f \x1f, % 7.3f \x1e [ms] / % 6.2f FPS" , double(frameTime)*toMs , double(min)*toMs diff --git a/src/renderer_gl.cpp b/src/renderer_gl.cpp index 16f55dd4f..b613cef16 100644 --- a/src/renderer_gl.cpp +++ b/src/renderer_gl.cpp @@ -117,12 +117,12 @@ namespace bgfx static void GL_APIENTRY stubDrawArraysInstanced(GLenum _mode, GLint _first, GLsizei _count, GLsizei /*_primcount*/) { - glDrawArrays(_mode, _first, _count); + GL_CHECK(glDrawArrays(_mode, _first, _count) ); } static void GL_APIENTRY stubDrawElementsInstanced(GLenum _mode, GLsizei _count, GLenum _type, const GLvoid* _indices, GLsizei /*_primcount*/) { - glDrawElements(_mode, _count, _type, _indices); + GL_CHECK(glDrawElements(_mode, _count, _type, _indices) ); } #if BGFX_CONFIG_RENDERER_OPENGLES3 @@ -1404,7 +1404,7 @@ namespace bgfx if (0 != (_flags & (BGFX_TEXTURE_MIN_ANISOTROPIC|BGFX_TEXTURE_MAG_ANISOTROPIC) ) && 0.0f < s_renderCtx.m_maxAnisotropy) { - glTexParameterf(m_target, GL_TEXTURE_MAX_ANISOTROPY_EXT, s_renderCtx.m_maxAnisotropy); + GL_CHECK(glTexParameterf(m_target, GL_TEXTURE_MAX_ANISOTROPY_EXT, s_renderCtx.m_maxAnisotropy) ); } GL_CHECK(glBindTexture(m_target, 0) ); @@ -1446,8 +1446,8 @@ namespace bgfx GL_CHECK(glGenTextures(1, &m_id) ); BX_CHECK(0 != m_id, "Failed to generate texture id."); GL_CHECK(glBindTexture(m_target, m_id) ); -// glTexParameteri(m_target, GL_TEXTURE_COMPARE_MODE, GL_NONE); -// glTexParameteri(m_target, GL_DEPTH_TEXTURE_MODE, GL_NONE); +// GL_CHECK(glTexParameteri(m_target, GL_TEXTURE_COMPARE_MODE, GL_NONE) ); +// GL_CHECK(glTexParameteri(m_target, GL_DEPTH_TEXTURE_MODE, GL_NONE) ); GL_CHECK(glTexParameteri(m_target, GL_TEXTURE_MIN_FILTER, GL_LINEAR) ); GL_CHECK(glTexParameteri(m_target, GL_TEXTURE_MAG_FILTER, GL_LINEAR) ); GL_CHECK(glTexParameteri(m_target, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE) ); @@ -1941,11 +1941,12 @@ namespace bgfx GL_GET(GL_MAX_RENDERBUFFER_SIZE, 1); const char* version = (const char*)glGetString(GL_SHADING_LANGUAGE_VERSION); - GL_CHECK(version = version); // check if error is generated by glGetString. + GL_CHECK(;); // check if error is generated by glGetString. BX_TRACE("GLSL version: %s", version); #endif // BGFX_CONFIG_DEBUG const char* extensions = (const char*)glGetString(GL_EXTENSIONS); + GL_CHECK(;); // check if error is generated by glGetString. if (NULL != extensions) { char name[1024]; @@ -2026,13 +2027,13 @@ namespace bgfx if (s_extension[Extension::EXT_texture_filter_anisotropic].m_supported) { - glGetFloatv(GL_MAX_TEXTURE_MAX_ANISOTROPY_EXT, &s_renderCtx.m_maxAnisotropy); + GL_CHECK(glGetFloatv(GL_MAX_TEXTURE_MAX_ANISOTROPY_EXT, &s_renderCtx.m_maxAnisotropy) ); } #if BGFX_CONFIG_RENDERER_OPENGL|BGFX_CONFIG_RENDERER_OPENGLES3 if (s_extension[Extension::ARB_texture_multisample].m_supported) { - glGetIntegerv(GL_MAX_SAMPLES, &s_renderCtx.m_maxMsaa); + GL_CHECK(glGetIntegerv(GL_MAX_SAMPLES, &s_renderCtx.m_maxMsaa) ); } #endif // BGFX_CONFIG_RENDERER_OPENGL|BGFX_CONFIG_RENDERER_OPENGLES3 @@ -2991,7 +2992,7 @@ namespace bgfx tvm.clear(); uint16_t pos = 10; - tvm.printf(0, 0, 0x8f, " " BGFX_RENDERER_NAME " "); + tvm.printf(0, 0, BGFX_CONFIG_DEBUG ? 0x89 : 0x8f, " " BGFX_RENDERER_NAME " "); tvm.printf(10, pos++, 0x8e, " Frame CPU: %7.3f, % 7.3f \x1f, % 7.3f \x1e [ms] / % 6.2f FPS" , double(frameTime)*toMs , double(min)*toMs From e0eca362ad36e971afedff3bd4d5146cc7c83ff3 Mon Sep 17 00:00:00 2001 From: bkaradzic Date: Sat, 23 Feb 2013 19:02:51 -0800 Subject: [PATCH 3/4] Fixed DX9 lack of non-normalized UINT16 vertex decl type. --- examples/06-bump/bump.cpp | 54 +++++++++++++++++++-------------------- include/bgfx.h | 10 +++++++- src/renderer_d3d11.cpp | 8 +++--- src/renderer_gl.cpp | 2 +- src/vertexdecl.cpp | 36 +++++++++++++------------- 5 files changed, 59 insertions(+), 51 deletions(-) diff --git a/examples/06-bump/bump.cpp b/examples/06-bump/bump.cpp index 1b55bb22d..4851ef7eb 100644 --- a/examples/06-bump/bump.cpp +++ b/examples/06-bump/bump.cpp @@ -22,8 +22,8 @@ struct PosNormalTangentTexcoordVertex float m_z; uint32_t m_normal; uint32_t m_tangent; - float m_u; - float m_v; + uint16_t m_u; + uint16_t m_v; }; static bgfx::VertexDecl s_PosNormalTangentTexcoordDecl; @@ -55,30 +55,30 @@ uint32_t packF4u(float _x, float _y = 0.0f, float _z = 0.0f, float _w = 0.0f) static PosNormalTangentTexcoordVertex s_cubeVertices[24] = { - {-1.0f, 1.0f, 1.0f, packF4u( 0.0f, 0.0f, 1.0f), 0, 0.0f, 0.0f }, - { 1.0f, 1.0f, 1.0f, packF4u( 0.0f, 0.0f, 1.0f), 0, 1.0f, 0.0f }, - {-1.0f, -1.0f, 1.0f, packF4u( 0.0f, 0.0f, 1.0f), 0, 0.0f, 1.0f }, - { 1.0f, -1.0f, 1.0f, packF4u( 0.0f, 0.0f, 1.0f), 0, 1.0f, 1.0f }, - {-1.0f, 1.0f, -1.0f, packF4u( 0.0f, 0.0f, -1.0f), 0, 0.0f, 0.0f }, - { 1.0f, 1.0f, -1.0f, packF4u( 0.0f, 0.0f, -1.0f), 0, 1.0f, 0.0f }, - {-1.0f, -1.0f, -1.0f, packF4u( 0.0f, 0.0f, -1.0f), 0, 0.0f, 1.0f }, - { 1.0f, -1.0f, -1.0f, packF4u( 0.0f, 0.0f, -1.0f), 0, 1.0f, 1.0f }, - {-1.0f, 1.0f, 1.0f, packF4u( 0.0f, 1.0f, 0.0f), 0, 0.0f, 0.0f }, - { 1.0f, 1.0f, 1.0f, packF4u( 0.0f, 1.0f, 0.0f), 0, 1.0f, 0.0f }, - {-1.0f, 1.0f, -1.0f, packF4u( 0.0f, 1.0f, 0.0f), 0, 0.0f, 1.0f }, - { 1.0f, 1.0f, -1.0f, packF4u( 0.0f, 1.0f, 0.0f), 0, 1.0f, 1.0f }, - {-1.0f, -1.0f, 1.0f, packF4u( 0.0f, -1.0f, 0.0f), 0, 0.0f, 0.0f }, - { 1.0f, -1.0f, 1.0f, packF4u( 0.0f, -1.0f, 0.0f), 0, 1.0f, 0.0f }, - {-1.0f, -1.0f, -1.0f, packF4u( 0.0f, -1.0f, 0.0f), 0, 0.0f, 1.0f }, - { 1.0f, -1.0f, -1.0f, packF4u( 0.0f, -1.0f, 0.0f), 0, 1.0f, 1.0f }, - { 1.0f, -1.0f, 1.0f, packF4u( 1.0f, 0.0f, 0.0f), 0, 0.0f, 0.0f }, - { 1.0f, 1.0f, 1.0f, packF4u( 1.0f, 0.0f, 0.0f), 0, 1.0f, 0.0f }, - { 1.0f, -1.0f, -1.0f, packF4u( 1.0f, 0.0f, 0.0f), 0, 0.0f, 1.0f }, - { 1.0f, 1.0f, -1.0f, packF4u( 1.0f, 0.0f, 0.0f), 0, 1.0f, 1.0f }, - {-1.0f, -1.0f, 1.0f, packF4u(-1.0f, 0.0f, 0.0f), 0, 0.0f, 0.0f }, - {-1.0f, 1.0f, 1.0f, packF4u(-1.0f, 0.0f, 0.0f), 0, 1.0f, 0.0f }, - {-1.0f, -1.0f, -1.0f, packF4u(-1.0f, 0.0f, 0.0f), 0, 0.0f, 1.0f }, - {-1.0f, 1.0f, -1.0f, packF4u(-1.0f, 0.0f, 0.0f), 0, 1.0f, 1.0f }, + {-1.0f, 1.0f, 1.0f, packF4u( 0.0f, 0.0f, 1.0f), 0, 0, 0 }, + { 1.0f, 1.0f, 1.0f, packF4u( 0.0f, 0.0f, 1.0f), 0, 0x7fff, 0 }, + {-1.0f, -1.0f, 1.0f, packF4u( 0.0f, 0.0f, 1.0f), 0, 0, 0x7fff }, + { 1.0f, -1.0f, 1.0f, packF4u( 0.0f, 0.0f, 1.0f), 0, 0x7fff, 0x7fff }, + {-1.0f, 1.0f, -1.0f, packF4u( 0.0f, 0.0f, -1.0f), 0, 0, 0 }, + { 1.0f, 1.0f, -1.0f, packF4u( 0.0f, 0.0f, -1.0f), 0, 0x7fff, 0 }, + {-1.0f, -1.0f, -1.0f, packF4u( 0.0f, 0.0f, -1.0f), 0, 0, 0x7fff }, + { 1.0f, -1.0f, -1.0f, packF4u( 0.0f, 0.0f, -1.0f), 0, 0x7fff, 0x7fff }, + {-1.0f, 1.0f, 1.0f, packF4u( 0.0f, 1.0f, 0.0f), 0, 0, 0 }, + { 1.0f, 1.0f, 1.0f, packF4u( 0.0f, 1.0f, 0.0f), 0, 0x7fff, 0 }, + {-1.0f, 1.0f, -1.0f, packF4u( 0.0f, 1.0f, 0.0f), 0, 0, 0x7fff }, + { 1.0f, 1.0f, -1.0f, packF4u( 0.0f, 1.0f, 0.0f), 0, 0x7fff, 0x7fff }, + {-1.0f, -1.0f, 1.0f, packF4u( 0.0f, -1.0f, 0.0f), 0, 0, 0 }, + { 1.0f, -1.0f, 1.0f, packF4u( 0.0f, -1.0f, 0.0f), 0, 0x7fff, 0 }, + {-1.0f, -1.0f, -1.0f, packF4u( 0.0f, -1.0f, 0.0f), 0, 0, 0x7fff }, + { 1.0f, -1.0f, -1.0f, packF4u( 0.0f, -1.0f, 0.0f), 0, 0x7fff, 0x7fff }, + { 1.0f, -1.0f, 1.0f, packF4u( 1.0f, 0.0f, 0.0f), 0, 0, 0 }, + { 1.0f, 1.0f, 1.0f, packF4u( 1.0f, 0.0f, 0.0f), 0, 0x7fff, 0 }, + { 1.0f, -1.0f, -1.0f, packF4u( 1.0f, 0.0f, 0.0f), 0, 0, 0x7fff }, + { 1.0f, 1.0f, -1.0f, packF4u( 1.0f, 0.0f, 0.0f), 0, 0x7fff, 0x7fff }, + {-1.0f, -1.0f, 1.0f, packF4u(-1.0f, 0.0f, 0.0f), 0, 0, 0 }, + {-1.0f, 1.0f, 1.0f, packF4u(-1.0f, 0.0f, 0.0f), 0, 0x7fff, 0 }, + {-1.0f, -1.0f, -1.0f, packF4u(-1.0f, 0.0f, 0.0f), 0, 0, 0x7fff }, + {-1.0f, 1.0f, -1.0f, packF4u(-1.0f, 0.0f, 0.0f), 0, 0x7fff, 0x7fff }, }; static const uint16_t s_cubeIndices[36] = @@ -299,7 +299,7 @@ int _main_(int _argc, char** _argv) s_PosNormalTangentTexcoordDecl.add(bgfx::Attrib::Position, 3, bgfx::AttribType::Float); s_PosNormalTangentTexcoordDecl.add(bgfx::Attrib::Normal, 4, bgfx::AttribType::Uint8, true, true); s_PosNormalTangentTexcoordDecl.add(bgfx::Attrib::Tangent, 4, bgfx::AttribType::Uint8, true, true); - s_PosNormalTangentTexcoordDecl.add(bgfx::Attrib::TexCoord0, 2, bgfx::AttribType::Float); + s_PosNormalTangentTexcoordDecl.add(bgfx::Attrib::TexCoord0, 2, bgfx::AttribType::Int16, true, true); s_PosNormalTangentTexcoordDecl.end(); const bgfx::Memory* mem; diff --git a/include/bgfx.h b/include/bgfx.h index 007b1b38b..1c31e8855 100644 --- a/include/bgfx.h +++ b/include/bgfx.h @@ -284,7 +284,7 @@ namespace bgfx enum Enum { Uint8, - Uint16, + Int16, Half, Float, @@ -450,6 +450,14 @@ namespace bgfx /// Add attribute to VertexDecl. /// + /// @param _attrib Attribute semantics. + /// @param _num Number of elements 1, 2, 3 or 4. + /// @param _type Element type. + /// @param _normalized Value is normalized for vertex shader. + /// @param _asInt Packaging rule for vertexPack, vertexUnpack, and + /// vertexConvert for AttribType::Uint8 and AttribType::Int16. + /// Unpacking code must be implemented inside vertex shader. + /// /// NOTE: /// Must be called between begin/end. void add(Attrib::Enum _attrib, uint8_t _num, AttribType::Enum _type, bool _normalized = false, bool _asInt = false); diff --git a/src/renderer_d3d11.cpp b/src/renderer_d3d11.cpp index 01bd1e36a..6a87a6e09 100644 --- a/src/renderer_d3d11.cpp +++ b/src/renderer_d3d11.cpp @@ -194,10 +194,10 @@ namespace bgfx { DXGI_FORMAT_R8G8B8A8_UINT, DXGI_FORMAT_R8G8B8A8_UNORM }, }, { - { DXGI_FORMAT_R16_UINT, DXGI_FORMAT_R16_UNORM }, - { DXGI_FORMAT_R16G16_UINT, DXGI_FORMAT_R16G16_UNORM }, - { DXGI_FORMAT_R16G16B16A16_UINT, DXGI_FORMAT_R16G16B16A16_UNORM }, - { DXGI_FORMAT_R16G16B16A16_UINT, DXGI_FORMAT_R16G16B16A16_UNORM }, + { DXGI_FORMAT_R16_SINT, DXGI_FORMAT_R16_SNORM }, + { DXGI_FORMAT_R16G16_SINT, DXGI_FORMAT_R16G16_SNORM }, + { DXGI_FORMAT_R16G16B16A16_SINT, DXGI_FORMAT_R16G16B16A16_SNORM }, + { DXGI_FORMAT_R16G16B16A16_SINT, DXGI_FORMAT_R16G16B16A16_SNORM }, }, { { DXGI_FORMAT_R16_FLOAT, DXGI_FORMAT_R16_FLOAT }, diff --git a/src/renderer_gl.cpp b/src/renderer_gl.cpp index b613cef16..9e080a715 100644 --- a/src/renderer_gl.cpp +++ b/src/renderer_gl.cpp @@ -534,7 +534,7 @@ namespace bgfx static const GLenum s_attribType[AttribType::Count] = { GL_UNSIGNED_BYTE, - GL_UNSIGNED_SHORT, + GL_SHORT, GL_HALF_FLOAT, GL_FLOAT, }; diff --git a/src/vertexdecl.cpp b/src/vertexdecl.cpp index 2a22f754a..99bc2377b 100644 --- a/src/vertexdecl.cpp +++ b/src/vertexdecl.cpp @@ -207,7 +207,7 @@ namespace bgfx } break; - case AttribType::Uint16: + case AttribType::Int16: { uint16_t* packed = (uint16_t*)data; if (_inputNormalized) @@ -216,20 +216,20 @@ namespace bgfx { switch (num) { - default: *packed++ = uint16_t(*_input++ * 32767.0f + 32768.0f); - case 3: *packed++ = uint16_t(*_input++ * 32767.0f + 32768.0f); - case 2: *packed++ = uint16_t(*_input++ * 32767.0f + 32768.0f); - case 1: *packed++ = uint16_t(*_input++ * 32767.0f + 32768.0f); + default: *packed++ = uint16_t(*_input++ * 32767.0f); + case 3: *packed++ = uint16_t(*_input++ * 32767.0f); + case 2: *packed++ = uint16_t(*_input++ * 32767.0f); + case 1: *packed++ = uint16_t(*_input++ * 32767.0f); } } else { switch (num) { - default: *packed++ = uint16_t(*_input++ * 65535.0f); - case 3: *packed++ = uint16_t(*_input++ * 65535.0f); - case 2: *packed++ = uint16_t(*_input++ * 65535.0f); - case 1: *packed++ = uint16_t(*_input++ * 65535.0f); + default: *packed++ = uint16_t(*_input++ * 65535.0f - 32768.0f); + case 3: *packed++ = uint16_t(*_input++ * 65535.0f - 32768.0f); + case 2: *packed++ = uint16_t(*_input++ * 65535.0f - 32768.0f); + case 1: *packed++ = uint16_t(*_input++ * 65535.0f - 32768.0f); } } } @@ -311,27 +311,27 @@ namespace bgfx } break; - case AttribType::Uint16: + case AttribType::Int16: { uint16_t* packed = (uint16_t*)data; if (asInt) { switch (num) { - default: *_output++ = (float(*packed++) - 32768.0f)*1.0f/32767.0f; - case 3: *_output++ = (float(*packed++) - 32768.0f)*1.0f/32767.0f; - case 2: *_output++ = (float(*packed++) - 32768.0f)*1.0f/32767.0f; - case 1: *_output++ = (float(*packed++) - 32768.0f)*1.0f/32767.0f; + default: *_output++ = float(*packed++)*1.0f/32767.0f; + case 3: *_output++ = float(*packed++)*1.0f/32767.0f; + case 2: *_output++ = float(*packed++)*1.0f/32767.0f; + case 1: *_output++ = float(*packed++)*1.0f/32767.0f; } } else { switch (num) { - default: *_output++ = float(*packed++)*1.0f/65535.0f; - case 3: *_output++ = float(*packed++)*1.0f/65535.0f; - case 2: *_output++ = float(*packed++)*1.0f/65535.0f; - case 1: *_output++ = float(*packed++)*1.0f/65535.0f; + default: *_output++ = (float(*packed++) + 32768.0f)*1.0f/65535.0f; + case 3: *_output++ = (float(*packed++) + 32768.0f)*1.0f/65535.0f; + case 2: *_output++ = (float(*packed++) + 32768.0f)*1.0f/65535.0f; + case 1: *_output++ = (float(*packed++) + 32768.0f)*1.0f/65535.0f; } } } From 5fe1132b1c7670cd9022fa9109c4833acbfb0115 Mon Sep 17 00:00:00 2001 From: bkaradzic Date: Sat, 23 Feb 2013 20:43:31 -0800 Subject: [PATCH 4/4] Cleanup. --- examples/06-bump/bump.cpp | 4 ++-- src/bgfx_p.h | 4 ++-- src/vertexdecl.cpp | 28 ++++++++++++++-------------- 3 files changed, 18 insertions(+), 18 deletions(-) diff --git a/examples/06-bump/bump.cpp b/examples/06-bump/bump.cpp index 4851ef7eb..c75e05ea2 100644 --- a/examples/06-bump/bump.cpp +++ b/examples/06-bump/bump.cpp @@ -22,8 +22,8 @@ struct PosNormalTangentTexcoordVertex float m_z; uint32_t m_normal; uint32_t m_tangent; - uint16_t m_u; - uint16_t m_v; + int16_t m_u; + int16_t m_v; }; static bgfx::VertexDecl s_PosNormalTangentTexcoordDecl; diff --git a/src/bgfx_p.h b/src/bgfx_p.h index 8e9d7bb03..76222bd49 100755 --- a/src/bgfx_p.h +++ b/src/bgfx_p.h @@ -194,12 +194,12 @@ namespace bgfx const char* getAttribName(Attrib::Enum _attr); bool renderFrame(); - inline uint32_t uint16_min(uint16_t _a, uint16_t _b) + inline uint16_t uint16_min(uint16_t _a, uint16_t _b) { return _a > _b ? _b : _a; } - inline uint32_t uint16_max(uint16_t _a, uint16_t _b) + inline uint16_t uint16_max(uint16_t _a, uint16_t _b) { return _a < _b ? _b : _a; } diff --git a/src/vertexdecl.cpp b/src/vertexdecl.cpp index 99bc2377b..6518520de 100644 --- a/src/vertexdecl.cpp +++ b/src/vertexdecl.cpp @@ -209,27 +209,27 @@ namespace bgfx case AttribType::Int16: { - uint16_t* packed = (uint16_t*)data; + int16_t* packed = (int16_t*)data; if (_inputNormalized) { if (asInt) { switch (num) { - default: *packed++ = uint16_t(*_input++ * 32767.0f); - case 3: *packed++ = uint16_t(*_input++ * 32767.0f); - case 2: *packed++ = uint16_t(*_input++ * 32767.0f); - case 1: *packed++ = uint16_t(*_input++ * 32767.0f); + default: *packed++ = int16_t(*_input++ * 32767.0f); + case 3: *packed++ = int16_t(*_input++ * 32767.0f); + case 2: *packed++ = int16_t(*_input++ * 32767.0f); + case 1: *packed++ = int16_t(*_input++ * 32767.0f); } } else { switch (num) { - default: *packed++ = uint16_t(*_input++ * 65535.0f - 32768.0f); - case 3: *packed++ = uint16_t(*_input++ * 65535.0f - 32768.0f); - case 2: *packed++ = uint16_t(*_input++ * 65535.0f - 32768.0f); - case 1: *packed++ = uint16_t(*_input++ * 65535.0f - 32768.0f); + default: *packed++ = int16_t(*_input++ * 65535.0f - 32768.0f); + case 3: *packed++ = int16_t(*_input++ * 65535.0f - 32768.0f); + case 2: *packed++ = int16_t(*_input++ * 65535.0f - 32768.0f); + case 1: *packed++ = int16_t(*_input++ * 65535.0f - 32768.0f); } } } @@ -237,10 +237,10 @@ namespace bgfx { switch (num) { - default: *packed++ = uint16_t(*_input++); - case 3: *packed++ = uint16_t(*_input++); - case 2: *packed++ = uint16_t(*_input++); - case 1: *packed++ = uint16_t(*_input++); + default: *packed++ = int16_t(*_input++); + case 3: *packed++ = int16_t(*_input++); + case 2: *packed++ = int16_t(*_input++); + case 1: *packed++ = int16_t(*_input++); } } } @@ -313,7 +313,7 @@ namespace bgfx case AttribType::Int16: { - uint16_t* packed = (uint16_t*)data; + int16_t* packed = (int16_t*)data; if (asInt) { switch (num)