From 7243b7cbf276f99f8455811bdaaece5f62b4618d Mon Sep 17 00:00:00 2001 From: Richard Moe Gustavsen Date: Tue, 18 Apr 2017 11:06:36 +0200 Subject: qmacmime: modernize QMacPasteboardMimeTiff MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Since QMacPasteboardMimeTiff was moved out of the cocoa plugin and into platformsupport, we take the opportunity to give the code some overhaul as well. Change-Id: I7d5425d336ba41474698915008b2086e98ea49dc Reviewed-by: Tor Arne Vestbø --- src/platformsupport/clipboard/qmacmime.mm | 63 ++++++++++++------------------- 1 file changed, 24 insertions(+), 39 deletions(-) (limited to 'src/platformsupport/clipboard/qmacmime.mm') diff --git a/src/platformsupport/clipboard/qmacmime.mm b/src/platformsupport/clipboard/qmacmime.mm index e3f539cfd7..09901ba0a5 100644 --- a/src/platformsupport/clipboard/qmacmime.mm +++ b/src/platformsupport/clipboard/qmacmime.mm @@ -827,55 +827,40 @@ QVariant QMacPasteboardMimeTiff::convertToMime(const QString &mime, QList 1) qWarning("QMacPasteboardMimeTiff: Cannot handle multiple member data"); - QVariant ret; + if (!canConvert(mime, flav)) - return ret; - const QByteArray &a = data.first(); - QCFType image; - QCFType tiffData = CFDataCreateWithBytesNoCopy(0, - reinterpret_cast(a.constData()), - a.size(), kCFAllocatorNull); + return QVariant(); + + QCFType tiffData = data.first().toRawCFData(); QCFType imageSource = CGImageSourceCreateWithData(tiffData, 0); - image = CGImageSourceCreateImageAtIndex(imageSource, 0, 0); - if (image != 0) - ret = QVariant(qt_mac_toQImage(image)); - return ret; + + if (QCFType image = CGImageSourceCreateImageAtIndex(imageSource, 0, 0)) + return QVariant(qt_mac_toQImage(image)); + + return QVariant(); } QList QMacPasteboardMimeTiff::convertFromMime(const QString &mime, QVariant variant, QString flav) { - QList ret; if (!canConvert(mime, flav)) - return ret; - - QImage img = qvariant_cast(variant); - QCFType cgimage = qt_mac_toCGImage(img); + return QList(); QCFType data = CFDataCreateMutable(0, 0); QCFType imageDestination = CGImageDestinationCreateWithData(data, kUTTypeTIFF, 1, 0); - if (imageDestination != 0) { - CFTypeRef keys[2]; - QCFType values[2]; - QCFType options; - keys[0] = kCGImagePropertyPixelWidth; - keys[1] = kCGImagePropertyPixelHeight; - int width = img.width(); - int height = img.height(); - values[0] = CFNumberCreate(0, kCFNumberIntType, &width); - values[1] = CFNumberCreate(0, kCFNumberIntType, &height); - options = CFDictionaryCreate(0, reinterpret_cast(keys), - reinterpret_cast(values), 2, - &kCFTypeDictionaryKeyCallBacks, - &kCFTypeDictionaryValueCallBacks); - CGImageDestinationAddImage(imageDestination, cgimage, options); - CGImageDestinationFinalize(imageDestination); - } - QByteArray ar(CFDataGetLength(data), 0); - CFDataGetBytes(data, - CFRangeMake(0, ar.size()), - reinterpret_cast(ar.data())); - ret.append(ar); - return ret; + + if (!imageDestination) + return QList(); + + QImage img = qvariant_cast(variant); + NSDictionary *props = @{ + static_cast(kCGImagePropertyPixelWidth) : [NSNumber numberWithInt:img.width()], + static_cast(kCGImagePropertyPixelHeight) : [NSNumber numberWithInt:img.height()] + }; + + CGImageDestinationAddImage(imageDestination, qt_mac_toCGImage(img), static_cast(props)); + CGImageDestinationFinalize(imageDestination); + + return QList() << QByteArray::fromCFData(data); } /*! -- cgit v1.2.3