better support for tiled overlays

svn path=/trunk/KDE/kdelibs/; revision=928085
This commit is contained in:
Marco Martin 2009-02-18 21:35:23 +00:00
parent ae80ec1806
commit 0a60f4c5d2

View File

@ -562,8 +562,15 @@ void FrameSvgPrivate::generateBackground(FrameData *frame)
if (q->hasElement(prefix+"hint-overlay-random-pos")) { if (q->hasElement(prefix+"hint-overlay-random-pos")) {
pos = overlayPos; pos = overlayPos;
//Stretched or Tiled? //Stretched or Tiled?
} else if (q->hasElement(prefix+"hint-overlay-stretch") || q->hasElement(prefix+"hint-overlay-tile")) { } else if (q->hasElement(prefix+"hint-overlay-stretch")) {
overlaySize = frame->frameSize; overlaySize = frame->frameSize;
} else {
if (q->hasElement(prefix+"hint-overlay-tile-horizontal")) {
overlaySize.setWidth(frame->frameSize.width());
}
if (q->hasElement(prefix+"hint-overlay-tile-vertical")) {
overlaySize.setHeight(frame->frameSize.height());
}
} }
QString id = QString::fromLatin1("overlay_%7_%6_%5_%4_%3_%2_%1_"). QString id = QString::fromLatin1("overlay_%7_%6_%5_%4_%3_%2_%1_").
@ -575,10 +582,14 @@ void FrameSvgPrivate::generateBackground(FrameData *frame)
overlayPainter.setCompositionMode(QPainter::CompositionMode_SourceIn); overlayPainter.setCompositionMode(QPainter::CompositionMode_SourceIn);
//Tiling? //Tiling?
if (q->hasElement(prefix+"hint-overlay-tile")) { if (q->hasElement(prefix+"hint-overlay-tile-horizontal") ||
q->hasElement(prefix+"hint-overlay-tile-vertical")) {
QSize s = q->size();
q->resize(q->elementSize(prefix+"overlay")); q->resize(q->elementSize(prefix+"overlay"));
kWarning()<<"AAAAAAA"<<q->elementSize(prefix+"overlay");
overlayPainter.drawTiledPixmap(QRect(QPoint(0,0), overlaySize), q->pixmap(prefix+"overlay")); overlayPainter.drawTiledPixmap(QRect(QPoint(0,0), overlaySize), q->pixmap(prefix+"overlay"));
q->resize(); q->resize(s);
} else { } else {
q->paint(&overlayPainter, QRect(overlayPos, overlaySize), prefix+"overlay"); q->paint(&overlayPainter, QRect(overlayPos, overlaySize), prefix+"overlay");
} }