| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright 2014 Google Inc. | 2 * Copyright 2014 Google Inc. |
| 3 * | 3 * |
| 4 * Use of this source code is governed by a BSD-style license that can be | 4 * Use of this source code is governed by a BSD-style license that can be |
| 5 * found in the LICENSE file. | 5 * found in the LICENSE file. |
| 6 */ | 6 */ |
| 7 | 7 |
| 8 #include "Test.h" | 8 #include "Test.h" |
| 9 #include "RecordTestUtils.h" | 9 #include "RecordTestUtils.h" |
| 10 | 10 |
| (...skipping 209 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 220 assert_type<SkRecords::Save> (r, rerecord, 0); | 220 assert_type<SkRecords::Save> (r, rerecord, 0); |
| 221 assert_type<SkRecords::DrawRect>(r, rerecord, 1); | 221 assert_type<SkRecords::DrawRect>(r, rerecord, 1); |
| 222 assert_type<SkRecords::Restore> (r, rerecord, 2); | 222 assert_type<SkRecords::Restore> (r, rerecord, 2); |
| 223 | 223 |
| 224 const SkRecords::DrawRect* drawRect = assert_type<SkRecords::DrawRect>(r, re
record, 1); | 224 const SkRecords::DrawRect* drawRect = assert_type<SkRecords::DrawRect>(r, re
record, 1); |
| 225 REPORTER_ASSERT(r, drawRect->rect == rect); | 225 REPORTER_ASSERT(r, drawRect->rect == rect); |
| 226 REPORTER_ASSERT(r, drawRect->paint.getColor() == SK_ColorRED); | 226 REPORTER_ASSERT(r, drawRect->paint.getColor() == SK_ColorRED); |
| 227 } | 227 } |
| 228 | 228 |
| 229 // A regression test for crbug.com/415468 and skbug.com/2957. | 229 // A regression test for crbug.com/415468 and skbug.com/2957. |
| 230 // |
| 231 // This also now serves as a regression test for crbug.com/418417. We used to a
djust the |
| 232 // bounds for the saveLayer, clip, and restore to be greater than the bounds of
the picture. |
| 233 // (We were applying the saveLayer paint to the bounds after restore, which make
s no sense.) |
| 230 DEF_TEST(RecordDraw_SaveLayerAffectsClipBounds, r) { | 234 DEF_TEST(RecordDraw_SaveLayerAffectsClipBounds, r) { |
| 231 SkRecord record; | 235 SkRecord record; |
| 232 SkRecorder recorder(&record, 50, 50); | 236 SkRecorder recorder(&record, 50, 50); |
| 233 | 237 |
| 234 // We draw a rectangle with a long drop shadow. We used to not update the c
lip | 238 // We draw a rectangle with a long drop shadow. We used to not update the c
lip |
| 235 // bounds based on SaveLayer paints, so the drop shadow could be cut off. | 239 // bounds based on SaveLayer paints, so the drop shadow could be cut off. |
| 236 SkPaint paint; | 240 SkPaint paint; |
| 237 paint.setImageFilter(SkDropShadowImageFilter::Create(20, 0, 0, 0, SK_ColorBL
ACK))->unref(); | 241 paint.setImageFilter(SkDropShadowImageFilter::Create(20, 0, 0, 0, SK_ColorBL
ACK))->unref(); |
| 238 | 242 |
| 239 recorder.saveLayer(NULL, &paint); | 243 recorder.saveLayer(NULL, &paint); |
| 240 recorder.clipRect(SkRect::MakeWH(20, 40)); | 244 recorder.clipRect(SkRect::MakeWH(20, 40)); |
| 241 recorder.drawRect(SkRect::MakeWH(20, 40), SkPaint()); | 245 recorder.drawRect(SkRect::MakeWH(20, 40), SkPaint()); |
| 242 recorder.restore(); | 246 recorder.restore(); |
| 243 | 247 |
| 244 // Under the original bug, all the right edge values would be 20 less than a
sserted here | 248 // Under the original bug, the right edge value of the drawRect would be 20
less than asserted |
| 245 // because we intersected them with a clip that had not been adjusted for th
e drop shadow. | 249 // here because we intersected it with a clip that had not been adjusted for
the drop shadow. |
| 250 // |
| 251 // The second bug showed up as adjusting the picture bounds (0,0,50,50) by t
he drop shadow too. |
| 252 // The saveLayer, clipRect, and restore bounds were incorrectly (0,0,70,50). |
| 246 TestBBH bbh; | 253 TestBBH bbh; |
| 247 SkRecordFillBounds(record, &bbh); | 254 SkRecordFillBounds(record, &bbh); |
| 248 REPORTER_ASSERT(r, bbh.entries.count() == 4); | 255 REPORTER_ASSERT(r, bbh.entries.count() == 4); |
| 249 REPORTER_ASSERT(r, sloppy_rect_eq(bbh.entries[0].bounds, SkRect::MakeLTRB(0,
0, 70, 50))); | 256 REPORTER_ASSERT(r, sloppy_rect_eq(bbh.entries[0].bounds, SkRect::MakeLTRB(0,
0, 50, 50))); |
| 250 REPORTER_ASSERT(r, sloppy_rect_eq(bbh.entries[1].bounds, SkRect::MakeLTRB(0,
0, 70, 50))); | 257 REPORTER_ASSERT(r, sloppy_rect_eq(bbh.entries[1].bounds, SkRect::MakeLTRB(0,
0, 50, 50))); |
| 251 REPORTER_ASSERT(r, sloppy_rect_eq(bbh.entries[2].bounds, SkRect::MakeLTRB(0,
0, 40, 40))); | 258 REPORTER_ASSERT(r, sloppy_rect_eq(bbh.entries[2].bounds, SkRect::MakeLTRB(0,
0, 40, 40))); |
| 252 REPORTER_ASSERT(r, sloppy_rect_eq(bbh.entries[3].bounds, SkRect::MakeLTRB(0,
0, 70, 50))); | 259 REPORTER_ASSERT(r, sloppy_rect_eq(bbh.entries[3].bounds, SkRect::MakeLTRB(0,
0, 50, 50))); |
| 253 } | 260 } |
| OLD | NEW |