Commit b3a201c3 authored by Ilkka Ollakka's avatar Ilkka Ollakka

Qt4: speedup pictureflow rendering littlebit by using scanline and qtransform...

Qt4: speedup pictureflow rendering littlebit by using scanline and qtransform instead of doing those by hand
parent b520bf12
...@@ -509,23 +509,32 @@ static QImage* prepareSurface(const QImage* slideImage, int w, int h, QRgb bgcol ...@@ -509,23 +509,32 @@ static QImage* prepareSurface(const QImage* slideImage, int w, int h, QRgb bgcol
// offscreen buffer: black is sweet // offscreen buffer: black is sweet
QImage* result = new QImage(hs, w, QImage::Format_RGB32); QImage* result = new QImage(hs, w, QImage::Format_RGB32);
QPainter imagePainter( result );
QTransform rotation;
rotation.rotate(90);
result->fill(bgcolor); result->fill(bgcolor);
// transpose the image, this is to speed-up the rendering // transpose the image, this is to speed-up the rendering
// because we process one column at a time // because we process one column at a time
// (and much better and faster to work row-wise, i.e in one scanline) // (and much better and faster to work row-wise, i.e in one scanline)
/*
for (int x = 0; x < w; x++) for (int x = 0; x < w; x++)
for (int y = 0; y < h; y++) for (int y = 0; y < h; y++)
result->setPixel(hofs + y, x, img.pixel(x, y)); result->setPixel(hofs + y, x, img.pixel(x, y));
*/
imagePainter.drawImage( hofs+h, 0, result->transformed( rotation ) );
if (reflectionEffect != PictureFlow::NoReflection) { if (reflectionEffect != PictureFlow::NoReflection) {
// create the reflection // create the reflection
int ht = hs - h - hofs; int ht = hs - h - hofs;
int hte = ht; int hte = ht;
for (int x = 0; x < w; x++) for (int x = 0; x < w; x++)
{
QRgb *line = (QRgb*)(result->scanLine( x ));
for (int y = 0; y < ht; y++) { for (int y = 0; y < ht; y++) {
QRgb color = img.pixel(x, img.height() - y - 1); QRgb color = img.pixel(x, img.height() - y - 1);
result->setPixel(h + hofs + y, x, blendColor(color, bgcolor, 128*(hte - y) / hte)); line[h+hofs+y] = blendColor( color, bgcolor, 128*(hte-y)/hte );
//result->setPixel(h + hofs + y, x, blendColor(color, bgcolor, 128*(hte - y) / hte));
}
} }
if (reflectionEffect == PictureFlow::BlurredReflection) { if (reflectionEffect == PictureFlow::BlurredReflection) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment