skia2/tests/WindowRectanglesTest.cpp
csmartdalton bf4a8f90c8 Improve usage of window rectangles
* Skips non-AA diff rect elements and replaces them with window
  rectangles.
* Places window rectangles in the interiors of antialiased diff rects.
* Arranges two overlapping window rectangles in a plus shape inside of
  diff rounded rects.
* Enables window rectangles when clearing and generating clip masks.

GTX 960 perf result (with vs. without window rectangles):

                              glinst4                msaa16                 gpu
keymobi_pinterest.skp         0.48 -> 0.17 [ 35%]    2.77 -> 1.49 [ 54%]    0.22 -> 0.16 [ 70%]
keymobi_digg_com.skp          0.42 -> 0.23 [ 55%]    2.34 -> 1.08 [ 46%]    0.25 -> 0.21 [ 83%]
desk_jsfiddlebigcar.skp       0.28 -> 0.16 [ 59%]    1.70 -> 0.96 [ 57%]    0.19 -> 0.14 [ 70%]
top25desk_wordpress.skp       0.45 -> 0.18 [ 40%]    2.78 -> 1.53 [ 55%]    0.21 -> 0.19 [ 94%]
top25desk_weather_com.skp     2.01 -> 1.93 [ 96%]    23.5 -> 2.54 [ 11%]    1.90 -> 1.68 [ 88%]
keymobi_blogger.skp           0.57 -> 0.37 [ 65%]    2.87 -> 1.54 [ 54%]    0.43 -> 0.33 [ 77%]
keymobi_linkedin.skp          0.32 -> 0.17 [ 51%]    1.93 -> 1.04 [ 54%]    0.17 -> 0.15 [ 91%]
keymobi_bing_com_search_...   0.29 -> 0.25 [ 83%]    1.85 -> 1.23 [ 66%]    0.50 -> 0.24 [ 48%]
keymobi_theverge_com_201...   1.00 -> 0.67 [ 68%]    9.46 -> 3.84 [ 41%]    0.72 -> 0.65 [ 90%]
keymobi_sfgate_com_.skp       1.56 -> 1.13 [ 72%]    4.49 -> 2.86 [ 64%]    1.54 -> 1.11 [ 72%]
...
GEOMEAN (All 79 blink skps)   1.04 -> 0.90 [ 86%]    4.22 -> 2.81 [ 67%]    0.95 -> 0.89 [ 94%]

BUG=skia:
GOLD_TRYBOT_URL= https://gold.skia.org/search?issue=2289363005

Committed: https://skia.googlesource.com/skia/+/db42be9a326c747ff92ed1da8c3536c5b3e8e22b
Review-Url: https://codereview.chromium.org/2289363005
2016-09-06 10:01:07 -07:00

77 lines
2.7 KiB
C++

/*
* Copyright 2016 Google Inc.
*
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#include "SkTypes.h"
#include "Test.h"
#if SK_SUPPORT_GPU
#include "GrWindowRectangles.h"
static SkIRect next_irect(SkRandom& r) {
return {r.nextS(), r.nextS(), r.nextS(), r.nextS()};
}
DEF_TEST(WindowRectangles, reporter) {
SkRandom r;
SkIRect windowData[GrWindowRectangles::kMaxWindows];
for (int i = 0; i < GrWindowRectangles::kMaxWindows; ++i) {
windowData[i] = next_irect(r);
}
GrWindowRectangles wr;
for (int i = 0; i < GrWindowRectangles::kMaxWindows - 1; ++i) {
REPORTER_ASSERT(reporter, wr.count() == i);
REPORTER_ASSERT(reporter, !memcmp(wr.data(), windowData, i * sizeof(SkIRect)));
GrWindowRectangles wr2(wr);
REPORTER_ASSERT(reporter, wr2 == wr);
REPORTER_ASSERT(reporter, wr2.count() == wr.count());
REPORTER_ASSERT(reporter, !memcmp(wr2.data(), wr.data(), i * sizeof(SkIRect)));
wr.addWindow(windowData[i]);
}
SkASSERT(wr.count() == GrWindowRectangles::kMaxWindows - 1);
{
GrWindowRectangles A(wr), B(wr);
REPORTER_ASSERT(reporter, B == A);
REPORTER_ASSERT(reporter, B.data() == A.data()); // Should use copy-on-write.
A.addWindow(windowData[GrWindowRectangles::kMaxWindows - 1]);
REPORTER_ASSERT(reporter, B.data() != A.data());
REPORTER_ASSERT(reporter, B != A);
B.addWindow(SkIRect::MakeLargest());
REPORTER_ASSERT(reporter, B != A);
REPORTER_ASSERT(reporter, !memcmp(A.data(), windowData,
GrWindowRectangles::kMaxWindows * sizeof(SkIRect)));
REPORTER_ASSERT(reporter, !memcmp(B.data(), windowData,
(GrWindowRectangles::kMaxWindows - 1) * sizeof(SkIRect)));
REPORTER_ASSERT(reporter,
B.data()[GrWindowRectangles::kMaxWindows - 1] == SkIRect::MakeLargest());
}
{
GrWindowRectangles A(wr), B(wr);
REPORTER_ASSERT(reporter, B == A);
REPORTER_ASSERT(reporter, B.data() == A.data()); // Should use copy-on-write.
A.addWindow(windowData[GrWindowRectangles::kMaxWindows - 1]);
B.addWindow(windowData[GrWindowRectangles::kMaxWindows - 1]);
REPORTER_ASSERT(reporter, B == A);
REPORTER_ASSERT(reporter, B.data() != A.data());
REPORTER_ASSERT(reporter, !memcmp(B.data(), A.data(),
GrWindowRectangles::kMaxWindows * sizeof(SkIRect)));
REPORTER_ASSERT(reporter, !memcmp(A.data(), windowData,
GrWindowRectangles::kMaxWindows * sizeof(SkIRect)));
}
}
#endif