summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAshod Nakashian <ashod.nakashian@collabora.co.uk>2017-12-03 23:34:22 -0500
committerAshod Nakashian <ashod.nakashian@collabora.co.uk>2017-12-06 20:41:02 -0500
commitb7d893d8a1ecb24290c4470e12d71caba2b85216 (patch)
tree4d3c6a34ec30ba47a8476609d2239ec09a891064
parentabc7959a1902565d1f8ed1cb7d8f8c976af8cbcf (diff)
LOK: support tile-dumping in tilebench
And other improvements. Change-Id: I5a27d6d2df5f946a708dd3b0b4fef8159da86e5c
-rw-r--r--libreofficekit/qa/tilebench/tilebench.cxx73
1 files changed, 61 insertions, 12 deletions
diff --git a/libreofficekit/qa/tilebench/tilebench.cxx b/libreofficekit/qa/tilebench/tilebench.cxx
index 6ad0d578c464..a5745b28e5d2 100644
--- a/libreofficekit/qa/tilebench/tilebench.cxx
+++ b/libreofficekit/qa/tilebench/tilebench.cxx
@@ -13,6 +13,7 @@
#include <cmath>
#include <vector>
+#include <fstream>
#include <osl/time.h>
#include <LibreOfficeKit/LibreOfficeKitEnums.h>
@@ -36,6 +37,48 @@ static double getTimeNow()
(double)aValue.Nanosec / (1000*1000*1000);
}
+/// Dump an array of RGBA or BGRA to an RGB PPM file.
+static void dumpTile(const int nWidth, const int nHeight, const int mode, const char* pBuffer)
+{
+ std::ofstream ofs("/tmp/dump_tile.ppm");
+ ofs << "P6" << "\n"
+ << nWidth << " "
+ << nHeight << "\n"
+ << 255 << "\n" ;
+
+ for (int y = 0; y < nHeight; ++y)
+ {
+ const char* row = pBuffer + y * nWidth * 4;
+ for (int x = 0; x < nWidth; ++x)
+ {
+ const char* pixel = row + x * 4;
+ if (mode == LOK_TILEMODE_RGBA)
+ {
+ ofs.write(pixel, 3); // Skip alpha
+ }
+ else if (mode == LOK_TILEMODE_BGRA)
+ {
+ const int alpha = *(pixel + 3);
+ char buf[3];
+ if (alpha == 0)
+ {
+ buf[0] = 0;
+ buf[1] = 0;
+ buf[2] = 0;
+ }
+ else
+ {
+ buf[0] = (*(pixel + 2) * 255 + alpha / 2) / alpha;
+ buf[1] = (*(pixel + 1) * 255 + alpha / 2) / alpha;
+ buf[2] = (*(pixel + 0) * 255 + alpha / 2) / alpha;
+ }
+
+ ofs.write(buf, 3);
+ }
+ }
+ }
+}
+
int main( int argc, char* argv[] )
{
static const double origin = getTimeNow();
@@ -73,35 +116,42 @@ int main( int argc, char* argv[] )
aTimes.push_back(TimeRecord());
const int max_parts = (argc > 3 ? atoi(argv[3]) : -1);
- const int max_tiles = (argc > 4 ? atoi(argv[4]) : -1);
+ int max_tiles = (argc > 4 ? atoi(argv[4]) : -1);
+ const bool dump = true;
if (argv[2] != nullptr)
{
aTimes.emplace_back("load document");
Document *pDocument(pOffice->documentLoad(argv[2]));
aTimes.emplace_back();
+ const int mode = pDocument->getTileMode();
aTimes.emplace_back("getparts");
- const int nOriginalPart = pDocument->getPart();
+ const int nOriginalPart = (pDocument->getDocumentType() == LOK_DOCTYPE_TEXT ? 1 : pDocument->getPart());
// Writer really has 1 part (the full doc).
const int nTotalParts = (pDocument->getDocumentType() == LOK_DOCTYPE_TEXT ? 1 : pDocument->getParts());
const int nParts = (max_parts < 0 ? nTotalParts : std::min(max_parts, nTotalParts));
- fprintf(stderr, "Parts to render: %d, Total Parts: %d, Max parts: %d, Max tiles: %d\n", nParts, nTotalParts, max_parts, max_tiles);
aTimes.emplace_back();
aTimes.emplace_back("get size of parts");
+ long nWidth = 0;
+ long nHeight = 0;
for (int n = 0; n < nParts; ++n)
{
const int nPart = (nOriginalPart + n) % nTotalParts;
char* pName = pDocument->getPartName(nPart);
pDocument->setPart(nPart);
- long nWidth = 0, nHeight = 0;
pDocument->getDocumentSize(&nWidth, &nHeight);
fprintf (stderr, " '%s' -> %ld, %ld\n", pName, nWidth, nHeight);
free (pName);
}
aTimes.emplace_back();
+ // Estimate the maximum tiles based on the number of parts requested, if Writer.
+ if (pDocument->getDocumentType() == LOK_DOCTYPE_TEXT)
+ max_tiles = (int)ceil(max_parts * 16128. / nTilePixelHeight) * ceil((double)nWidth / nTilePixelWidth);
+ fprintf(stderr, "Parts to render: %d, Total Parts: %d, Max parts: %d, Max tiles: %d\n", nParts, nTotalParts, max_parts, max_tiles);
+
std::vector<unsigned char> vBuffer(nTilePixelWidth * nTilePixelHeight * 4);
unsigned char* pPixels = &vBuffer[0];
@@ -110,25 +160,25 @@ int main( int argc, char* argv[] )
const int nPart = (nOriginalPart + n) % nTotalParts;
char* pName = pDocument->getPartName(nPart);
pDocument->setPart(nPart);
- long nWidth = 0, nHeight = 0;
pDocument->getDocumentSize(&nWidth, &nHeight);
fprintf (stderr, "render '%s' -> %ld, %ld\n", pName, nWidth, nHeight);
free (pName);
- if (pDocument->getDocumentType() != LOK_DOCTYPE_TEXT)
- { // whole part; meaningful only for non-writer documents.
- aTimes.emplace_back("render whole document");
+ if (dump || pDocument->getDocumentType() != LOK_DOCTYPE_TEXT)
+ {
+ // whole part; meaningful only for non-writer documents.
+ aTimes.emplace_back("render whole part");
pDocument->paintTile(pPixels, nTilePixelWidth, nTilePixelHeight,
- 0, 0, nWidth, nHeight); // not square
+ nWidth/2, 2000, 1000, 1000); // not square
aTimes.emplace_back();
+ if (dump)
+ dumpTile(nTilePixelWidth, nTilePixelHeight, mode, (char*)pPixels);
}
{ // 1:1
aTimes.emplace_back("render sub-region at 1:1");
// Estimate the maximum tiles based on the number of parts requested, if Writer.
int nMaxTiles = max_tiles;
- if (pDocument->getDocumentType() == LOK_DOCTYPE_TEXT)
- nMaxTiles = (int)ceil(max_parts * 16128. / nTilePixelHeight) * ceil((double)nWidth / nTilePixelWidth);
int nTiles = 0;
for (int nY = 0; nY < nHeight - 1; nY += nTilePixelHeight)
{
@@ -152,7 +202,6 @@ int main( int argc, char* argv[] )
{ // scaled
aTimes.emplace_back("render sub-regions at scale");
- // Estimate the maximum tiles based on the number of parts requested, if Writer.
int nMaxTiles = max_tiles;
if (pDocument->getDocumentType() == LOK_DOCTYPE_TEXT)
nMaxTiles = (int)ceil(max_parts * 16128. / nTileTwipHeight) * ceil((double)nWidth / nTileTwipWidth);