Port Qt 5 to Mac.

This commit is contained in:
Morten Sorvig 2011-05-18 12:09:17 +02:00
parent 516f4e283b
commit 864815ef2e
19 changed files with 323 additions and 84 deletions

View File

@ -39,7 +39,11 @@
** **
****************************************************************************/ ****************************************************************************/
#ifdef __APPLE__
#include <OpenGL/gl.h>
#else
#include <GL/gl.h> #include <GL/gl.h>
#endif
int main(int, char **) int main(int, char **)
{ {

10
configure vendored
View File

@ -3311,7 +3311,7 @@ if [ '!' -z "$CFG_SDK" ]; then
fi fi
# find the default framework value # find the default framework value
if [ "$PLATFORM_MAC" = "yes" ] && [ "$PLATFORM" != "macx-xlc" ]; then if [ "$CFG_ARCH" = "macosx" ]; then
if [ "$CFG_FRAMEWORK" = "auto" ]; then if [ "$CFG_FRAMEWORK" = "auto" ]; then
CFG_FRAMEWORK="$CFG_SHARED" CFG_FRAMEWORK="$CFG_SHARED"
elif [ "$CFG_FRAMEWORK" = "yes" ] && [ "$CFG_SHARED" = "no" ]; then elif [ "$CFG_FRAMEWORK" = "yes" ] && [ "$CFG_SHARED" = "no" ]; then
@ -3450,7 +3450,7 @@ if [ "$PLATFORM_MAC" = "yes" ] && [ "$XPLATFORM_SYMBIAN" = "no" ]; then
fi fi
# find the default framework value # find the default framework value
if [ "$PLATFORM_MAC" = "yes" ] && [ "$PLATFORM" != "macx-xlc" ]; then if [ "$CFG_ARCH" = "macosx" ]; then
if [ "$CFG_FRAMEWORK" = "auto" ]; then if [ "$CFG_FRAMEWORK" = "auto" ]; then
CFG_FRAMEWORK="$CFG_SHARED" CFG_FRAMEWORK="$CFG_SHARED"
elif [ "$CFG_FRAMEWORK" = "yes" ] && [ "$CFG_SHARED" = "no" ]; then elif [ "$CFG_FRAMEWORK" = "yes" ] && [ "$CFG_SHARED" = "no" ]; then
@ -6188,7 +6188,9 @@ fi
if [ "$PLATFORM_QPA" = "yes" ]; then if [ "$PLATFORM_QPA" = "yes" ]; then
# auto-detect OpenGL support (es1 = OpenGL ES 1.x Common, es2 = OpenGL ES 2.x) # auto-detect OpenGL support (es1 = OpenGL ES 1.x Common, es2 = OpenGL ES 2.x)
if [ "$CFG_OPENGL" = "auto" ] || [ "$CFG_OPENGL" = "yes" ]; then if [ "$CFG_ARCH" = "macosx" ]; then
CFG_OPENGL=desktop
elif [ "$CFG_OPENGL" = "auto" ] || [ "$CFG_OPENGL" = "yes" ]; then
if "$unixtests/compile.test" "$XQMAKESPEC" "$QMAKE_CONFIG" $OPT_VERBOSE "$relpath" "$outpath" config.tests/unix/opengldesktop "OpenGL" $L_FLAGS $I_FLAGS $l_FLAGS $X11TESTS_FLAGS; then if "$unixtests/compile.test" "$XQMAKESPEC" "$QMAKE_CONFIG" $OPT_VERBOSE "$relpath" "$outpath" config.tests/unix/opengldesktop "OpenGL" $L_FLAGS $I_FLAGS $l_FLAGS $X11TESTS_FLAGS; then
CFG_OPENGL=desktop CFG_OPENGL=desktop
elif "$unixtests/compile.test" "$XQMAKESPEC" "$QMAKE_CONFIG" $OPT_VERBOSE "$relpath" "$outpath" config.tests/unix/opengles2 "OpenGL ES 2.x" $L_FLAGS $I_FLAGS $l_FLAGS; then elif "$unixtests/compile.test" "$XQMAKESPEC" "$QMAKE_CONFIG" $OPT_VERBOSE "$relpath" "$outpath" config.tests/unix/opengles2 "OpenGL ES 2.x" $L_FLAGS $I_FLAGS $l_FLAGS; then
@ -7342,7 +7344,7 @@ fi
[ '!' -z "$L_FLAGS" ] && QMakeVar add QMAKE_LIBDIR_FLAGS "$L_FLAGS" [ '!' -z "$L_FLAGS" ] && QMakeVar add QMAKE_LIBDIR_FLAGS "$L_FLAGS"
[ '!' -z "$l_FLAGS" ] && QMakeVar add LIBS "$l_FLAGS" [ '!' -z "$l_FLAGS" ] && QMakeVar add LIBS "$l_FLAGS"
if [ "$PLATFORM_MAC" = "yes" ]; then if [ "$CFG_ARCH" = "macosx" ]; then
if [ "$CFG_RPATH" = "yes" ]; then if [ "$CFG_RPATH" = "yes" ]; then
QMAKE_CONFIG="$QMAKE_CONFIG absolute_library_soname" QMAKE_CONFIG="$QMAKE_CONFIG absolute_library_soname"
fi fi

View File

@ -39,6 +39,11 @@
** **
****************************************************************************/ ****************************************************************************/
#if !defined(QWS) && defined(Q_OS_MAC)
# include "private/qcore_mac_p.h"
# include <CoreFoundation/CoreFoundation.h>
#endif
#include "qglobal.h" #include "qglobal.h"
#ifndef QT_NO_SYSTEMLOCALE #ifndef QT_NO_SYSTEMLOCALE
@ -65,10 +70,6 @@ QT_END_NAMESPACE
# include "qt_windows.h" # include "qt_windows.h"
# include <time.h> # include <time.h>
#endif #endif
#if !defined(QWS) && defined(Q_OS_MAC)
# include "private/qcore_mac_p.h"
# include <CoreFoundation/CoreFoundation.h>
#endif
#include "private/qnumeric_p.h" #include "private/qnumeric_p.h"
#include "private/qsystemlibrary_p.h" #include "private/qsystemlibrary_p.h"

View File

@ -58,7 +58,7 @@ QT_BEGIN_HEADER
# include <QtCore/qt_windows.h> # include <QtCore/qt_windows.h>
#endif #endif
#if defined(Q_WS_MAC) #if defined(Q_OS_MAC)
# include <OpenGL/gl.h> # include <OpenGL/gl.h>
#elif defined(QT_OPENGL_ES_1) #elif defined(QT_OPENGL_ES_1)
# if defined(Q_OS_MAC) # if defined(Q_OS_MAC)

View File

@ -55,7 +55,7 @@
#include <qpaintdevice.h> #include <qpaintdevice.h>
#include <qgl.h> #include <QtOpenGL/qgl.h>
QT_BEGIN_NAMESPACE QT_BEGIN_NAMESPACE

View File

@ -9,7 +9,8 @@ OBJECTIVE_SOURCES = main.mm \
qnsview.mm \ qnsview.mm \
qcocoaeventloopintegration.mm \ qcocoaeventloopintegration.mm \
qcocoaautoreleasepool.mm \ qcocoaautoreleasepool.mm \
qnswindowdelegate.mm qnswindowdelegate.mm \
qcocoaglcontext.mm
OBJECTIVE_HEADERS = qcocoaintegration.h \ OBJECTIVE_HEADERS = qcocoaintegration.h \
qcocoawindowsurface.h \ qcocoawindowsurface.h \
@ -17,13 +18,16 @@ OBJECTIVE_HEADERS = qcocoaintegration.h \
qnsview.h \ qnsview.h \
qcocoaeventloopintegration.h \ qcocoaeventloopintegration.h \
qcocoaautoreleasepool.h \ qcocoaautoreleasepool.h \
qnswindowdelegate.h qnswindowdelegate.h \
qcocoaglcontext.h
#add libz for freetype. #add libz for freetype.
LIBS += -lz LIBS += -lz
LIBS += -framework cocoa LIBS += -framework cocoa
include(../fontdatabases/coretext/coretext.pri) QT += core-private gui-private
include(../fontdatabases/basicunix/basicunix.pri)
target.path += $$[QT_INSTALL_PLUGINS]/platforms target.path += $$[QT_INSTALL_PLUGINS]/platforms
INSTALLS += target INSTALLS += target

View File

@ -47,9 +47,6 @@
#include <QtCore/QElapsedTimer> #include <QtCore/QElapsedTimer>
#include <QDebug>
#include <QApplication>
void wakeupCallback ( void * ) { void wakeupCallback ( void * ) {
QPlatformEventLoopIntegration::processEvents(); QPlatformEventLoopIntegration::processEvents();
} }

View File

@ -0,0 +1,27 @@
#ifndef QCOCOAGLCONTEXT_H
#define QCOCOAGLCONTEXT_H
#include <QtGui/QPlatformGLContext>
#include <QtGui/QWindowFormat>
#include <Cocoa/Cocoa.h>
QT_BEGIN_NAMESPACE
class QCocoaGLContext : public QPlatformGLContext
{
public:
QCocoaGLContext(NSOpenGLView *glView);
void makeCurrent();
void doneCurrent();
void swapBuffers();
void* getProcAddress(const QString& procName);
QWindowFormat windowFormat() const;
static NSOpenGLPixelFormat *createNSOpenGLPixelFormat();
private:
NSOpenGLView *m_glView;
};
QT_END_NAMESPACE
#endif // QCOCOAGLCONTEXT_H

View File

@ -0,0 +1,78 @@
#include "qcocoaglcontext.h"
#include <qdebug.h>
#include <QtCore/private/qcore_mac_p.h>
#import <Cocoa/Cocoa.h>
QCocoaGLContext::QCocoaGLContext(NSOpenGLView *glView)
:m_glView(glView)
{
}
void QCocoaGLContext::makeCurrent()
{
[[m_glView openGLContext] makeCurrentContext];
}
void QCocoaGLContext::doneCurrent()
{
[NSOpenGLContext clearCurrentContext];
}
void QCocoaGLContext::swapBuffers()
{
[[m_glView openGLContext] flushBuffer];
}
void* QCocoaGLContext::getProcAddress(const QString& procName)
{
CFURLRef url = CFURLCreateWithFileSystemPath(kCFAllocatorDefault,
CFSTR("/System/Library/Frameworks/OpenGL.framework"), kCFURLPOSIXPathStyle, false);
CFBundleRef bundle = CFBundleCreate(kCFAllocatorDefault, url);
CFStringRef procNameCF = QCFString::toCFStringRef(procName);
void *proc = CFBundleGetFunctionPointerForName(bundle, procNameCF);
CFRelease(url);
CFRelease(bundle);
CFRelease(procNameCF);
return proc;
}
// Match up with createNSOpenGLPixelFormat below!
QWindowFormat QCocoaGLContext::windowFormat() const
{
QWindowFormat format;
format.setRedBufferSize(8);
format.setGreenBufferSize(8);
format.setBlueBufferSize(8);
format.setAlphaBufferSize(8);
/*
format.setDepthBufferSize(24);
format.setAccumBufferSize(0);
format.setStencilBufferSize(8);
format.setSampleBuffers(false);
format.setSamples(1);
format.setDepth(true);
format.setRgba(true);
format.setAlpha(true);
format.setAccum(false);
format.setStencil(true);
format.setStereo(false);
format.setDirectRendering(false);
*/
return format;
}
NSOpenGLPixelFormat *QCocoaGLContext::createNSOpenGLPixelFormat()
{
NSOpenGLPixelFormatAttribute attrs[] =
{
NSOpenGLPFADoubleBuffer,
NSOpenGLPFADepthSize, 32,
0
};
NSOpenGLPixelFormat* pixelFormat = [[NSOpenGLPixelFormat alloc] initWithAttributes:attrs];
return pixelFormat;
}

View File

@ -77,8 +77,8 @@ public:
bool hasCapability(QPlatformIntegration::Capability cap) const; bool hasCapability(QPlatformIntegration::Capability cap) const;
QPixmapData *createPixmapData(QPixmapData::PixelType type) const; QPixmapData *createPixmapData(QPixmapData::PixelType type) const;
QPlatformWindow *createPlatformWindow(QWidget *widget, WId winId = 0) const; QPlatformWindow *createPlatformWindow(QWindow *window) const;
QWindowSurface *createWindowSurface(QWidget *widget, WId winId) const; QWindowSurface *createWindowSurface(QWindow *widget, WId winId) const;
QList<QPlatformScreen *> screens() const { return mScreens; } QList<QPlatformScreen *> screens() const { return mScreens; }

View File

@ -45,9 +45,7 @@
#include "qcocoawindowsurface.h" #include "qcocoawindowsurface.h"
#include "qcocoaeventloopintegration.h" #include "qcocoaeventloopintegration.h"
#include "qcoretextfontdatabase.h" #include "qbasicunixfontdatabase.h"
#include <QtGui/QApplication>
#include <private/qpixmap_raster_p.h> #include <private/qpixmap_raster_p.h>
@ -74,7 +72,7 @@ QCocoaScreen::~QCocoaScreen()
} }
QCocoaIntegration::QCocoaIntegration() QCocoaIntegration::QCocoaIntegration()
: mFontDb(new QCoreTextFontDatabase()) : mFontDb(new QBasicUnixFontDatabase())
{ {
mPool = new QCocoaAutoReleasePool; mPool = new QCocoaAutoReleasePool;
@ -98,6 +96,7 @@ bool QCocoaIntegration::hasCapability(QPlatformIntegration::Capability cap) cons
{ {
switch (cap) { switch (cap) {
case ThreadedPixmaps: return true; case ThreadedPixmaps: return true;
case OpenGL : return true;
default: return QPlatformIntegration::hasCapability(cap); default: return QPlatformIntegration::hasCapability(cap);
} }
} }
@ -109,15 +108,14 @@ QPixmapData *QCocoaIntegration::createPixmapData(QPixmapData::PixelType type) co
return new QRasterPixmapData(type); return new QRasterPixmapData(type);
} }
QPlatformWindow *QCocoaIntegration::createPlatformWindow(QWidget *widget, WId winId) const QPlatformWindow *QCocoaIntegration::createPlatformWindow(QWindow *window) const
{ {
Q_UNUSED(winId); return new QCocoaWindow(window);
return new QCocoaWindow(widget);
} }
QWindowSurface *QCocoaIntegration::createWindowSurface(QWidget *widget, WId winId) const QWindowSurface *QCocoaIntegration::createWindowSurface(QWindow *window, WId winId) const
{ {
return new QCocoaWindowSurface(widget,winId); return new QCocoaWindowSurface(window, winId);
} }
QPlatformFontDatabase *QCocoaIntegration::fontDatabase() const QPlatformFontDatabase *QCocoaIntegration::fontDatabase() const

View File

@ -46,27 +46,32 @@
#include <QPlatformWindow> #include <QPlatformWindow>
#include "qcocoaglcontext.h"
#include "qnsview.h"
QT_BEGIN_NAMESPACE QT_BEGIN_NAMESPACE
class QCocoaWindow : public QPlatformWindow class QCocoaWindow : public QPlatformWindow
{ {
public: public:
QCocoaWindow(QWidget *tlw); QCocoaWindow(QWindow *tlw);
~QCocoaWindow(); ~QCocoaWindow();
void setGeometry(const QRect &rect); void setGeometry(const QRect &rect);
void setVisible(bool visible); void setVisible(bool visible);
WId winId() const; WId winId() const;
NSView *contentView() const; NSView *contentView() const;
void setContentView(NSView *contentView);
void windowDidResize(); void windowDidResize();
QPlatformGLContext *glContext() const;
private: private:
friend class QCocoaWindowSurface;
NSWindow *m_nsWindow; NSWindow *m_nsWindow;
QNSView *m_contentView;
NSView *m_windowSurfaceView;
mutable QCocoaGLContext *m_glContext;
}; };
QT_END_NAMESPACE QT_END_NAMESPACE

View File

@ -41,17 +41,16 @@
#include "qcocoawindow.h" #include "qcocoawindow.h"
#include "qnswindowdelegate.h" #include "qnswindowdelegate.h"
#include "qcocoaautoreleasepool.h" #include "qcocoaautoreleasepool.h"
#include "qcocoaglcontext.h"
#include <QWidget> #include "qnsview.h"
#include <QtGui/QApplication>
#include <QWindowSystemInterface> #include <QWindowSystemInterface>
#include <QDebug> #include <QDebug>
QCocoaWindow::QCocoaWindow(QWidget *tlw) QCocoaWindow::QCocoaWindow(QWindow *tlw)
: QPlatformWindow(tlw) : QPlatformWindow(tlw)
, m_glContext(0)
{ {
QCocoaAutoReleasePool pool; QCocoaAutoReleasePool pool;
const QRect geo = tlw->geometry(); const QRect geo = tlw->geometry();
@ -67,6 +66,20 @@ QCocoaWindow::QCocoaWindow(QWidget *tlw)
[m_nsWindow makeKeyAndOrderFront:nil]; [m_nsWindow makeKeyAndOrderFront:nil];
[m_nsWindow setAcceptsMouseMovedEvents:YES]; [m_nsWindow setAcceptsMouseMovedEvents:YES];
m_contentView = [[QNSView alloc] initWithQWindow:tlw];
if (tlw->surfaceType() == QWindow::OpenGLSurface) {
NSRect glFrame = NSMakeRect(0, 0, geo.width(), geo.height());
m_windowSurfaceView = [[NSOpenGLView alloc] initWithFrame : glFrame pixelFormat : QCocoaGLContext::createNSOpenGLPixelFormat() ];
[m_contentView setAutoresizesSubviews : YES];
[m_windowSurfaceView setAutoresizingMask : (NSViewWidthSizable | NSViewHeightSizable)];
[m_contentView addSubview : m_windowSurfaceView];
} else {
m_windowSurfaceView = m_contentView;
}
[m_nsWindow setContentView:m_contentView];
} }
QCocoaWindow::~QCocoaWindow() QCocoaWindow::~QCocoaWindow()
@ -88,7 +101,7 @@ void QCocoaWindow::setVisible(bool visible)
WId QCocoaWindow::winId() const WId QCocoaWindow::winId() const
{ {
return WId([m_nsWindow windowNumber]); return WId(m_nsWindow);
} }
NSView *QCocoaWindow::contentView() const NSView *QCocoaWindow::contentView() const
@ -96,15 +109,18 @@ NSView *QCocoaWindow::contentView() const
return [m_nsWindow contentView]; return [m_nsWindow contentView];
} }
void QCocoaWindow::setContentView(NSView *contentView)
{
[m_nsWindow setContentView:contentView];
}
void QCocoaWindow::windowDidResize() void QCocoaWindow::windowDidResize()
{ {
//jlind: XXX This isn't ideal. Eventdispatcher does not run when resizing... //jlind: XXX This isn't ideal. Eventdispatcher does not run when resizing...
NSRect rect = [[m_nsWindow contentView]frame]; NSRect rect = [[m_nsWindow contentView]frame];
QRect geo(rect.origin.x,rect.origin.y,rect.size.width,rect.size.height); QRect geo(rect.origin.x,rect.origin.y,rect.size.width,rect.size.height);
QWindowSystemInterface::handleGeometryChange(widget(),geo); QWindowSystemInterface::handleGeometryChange(window(),geo);
}
QPlatformGLContext *QCocoaWindow::glContext() const
{
if (!m_glContext) {
m_glContext = new QCocoaGLContext(m_windowSurfaceView);
}
return m_glContext;
} }

View File

@ -54,18 +54,16 @@ QT_BEGIN_NAMESPACE
class QCocoaWindowSurface : public QWindowSurface class QCocoaWindowSurface : public QWindowSurface
{ {
public: public:
QCocoaWindowSurface(QWidget *window, WId wid); QCocoaWindowSurface(QWindow *window, WId wid);
~QCocoaWindowSurface(); ~QCocoaWindowSurface();
QPaintDevice *paintDevice(); QPaintDevice *paintDevice();
void flush(QWidget *widget, const QRegion &region, const QPoint &offset); void flush(QWindow *widget, const QRegion &region, const QPoint &offset);
void resize (const QSize &size); void resize (const QSize &size);
private: private:
QCocoaWindow *m_cocoaWindow; QCocoaWindow *m_cocoaWindow;
QImage *m_image; QImage *m_image;
QNSView *m_contentView;
}; };
QT_END_NAMESPACE QT_END_NAMESPACE

View File

@ -42,7 +42,6 @@
#include "qcocoawindowsurface.h" #include "qcocoawindowsurface.h"
#include <QtCore/qdebug.h> #include <QtCore/qdebug.h>
#include <QtGui/QPainter> #include <QtGui/QPainter>
QT_BEGIN_NAMESPACE QT_BEGIN_NAMESPACE
@ -56,17 +55,16 @@ QRect flipedRect(const QRect &sourceRect,int height)
return flippedRect; return flippedRect;
} }
QCocoaWindowSurface::QCocoaWindowSurface(QWidget *window, WId wId) QCocoaWindowSurface::QCocoaWindowSurface(QWindow *window, WId wId)
: QWindowSurface(window) : QWindowSurface(window)
{ {
m_cocoaWindow = static_cast<QCocoaWindow *>(window->platformWindow()); Q_UNUSED(wId);
m_cocoaWindow = static_cast<QCocoaWindow *>(window->handle());
const QRect geo = window->geometry(); const QRect geo = window->geometry();
NSRect rect = NSMakeRect(geo.x(),geo.y(),geo.width(),geo.height()); NSRect rect = NSMakeRect(geo.x(),geo.y(),geo.width(),geo.height());
m_contentView = [[QNSView alloc] initWithWidget:window];
m_cocoaWindow->setContentView(m_contentView);
m_image = new QImage(window->size(),QImage::Format_ARGB32); m_image = new QImage(window->geometry().size(),QImage::Format_ARGB32);
} }
QCocoaWindowSurface::~QCocoaWindowSurface() QCocoaWindowSurface::~QCocoaWindowSurface()
@ -79,7 +77,7 @@ QPaintDevice *QCocoaWindowSurface::paintDevice()
return m_image; return m_image;
} }
void QCocoaWindowSurface::flush(QWidget *widget, const QRegion &region, const QPoint &offset) void QCocoaWindowSurface::flush(QWindow *widget, const QRegion &region, const QPoint &offset)
{ {
Q_UNUSED(widget); Q_UNUSED(widget);
Q_UNUSED(offset); Q_UNUSED(offset);
@ -87,7 +85,7 @@ void QCocoaWindowSurface::flush(QWidget *widget, const QRegion &region, const QP
QRect geo = region.boundingRect(); QRect geo = region.boundingRect();
NSRect rect = NSMakeRect(geo.x(), geo.y(), geo.width(), geo.height()); NSRect rect = NSMakeRect(geo.x(), geo.y(), geo.width(), geo.height());
[m_contentView displayRect:rect]; [m_cocoaWindow->m_windowSurfaceView displayRect:rect];
} }
void QCocoaWindowSurface::resize(const QSize &size) void QCocoaWindowSurface::resize(const QSize &size)
@ -96,8 +94,7 @@ void QCocoaWindowSurface::resize(const QSize &size)
delete m_image; delete m_image;
m_image = new QImage(size,QImage::Format_ARGB32_Premultiplied); m_image = new QImage(size,QImage::Format_ARGB32_Premultiplied);
NSSize newSize = NSMakeSize(size.width(),size.height()); NSSize newSize = NSMakeSize(size.width(),size.height());
[m_contentView setImage:m_image]; [m_cocoaWindow->m_windowSurfaceView setImage:m_image];
} }
QT_END_NAMESPACE QT_END_NAMESPACE

View File

@ -48,17 +48,18 @@
@interface QNSView : NSView { @interface QNSView : NSView {
CGImageRef m_cgImage; CGImageRef m_cgImage;
QWidget *m_widget; QWindow *m_window;
Qt::MouseButtons m_buttons; Qt::MouseButtons m_buttons;
} }
- (id)init; - (id)init;
- (id)initWithWidget:(QWidget *)widget; - (id)initWithQWindow:(QWindow *)window;
- (void)setImage:(QImage *)image; - (void)setImage:(QImage *)image;
- (void)drawRect:(NSRect)dirtyRect; - (void)drawRect:(NSRect)dirtyRect;
- (BOOL)isFlipped; - (BOOL)isFlipped;
- (BOOL)acceptsFirstResponder;
- (void)handleMouseEvent:(NSEvent *)theEvent; - (void)handleMouseEvent:(NSEvent *)theEvent;
- (void)mouseDown:(NSEvent *)theEvent; - (void)mouseDown:(NSEvent *)theEvent;
@ -74,6 +75,12 @@
- (void)otherMouseDragged:(NSEvent *)theEvent; - (void)otherMouseDragged:(NSEvent *)theEvent;
- (void)otherMouseUp:(NSEvent *)theEvent; - (void)otherMouseUp:(NSEvent *)theEvent;
- (int) convertKeyCode : (QChar)keyCode;
- (Qt::KeyboardModifiers) convertKeyModifiers : (ulong)modifierFlags;
- (void)handleKeyEvent:(NSEvent *)theEvent eventType:(int)eventType;
- (void)keyDown:(NSEvent *)theEvent;
- (void)keyUp:(NSEvent *)theEvent;
@end @end
#endif //QNSVIEW_H #endif //QNSVIEW_H

View File

@ -52,16 +52,16 @@
self = [super init]; self = [super init];
if (self) { if (self) {
m_cgImage = 0; m_cgImage = 0;
m_widget = 0; m_window = 0;
m_buttons = Qt::NoButton; m_buttons = Qt::NoButton;
} }
return self; return self;
} }
- (id)initWithWidget:(QWidget *)widget { - (id)initWithQWindow:(QWindow *)widget {
self = [self init]; self = [self init];
if (self) { if (self) {
m_widget = widget; m_window = widget;
} }
return self; return self;
} }
@ -130,6 +130,11 @@
return YES; return YES;
} }
- (BOOL)acceptsFirstResponder
{
return YES;
}
- (void)handleMouseEvent:(NSEvent *)theEvent; - (void)handleMouseEvent:(NSEvent *)theEvent;
{ {
NSPoint point = [self convertPoint: [theEvent locationInWindow] fromView: nil]; NSPoint point = [self convertPoint: [theEvent locationInWindow] fromView: nil];
@ -138,40 +143,42 @@
NSTimeInterval timestamp = [theEvent timestamp]; NSTimeInterval timestamp = [theEvent timestamp];
ulong qt_timestamp = timestamp * 1000; ulong qt_timestamp = timestamp * 1000;
QWindowSystemInterface::handleMouseEvent(m_widget,qt_timestamp,qt_localPoint,QPoint(),m_buttons); QWindowSystemInterface::handleMouseEvent(m_window,qt_timestamp,qt_localPoint,QPoint(),m_buttons);
} }
- (void)mouseDown:(NSEvent *)theEvent
{ - (void)mouseDown:(NSEvent *)theEvent
m_buttons |= Qt::LeftButton; {
[self handleMouseEvent:theEvent]; m_buttons |= Qt::LeftButton;
} [self handleMouseEvent:theEvent];
- (void)mouseDragged:(NSEvent *)theEvent }
{
if (!(m_buttons & Qt::LeftButton)) - (void)mouseDragged:(NSEvent *)theEvent
qWarning("Internal Mousebutton tracking invalid(missing Qt::LeftButton"); {
[self handleMouseEvent:theEvent]; if (!(m_buttons & Qt::LeftButton))
} qWarning("Internal Mousebutton tracking invalid(missing Qt::LeftButton");
- (void)mouseUp:(NSEvent *)theEvent [self handleMouseEvent:theEvent];
{ }
m_buttons &= QFlag(~int(Qt::LeftButton));
[self handleMouseEvent:theEvent]; - (void)mouseUp:(NSEvent *)theEvent
} {
m_buttons &= QFlag(~int(Qt::LeftButton));
[self handleMouseEvent:theEvent];
}
- (void)mouseMoved:(NSEvent *)theEvent - (void)mouseMoved:(NSEvent *)theEvent
{ {
qDebug() << "mouseMove";
[self handleMouseEvent:theEvent]; [self handleMouseEvent:theEvent];
} }
- (void)mouseEntered:(NSEvent *)theEvent - (void)mouseEntered:(NSEvent *)theEvent
{ {
Q_UNUSED(theEvent); Q_UNUSED(theEvent);
QWindowSystemInterface::handleEnterEvent(m_widget); QWindowSystemInterface::handleEnterEvent(m_window);
} }
- (void)mouseExited:(NSEvent *)theEvent - (void)mouseExited:(NSEvent *)theEvent
{ {
Q_UNUSED(theEvent); Q_UNUSED(theEvent);
QWindowSystemInterface::handleLeaveEvent(m_widget); QWindowSystemInterface::handleLeaveEvent(m_window);
} }
- (void)rightMouseDown:(NSEvent *)theEvent - (void)rightMouseDown:(NSEvent *)theEvent
{ {
@ -206,6 +213,84 @@
[self handleMouseEvent:theEvent]; [self handleMouseEvent:theEvent];
} }
- (int) convertKeyCode : (QChar)keyChar
{
if (keyChar.isLower())
keyChar = keyChar.toUpper();
int keyCode = keyChar.unicode();
int qtKeyCode = Qt::Key(keyCode); // default case, overrides below
switch (keyCode) {
case NSEnterCharacter: qtKeyCode = Qt::Key_Enter; break;
case NSBackspaceCharacter: qtKeyCode = Qt::Key_Backspace; break;
case NSTabCharacter: qtKeyCode = Qt::Key_Tab; break;
case NSNewlineCharacter: qtKeyCode = Qt::Key_Return; break;
case NSCarriageReturnCharacter: qtKeyCode = Qt::Key_Return; break;
case NSBackTabCharacter: qtKeyCode = Qt::Key_Backtab; break;
case 27 : qtKeyCode = Qt::Key_Escape; break;
case NSDeleteCharacter : qtKeyCode = Qt::Key_Backspace; break; // Cocoa sends us delete when pressing backspace.
case NSUpArrowFunctionKey: qtKeyCode = Qt::Key_Up; break;
case NSDownArrowFunctionKey: qtKeyCode = Qt::Key_Down; break;
case NSLeftArrowFunctionKey: qtKeyCode = Qt::Key_Left; break;
case NSRightArrowFunctionKey: qtKeyCode = Qt::Key_Right; break;
case NSInsertFunctionKey: qtKeyCode = Qt::Key_Insert; break;
case NSDeleteFunctionKey: qtKeyCode = Qt::Key_Delete; break;
case NSHomeFunctionKey: qtKeyCode = Qt::Key_Home; break;
case NSEndFunctionKey: qtKeyCode = Qt::Key_End; break;
case NSPageUpFunctionKey: qtKeyCode = Qt::Key_PageUp; break;
case NSPageDownFunctionKey: qtKeyCode = Qt::Key_PageDown; break;
case NSPrintScreenFunctionKey: qtKeyCode = Qt::Key_Print; break;
case NSScrollLockFunctionKey: qtKeyCode = Qt::Key_ScrollLock; break;
case NSPauseFunctionKey: qtKeyCode = Qt::Key_Pause; break;
case NSSysReqFunctionKey: qtKeyCode = Qt::Key_SysReq; break;
case NSMenuFunctionKey: qtKeyCode = Qt::Key_Menu; break;
case NSHelpFunctionKey: qtKeyCode = Qt::Key_Help; break;
default : break;
}
// handle all function keys (F1-F35)
if (keyCode >= NSF1FunctionKey && keyCode <= NSF35FunctionKey)
qtKeyCode = Qt::Key_F1 + (keyCode - NSF1FunctionKey);
return qtKeyCode;
}
- (Qt::KeyboardModifiers) convertKeyModifiers : (ulong)modifierFlags
{
Qt::KeyboardModifiers qtMods =Qt::NoModifier;
if (modifierFlags & NSShiftKeyMask)
qtMods |= Qt::ShiftModifier;
if (modifierFlags & NSControlKeyMask)
qtMods |= Qt::MetaModifier;
if (modifierFlags & NSAlternateKeyMask)
qtMods |= Qt::AltModifier;
if (modifierFlags & NSCommandKeyMask)
qtMods |= Qt::ControlModifier;
if (modifierFlags & NSNumericPadKeyMask)
qtMods |= Qt::KeypadModifier;
return qtMods;
}
- (void)handleKeyEvent:(NSEvent *)theEvent eventType:(int)eventType
{
NSTimeInterval timestamp = [theEvent timestamp];
ulong qt_timestamp = timestamp * 1000;
QString characters = QString::fromUtf8([[theEvent characters] UTF8String]);
Qt::KeyboardModifiers modifiers = [self convertKeyModifiers : [theEvent modifierFlags]];
QChar ch([[theEvent charactersIgnoringModifiers] characterAtIndex:0]);
int keyCode = [self convertKeyCode : ch];
QWindowSystemInterface::handleKeyEvent(m_window, qt_timestamp, QEvent::Type(eventType), keyCode, modifiers, characters);
}
- (void)keyDown:(NSEvent *)theEvent
{
[self handleKeyEvent : theEvent eventType :int(QEvent::KeyPress)];
}
- (void)keyUp:(NSEvent *)theEvent
{
[self handleKeyEvent : theEvent eventType :int(QEvent::KeyRelease)];
}
@end @end

View File

@ -46,6 +46,26 @@
#include "qcocoawindow.h" #include "qcocoawindow.h"
#if MAC_OS_X_VERSION_MAX_ALLOWED <= MAC_OS_X_VERSION_10_5
@protocol NSWindowDelegate <NSObject>
//- (NSSize)windowWillResize:(NSWindow *)window toSize:(NSSize)proposedFrameSize;
//- (void)windowDidMiniaturize:(NSNotification*)notification;
- (void)windowDidResize:(NSNotification *)notification;
- (void)windowWillClose:(NSNotification *)notification;
//- (NSRect)windowWillUseStandardFrame:(NSWindow *)window defaultFrame:(NSRect)defaultFrame;
//- (void)windowDidMove:(NSNotification *)notification;
//- (BOOL)windowShouldClose:(id)window;
//- (void)windowDidDeminiaturize:(NSNotification *)notification;
//- (void)windowDidBecomeMain:(NSNotification*)notification;
//- (void)windowDidResignMain:(NSNotification*)notification;
//- (void)windowDidBecomeKey:(NSNotification*)notification;
//- (void)windowDidResignKey:(NSNotification*)notification;
//- (BOOL)window:(NSWindow *)window shouldPopUpDocumentPathMenu:(NSMenu *)menu;
//- (BOOL)window:(NSWindow *)window shouldDragDocumentWithEvent:(NSEvent *)event from:(NSPoint)dragImageLocation withPasteboard:(NSPasteboard *)pasteboard;
//- (BOOL)windowShouldZoom:(NSWindow *)window toFrame:(NSRect)newFrame;
@end
#endif
@interface QNSWindowDelegate : NSObject <NSWindowDelegate> @interface QNSWindowDelegate : NSObject <NSWindowDelegate>
{ {
QCocoaWindow *m_cocoaWindow; QCocoaWindow *m_cocoaWindow;

View File

@ -67,7 +67,7 @@
- (void)windowWillClose:(NSNotification *)notification - (void)windowWillClose:(NSNotification *)notification
{ {
Q_UNUSED(notification); Q_UNUSED(notification);
QWindowSystemInterface::handleCloseEvent(m_cocoaWindow->widget()); QWindowSystemInterface::handleCloseEvent(m_cocoaWindow->window());
} }
@end @end