From: David Edmundson Date: Tue, 31 Mar 2015 13:19:51 +0000 (+0200) Subject: Remove deprecated X scaling of QPixmaps X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/commitdiff_plain/de84f223d4408dc1eaf6f15ebeed2e8acf49ad4c Remove deprecated X scaling of QPixmaps QPixmaps are no longer X pixmaps so this won't ever work anymore REVIEW: 123138 --- diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index bf42fd06d..89a4e431c 100644 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -16,12 +16,6 @@ remove_definitions( -DQT_NO_CAST_TO_ASCII ) -if(X11_Xrender_FOUND) - set(HAVE_XRENDER TRUE) -endif() - -configure_file(config-X11.h.cmake ${CMAKE_CURRENT_BINARY_DIR}/config-X11.h) - ########################################## set(dolphinvcs_LIB_SRCS @@ -169,10 +163,6 @@ else() ) endif() -if(X11_Xrender_FOUND) - target_link_libraries(dolphinprivate ${X11_Xrender_LIB}) -endif(X11_Xrender_FOUND) - set_target_properties(dolphinprivate PROPERTIES VERSION ${DOLPHINPRIVATE_VERSION_STRING} SOVERSION ${DOLPHINPRIVATE_SOVERSION} diff --git a/src/kitemviews/private/kpixmapmodifier.cpp b/src/kitemviews/private/kpixmapmodifier.cpp index 4693b313a..9340c9790 100644 --- a/src/kitemviews/private/kpixmapmodifier.cpp +++ b/src/kitemviews/private/kpixmapmodifier.cpp @@ -40,14 +40,6 @@ #include #include - -#include // for HAVE_XRENDER -#if defined(Q_WS_X11) && defined(HAVE_XRENDER) -# include -# include -# include -#endif - static const quint32 stackBlur8Mul[255] = { 512,512,456,512,328,456,335,512,405,328,271,456,388,335,292,512, @@ -331,45 +323,9 @@ void KPixmapModifier::scale(QPixmap& pixmap, const QSize& scaledSize) pixmap = QPixmap(); return; } - -#if defined(Q_WS_X11) && defined(HAVE_XRENDER) - // Assume that the texture size limit is 2048x2048 - if ((pixmap.width() <= 2048) && (pixmap.height() <= 2048) && pixmap.x11PictureHandle()) { - const QPixmap unscaledPixmap = pixmap.copy(); // Make a deep copy for XRender - QSize scaledPixmapSize = pixmap.size(); - scaledPixmapSize.scale(scaledSize, Qt::KeepAspectRatio); - - const qreal factor = scaledPixmapSize.width() / qreal(unscaledPixmap.width()); - - XTransform xform = {{ - { XDoubleToFixed(1 / factor), 0, 0 }, - { 0, XDoubleToFixed(1 / factor), 0 }, - { 0, 0, XDoubleToFixed(1) } - }}; - - QPixmap scaledPixmap(scaledPixmapSize); - scaledPixmap.setDevicePixelRatio(pixmap.devicePixelRatio()); - scaledPixmap.fill(Qt::transparent); - - Display* dpy = QX11Info::display(); - - XRenderPictureAttributes attr; - attr.repeat = RepeatPad; - XRenderChangePicture(dpy, unscaledPixmap.x11PictureHandle(), CPRepeat, &attr); - - XRenderSetPictureFilter(dpy, unscaledPixmap.x11PictureHandle(), FilterBilinear, 0, 0); - XRenderSetPictureTransform(dpy, unscaledPixmap.x11PictureHandle(), &xform); - XRenderComposite(dpy, PictOpOver, unscaledPixmap.x11PictureHandle(), None, scaledPixmap.x11PictureHandle(), - 0, 0, 0, 0, 0, 0, scaledPixmap.width(), scaledPixmap.height()); - pixmap = scaledPixmap; - } else { - pixmap = pixmap.scaled(scaledSize, Qt::KeepAspectRatio, Qt::SmoothTransformation); - } -#else qreal dpr = pixmap.devicePixelRatio(); pixmap = pixmap.scaled(scaledSize, Qt::KeepAspectRatio, Qt::SmoothTransformation); pixmap.setDevicePixelRatio(dpr); -#endif } void KPixmapModifier::applyFrame(QPixmap& icon, const QSize& scaledSize)