/**************************************************************************** ** ** Copyright (C) 2012 Digia Plc and/or its subsidiary(-ies). ** Contact: http://www.qt-project.org/legal ** ** This file is part of the QtMacExtras module of the Qt Toolkit. ** ** $QT_BEGIN_LICENSE:LGPL$ ** Commercial License Usage ** Licensees holding valid commercial Qt licenses may use this file in ** accordance with the commercial license agreement provided with the ** Software or, alternatively, in accordance with the terms contained in ** a written agreement between you and Digia. For licensing terms and ** conditions see http://qt.digia.com/licensing. For further information ** use the contact form at http://qt.digia.com/contact-us. ** ** GNU Lesser General Public License Usage ** Alternatively, this file may be used under the terms of the GNU Lesser ** General Public License version 2.1 as published by the Free Software ** Foundation and appearing in the file LICENSE.LGPL included in the ** packaging of this file. Please review the following information to ** ensure the GNU Lesser General Public License version 2.1 requirements ** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. ** ** In addition, as a special exception, Digia gives you certain additional ** rights. These rights are described in the Digia Qt LGPL Exception ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. ** ** GNU General Public License Usage ** Alternatively, this file may be used under the terms of the GNU ** General Public License version 3.0 as published by the Free Software ** Foundation and appearing in the file LICENSE.GPL included in the ** packaging of this file. Please review the following information to ** ensure the GNU General Public License version 3.0 requirements will be ** met: http://www.gnu.org/copyleft/gpl.html. ** ** ** $QT_END_LICENSE$ ** ****************************************************************************/ #import #import #include "qmacfunctions.h" #include "qmacfunctions_p.h" #include #if QT_VERSION > QT_VERSION_CHECK(5, 0, 0) #include #include #include #include #endif QT_BEGIN_NAMESPACE namespace QtMac { /*! Creates an \c NSImage equivalent to the QPixmap. Returns the \c NSImage handle. It is the caller's responsibility to release the \c NSImage data after use. */ NSImage* toNSImage(const QPixmap &pixmap) { NSBitmapImageRep *bitmapRep = [[NSBitmapImageRep alloc] initWithCGImage:toCGImageRef(pixmap)]; NSImage *image = [[NSImage alloc] init]; [image addRepresentation:bitmapRep]; [bitmapRep release]; return image; } #if QT_VERSION >= QT_VERSION_CHECK(5, 0, 0) /*! Returns whether the given QWindow is the application's main window */ bool isMainWindow(QWindow *window) { NSWindow *macWindow = static_cast( QGuiApplication::platformNativeInterface()->nativeResourceForWindow("nswindow", window)); if (!macWindow) return false; return [macWindow isMainWindow]; } #endif /*! Returns the current CoreGraphics context. */ CGContextRef currentCGContext() { return reinterpret_cast([[NSGraphicsContext currentContext] graphicsPort]); } /*! Sets the text shown on the application icon a.k.a badge. This is generally used with numbers (e.g. number of unread emails); it can also show a string. \sa badgeLabelText() */ void setBadgeLabelText(const QString &text) { [[[NSApplication sharedApplication] dockTile] setBadgeLabel:text.toNSString()]; } /*! Returns the text of the application icon a.k.a badge. \sa setBadgeText() */ QString badgeLabelText() { return QString::fromNSString([[[NSApplication sharedApplication] dockTile] badgeLabel]); } } // namespace QtMac QT_END_NAMESPACE