summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAllan Sandfeld Jensen <[email protected]>2024-09-30 15:01:51 +0200
committerAllan Sandfeld Jensen <[email protected]>2024-10-21 11:02:58 +0000
commit7447b9d350ec0111461a5defacee7634a7470674 (patch)
tree6c49f579bce17a110a2512c5054ead7e6a52b029
parentb782e8074a63f4aca13fc2187114593f66c8e100 (diff)
Add optimized text rendering path for the ARGB32 A8 non-clipped case
Pick-to: 6.8 Change-Id: If3e7a4c5f6f6c33cdf9dd8b6c7c858b004576ad5 Reviewed-by: Eirik Aavitsland <[email protected]>
-rw-r--r--src/gui/painting/qdrawhelper.cpp107
1 files changed, 88 insertions, 19 deletions
diff --git a/src/gui/painting/qdrawhelper.cpp b/src/gui/painting/qdrawhelper.cpp
index 3476b85dfac..376753879b5 100644
--- a/src/gui/painting/qdrawhelper.cpp
+++ b/src/gui/painting/qdrawhelper.cpp
@@ -5329,6 +5329,15 @@ static inline void alphamapblend_generic(int coverage, QRgba64 *dest, int x, con
}
}
+static void qt_alphamapblit_generic_oneline(const uchar *map, int len,
+ const QRgba64 srcColor, QRgba64 *dest,
+ const QRgba64 color,
+ const QColorTrcLut *colorProfile)
+{
+ for (int j = 0; j < len; ++j)
+ alphamapblend_generic(map[j], dest, j, srcColor, color, colorProfile);
+}
+
static void qt_alphamapblit_generic(QRasterBuffer *rasterBuffer,
int x, int y, const QRgba64 &color,
const uchar *map,
@@ -5357,11 +5366,11 @@ static void qt_alphamapblit_generic(QRasterBuffer *rasterBuffer,
int length = mapWidth;
while (length > 0) {
int l = qMin(BufferSize, length);
+
QRgba64 *dest = destFetch64(buffer, rasterBuffer, i, y + ly, l);
- for (int j=0; j < l; ++j) {
- const int coverage = map[j + (i - x)];
- alphamapblend_generic(coverage, dest, j, srcColor, color, colorProfile);
- }
+ qt_alphamapblit_generic_oneline(map + i - x, l,
+ srcColor, dest, color,
+ colorProfile);
if (destStore64)
destStore64(rasterBuffer, i, y + ly, dest, l);
length -= l;
@@ -5388,11 +5397,9 @@ static void qt_alphamapblit_generic(QRasterBuffer *rasterBuffer,
continue;
Q_ASSERT(end - start <= BufferSize);
QRgba64 *dest = destFetch64(buffer, rasterBuffer, start, clip.y, end - start);
-
- for (int xp=start; xp<end; ++xp) {
- const int coverage = map[xp - x];
- alphamapblend_generic(coverage, dest, xp - start, srcColor, color, colorProfile);
- }
+ qt_alphamapblit_generic_oneline(map + start - x, end - start,
+ srcColor, dest, color,
+ colorProfile);
if (destStore64)
destStore64(rasterBuffer, start, clip.y, dest, end - start);
} // for (i -> line.count)
@@ -5535,6 +5542,15 @@ void qt_alphamapblit_quint16(QRasterBuffer *rasterBuffer,
}
}
+static void qt_alphamapblit_argb32_oneline(const uchar *map,
+ int mapWidth, const QRgba64 &srcColor,
+ quint32 *dest, const quint32 c,
+ const QColorTrcLut *colorProfile)
+{
+ for (int i = 0; i < mapWidth; ++i)
+ alphamapblend_argb32(dest + i, map[i], srcColor, c, colorProfile);
+}
+
static void qt_alphamapblit_argb32(QRasterBuffer *rasterBuffer,
int x, int y, const QRgba64 &color,
const uchar *map,
@@ -5559,10 +5575,7 @@ static void qt_alphamapblit_argb32(QRasterBuffer *rasterBuffer,
if (!clip) {
quint32 *dest = reinterpret_cast<quint32*>(rasterBuffer->scanLine(y)) + x;
while (--mapHeight >= 0) {
- for (int i = 0; i < mapWidth; ++i) {
- const int coverage = map[i];
- alphamapblend_argb32(dest + i, coverage, srcColor, c, colorProfile);
- }
+ qt_alphamapblit_argb32_oneline(map, mapWidth, srcColor, dest, c, colorProfile);
dest += destStride;
map += mapStride;
}
@@ -5580,20 +5593,72 @@ static void qt_alphamapblit_argb32(QRasterBuffer *rasterBuffer,
for (int i=0; i<line.count; ++i) {
const QT_FT_Span &clip = line.spans[i];
-
int start = qMax<int>(x, clip.x);
int end = qMin<int>(x + mapWidth, clip.x + clip.len);
-
- for (int xp=start; xp<end; ++xp) {
- const int coverage = map[xp - x];
- alphamapblend_argb32(dest + xp, coverage, srcColor, c, colorProfile);
- } // for (i -> line.count)
+ qt_alphamapblit_argb32_oneline(map + start - x, end - start, srcColor, dest + start, c, colorProfile);
} // for (yp -> bottom)
map += mapStride;
}
}
}
+#if QT_CONFIG(raster_64bit)
+static void qt_alphamapblit_nonpremul_argb32(QRasterBuffer *rasterBuffer,
+ int x, int y, const QRgba64 &color,
+ const uchar *map,
+ int mapWidth, int mapHeight, int mapStride,
+ const QClipData *clip, bool useGammaCorrection)
+{
+ if (clip)
+ return qt_alphamapblit_generic(rasterBuffer, x, y, color, map, mapWidth, mapHeight,
+ mapStride, clip, useGammaCorrection);
+
+ if (color.isTransparent())
+ return;
+
+ const QColorTrcLut *colorProfile = nullptr;
+
+ if (useGammaCorrection)
+ colorProfile = QGuiApplicationPrivate::instance()->colorProfileForA8Text();
+
+ const quint32 c = color.toArgb32();
+ QRgba64 srcColor = color;
+ if (colorProfile && color.isOpaque())
+ srcColor = colorProfile->toLinear(srcColor);
+
+ alignas(8) QRgba64 buffer[BufferSize];
+ const DestFetchProc64 destFetch64 = destFetchProc64[rasterBuffer->format];
+ const DestStoreProc64 destStore64 = destStoreProc64[rasterBuffer->format];
+
+ for (int ly = 0; ly < mapHeight; ++ly) {
+ bool dstFullyOpaque = true;
+ int i = x;
+ int length = mapWidth;
+ while (length > 0) {
+ int l = qMin(BufferSize, length);
+ quint32 *dest = reinterpret_cast<quint32*>(rasterBuffer->scanLine(y + ly)) + i;
+ for (int j = 0; j < l && dstFullyOpaque; ++j)
+ dstFullyOpaque = (dest[j] & 0xff000000) == 0xff000000;
+ if (dstFullyOpaque) {
+ // Use RGB/ARGB32PM optimized version
+ qt_alphamapblit_argb32_oneline(map + i - x, l, srcColor, dest, c, colorProfile);
+ } else {
+ // Use generic version
+ QRgba64 *dest64 = destFetch64(buffer, rasterBuffer, i, y + ly, l);
+ qt_alphamapblit_generic_oneline(map + i - x, l,
+ srcColor, dest64, color,
+ colorProfile);
+ if (destStore64)
+ destStore64(rasterBuffer, i, y + ly, dest64, l);
+ }
+ length -= l;
+ i += l;
+ }
+ map += mapStride;
+ }
+}
+#endif
+
static inline int qRgbAvg(QRgb rgb)
{
return (qRed(rgb) * 5 + qGreen(rgb) * 6 + qBlue(rgb) * 5) / 16;
@@ -6051,7 +6116,11 @@ DrawHelper qDrawHelper[] =
{
blend_color_generic,
qt_bitmapblit_argb32,
+#if QT_CONFIG(raster_64bit)
+ qt_alphamapblit_nonpremul_argb32,
+#else
qt_alphamapblit_generic,
+#endif
qt_alphargbblit_generic,
qt_rectfill_nonpremul_argb32
},