|
|
@ -16,13 +16,6 @@
|
|
|
|
|
|
|
|
|
|
|
|
#include "cocoa_event_emitter.h"
|
|
|
|
#include "cocoa_event_emitter.h"
|
|
|
|
|
|
|
|
|
|
|
|
#include "nel/misc/event_server.h"
|
|
|
|
|
|
|
|
#include "nel/misc/events.h"
|
|
|
|
|
|
|
|
#include "nel/misc/game_device_events.h"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#include <Carbon/Carbon.h>
|
|
|
|
|
|
|
|
#import <Cocoa/Cocoa.h>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
namespace NLMISC
|
|
|
|
namespace NLMISC
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
@ -217,22 +210,21 @@ static bool isTextKeyEvent(NSEvent* event)
|
|
|
|
return false;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void CCocoaEventEmitter::submitEvents(CEventServer& server, bool /* allWins */)
|
|
|
|
void CCocoaEventEmitter::init(NL3D::IDriver* driver, CocoaOpenGLView* glView)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// break if there was no event to handle
|
|
|
|
_driver = driver;
|
|
|
|
while(true)
|
|
|
|
_glView = glView;
|
|
|
|
{
|
|
|
|
}
|
|
|
|
// get the next event to handle
|
|
|
|
|
|
|
|
NSEvent* event = [NSApp nextEventMatchingMask:NSAnyEventMask
|
|
|
|
|
|
|
|
untilDate:nil /*[NSDate distantFuture]*/
|
|
|
|
|
|
|
|
inMode:NSDefaultRunLoopMode dequeue:YES];
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// stop, if there was no event
|
|
|
|
bool CCocoaEventEmitter::processMessage(NSEvent* event, CEventServer* server)
|
|
|
|
if(!event)
|
|
|
|
{
|
|
|
|
break;
|
|
|
|
if(!server && !_server)
|
|
|
|
|
|
|
|
nlerror("no server to post events to");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(!server)
|
|
|
|
|
|
|
|
server = _server;
|
|
|
|
|
|
|
|
|
|
|
|
NSView* glView = [[[[event window] contentView] subviews] lastObject];
|
|
|
|
NSRect viewRect = [_glView frame];
|
|
|
|
NSRect viewRect = [glView frame];
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// TODO this code assumes, that the view fills the window
|
|
|
|
// TODO this code assumes, that the view fills the window
|
|
|
|
// convert the mouse position to NeL style (relative)
|
|
|
|
// convert the mouse position to NeL style (relative)
|
|
|
@ -244,7 +236,7 @@ void CCocoaEventEmitter::submitEvents(CEventServer& server, bool /* allWins */)
|
|
|
|
event.type != NSKeyDown && event.type != NSKeyUp)
|
|
|
|
event.type != NSKeyDown && event.type != NSKeyUp)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
[NSApp sendEvent:event];
|
|
|
|
[NSApp sendEvent:event];
|
|
|
|
continue;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// convert the modifiers for nel to pass them with the events
|
|
|
|
// convert the modifiers for nel to pass them with the events
|
|
|
@ -255,28 +247,28 @@ void CCocoaEventEmitter::submitEvents(CEventServer& server, bool /* allWins */)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
case NSLeftMouseDown:
|
|
|
|
case NSLeftMouseDown:
|
|
|
|
{
|
|
|
|
{
|
|
|
|
server.postEvent(new NLMISC::CEventMouseDown(
|
|
|
|
server->postEvent(new NLMISC::CEventMouseDown(
|
|
|
|
mouseX, mouseY,
|
|
|
|
mouseX, mouseY,
|
|
|
|
(NLMISC::TMouseButton)(NLMISC::leftButton | modifiers), this));
|
|
|
|
(NLMISC::TMouseButton)(NLMISC::leftButton | modifiers), this));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
case NSLeftMouseUp:
|
|
|
|
case NSLeftMouseUp:
|
|
|
|
{
|
|
|
|
{
|
|
|
|
server.postEvent(new NLMISC::CEventMouseUp(
|
|
|
|
server->postEvent(new NLMISC::CEventMouseUp(
|
|
|
|
mouseX, mouseY,
|
|
|
|
mouseX, mouseY,
|
|
|
|
(NLMISC::TMouseButton)(NLMISC::leftButton | modifiers), this));
|
|
|
|
(NLMISC::TMouseButton)(NLMISC::leftButton | modifiers), this));
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
case NSRightMouseDown:
|
|
|
|
case NSRightMouseDown:
|
|
|
|
{
|
|
|
|
{
|
|
|
|
server.postEvent(new NLMISC::CEventMouseDown(
|
|
|
|
server->postEvent(new NLMISC::CEventMouseDown(
|
|
|
|
mouseX, mouseY,
|
|
|
|
mouseX, mouseY,
|
|
|
|
(NLMISC::TMouseButton)(NLMISC::rightButton | modifiers), this));
|
|
|
|
(NLMISC::TMouseButton)(NLMISC::rightButton | modifiers), this));
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
case NSRightMouseUp:
|
|
|
|
case NSRightMouseUp:
|
|
|
|
{
|
|
|
|
{
|
|
|
|
server.postEvent(new NLMISC::CEventMouseUp(
|
|
|
|
server->postEvent(new NLMISC::CEventMouseUp(
|
|
|
|
mouseX, mouseY,
|
|
|
|
mouseX, mouseY,
|
|
|
|
(NLMISC::TMouseButton)(NLMISC::rightButton | modifiers), this));
|
|
|
|
(NLMISC::TMouseButton)(NLMISC::rightButton | modifiers), this));
|
|
|
|
break;
|
|
|
|
break;
|
|
|
@ -295,7 +287,7 @@ void CCocoaEventEmitter::submitEvents(CEventServer& server, bool /* allWins */)
|
|
|
|
nelEvent = new NLMISC::CEventMouseMove(
|
|
|
|
nelEvent = new NLMISC::CEventMouseMove(
|
|
|
|
mouseX, mouseY, (NLMISC::TMouseButton)modifiers, this);
|
|
|
|
mouseX, mouseY, (NLMISC::TMouseButton)modifiers, this);
|
|
|
|
|
|
|
|
|
|
|
|
server.postEvent(nelEvent);
|
|
|
|
server->postEvent(nelEvent);
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
case NSLeftMouseDragged:
|
|
|
|
case NSLeftMouseDragged:
|
|
|
@ -312,7 +304,7 @@ void CCocoaEventEmitter::submitEvents(CEventServer& server, bool /* allWins */)
|
|
|
|
nelEvent = new NLMISC::CEventMouseMove(mouseX, mouseY,
|
|
|
|
nelEvent = new NLMISC::CEventMouseMove(mouseX, mouseY,
|
|
|
|
(NLMISC::TMouseButton)(NLMISC::leftButton | modifiers), this);
|
|
|
|
(NLMISC::TMouseButton)(NLMISC::leftButton | modifiers), this);
|
|
|
|
|
|
|
|
|
|
|
|
server.postEvent(nelEvent);
|
|
|
|
server->postEvent(nelEvent);
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
case NSRightMouseDragged:
|
|
|
|
case NSRightMouseDragged:
|
|
|
@ -329,7 +321,7 @@ void CCocoaEventEmitter::submitEvents(CEventServer& server, bool /* allWins */)
|
|
|
|
nelEvent = new NLMISC::CEventMouseMove(mouseX, mouseY,
|
|
|
|
nelEvent = new NLMISC::CEventMouseMove(mouseX, mouseY,
|
|
|
|
(NLMISC::TMouseButton)(NLMISC::rightButton | modifiers), this);
|
|
|
|
(NLMISC::TMouseButton)(NLMISC::rightButton | modifiers), this);
|
|
|
|
|
|
|
|
|
|
|
|
server.postEvent(nelEvent);
|
|
|
|
server->postEvent(nelEvent);
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
case NSMouseEntered:break;
|
|
|
|
case NSMouseEntered:break;
|
|
|
@ -337,7 +329,7 @@ void CCocoaEventEmitter::submitEvents(CEventServer& server, bool /* allWins */)
|
|
|
|
case NSKeyDown:
|
|
|
|
case NSKeyDown:
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// push the key press event to the event server
|
|
|
|
// push the key press event to the event server
|
|
|
|
server.postEvent(new NLMISC::CEventKeyDown(
|
|
|
|
server->postEvent(new NLMISC::CEventKeyDown(
|
|
|
|
virtualKeycodeToNelKey([event keyCode]),
|
|
|
|
virtualKeycodeToNelKey([event keyCode]),
|
|
|
|
modifierFlagsToNelKeyButton([event modifierFlags]),
|
|
|
|
modifierFlagsToNelKeyButton([event modifierFlags]),
|
|
|
|
[event isARepeat] == NO, this));
|
|
|
|
[event isARepeat] == NO, this));
|
|
|
@ -351,7 +343,7 @@ void CCocoaEventEmitter::submitEvents(CEventServer& server, bool /* allWins */)
|
|
|
|
ucstr.fromUtf8([[event characters] UTF8String]);
|
|
|
|
ucstr.fromUtf8([[event characters] UTF8String]);
|
|
|
|
|
|
|
|
|
|
|
|
// push the text event to event server as well
|
|
|
|
// push the text event to event server as well
|
|
|
|
server.postEvent(new NLMISC::CEventChar(
|
|
|
|
server->postEvent(new NLMISC::CEventChar(
|
|
|
|
ucstr[0], NLMISC::noKeyButton, this));
|
|
|
|
ucstr[0], NLMISC::noKeyButton, this));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
break;
|
|
|
@ -359,7 +351,7 @@ void CCocoaEventEmitter::submitEvents(CEventServer& server, bool /* allWins */)
|
|
|
|
case NSKeyUp:
|
|
|
|
case NSKeyUp:
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// push the key release event to the event server
|
|
|
|
// push the key release event to the event server
|
|
|
|
server.postEvent(new NLMISC::CEventKeyUp(
|
|
|
|
server->postEvent(new NLMISC::CEventKeyUp(
|
|
|
|
virtualKeycodeToNelKey([event keyCode]),
|
|
|
|
virtualKeycodeToNelKey([event keyCode]),
|
|
|
|
modifierFlagsToNelKeyButton([event modifierFlags]), this));
|
|
|
|
modifierFlagsToNelKeyButton([event modifierFlags]), this));
|
|
|
|
break;
|
|
|
|
break;
|
|
|
@ -373,7 +365,7 @@ void CCocoaEventEmitter::submitEvents(CEventServer& server, bool /* allWins */)
|
|
|
|
case NSScrollWheel:
|
|
|
|
case NSScrollWheel:
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if(fabs(event.deltaY) > 0.1)
|
|
|
|
if(fabs(event.deltaY) > 0.1)
|
|
|
|
server.postEvent(new NLMISC::CEventMouseWheel(
|
|
|
|
server->postEvent(new NLMISC::CEventMouseWheel(
|
|
|
|
mouseX, mouseY, (NLMISC::TMouseButton)modifiers,
|
|
|
|
mouseX, mouseY, (NLMISC::TMouseButton)modifiers,
|
|
|
|
(event.deltaY > 0), this));
|
|
|
|
(event.deltaY > 0), this));
|
|
|
|
|
|
|
|
|
|
|
@ -401,7 +393,41 @@ void CCocoaEventEmitter::submitEvents(CEventServer& server, bool /* allWins */)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
[NSApp sendEvent:event];
|
|
|
|
[NSApp sendEvent:event];
|
|
|
|
|
|
|
|
return true;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
typedef bool (*cocoaProc)(NL3D::IDriver*, void* e);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void CCocoaEventEmitter::submitEvents(CEventServer& server, bool /* allWins */)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
// break if there was no event to handle
|
|
|
|
|
|
|
|
while(true)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
// get the next event to handle
|
|
|
|
|
|
|
|
NSEvent* event = [NSApp nextEventMatchingMask:NSAnyEventMask
|
|
|
|
|
|
|
|
untilDate:nil /*[NSDate distantFuture]*/
|
|
|
|
|
|
|
|
inMode:NSDefaultRunLoopMode dequeue:YES];
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// stop, if there was no event
|
|
|
|
|
|
|
|
if(!event)
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(_driver)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
cocoaProc proc = (cocoaProc)_driver->getWindowProc();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(proc)
|
|
|
|
|
|
|
|
proc(_driver, event);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
processMessage(event, &server);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// TODO like internal server in unix event emitter... review!
|
|
|
|
|
|
|
|
_server = &server;
|
|
|
|
|
|
|
|
// _server->pump();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void CCocoaEventEmitter::emulateMouseRawMode(bool enable)
|
|
|
|
void CCocoaEventEmitter::emulateMouseRawMode(bool enable)
|
|
|
|