diff options
author | tomhudson <tomhudson@google.com> | 2016-05-18 07:24:16 -0700 |
---|---|---|
committer | Commit bot <commit-bot@chromium.org> | 2016-05-18 07:24:16 -0700 |
commit | cb3bd18a4b787f6281930dbe49e1c430f28a367c (patch) | |
tree | 1c32f57742e253980f7480196c9d529ebd074c9b /tests/CanvasTest.cpp | |
parent | 3ab53d0c778704111a72b7107154ade4aa536232 (diff) |
SkCanvas::adjustToTopLayer()
Given a matrix and a clip bounds, offsets them to reflect the difference
between device coordinates and global coordinates. Useful when a client
wants an OS-specific backing for a canvas.
R=reed@google.com
BUG=skia:
GOLD_TRYBOT_URL= https://gold.skia.org/search2?unt=true&query=source_type%3Dgm&master=false&issue=1986383002
Review-Url: https://codereview.chromium.org/1986383002
Diffstat (limited to 'tests/CanvasTest.cpp')
-rw-r--r-- | tests/CanvasTest.cpp | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/tests/CanvasTest.cpp b/tests/CanvasTest.cpp index 1f217e21ca..70c2c04ffa 100644 --- a/tests/CanvasTest.cpp +++ b/tests/CanvasTest.cpp @@ -18,6 +18,7 @@ * function of the form: * * static void MyTestStepFunction(SkCanvas* canvas, + * const TestData& d, * skiatest::Reporter* reporter, * CanvasTestStep* testStep) * { @@ -498,6 +499,45 @@ static void NestedSaveRestoreWithFlushTestStep(SkCanvas* canvas, const TestData& } TEST_STEP(NestedSaveRestoreWithFlush, NestedSaveRestoreWithFlushTestStep); +static void DescribeTopLayerTestStep(SkCanvas* canvas, + const TestData& d, + skiatest::Reporter* reporter, + CanvasTestStep* testStep) { + SkMatrix m; + SkIRect r; + // NOTE: adjustToTopLayer() does *not* reduce the clip size, even if the canvas + // is smaller than 10x10! + + canvas->temporary_internal_describeTopLayer(&m, &r); + REPORTER_ASSERT_MESSAGE(reporter, m.isIdentity(), testStep->assertMessage()); + REPORTER_ASSERT_MESSAGE(reporter, r == SkIRect::MakeXYWH(0, 0, 2, 2), + testStep->assertMessage()); + + // Putting a full-canvas layer on it should make no change to the results. + SkRect layerBounds = SkRect::MakeXYWH(0.f, 0.f, 10.f, 10.f); + canvas->saveLayer(layerBounds, nullptr); + canvas->temporary_internal_describeTopLayer(&m, &r); + REPORTER_ASSERT_MESSAGE(reporter, m.isIdentity(), testStep->assertMessage()); + REPORTER_ASSERT_MESSAGE(reporter, r == SkIRect::MakeXYWH(0, 0, 2, 2), + testStep->assertMessage()); + canvas->restore(); + + // Adding a translated layer translates the results. + // Default canvas is only 2x2, so can't offset our layer by very much at all; + // saveLayer() aborts if the bounds don't intersect. + layerBounds = SkRect::MakeXYWH(1.f, 1.f, 6.f, 6.f); + canvas->saveLayer(layerBounds, nullptr); + canvas->temporary_internal_describeTopLayer(&m, &r); + REPORTER_ASSERT_MESSAGE(reporter, m == SkMatrix::MakeTrans(-1.f, -1.f), + testStep->assertMessage()); + REPORTER_ASSERT_MESSAGE(reporter, r == SkIRect::MakeXYWH(0, 0, 1, 1), + testStep->assertMessage()); + canvas->restore(); + +} +TEST_STEP(DescribeTopLayer, DescribeTopLayerTestStep); + + class CanvasTestingAccess { public: static bool SameState(const SkCanvas* canvas1, const SkCanvas* canvas2) { |