commit
2b6a5929aa
@ -211,6 +211,7 @@ namespace entry
|
||||
void setWindowSize(WindowHandle _handle, uint32_t _width, uint32_t _height);
|
||||
void setWindowTitle(WindowHandle _handle, const char* _title);
|
||||
void toggleWindowFrame(WindowHandle _handle);
|
||||
void toggleFullscreen(WindowHandle _handle);
|
||||
void setMouseLock(WindowHandle _handle, bool _lock);
|
||||
|
||||
struct WindowState
|
||||
|
@ -440,6 +440,11 @@ namespace entry
|
||||
BX_UNUSED(_handle);
|
||||
}
|
||||
|
||||
void toggleFullscreen(WindowHandle _handle)
|
||||
{
|
||||
BX_UNUSED(_handle);
|
||||
}
|
||||
|
||||
void setMouseLock(WindowHandle _handle, bool _lock)
|
||||
{
|
||||
BX_UNUSED(_handle, _lock);
|
||||
|
@ -59,6 +59,11 @@ namespace entry
|
||||
BX_UNUSED(_handle);
|
||||
}
|
||||
|
||||
void toggleFullscreen(WindowHandle _handle)
|
||||
{
|
||||
BX_UNUSED(_handle);
|
||||
}
|
||||
|
||||
void setMouseLock(WindowHandle _handle, bool _lock)
|
||||
{
|
||||
BX_UNUSED(_handle, _lock);
|
||||
|
@ -126,6 +126,11 @@ namespace entry
|
||||
BX_UNUSED(_handle);
|
||||
}
|
||||
|
||||
void toggleFullscreen(WindowHandle _handle)
|
||||
{
|
||||
BX_UNUSED(_handle);
|
||||
}
|
||||
|
||||
void setMouseLock(WindowHandle _handle, bool _lock)
|
||||
{
|
||||
BX_UNUSED(_handle, _lock);
|
||||
|
@ -94,6 +94,11 @@ namespace entry
|
||||
BX_UNUSED(_handle);
|
||||
}
|
||||
|
||||
void toggleFullscreen(WindowHandle _handle)
|
||||
{
|
||||
BX_UNUSED(_handle);
|
||||
}
|
||||
|
||||
void setMouseLock(WindowHandle _handle, bool _lock)
|
||||
{
|
||||
BX_UNUSED(_handle, _lock);
|
||||
|
@ -81,7 +81,9 @@ namespace entry
|
||||
, m_mx(0)
|
||||
, m_my(0)
|
||||
, m_scroll(0)
|
||||
, m_style(0)
|
||||
, m_exit(false)
|
||||
, m_fullscreen(false)
|
||||
{
|
||||
s_translateKey[27] = Key::Esc;
|
||||
s_translateKey[13] = Key::Return;
|
||||
@ -138,7 +140,7 @@ namespace entry
|
||||
NSWindow* window = m_window[handle.idx];
|
||||
NSRect originalFrame = [window frame];
|
||||
NSPoint location = [window mouseLocationOutsideOfEventStream];
|
||||
NSRect adjustFrame = [NSWindow contentRectForFrameRect: originalFrame styleMask: NSTitledWindowMask];
|
||||
NSRect adjustFrame = [window contentRectForFrameRect: originalFrame];
|
||||
|
||||
int x = location.x;
|
||||
int y = (int)adjustFrame.size.height - (int)location.y;
|
||||
@ -246,9 +248,9 @@ namespace entry
|
||||
case NSLeftMouseDown:
|
||||
{
|
||||
// TODO: remove!
|
||||
// Shift + Left Mouse Button acts as middle! This just a temporary solution!
|
||||
// Command + Left Mouse Button acts as middle! This just a temporary solution!
|
||||
// This is becase the average OSX user doesn't have middle mouse click.
|
||||
MouseButton::Enum mb = ([event modifierFlags] & NSShiftKeyMask) ? MouseButton::Middle : MouseButton::Left;
|
||||
MouseButton::Enum mb = ([event modifierFlags] & NSCommandKeyMask) ? MouseButton::Middle : MouseButton::Left;
|
||||
m_eventQueue.postMouseEvent(s_defaultWindow, m_mx, m_my, m_scroll, mb, true);
|
||||
break;
|
||||
}
|
||||
@ -306,8 +308,13 @@ namespace entry
|
||||
{
|
||||
m_eventQueue.postExitEvent();
|
||||
}
|
||||
else if ( (Key::Key0 <= key && key <= Key::KeyZ)
|
||||
|| (Key::Esc <= key && key <= Key::Minus) )
|
||||
else
|
||||
{
|
||||
enum { ShiftMask = Modifier::LeftShift|Modifier::RightShift };
|
||||
const bool nonShiftModifiers = (0 != (modifiers&(~ShiftMask) ) );
|
||||
const bool isCharPressed = (Key::Key0 <= key && key <= Key::KeyZ) || (Key::Esc <= key && key <= Key::Minus) ;
|
||||
const bool isText = isCharPressed && !nonShiftModifiers;
|
||||
if (isText)
|
||||
{
|
||||
m_eventQueue.postCharEvent(s_defaultWindow, 1, pressedChar);
|
||||
return false;
|
||||
@ -318,6 +325,7 @@ namespace entry
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
break;
|
||||
}
|
||||
@ -354,7 +362,7 @@ namespace entry
|
||||
WindowHandle handle = { 0 };
|
||||
NSWindow* window = m_window[handle.idx];
|
||||
NSRect originalFrame = [window frame];
|
||||
NSRect rect = [NSWindow contentRectForFrameRect: originalFrame styleMask: NSTitledWindowMask];
|
||||
NSRect rect = [window contentRectForFrameRect: originalFrame];
|
||||
uint32_t width = uint32_t(rect.size.width);
|
||||
uint32_t height = uint32_t(rect.size.height);
|
||||
m_eventQueue.postSizeEvent(handle, width, height);
|
||||
@ -398,26 +406,33 @@ namespace entry
|
||||
[menubar addItem:appMenuItem];
|
||||
[NSApp setMainMenu:menubar];
|
||||
|
||||
m_style = 0
|
||||
| NSTitledWindowMask
|
||||
| NSClosableWindowMask
|
||||
| NSMiniaturizableWindowMask
|
||||
| NSResizableWindowMask
|
||||
;
|
||||
|
||||
NSRect screenRect = [[NSScreen mainScreen] frame];
|
||||
const float centerX = (screenRect.size.width - (float)ENTRY_DEFAULT_WIDTH )*0.5f;
|
||||
const float centerY = (screenRect.size.height - (float)ENTRY_DEFAULT_HEIGHT)*0.5f;
|
||||
|
||||
m_windowAlloc.alloc();
|
||||
NSRect rect = NSMakeRect(0, 0, ENTRY_DEFAULT_WIDTH, ENTRY_DEFAULT_HEIGHT);
|
||||
NSRect rect = NSMakeRect(centerX, centerY, (float)ENTRY_DEFAULT_WIDTH, (float)ENTRY_DEFAULT_HEIGHT);
|
||||
NSWindow* window = [[NSWindow alloc]
|
||||
initWithContentRect:rect
|
||||
styleMask:0
|
||||
|NSTitledWindowMask
|
||||
|NSClosableWindowMask
|
||||
|NSMiniaturizableWindowMask
|
||||
|NSResizableWindowMask
|
||||
styleMask:m_style
|
||||
backing:NSBackingStoreBuffered defer:NO
|
||||
];
|
||||
NSString* appName = [[NSProcessInfo processInfo] processName];
|
||||
[window setTitle:appName];
|
||||
[window cascadeTopLeftFromPoint:NSMakePoint(20,20)];
|
||||
[window makeKeyAndOrderFront:window];
|
||||
[window setAcceptsMouseMovedEvents:YES];
|
||||
[window setBackgroundColor:[NSColor blackColor]];
|
||||
[[Window sharedDelegate] windowCreated:window];
|
||||
|
||||
m_window[0] = window;
|
||||
m_windowFrame = [window frame];
|
||||
|
||||
bgfx::osxSetNSWindow(window);
|
||||
|
||||
@ -448,16 +463,24 @@ namespace entry
|
||||
return 0;
|
||||
}
|
||||
|
||||
bool isValid(WindowHandle _handle)
|
||||
{
|
||||
return m_windowAlloc.isValid(_handle.idx);
|
||||
}
|
||||
|
||||
EventQueue m_eventQueue;
|
||||
|
||||
bx::HandleAllocT<ENTRY_CONFIG_MAX_WINDOWS> m_windowAlloc;
|
||||
NSWindow* m_window[ENTRY_CONFIG_MAX_WINDOWS];
|
||||
NSRect m_windowFrame;
|
||||
|
||||
float m_scrollf;
|
||||
int32_t m_mx;
|
||||
int32_t m_my;
|
||||
int32_t m_scroll;
|
||||
int32_t m_style;
|
||||
bool m_exit;
|
||||
bool m_fullscreen;
|
||||
};
|
||||
|
||||
static Context s_ctx;
|
||||
@ -486,27 +509,104 @@ namespace entry
|
||||
|
||||
void destroyWindow(WindowHandle _handle)
|
||||
{
|
||||
BX_UNUSED(_handle);
|
||||
if (s_ctx.isValid(_handle) )
|
||||
{
|
||||
dispatch_async(dispatch_get_main_queue()
|
||||
, ^{
|
||||
[s_ctx.m_window[_handle.idx] performClose: nil];
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
void setWindowPos(WindowHandle _handle, int32_t _x, int32_t _y)
|
||||
{
|
||||
BX_UNUSED(_handle, _x, _y);
|
||||
if (s_ctx.isValid(_handle) )
|
||||
{
|
||||
NSWindow* window = s_ctx.m_window[_handle.idx];
|
||||
NSScreen* screen = [window screen];
|
||||
|
||||
NSRect screenRect = [screen frame];
|
||||
CGFloat menuBarHeight = [[[NSApplication sharedApplication] mainMenu] menuBarHeight];
|
||||
|
||||
NSPoint position = { float(_x), screenRect.size.height - menuBarHeight - float(_y) };
|
||||
|
||||
dispatch_async(dispatch_get_main_queue()
|
||||
, ^{
|
||||
[window setFrameTopLeftPoint: position];
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
void setWindowSize(WindowHandle _handle, uint32_t _width, uint32_t _height)
|
||||
{
|
||||
BX_UNUSED(_handle, _width, _height);
|
||||
if (s_ctx.isValid(_handle) )
|
||||
{
|
||||
NSSize size = { float(_width), float(_height) };
|
||||
dispatch_async(dispatch_get_main_queue()
|
||||
, ^{
|
||||
[s_ctx.m_window[_handle.idx] setContentSize: size];
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
void setWindowTitle(WindowHandle _handle, const char* _title)
|
||||
{
|
||||
BX_UNUSED(_handle, _title);
|
||||
if (s_ctx.isValid(_handle) )
|
||||
{
|
||||
NSString* title = [[NSString alloc] initWithCString:_title encoding:1];
|
||||
dispatch_async(dispatch_get_main_queue()
|
||||
, ^{
|
||||
[s_ctx.m_window[_handle.idx] setTitle: title];
|
||||
});
|
||||
[title release];
|
||||
}
|
||||
}
|
||||
|
||||
void toggleWindowFrame(WindowHandle _handle)
|
||||
{
|
||||
BX_UNUSED(_handle);
|
||||
if (s_ctx.isValid(_handle) )
|
||||
{
|
||||
s_ctx.m_style ^= NSTitledWindowMask;
|
||||
dispatch_async(dispatch_get_main_queue()
|
||||
, ^{
|
||||
[s_ctx.m_window[_handle.idx] setStyleMask: s_ctx.m_style];
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
void toggleFullscreen(WindowHandle _handle)
|
||||
{
|
||||
if (s_ctx.isValid(_handle) )
|
||||
{
|
||||
NSWindow* window = s_ctx.m_window[_handle.idx];
|
||||
NSScreen* screen = [window screen];
|
||||
NSRect screenRect = [screen frame];
|
||||
|
||||
if (!s_ctx.m_fullscreen)
|
||||
{
|
||||
[NSMenu setMenuBarVisible: false];
|
||||
s_ctx.m_style &= ~NSTitledWindowMask;
|
||||
dispatch_async(dispatch_get_main_queue()
|
||||
, ^{
|
||||
[window setStyleMask: s_ctx.m_style];
|
||||
[window setFrame:screenRect display:YES];
|
||||
});
|
||||
|
||||
s_ctx.m_fullscreen = true;
|
||||
}
|
||||
else
|
||||
{
|
||||
[NSMenu setMenuBarVisible: true];
|
||||
s_ctx.m_style |= NSTitledWindowMask;
|
||||
dispatch_async(dispatch_get_main_queue()
|
||||
, ^{
|
||||
[window setStyleMask: s_ctx.m_style];
|
||||
[window setFrame:s_ctx.m_windowFrame display:YES];
|
||||
});
|
||||
|
||||
s_ctx.m_fullscreen = false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void setMouseLock(WindowHandle _handle, bool _lock)
|
||||
@ -610,6 +710,7 @@ namespace entry
|
||||
using namespace entry;
|
||||
s_ctx.windowDidResize();
|
||||
}
|
||||
|
||||
@end
|
||||
|
||||
int main(int _argc, char** _argv)
|
||||
|
@ -59,6 +59,11 @@ namespace entry
|
||||
BX_UNUSED(_handle);
|
||||
}
|
||||
|
||||
void toggleFullscreen(WindowHandle _handle)
|
||||
{
|
||||
BX_UNUSED(_handle);
|
||||
}
|
||||
|
||||
void setMouseLock(WindowHandle _handle, bool _lock)
|
||||
{
|
||||
BX_UNUSED(_handle, _lock);
|
||||
|
@ -179,6 +179,7 @@ namespace entry
|
||||
SDL_USER_WINDOW_SET_POS,
|
||||
SDL_USER_WINDOW_SET_SIZE,
|
||||
SDL_USER_WINDOW_TOGGLE_FRAME,
|
||||
SDL_USER_WINDOW_TOGGLE_FULL_SCREEN,
|
||||
SDL_USER_WINDOW_MOUSE_LOCK,
|
||||
};
|
||||
|
||||
@ -211,6 +212,7 @@ namespace entry
|
||||
, m_height(ENTRY_DEFAULT_HEIGHT)
|
||||
, m_aspectRatio(16.0f/9.0f)
|
||||
, m_mouseLock(false)
|
||||
, m_fullscreen(false)
|
||||
{
|
||||
memset(s_translateKey, 0, sizeof(s_translateKey) );
|
||||
initTranslateKey(SDL_SCANCODE_ESCAPE, Key::Esc);
|
||||
@ -615,6 +617,13 @@ namespace entry
|
||||
}
|
||||
break;
|
||||
|
||||
case SDL_USER_WINDOW_TOGGLE_FULL_SCREEN:
|
||||
{
|
||||
m_fullscreen = !m_fullscreen;
|
||||
SDL_SetWindowFullscreen(m_window[handle.idx], m_fullscreen ? SDL_WINDOW_FULLSCREEN_DESKTOP : 0);
|
||||
}
|
||||
break;
|
||||
|
||||
case SDL_USER_WINDOW_MOUSE_LOCK:
|
||||
{
|
||||
SDL_SetRelativeMouseMode(!!uev.code ? SDL_TRUE : SDL_FALSE);
|
||||
@ -723,6 +732,7 @@ namespace entry
|
||||
int32_t m_mx;
|
||||
int32_t m_my;
|
||||
bool m_mouseLock;
|
||||
bool m_fullscreen;
|
||||
};
|
||||
|
||||
static Context s_ctx;
|
||||
@ -805,6 +815,11 @@ namespace entry
|
||||
sdlPostEvent(SDL_USER_WINDOW_TOGGLE_FRAME, _handle);
|
||||
}
|
||||
|
||||
void toggleFullscreen(WindowHandle _handle)
|
||||
{
|
||||
sdlPostEvent(SDL_USER_WINDOW_TOGGLE_FULL_SCREEN, _handle);
|
||||
}
|
||||
|
||||
void setMouseLock(WindowHandle _handle, bool _lock)
|
||||
{
|
||||
sdlPostEvent(SDL_USER_WINDOW_MOUSE_LOCK, _handle, NULL, _lock);
|
||||
|
@ -175,6 +175,11 @@ namespace entry
|
||||
BX_UNUSED(_handle);
|
||||
}
|
||||
|
||||
void toggleFullscreen(WindowHandle _handle)
|
||||
{
|
||||
BX_UNUSED(_handle);
|
||||
}
|
||||
|
||||
void setMouseLock(WindowHandle _handle, bool _lock)
|
||||
{
|
||||
BX_UNUSED(_handle, _lock);
|
||||
|
@ -664,6 +664,11 @@ namespace entry
|
||||
BX_UNUSED(_handle);
|
||||
}
|
||||
|
||||
void toggleFullscreen(WindowHandle _handle)
|
||||
{
|
||||
BX_UNUSED(_handle);
|
||||
}
|
||||
|
||||
void setMouseLock(WindowHandle _handle, bool _lock)
|
||||
{
|
||||
BX_UNUSED(_handle, _lock);
|
||||
|
Loading…
Reference in New Issue
Block a user