mirror of
https://github.com/SFML/SFML.git
synced 2025-01-19 15:55:13 +08:00
Improved Mac OS X implementation (Close #195)
This commit is contained in:
parent
be7bcae823
commit
19276a552e
@ -28,6 +28,7 @@
|
||||
////////////////////////////////////////////////////////////
|
||||
#import <SFML/Window/OSX/SFViewController.h>
|
||||
#import <SFML/Window/OSX/SFOpenGLView.h>
|
||||
#import <SFML/Window/OSX/SFApplication.h>
|
||||
#include <SFML/System/Err.hpp>
|
||||
#include <SFML/Window/OSX/WindowImplCocoa.hpp>
|
||||
|
||||
@ -107,7 +108,7 @@
|
||||
////////////////////////////////////////////////////////
|
||||
-(void)changeTitle:(NSString *)title
|
||||
{
|
||||
sf::err() << "Cannot change the title of the view." << std::endl;
|
||||
sf::err() << "Cannot change the title of the SFML area when SFML is integrated in a NSView." << std::endl;
|
||||
}
|
||||
|
||||
|
||||
@ -156,7 +157,7 @@
|
||||
////////////////////////////////////////////////////////
|
||||
-(void)closeWindow
|
||||
{
|
||||
sf::err() << "Cannot close the view." << std::endl;
|
||||
sf::err() << "Cannot close SFML area when SFML is integrated in a NSView." << std::endl;
|
||||
[self setRequesterTo:0];
|
||||
}
|
||||
|
||||
@ -198,19 +199,14 @@
|
||||
////////////////////////////////////////////////////////////
|
||||
-(NSPoint)position
|
||||
{
|
||||
NSPoint pos = [m_view frame].origin;
|
||||
|
||||
// Flip screen coodinates
|
||||
float const screenHeight = NSHeight([[[m_view window] screen] frame]);
|
||||
pos.y = screenHeight - pos.y;
|
||||
|
||||
return pos;
|
||||
// Origin is bottom-left corner of the window
|
||||
return [m_view convertPoint:NSMakePoint(0, 0) toView:nil]; // nil means window
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////.
|
||||
-(void)setWindowPositionToX:(unsigned int)x Y:(unsigned int)y
|
||||
{
|
||||
sf::err() << "Cannot move the view." << std::endl;
|
||||
sf::err() << "Cannot move SFML area when SFML is integrated in a NSView. Use the view hanlder directly instead." << std::endl;
|
||||
}
|
||||
|
||||
|
||||
@ -237,14 +233,30 @@
|
||||
by:(unsigned int)height
|
||||
with:(sf::Uint8 const *)pixels
|
||||
{
|
||||
sf::err() << "Cannot set an icon to the view." << std::endl;
|
||||
sf::err() << "Cannot set an icon when SFML is integrated in a NSView." << std::endl;
|
||||
}
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////
|
||||
-(void)processEvent
|
||||
{
|
||||
sf::err() << "Cannot process event from the view." << std::endl;
|
||||
// If we are not on the main thread we stop here and advice the user.
|
||||
if ([NSThread currentThread] != [NSThread mainThread]) {
|
||||
/*
|
||||
* See http://lists.apple.com/archives/cocoa-dev/2011/Feb/msg00460.html
|
||||
* for more information.
|
||||
*/
|
||||
sf::err()
|
||||
<< "Cannot fetch event from a worker thread. (OS X restriction)"
|
||||
<< std::endl;
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
// If we don't have a requester we don't fetch event.
|
||||
if (m_requester != 0) {
|
||||
[SFApplication processEvent];
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
@ -74,9 +74,7 @@ WindowImplCocoa::WindowImplCocoa(WindowHandle handle)
|
||||
|
||||
}
|
||||
|
||||
// NO :
|
||||
// [m_delegate setRequesterTo:this];
|
||||
// because we don't handle event.
|
||||
[m_delegate setRequesterTo:this];
|
||||
}
|
||||
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user