Merge pull request #280 from dariomanesku/master

OS X candy.. :)
This commit is contained in:
Branimir Karadžić 2015-03-07 19:55:21 -08:00
commit 2b6a5929aa
10 changed files with 176 additions and 24 deletions

View File

@ -211,6 +211,7 @@ namespace entry
void setWindowSize(WindowHandle _handle, uint32_t _width, uint32_t _height); void setWindowSize(WindowHandle _handle, uint32_t _width, uint32_t _height);
void setWindowTitle(WindowHandle _handle, const char* _title); void setWindowTitle(WindowHandle _handle, const char* _title);
void toggleWindowFrame(WindowHandle _handle); void toggleWindowFrame(WindowHandle _handle);
void toggleFullscreen(WindowHandle _handle);
void setMouseLock(WindowHandle _handle, bool _lock); void setMouseLock(WindowHandle _handle, bool _lock);
struct WindowState struct WindowState

View File

@ -440,6 +440,11 @@ namespace entry
BX_UNUSED(_handle); BX_UNUSED(_handle);
} }
void toggleFullscreen(WindowHandle _handle)
{
BX_UNUSED(_handle);
}
void setMouseLock(WindowHandle _handle, bool _lock) void setMouseLock(WindowHandle _handle, bool _lock)
{ {
BX_UNUSED(_handle, _lock); BX_UNUSED(_handle, _lock);

View File

@ -59,6 +59,11 @@ namespace entry
BX_UNUSED(_handle); BX_UNUSED(_handle);
} }
void toggleFullscreen(WindowHandle _handle)
{
BX_UNUSED(_handle);
}
void setMouseLock(WindowHandle _handle, bool _lock) void setMouseLock(WindowHandle _handle, bool _lock)
{ {
BX_UNUSED(_handle, _lock); BX_UNUSED(_handle, _lock);

View File

@ -126,6 +126,11 @@ namespace entry
BX_UNUSED(_handle); BX_UNUSED(_handle);
} }
void toggleFullscreen(WindowHandle _handle)
{
BX_UNUSED(_handle);
}
void setMouseLock(WindowHandle _handle, bool _lock) void setMouseLock(WindowHandle _handle, bool _lock)
{ {
BX_UNUSED(_handle, _lock); BX_UNUSED(_handle, _lock);

View File

@ -94,6 +94,11 @@ namespace entry
BX_UNUSED(_handle); BX_UNUSED(_handle);
} }
void toggleFullscreen(WindowHandle _handle)
{
BX_UNUSED(_handle);
}
void setMouseLock(WindowHandle _handle, bool _lock) void setMouseLock(WindowHandle _handle, bool _lock)
{ {
BX_UNUSED(_handle, _lock); BX_UNUSED(_handle, _lock);

View File

@ -81,7 +81,9 @@ namespace entry
, m_mx(0) , m_mx(0)
, m_my(0) , m_my(0)
, m_scroll(0) , m_scroll(0)
, m_style(0)
, m_exit(false) , m_exit(false)
, m_fullscreen(false)
{ {
s_translateKey[27] = Key::Esc; s_translateKey[27] = Key::Esc;
s_translateKey[13] = Key::Return; s_translateKey[13] = Key::Return;
@ -138,7 +140,7 @@ namespace entry
NSWindow* window = m_window[handle.idx]; NSWindow* window = m_window[handle.idx];
NSRect originalFrame = [window frame]; NSRect originalFrame = [window frame];
NSPoint location = [window mouseLocationOutsideOfEventStream]; NSPoint location = [window mouseLocationOutsideOfEventStream];
NSRect adjustFrame = [NSWindow contentRectForFrameRect: originalFrame styleMask: NSTitledWindowMask]; NSRect adjustFrame = [window contentRectForFrameRect: originalFrame];
int x = location.x; int x = location.x;
int y = (int)adjustFrame.size.height - (int)location.y; int y = (int)adjustFrame.size.height - (int)location.y;
@ -246,9 +248,9 @@ namespace entry
case NSLeftMouseDown: case NSLeftMouseDown:
{ {
// TODO: remove! // 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. // 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); m_eventQueue.postMouseEvent(s_defaultWindow, m_mx, m_my, m_scroll, mb, true);
break; break;
} }
@ -306,16 +308,22 @@ namespace entry
{ {
m_eventQueue.postExitEvent(); m_eventQueue.postExitEvent();
} }
else if ( (Key::Key0 <= key && key <= Key::KeyZ)
|| (Key::Esc <= key && key <= Key::Minus) )
{
m_eventQueue.postCharEvent(s_defaultWindow, 1, pressedChar);
return false;
}
else else
{ {
m_eventQueue.postKeyEvent(s_defaultWindow, key, modifiers, true); enum { ShiftMask = Modifier::LeftShift|Modifier::RightShift };
return false; 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;
}
else
{
m_eventQueue.postKeyEvent(s_defaultWindow, key, modifiers, true);
return false;
}
} }
} }
@ -354,7 +362,7 @@ namespace entry
WindowHandle handle = { 0 }; WindowHandle handle = { 0 };
NSWindow* window = m_window[handle.idx]; NSWindow* window = m_window[handle.idx];
NSRect originalFrame = [window frame]; 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 width = uint32_t(rect.size.width);
uint32_t height = uint32_t(rect.size.height); uint32_t height = uint32_t(rect.size.height);
m_eventQueue.postSizeEvent(handle, width, height); m_eventQueue.postSizeEvent(handle, width, height);
@ -398,26 +406,33 @@ namespace entry
[menubar addItem:appMenuItem]; [menubar addItem:appMenuItem];
[NSApp setMainMenu:menubar]; [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(); 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] NSWindow* window = [[NSWindow alloc]
initWithContentRect:rect initWithContentRect:rect
styleMask:0 styleMask:m_style
|NSTitledWindowMask
|NSClosableWindowMask
|NSMiniaturizableWindowMask
|NSResizableWindowMask
backing:NSBackingStoreBuffered defer:NO backing:NSBackingStoreBuffered defer:NO
]; ];
NSString* appName = [[NSProcessInfo processInfo] processName]; NSString* appName = [[NSProcessInfo processInfo] processName];
[window setTitle:appName]; [window setTitle:appName];
[window cascadeTopLeftFromPoint:NSMakePoint(20,20)];
[window makeKeyAndOrderFront:window]; [window makeKeyAndOrderFront:window];
[window setAcceptsMouseMovedEvents:YES]; [window setAcceptsMouseMovedEvents:YES];
[window setBackgroundColor:[NSColor blackColor]]; [window setBackgroundColor:[NSColor blackColor]];
[[Window sharedDelegate] windowCreated:window]; [[Window sharedDelegate] windowCreated:window];
m_window[0] = window; m_window[0] = window;
m_windowFrame = [window frame];
bgfx::osxSetNSWindow(window); bgfx::osxSetNSWindow(window);
@ -448,16 +463,24 @@ namespace entry
return 0; return 0;
} }
bool isValid(WindowHandle _handle)
{
return m_windowAlloc.isValid(_handle.idx);
}
EventQueue m_eventQueue; EventQueue m_eventQueue;
bx::HandleAllocT<ENTRY_CONFIG_MAX_WINDOWS> m_windowAlloc; bx::HandleAllocT<ENTRY_CONFIG_MAX_WINDOWS> m_windowAlloc;
NSWindow* m_window[ENTRY_CONFIG_MAX_WINDOWS]; NSWindow* m_window[ENTRY_CONFIG_MAX_WINDOWS];
NSRect m_windowFrame;
float m_scrollf; float m_scrollf;
int32_t m_mx; int32_t m_mx;
int32_t m_my; int32_t m_my;
int32_t m_scroll; int32_t m_scroll;
int32_t m_style;
bool m_exit; bool m_exit;
bool m_fullscreen;
}; };
static Context s_ctx; static Context s_ctx;
@ -486,27 +509,104 @@ namespace entry
void destroyWindow(WindowHandle _handle) 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) 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) 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) 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) 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) void setMouseLock(WindowHandle _handle, bool _lock)
@ -610,6 +710,7 @@ namespace entry
using namespace entry; using namespace entry;
s_ctx.windowDidResize(); s_ctx.windowDidResize();
} }
@end @end
int main(int _argc, char** _argv) int main(int _argc, char** _argv)

View File

@ -59,6 +59,11 @@ namespace entry
BX_UNUSED(_handle); BX_UNUSED(_handle);
} }
void toggleFullscreen(WindowHandle _handle)
{
BX_UNUSED(_handle);
}
void setMouseLock(WindowHandle _handle, bool _lock) void setMouseLock(WindowHandle _handle, bool _lock)
{ {
BX_UNUSED(_handle, _lock); BX_UNUSED(_handle, _lock);

View File

@ -179,6 +179,7 @@ namespace entry
SDL_USER_WINDOW_SET_POS, SDL_USER_WINDOW_SET_POS,
SDL_USER_WINDOW_SET_SIZE, SDL_USER_WINDOW_SET_SIZE,
SDL_USER_WINDOW_TOGGLE_FRAME, SDL_USER_WINDOW_TOGGLE_FRAME,
SDL_USER_WINDOW_TOGGLE_FULL_SCREEN,
SDL_USER_WINDOW_MOUSE_LOCK, SDL_USER_WINDOW_MOUSE_LOCK,
}; };
@ -211,6 +212,7 @@ namespace entry
, m_height(ENTRY_DEFAULT_HEIGHT) , m_height(ENTRY_DEFAULT_HEIGHT)
, m_aspectRatio(16.0f/9.0f) , m_aspectRatio(16.0f/9.0f)
, m_mouseLock(false) , m_mouseLock(false)
, m_fullscreen(false)
{ {
memset(s_translateKey, 0, sizeof(s_translateKey) ); memset(s_translateKey, 0, sizeof(s_translateKey) );
initTranslateKey(SDL_SCANCODE_ESCAPE, Key::Esc); initTranslateKey(SDL_SCANCODE_ESCAPE, Key::Esc);
@ -615,6 +617,13 @@ namespace entry
} }
break; 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: case SDL_USER_WINDOW_MOUSE_LOCK:
{ {
SDL_SetRelativeMouseMode(!!uev.code ? SDL_TRUE : SDL_FALSE); SDL_SetRelativeMouseMode(!!uev.code ? SDL_TRUE : SDL_FALSE);
@ -723,6 +732,7 @@ namespace entry
int32_t m_mx; int32_t m_mx;
int32_t m_my; int32_t m_my;
bool m_mouseLock; bool m_mouseLock;
bool m_fullscreen;
}; };
static Context s_ctx; static Context s_ctx;
@ -805,6 +815,11 @@ namespace entry
sdlPostEvent(SDL_USER_WINDOW_TOGGLE_FRAME, _handle); 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) void setMouseLock(WindowHandle _handle, bool _lock)
{ {
sdlPostEvent(SDL_USER_WINDOW_MOUSE_LOCK, _handle, NULL, _lock); sdlPostEvent(SDL_USER_WINDOW_MOUSE_LOCK, _handle, NULL, _lock);

View File

@ -175,6 +175,11 @@ namespace entry
BX_UNUSED(_handle); BX_UNUSED(_handle);
} }
void toggleFullscreen(WindowHandle _handle)
{
BX_UNUSED(_handle);
}
void setMouseLock(WindowHandle _handle, bool _lock) void setMouseLock(WindowHandle _handle, bool _lock)
{ {
BX_UNUSED(_handle, _lock); BX_UNUSED(_handle, _lock);

View File

@ -664,6 +664,11 @@ namespace entry
BX_UNUSED(_handle); BX_UNUSED(_handle);
} }
void toggleFullscreen(WindowHandle _handle)
{
BX_UNUSED(_handle);
}
void setMouseLock(WindowHandle _handle, bool _lock) void setMouseLock(WindowHandle _handle, bool _lock)
{ {
BX_UNUSED(_handle, _lock); BX_UNUSED(_handle, _lock);