| Previous | 199869 Revisions | Next |
| r36307 Saturday 7th March, 2015 at 18:12:51 UTC by Miodrag Milanović |
|---|
| update bgfx (nw) |
| [3rdparty/bgfx] | README.md |
| [3rdparty/bgfx/examples/23-vectordisplay] | vectordisplay.cpp |
| [3rdparty/bgfx/examples/common/entry] | entry_osx.mm |
| [3rdparty/bgfx/examples/common/imgui] | imgui.cpp |
| [3rdparty/bgfx/include] | bgfx.c99.h bgfx.h |
| [3rdparty/bgfx/scripts] | bgfx.lua example-common.lua |
| [3rdparty/bgfx/src] | bgfx.cpp bgfx_compute.sh bgfx_p.h config.h image.cpp renderer_d3d.h renderer_d3d11.cpp renderer_d3d9.cpp renderer_gl.cpp renderer_vk.cpp* vertexdecl.cpp |
| [3rdparty/bx/include/bx] | platform.h |
| [3rdparty/bx/scripts] | toolchain.lua |
| [3rdparty/bx/tools/bin/darwin] | genie |
| [3rdparty/bx/tools/bin/linux] | genie |
| [3rdparty/bx/tools/bin/windows] | genie.exe |
| [src/lib] | lib.mak |
| r244818 | r244819 | |
|---|---|---|
| 593 | 593 | - Animated mesh example. |
| 594 | 594 | - Direct3D 12 renderer backend. |
| 595 | 595 | - Metal renderer backend. |
| 596 | - Vulkan renderer backend. | |
| 596 | 597 | |
| 597 | 598 | Contact |
| 598 | 599 | ------- |
| r244818 | r244819 | |
|---|---|---|
| 152 | 152 | void VectorDisplay::endFrame() |
| 153 | 153 | { |
| 154 | 154 | float proj[16]; |
| 155 | float ident[16]; | |
| 156 | bx::mtxIdentity(ident); | |
| 157 | ||
| 158 | 155 | bx::mtxOrtho(proj, 0.0f, (float)m_screenWidth, (float)m_screenHeight, 0.0f, 0.0f, 1000.0f); |
| 159 | 156 | |
| 160 | 157 | bgfx::setViewRect(m_view, 0, 0, m_screenWidth, m_screenHeight); |
| r244818 | r244819 | |
| 171 | 168 | ); |
| 172 | 169 | m_vertexBuffersSize[m_currentDrawStep] = (uint32_t)m_points.size(); |
| 173 | 170 | |
| 174 | //if the index buffer is cleared from the last "submit"-call everything is fine, but if not | |
| 175 | //we clear it here again just to be sure it's not set... (the same for the Transform) | |
| 176 | bgfx::IndexBufferHandle ib; | |
| 177 | ib.idx = bgfx::invalidHandle; | |
| 178 | bgfx::setIndexBuffer(ib); | |
| 179 | ||
| 180 | bgfx::setTransform(ident); | |
| 181 | ||
| 182 | 171 | for (int loopvar = 0; loopvar < m_numberDecaySteps; loopvar++) |
| 183 | 172 | { |
| 184 | 173 | int stepi = m_numberDecaySteps - loopvar - 1; |
| r244818 | r244819 | |
|---|---|---|
| 77 | 77 | struct Context |
| 78 | 78 | { |
| 79 | 79 | Context() |
| 80 | : m_scroll(0) | |
| 80 | : m_scrollf(0.0f) | |
| 81 | , m_mx(0) | |
| 82 | , m_my(0) | |
| 83 | , m_scroll(0) | |
| 81 | 84 | , m_exit(false) |
| 82 | 85 | { |
| 83 | 86 | s_translateKey[27] = Key::Esc; |
| r244818 | r244819 | |
| 170 | 173 | return mask; |
| 171 | 174 | } |
| 172 | 175 | |
| 173 | Key::Enum handleKeyEvent(NSEvent* event, uint8_t* specialKeys) | |
| 176 | Key::Enum handleKeyEvent(NSEvent* event, uint8_t* specialKeys, uint8_t* _pressedChar) | |
| 174 | 177 | { |
| 175 | 178 | NSString* key = [event charactersIgnoringModifiers]; |
| 176 | 179 | unichar keyChar = 0; |
| 177 | //DBG("keyChar %d", keyChar); | |
| 178 | 180 | if ([key length] == 0) |
| 179 | 181 | { |
| 180 | 182 | return Key::None; |
| 181 | 183 | } |
| 182 | 184 | |
| 183 | 185 | keyChar = [key characterAtIndex:0]; |
| 186 | *_pressedChar = (uint8_t)keyChar; | |
| 184 | 187 | |
| 185 | 188 | int keyCode = keyChar; |
| 186 | //DBG("keyCode %d", keyCode); | |
| 187 | 189 | *specialKeys = translateModifiers([event modifierFlags]); |
| 188 | 190 | |
| 189 | 191 | // if this is a unhandled key just return None |
| r244818 | r244819 | |
| 236 | 238 | case NSRightMouseDragged: |
| 237 | 239 | case NSOtherMouseDragged: |
| 238 | 240 | { |
| 239 | int x, y; | |
| 240 | getMousePos(&x, &y); | |
| 241 | m_eventQueue.postMouseEvent(s_defaultWindow, x, y, m_scroll); | |
| 241 | getMousePos(&m_mx, &m_my); | |
| 242 | m_eventQueue.postMouseEvent(s_defaultWindow, m_mx, m_my, m_scroll); | |
| 242 | 243 | break; |
| 243 | 244 | } |
| 244 | 245 | |
| 245 | 246 | case NSLeftMouseDown: |
| 246 | 247 | { |
| 247 | int x, y; | |
| 248 | getMousePos(&x, &y); | |
| 249 | m_eventQueue.postMouseEvent(s_defaultWindow, x, y, m_scroll, MouseButton::Left, true); | |
| 248 | // TODO: remove! | |
| 249 | // Shift + Left Mouse Button acts as middle! This just a temporary solution! | |
| 250 | // This is becase the average OSX user doesn't have middle mouse click. | |
| 251 | MouseButton::Enum mb = ([event modifierFlags] & NSShiftKeyMask) ? MouseButton::Middle : MouseButton::Left; | |
| 252 | m_eventQueue.postMouseEvent(s_defaultWindow, m_mx, m_my, m_scroll, mb, true); | |
| 250 | 253 | break; |
| 251 | 254 | } |
| 252 | 255 | |
| 253 | 256 | case NSLeftMouseUp: |
| 254 | 257 | { |
| 255 | int x, y; | |
| 256 | getMousePos(&x, &y); | |
| 257 | m_eventQueue.postMouseEvent(s_defaultWindow, x, y, m_scroll, MouseButton::Left, false); | |
| 258 | m_eventQueue.postMouseEvent(s_defaultWindow, m_mx, m_my, m_scroll, MouseButton::Left, false); | |
| 259 | m_eventQueue.postMouseEvent(s_defaultWindow, m_mx, m_my, m_scroll, MouseButton::Middle, false); // TODO: remove! | |
| 258 | 260 | break; |
| 259 | 261 | } |
| 260 | 262 | |
| 261 | 263 | case NSRightMouseDown: |
| 262 | 264 | { |
| 263 | int x, y; | |
| 264 | getMousePos(&x, &y); | |
| 265 | m_eventQueue.postMouseEvent(s_defaultWindow, x, y, m_scroll, MouseButton::Right, true); | |
| 265 | m_eventQueue.postMouseEvent(s_defaultWindow, m_mx, m_my, m_scroll, MouseButton::Right, true); | |
| 266 | 266 | break; |
| 267 | 267 | } |
| 268 | 268 | |
| 269 | 269 | case NSRightMouseUp: |
| 270 | 270 | { |
| 271 | int x, y; | |
| 272 | getMousePos(&x, &y); | |
| 273 | m_eventQueue.postMouseEvent(s_defaultWindow, x, y, m_scroll, MouseButton::Right, false); | |
| 271 | m_eventQueue.postMouseEvent(s_defaultWindow, m_mx, m_my, m_scroll, MouseButton::Right, false); | |
| 274 | 272 | break; |
| 275 | 273 | } |
| 276 | 274 | |
| 277 | 275 | case NSOtherMouseDown: |
| 278 | 276 | { |
| 279 | int x, y; | |
| 280 | getMousePos(&x, &y); | |
| 281 | m_eventQueue.postMouseEvent(s_defaultWindow, x, y, m_scroll, MouseButton::Middle, true); | |
| 277 | m_eventQueue.postMouseEvent(s_defaultWindow, m_mx, m_my, m_scroll, MouseButton::Middle, true); | |
| 282 | 278 | break; |
| 283 | 279 | } |
| 284 | 280 | |
| 285 | 281 | case NSOtherMouseUp: |
| 286 | 282 | { |
| 287 | int x, y; | |
| 288 | getMousePos(&x, &y); | |
| 289 | m_eventQueue.postMouseEvent(s_defaultWindow, x, y, m_scroll, MouseButton::Middle, false); | |
| 283 | m_eventQueue.postMouseEvent(s_defaultWindow, m_mx, m_my, m_scroll, MouseButton::Middle, false); | |
| 290 | 284 | break; |
| 291 | 285 | } |
| 292 | 286 | |
| 293 | 287 | case NSScrollWheel: |
| 294 | 288 | { |
| 295 | int x, y; | |
| 296 | getMousePos(&x, &y); | |
| 297 | m_scroll += ([event deltaY] > 0.0f) ? 1 : -1; | |
| 298 | m_eventQueue.postMouseEvent(s_defaultWindow, x, y, m_scroll); | |
| 289 | m_scrollf += [event deltaY]; | |
| 290 | ||
| 291 | m_scroll = (int32_t)m_scrollf; | |
| 292 | m_eventQueue.postMouseEvent(s_defaultWindow, m_mx, m_my, m_scroll); | |
| 299 | 293 | break; |
| 300 | 294 | } |
| 301 | 295 | |
| 302 | 296 | case NSKeyDown: |
| 303 | 297 | { |
| 304 | 298 | uint8_t modifiers = 0; |
| 305 | Key::Enum key = handleKeyEvent(event, &modifiers); | |
| 299 | uint8_t pressedChar[4]; | |
| 300 | Key::Enum key = handleKeyEvent(event, &modifiers, &pressedChar[0]); | |
| 306 | 301 | |
| 307 | // If KeyCode is none we don't don't handle the key and special case for cmd+q (quit) | |
| 308 | // Note that return false here means that we take care of the key (instead of the default behavior) | |
| 302 | // Returning false means that we take care of the key (instead of the default behavior) | |
| 309 | 303 | if (key != Key::None) |
| 310 | 304 | { |
| 311 | if (key != Key::KeyQ | |
| 312 | && !(modifiers & Modifier::RightMeta) ) | |
| 305 | if (key == Key::KeyQ && (modifiers & Modifier::RightMeta) ) | |
| 313 | 306 | { |
| 307 | m_eventQueue.postExitEvent(); | |
| 308 | } | |
| 309 | else if ( (Key::Key0 <= key && key <= Key::KeyZ) | |
| 310 | || (Key::Esc <= key && key <= Key::Minus) ) | |
| 311 | { | |
| 312 | m_eventQueue.postCharEvent(s_defaultWindow, 1, pressedChar); | |
| 313 | return false; | |
| 314 | } | |
| 315 | else | |
| 316 | { | |
| 314 | 317 | m_eventQueue.postKeyEvent(s_defaultWindow, key, modifiers, true); |
| 315 | 318 | return false; |
| 316 | 319 | } |
| r244818 | r244819 | |
| 322 | 325 | case NSKeyUp: |
| 323 | 326 | { |
| 324 | 327 | uint8_t modifiers = 0; |
| 325 | Key::Enum key = handleKeyEvent(event, &modifiers); | |
| 328 | uint8_t pressedChar[4]; | |
| 329 | Key::Enum key = handleKeyEvent(event, &modifiers, &pressedChar[0]); | |
| 326 | 330 | |
| 331 | BX_UNUSED(pressedChar); | |
| 332 | ||
| 327 | 333 | if (key != Key::None) |
| 328 | 334 | { |
| 329 | 335 | m_eventQueue.postKeyEvent(s_defaultWindow, key, modifiers, false); |
| r244818 | r244819 | |
| 347 | 353 | { |
| 348 | 354 | WindowHandle handle = { 0 }; |
| 349 | 355 | NSWindow* window = m_window[handle.idx]; |
| 350 | NSRect rect = [window frame]; | |
| 356 | NSRect originalFrame = [window frame]; | |
| 357 | NSRect rect = [NSWindow contentRectForFrameRect: originalFrame styleMask: NSTitledWindowMask]; | |
| 351 | 358 | uint32_t width = uint32_t(rect.size.width); |
| 352 | 359 | uint32_t height = uint32_t(rect.size.height); |
| 353 | 360 | m_eventQueue.postSizeEvent(handle, width, height); |
| 361 | ||
| 362 | // Make sure mouse button state is 'up' after resize. | |
| 363 | m_eventQueue.postMouseEvent(s_defaultWindow, m_mx, m_my, m_scroll, MouseButton::Left, false); | |
| 364 | m_eventQueue.postMouseEvent(s_defaultWindow, m_mx, m_my, m_scroll, MouseButton::Right, false); | |
| 354 | 365 | } |
| 355 | 366 | |
| 356 | 367 | int32_t run(int _argc, char** _argv) |
| r244818 | r244819 | |
| 429 | 440 | } |
| 430 | 441 | } |
| 431 | 442 | |
| 432 | ||
| 433 | 443 | m_eventQueue.postExitEvent(); |
| 434 | 444 | |
| 435 | 445 | while (bgfx::RenderFrame::NoContext != bgfx::renderFrame() ) {}; |
| r244818 | r244819 | |
| 443 | 453 | bx::HandleAllocT<ENTRY_CONFIG_MAX_WINDOWS> m_windowAlloc; |
| 444 | 454 | NSWindow* m_window[ENTRY_CONFIG_MAX_WINDOWS]; |
| 445 | 455 | |
| 456 | float m_scrollf; | |
| 457 | int32_t m_mx; | |
| 458 | int32_t m_my; | |
| 446 | 459 | int32_t m_scroll; |
| 447 | bool m_exit; | |
| 460 | bool m_exit; | |
| 448 | 461 | }; |
| 449 | 462 | |
| 450 | 463 | static Context s_ctx; |
| r244818 | r244819 | |
|---|---|---|
| 1405 | 1405 | { |
| 1406 | 1406 | const size_t cursor = size_t(strlen(_str)); |
| 1407 | 1407 | |
| 1408 | if (m_char == 0x08) //backspace | |
| 1408 | if (m_char == 0x08 || m_char == 0x7f) //backspace or delete | |
| 1409 | 1409 | { |
| 1410 | 1410 | _str[cursor-1] = '\0'; |
| 1411 | 1411 | } |
| r244818 | r244819 | |
|---|---|---|
| 19 | 19 | BGFX_RENDERER_TYPE_NULL, |
| 20 | 20 | BGFX_RENDERER_TYPE_DIRECT3D9, |
| 21 | 21 | BGFX_RENDERER_TYPE_DIRECT3D11, |
| 22 | BGFX_RENDERER_TYPE_OPENGLES = 4, | |
| 22 | BGFX_RENDERER_TYPE_DIRECT3D12, | |
| 23 | BGFX_RENDERER_TYPE_OPENGLES, | |
| 23 | 24 | BGFX_RENDERER_TYPE_OPENGL, |
| 25 | BGFX_RENDERER_TYPE_VULKAN, | |
| 24 | 26 | |
| 25 | 27 | BGFX_RENDERER_TYPE_COUNT |
| 26 | 28 | |
| r244818 | r244819 | |
| 104 | 106 | BGFX_TEXTURE_FORMAT_RG32, |
| 105 | 107 | BGFX_TEXTURE_FORMAT_RG32F, |
| 106 | 108 | BGFX_TEXTURE_FORMAT_BGRA8, |
| 109 | BGFX_TEXTURE_FORMAT_RGBA8, | |
| 107 | 110 | BGFX_TEXTURE_FORMAT_RGBA16, |
| 108 | 111 | BGFX_TEXTURE_FORMAT_RGBA16F, |
| 109 | 112 | BGFX_TEXTURE_FORMAT_RGBA32, |
| r244818 | r244819 | |
|---|---|---|
| 49 | 49 | Direct3D12, //!< Direct3D 12.0 |
| 50 | 50 | OpenGLES, //!< OpenGL ES 2.0+ |
| 51 | 51 | OpenGL, //!< OpenGL 2.1+ |
| 52 | Vulkan, //!< Vulkan | |
| 52 | 53 | |
| 53 | 54 | Count |
| 54 | 55 | }; |
| r244818 | r244819 | |
| 142 | 143 | RG32, |
| 143 | 144 | RG32F, |
| 144 | 145 | BGRA8, |
| 146 | RGBA8, | |
| 145 | 147 | RGBA16, |
| 146 | 148 | RGBA16F, |
| 147 | 149 | RGBA32, |
| r244818 | r244819 | |
|---|---|---|
| 62 | 62 | "$(DXSDK_DIR)/include", |
| 63 | 63 | } |
| 64 | 64 | |
| 65 | if (_OPTIONS["vs"] == "vs2012-xp") or (_OPTIONS["vs"] == "vs2013-xp") then | |
| 66 | configuration { "vs201*" } | |
| 67 | includedirs { | |
| 68 | "$(DXSDK_DIR)/include", | |
| 69 | } | |
| 70 | end | |
| 71 | ||
| 65 | 72 | configuration { "winphone8*"} |
| 66 | 73 | linkoptions { |
| 67 | 74 | "/ignore:4264" -- LNK4264: archiving object file compiled with /ZW into a static library; note that when authoring Windows Runtime types it is not recommended to link with a static library that contains Windows Runtime metadata |
| r244818 | r244819 | |
|---|---|---|
| 35 | 35 | includedirs { |
| 36 | 36 | "$(DXSDK_DIR)/include", |
| 37 | 37 | } |
| 38 | if (_OPTIONS["vs"] == "vs2012-xp") or (_OPTIONS["vs"] == "vs2013-xp") then | |
| 39 | configuration { "vs201*" } | |
| 40 | includedirs { | |
| 41 | "$(DXSDK_DIR)/include", | |
| 42 | } | |
| 43 | end | |
| 38 | 44 | |
| 39 | ||
| 40 | 45 | configuration { "winphone8*"} |
| 41 | 46 | linkoptions { |
| 42 | 47 | "/ignore:4264" -- LNK4264: archiving object file compiled with /ZW into a static library; note that when authoring Windows Runtime types it is not recommended to link with a static library that contains Windows Runtime metadata |
| r244818 | r244819 | |
|---|---|---|
| 972 | 972 | m_viewRemap[ii] = ii; |
| 973 | 973 | } |
| 974 | 974 | |
| 975 | memset(m_fb, 0xff, sizeof(m_fb) ); | |
| 976 | memset(m_clear, 0, sizeof(m_clear) ); | |
| 977 | memset(m_rect, 0, sizeof(m_rect) ); | |
| 975 | memset(m_fb, 0xff, sizeof(m_fb) ); | |
| 976 | memset(m_clear, 0, sizeof(m_clear) ); | |
| 977 | memset(m_rect, 0, sizeof(m_rect) ); | |
| 978 | 978 | memset(m_scissor, 0, sizeof(m_scissor) ); |
| 979 | memset(m_seq, 0, sizeof(m_seq) ); | |
| 979 | memset(m_seq, 0, sizeof(m_seq) ); | |
| 980 | 980 | memset(m_seqMask, 0, sizeof(m_seqMask) ); |
| 981 | 981 | |
| 982 | 982 | for (uint32_t ii = 0; ii < BX_COUNTOF(m_rect); ++ii) |
| 983 | 983 | { |
| 984 | m_rect[ii].m_width = 1; | |
| 984 | m_rect[ii].m_width = 1; | |
| 985 | 985 | m_rect[ii].m_height = 1; |
| 986 | 986 | } |
| 987 | 987 | |
| r244818 | r244819 | |
| 1347 | 1347 | extern RendererContextI* rendererCreateD3D12(); |
| 1348 | 1348 | extern void rendererDestroyD3D12(); |
| 1349 | 1349 | |
| 1350 | extern RendererContextI* rendererCreateVK(); | |
| 1351 | extern void rendererDestroyVK(); | |
| 1352 | ||
| 1350 | 1353 | struct RendererCreator |
| 1351 | 1354 | { |
| 1352 | 1355 | RendererCreateFn createFn; |
| r244818 | r244819 | |
| 1363 | 1366 | { rendererCreateD3D12, rendererDestroyD3D12, BGFX_RENDERER_DIRECT3D12_NAME, !!BGFX_CONFIG_RENDERER_DIRECT3D12 }, // Direct3D12 |
| 1364 | 1367 | { rendererCreateGL, rendererDestroyGL, BGFX_RENDERER_OPENGL_NAME, !!BGFX_CONFIG_RENDERER_OPENGLES }, // OpenGLES |
| 1365 | 1368 | { rendererCreateGL, rendererDestroyGL, BGFX_RENDERER_OPENGL_NAME, !!BGFX_CONFIG_RENDERER_OPENGL }, // OpenGL |
| 1369 | { rendererCreateVK, rendererDestroyVK, BGFX_RENDERER_VULKAN_NAME, !!BGFX_CONFIG_RENDERER_VULKAN }, // Vulkan | |
| 1366 | 1370 | }; |
| 1367 | 1371 | BX_STATIC_ASSERT(BX_COUNTOF(s_rendererCreator) == RendererType::Count); |
| 1368 | 1372 | |
| r244818 | r244819 | |
| 1446 | 1450 | { |
| 1447 | 1451 | _type = RendererType::OpenGLES; |
| 1448 | 1452 | } |
| 1453 | else if (s_rendererCreator[RendererType::Vulkan].supported) | |
| 1454 | { | |
| 1455 | _type = RendererType::Vulkan; | |
| 1456 | } | |
| 1449 | 1457 | } |
| 1450 | 1458 | else if (BX_ENABLED(0 |
| 1451 | 1459 | || BX_PLATFORM_ANDROID |
| r244818 | r244819 | |
|---|---|---|
| 44 | 44 | |
| 45 | 45 | #define SHARED groupshared |
| 46 | 46 | |
| 47 | #define IMAGE2D_RO(_name, _reg) Texture2D _name : register(t[_reg]) | |
| 48 | #define IMAGE2D_RW(_name, _reg) RWTexture2D<float4> _name : register(u[_reg]) | |
| 49 | #define IMAGE2D_WR(_name, _reg) IMAGE2D_RW(_name, _reg) | |
| 47 | #define r32ui uint | |
| 48 | #define r32f float | |
| 49 | #define rg16f float2 | |
| 50 | #define rgba8 float4 | |
| 50 | 51 | |
| 52 | #define IMAGE2D_RO( _name, _format, _reg) Texture2D<_format> _name : register(t[_reg]) | |
| 53 | #define UIMAGE2D_RO(_name, _format, _reg) Texture2D<_format> _name : register(t[_reg]) | |
| 54 | #define IMAGE2D_WR( _name, _format, _reg) RWTexture2D<_format> _name : register(u[_reg]) | |
| 55 | #define UIMAGE2D_WR(_name, _format, _reg) RWTexture2D<_format> _name : register(u[_reg]) | |
| 56 | #define IMAGE2D_RW( _name, _reg) RWTexture2D<float> _name : register(u[_reg]) | |
| 57 | #define UIMAGE2D_RW(_name, _reg) RWTexture2D<uint> _name : register(u[_reg]) | |
| 58 | ||
| 51 | 59 | #define BUFFER_RO(_name, _struct, _reg) Buffer<_struct> _name : register(b[_reg]) |
| 52 | 60 | #define BUFFER_RW(_name, _struct, _reg) RWBuffer<_struct> _name : register(u[_reg]) |
| 53 | 61 | #define BUFFER_WR(_name, _struct, _reg) BUFFER_RW(_name, _struct, _reg) |
| r244818 | r244819 | |
| 153 | 161 | |
| 154 | 162 | #define SHARED shared |
| 155 | 163 | |
| 156 | #define __IMAGE2D_XX(_name, _reg, _access) \ | |
| 157 | layout(rgba8, binding=_reg) _access uniform highp image2D _name | |
| 164 | #define __IMAGE_XX(_name, _format, _reg, _image, _access) \ | |
| 165 | layout(_format, binding=_reg) _access uniform highp _image _name | |
| 158 | 166 | |
| 159 | 167 | #define readwrite |
| 160 | #define IMAGE2D_RO(_name, _reg) __IMAGE2D_XX(_name, _reg, readonly) | |
| 161 | #define IMAGE2D_RW(_name, _reg) __IMAGE2D_XX(_name, _reg, readwrite) | |
| 162 | #define IMAGE2D_WR(_name, _reg) __IMAGE2D_XX(_name, _reg, writeonly) | |
| 168 | #define IMAGE2D_RO( _name, _format, _reg) __IMAGE_XX(_name, _format, _reg, image2D, readonly) | |
| 169 | #define UIMAGE2D_RO(_name, _format, _reg) __IMAGE_XX(_name, _format, _reg, uimage2D, readonly) | |
| 170 | #define IMAGE2D_WR( _name, _format, _reg) __IMAGE_XX(_name, _format, _reg, image2D, writeonly) | |
| 171 | #define UIMAGE2D_WR(_name, _format, _reg) __IMAGE_XX(_name, _format, _reg, uimage2D, writeonly) | |
| 172 | #define IMAGE2D_RW( _name, _reg) __IMAGE_XX(_name, r32f, _reg, image2D, readwrite) | |
| 173 | #define UIMAGE2D_RW(_name, _reg) __IMAGE_XX(_name, r32ui, _reg, uimage2D, readwrite) | |
| 163 | 174 | |
| 164 | 175 | #define __BUFFER_XX(_name, _type, _reg, _access) \ |
| 165 | 176 | layout(std430, binding=_reg) _access buffer _name ## Buffer \ |
| r244818 | r244819 | |
|---|---|---|
| 154 | 154 | #define BGFX_RENDERER_DIRECT3D9_NAME "Direct3D 9" |
| 155 | 155 | #define BGFX_RENDERER_DIRECT3D11_NAME "Direct3D 11" |
| 156 | 156 | #define BGFX_RENDERER_DIRECT3D12_NAME "Direct3D 12" |
| 157 | #define BGFX_RENDERER_VULKAN_NAME "Vulkan" | |
| 157 | 158 | #define BGFX_RENDERER_NULL_NAME "NULL" |
| 158 | 159 | |
| 159 | 160 | #if BGFX_CONFIG_RENDERER_OPENGL |
| r244818 | r244819 | |
| 3260 | 3261 | BGFX_API_FUNC(void setImage(uint8_t _stage, UniformHandle _sampler, TextureHandle _handle, uint8_t _mip, Access::Enum _access, TextureFormat::Enum _format) ) |
| 3261 | 3262 | { |
| 3262 | 3263 | _format = TextureFormat::Count == _format ? TextureFormat::Enum(m_textureRef[_handle.idx].m_format) : _format; |
| 3264 | BX_CHECK(_format != TextureFormat::BGRA8 | |
| 3265 | , "Can't use TextureFormat::BGRA8 with compute, use TextureFormat::RGBA8 instead." | |
| 3266 | ); | |
| 3263 | 3267 | m_submit->setImage(_stage, _sampler, _handle, _mip, _access, _format); |
| 3264 | 3268 | } |
| 3265 | 3269 |
| r244818 | r244819 | |
|---|---|---|
| 17 | 17 | && !defined(BGFX_CONFIG_RENDERER_DIRECT3D12) \ |
| 18 | 18 | && !defined(BGFX_CONFIG_RENDERER_OPENGL) \ |
| 19 | 19 | && !defined(BGFX_CONFIG_RENDERER_OPENGLES) \ |
| 20 | && !defined(BGFX_CONFIG_RENDERER_VULKAN) \ | |
| 20 | 21 | && !defined(BGFX_CONFIG_RENDERER_NULL) |
| 21 | 22 | |
| 22 | 23 | # ifndef BGFX_CONFIG_RENDERER_DIRECT3D9 |
| r244818 | r244819 | |
| 59 | 60 | ? 1 : 0) |
| 60 | 61 | # endif // BGFX_CONFIG_RENDERER_OPENGLES |
| 61 | 62 | |
| 63 | # ifndef BGFX_CONFIG_RENDERER_VULKAN | |
| 64 | # define BGFX_CONFIG_RENDERER_VULKAN 0 | |
| 65 | # endif // BGFX_CONFIG_RENDERER_VULKAN | |
| 66 | ||
| 62 | 67 | # ifndef BGFX_CONFIG_RENDERER_NULL |
| 63 | 68 | # define BGFX_CONFIG_RENDERER_NULL (!(0 \ |
| 64 | 69 | || BGFX_CONFIG_RENDERER_DIRECT3D9 \ |
| r244818 | r244819 | |
| 89 | 94 | # define BGFX_CONFIG_RENDERER_OPENGLES 0 |
| 90 | 95 | # endif // BGFX_CONFIG_RENDERER_OPENGLES |
| 91 | 96 | |
| 97 | # ifndef BGFX_CONFIG_RENDERER_VULKAN | |
| 98 | # define BGFX_CONFIG_RENDERER_VULKAN 0 | |
| 99 | # endif // BGFX_CONFIG_RENDERER_VULKAN | |
| 100 | ||
| 92 | 101 | # ifndef BGFX_CONFIG_RENDERER_NULL |
| 93 | 102 | # define BGFX_CONFIG_RENDERER_NULL 0 |
| 94 | 103 | # endif // BGFX_CONFIG_RENDERER_NULL |
| r244818 | r244819 | |
|---|---|---|
| 49 | 49 | { 64, 1, 1, 8, 1, 1 }, // RG32 |
| 50 | 50 | { 64, 1, 1, 8, 1, 1 }, // RG32F |
| 51 | 51 | { 32, 1, 1, 4, 1, 1 }, // BGRA8 |
| 52 | { 32, 1, 1, 4, 1, 1 }, // RGBA8 | |
| 52 | 53 | { 64, 1, 1, 8, 1, 1 }, // RGBA16 |
| 53 | 54 | { 64, 1, 1, 8, 1, 1 }, // RGBA16F |
| 54 | 55 | { 128, 1, 1, 16, 1, 1 }, // RGBA32 |
| r244818 | r244819 | |
| 102 | 103 | "RG32", // RG32 |
| 103 | 104 | "RG32F", // RG32F |
| 104 | 105 | "BGRA8", // BGRA8 |
| 106 | "RGBA8", // RGBA8 | |
| 105 | 107 | "RGBA16", // RGBA16 |
| 106 | 108 | "RGBA16F", // RGBA16F |
| 107 | 109 | "RGBA32", // RGBA32 |
| r244818 | r244819 | |
|---|---|---|
| 138 | 138 | HashMap m_hashMap; |
| 139 | 139 | }; |
| 140 | 140 | |
| 141 | class StateCache | |
| 142 | { | |
| 143 | public: | |
| 144 | void add(uint64_t _id, uint16_t _item) | |
| 145 | { | |
| 146 | invalidate(_id); | |
| 147 | m_hashMap.insert(stl::make_pair(_id, _item)); | |
| 148 | } | |
| 149 | ||
| 150 | uint16_t find(uint64_t _id) | |
| 151 | { | |
| 152 | HashMap::iterator it = m_hashMap.find(_id); | |
| 153 | if (it != m_hashMap.end()) | |
| 154 | { | |
| 155 | return it->second; | |
| 156 | } | |
| 157 | ||
| 158 | return UINT16_MAX; | |
| 159 | } | |
| 160 | ||
| 161 | void invalidate(uint64_t _id) | |
| 162 | { | |
| 163 | HashMap::iterator it = m_hashMap.find(_id); | |
| 164 | if (it != m_hashMap.end()) | |
| 165 | { | |
| 166 | m_hashMap.erase(it); | |
| 167 | } | |
| 168 | } | |
| 169 | ||
| 170 | void invalidate() | |
| 171 | { | |
| 172 | m_hashMap.clear(); | |
| 173 | } | |
| 174 | ||
| 175 | uint32_t getCount() const | |
| 176 | { | |
| 177 | return uint32_t(m_hashMap.size()); | |
| 178 | } | |
| 179 | ||
| 180 | private: | |
| 181 | typedef stl::unordered_map<uint64_t, uint16_t> HashMap; | |
| 182 | HashMap m_hashMap; | |
| 183 | }; | |
| 184 | ||
| 141 | 185 | } // namespace bgfx |
| 142 | 186 | |
| 143 | 187 | #endif // BGFX_RENDERER_D3D_H_HEADER_GUARD |
| r244818 | r244819 | |
|---|---|---|
| 213 | 213 | { DXGI_FORMAT_R32G32_UINT, DXGI_FORMAT_R32G32_UINT, DXGI_FORMAT_UNKNOWN }, // RG32 |
| 214 | 214 | { DXGI_FORMAT_R32G32_FLOAT, DXGI_FORMAT_R32G32_FLOAT, DXGI_FORMAT_UNKNOWN }, // RG32F |
| 215 | 215 | { DXGI_FORMAT_B8G8R8A8_UNORM, DXGI_FORMAT_B8G8R8A8_UNORM, DXGI_FORMAT_UNKNOWN }, // BGRA8 |
| 216 | { DXGI_FORMAT_R8G8B8A8_UNORM, DXGI_FORMAT_R8G8B8A8_UNORM, DXGI_FORMAT_UNKNOWN }, // RGBA8 | |
| 216 | 217 | { DXGI_FORMAT_R16G16B16A16_UNORM, DXGI_FORMAT_R16G16B16A16_UNORM, DXGI_FORMAT_UNKNOWN }, // RGBA16 |
| 217 | 218 | { DXGI_FORMAT_R16G16B16A16_FLOAT, DXGI_FORMAT_R16G16B16A16_FLOAT, DXGI_FORMAT_UNKNOWN }, // RGBA16F |
| 218 | 219 | { DXGI_FORMAT_R32G32B32A32_UINT, DXGI_FORMAT_R32G32B32A32_UINT, DXGI_FORMAT_UNKNOWN }, // RGBA32 |
| r244818 | r244819 | |
|---|---|---|
| 219 | 219 | { D3DFMT_UNKNOWN }, // RG32 |
| 220 | 220 | { D3DFMT_G32R32F }, // RG32F |
| 221 | 221 | { D3DFMT_A8R8G8B8 }, // BGRA8 |
| 222 | { D3DFMT_A8R8G8B8 }, // RGBA8 | |
| 222 | 223 | { D3DFMT_A16B16G16R16 }, // RGBA16 |
| 223 | 224 | { D3DFMT_A16B16G16R16F }, // RGBA16F |
| 224 | 225 | { D3DFMT_UNKNOWN }, // RGBA32 |
| r244818 | r244819 | |
|---|---|---|
| 215 | 215 | { GL_RG32UI, GL_RG, GL_UNSIGNED_INT, true }, // RG32 |
| 216 | 216 | { GL_RG32F, GL_RG, GL_FLOAT, true }, // RG32F |
| 217 | 217 | { GL_RGBA, GL_RGBA, GL_UNSIGNED_BYTE, true }, // BGRA8 |
| 218 | { GL_RGBA, GL_RGBA, GL_UNSIGNED_BYTE, true }, // RGBA8 | |
| 218 | 219 | { GL_RGBA16, GL_RGBA, GL_UNSIGNED_BYTE, true }, // RGBA16 |
| 219 | 220 | { GL_RGBA16F, GL_RGBA, GL_HALF_FLOAT, true }, // RGBA16F |
| 220 | 221 | { GL_RGBA32UI, GL_RGBA, GL_UNSIGNED_INT, true }, // RGBA32 |
| r244818 | r244819 | |
| 268 | 269 | GL_RG32UI, // RG32 |
| 269 | 270 | GL_RG32F, // RG32F |
| 270 | 271 | GL_RGBA8, // BGRA8 |
| 272 | GL_RGBA8, // RGBA8 | |
| 271 | 273 | GL_RGBA16, // RGBA16 |
| 272 | 274 | GL_RGBA16F, // RGBA16F |
| 273 | 275 | GL_RGBA32UI, // RGBA32 |
| r244818 | r244819 | |
| 321 | 323 | GL_RG32UI, // RG32 |
| 322 | 324 | GL_RG32F, // RG32F |
| 323 | 325 | GL_RGBA8, // BGRA8 |
| 326 | GL_RGBA8, // RGBA8 | |
| 324 | 327 | GL_RGBA16, // RGBA16 |
| 325 | 328 | GL_RGBA16F, // RGBA16F |
| 326 | 329 | GL_RGBA32UI, // RGBA32 |
| r0 | r244819 | |
|---|---|---|
| 1 | /* | |
| 2 | * Copyright 2011-2015 Branimir Karadzic. All rights reserved. | |
| 3 | * License: http://www.opensource.org/licenses/BSD-2-Clause | |
| 4 | */ | |
| 5 | ||
| 6 | #include "bgfx_p.h" | |
| 7 | #if BGFX_CONFIG_RENDERER_VULKAN | |
| 8 | # include "../../vk/src/renderer_vk.cpp" | |
| 9 | #else | |
| 10 | ||
| 11 | namespace bgfx | |
| 12 | { | |
| 13 | RendererContextI* rendererCreateVK() | |
| 14 | { | |
| 15 | return NULL; | |
| 16 | } | |
| 17 | ||
| 18 | void rendererDestroyVK() | |
| 19 | { | |
| 20 | } | |
| 21 | } // namespace bgfx | |
| 22 | ||
| 23 | #endif // BGFX_CONFIG_RENDERER_VULKAN |
| r244818 | r244819 | |
|---|---|---|
| 45 | 45 | &s_attribTypeSizeDx9, |
| 46 | 46 | #elif BGFX_CONFIG_RENDERER_DIRECT3D11 || BGFX_CONFIG_RENDERER_DIRECT3D12 |
| 47 | 47 | &s_attribTypeSizeDx1x, |
| 48 | #elif BGFX_CONFIG_RENDERER_OPENGL || BGFX_CONFIG_RENDERER_OPENGLES | |
| 48 | #elif BGFX_CONFIG_RENDERER_OPENGL || BGFX_CONFIG_RENDERER_OPENGLES || BGFX_CONFIG_RENDERER_VULKAN | |
| 49 | 49 | &s_attribTypeSizeGl, |
| 50 | 50 | #else |
| 51 | 51 | &s_attribTypeSizeDx9, |
| r244818 | r244819 | |
| 55 | 55 | &s_attribTypeSizeDx1x, // Direct3D12 |
| 56 | 56 | &s_attribTypeSizeGl, // OpenGLES |
| 57 | 57 | &s_attribTypeSizeGl, // OpenGL |
| 58 | &s_attribTypeSizeGl, // Vulkan | |
| 58 | 59 | }; |
| 59 | 60 | BX_STATIC_ASSERT(BX_COUNTOF(s_attribTypeSize) == bgfx::RendererType::Count); |
| 60 | 61 | |
| r244818 | r244819 | |
| 140 | 141 | _asInt = !!(val&(1<<7) ); |
| 141 | 142 | } |
| 142 | 143 | |
| 143 | static const char* s_attrName[] = | |
| 144 | static const char* s_attrName[] = | |
| 144 | 145 | { |
| 145 | 146 | "Attrib::Position", |
| 146 | 147 | "Attrib::Normal", |
| r244818 | r244819 | |
|---|---|---|
| 125 | 125 | # ifndef NOMINMAX |
| 126 | 126 | # define NOMINMAX |
| 127 | 127 | # endif // NOMINMAX |
| 128 | # if defined(_MSC_VER) && (_MSC_VER >= 1700) | |
| 128 | // If _USING_V110_SDK71_ is defined it means we are using the v110_xp or v120_xp toolset. | |
| 129 | # if defined(_MSC_VER) && (_MSC_VER >= 1700) && (!_USING_V110_SDK71_) | |
| 129 | 130 | # include <winapifamily.h> |
| 130 | # endif // defined(_MSC_VER) && (_MSC_VER >= 1700) | |
| 131 | # endif // defined(_MSC_VER) && (_MSC_VER >= 1700) && (!_USING_V110_SDK71_) | |
| 131 | 132 | # if !defined(WINAPI_FAMILY) || (WINAPI_FAMILY == WINAPI_FAMILY_DESKTOP_APP) |
| 132 | 133 | # undef BX_PLATFORM_WINDOWS |
| 133 | 134 | # if !defined(WINVER) && !defined(_WIN32_WINNT) |
| r244818 | r244819 | |
|---|---|---|
| 40 | 40 | allowed = { |
| 41 | 41 | { "vs2012-clang", "Clang 3.6" }, |
| 42 | 42 | { "vs2013-clang", "Clang 3.6" }, |
| 43 | { "vs2012-xp", "Visual Studio 2012 targeting XP" }, | |
| 44 | { "vs2013-xp", "Visual Studio 2013 targeting XP" }, | |
| 43 | 45 | { "winphone8", "Windows Phone 8.0" }, |
| 44 | 46 | { "winphone81", "Windows Phone 8.1" }, |
| 45 | 47 | }, |
| r244818 | r244819 | |
| 291 | 293 | platforms { "ARM" } |
| 292 | 294 | location (path.join(_buildDir, "projects", _ACTION .. "-winphone81")) |
| 293 | 295 | end |
| 296 | ||
| 297 | if ("vs2012-xp") == _OPTIONS["vs"] then | |
| 298 | premake.vstudio.toolset = ("v110_xp") | |
| 299 | location (path.join(_buildDir, "projects", _ACTION .. "-xp")) | |
| 300 | end | |
| 301 | ||
| 302 | if ("vs2013-xp") == _OPTIONS["vs"] then | |
| 303 | premake.vstudio.toolset = ("v120_xp") | |
| 304 | location (path.join(_buildDir, "projects", _ACTION .. "-xp")) | |
| 305 | end | |
| 306 | ||
| 294 | 307 | elseif _ACTION == "xcode4" then |
| 295 | 308 | |
| 296 | 309 | if "osx" == _OPTIONS["xcode"] then |
| r244818 | r244819 |
|---|
| Previous | 199869 Revisions | Next |