Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(70)

Side by Side Diff: tests/skpdf_opaquesrcmodetosrcover.cpp

Issue 1159763004: SkPDF: with opaque draws, treat SRC mode as SRC_OVER (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: unify with blitter code Created 5 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« src/core/SkXfermodeInterpretation.h ('K') | « src/pdf/SkPDFDevice.cpp ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 /*
2 * Copyright 2015 Google Inc.
3 *
4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
6 */
7 #include "SkCanvas.h"
8 #include "SkDocument.h"
9 #include "SkStream.h"
10 #include "Test.h"
11
12 static void run_test(SkWStream* out, SkXfermode::Mode mode, U8CPU alpha) {
13 SkAutoTUnref<SkDocument> pdfDoc(SkDocument::CreatePDF(out));
14 SkCanvas* c = pdfDoc->beginPage(612.0f, 792.0f);
15 SkPaint black;
16 SkPaint background;
17 background.setColor(SK_ColorWHITE);
18 background.setAlpha(alpha);
19 background.setXfermodeMode(mode);
20 c->drawRect(SkRect::MakeWH(612.0f, 792.0f), background);
21 c->drawRect(SkRect::MakeXYWH(36.0f, 36.0f, 9.0f, 9.0f), black);
22 c->drawRect(SkRect::MakeXYWH(72.0f, 72.0f, 468.0f, 648.0f), background);
23 c->drawRect(SkRect::MakeXYWH(108.0f, 108.0f, 9.0f, 9.0f), black);
24 pdfDoc->close();
25 }
26
27 // http://crbug.com/473572
28 DEF_TEST(SkPDF_OpaqueSrcModeToSrcOver, r) {
29 SkDynamicMemoryWStream srcMode;
30 SkDynamicMemoryWStream srcOverMode;
31
32 U8CPU alpha = SK_AlphaOPAQUE;
33 run_test(&srcMode, SkXfermode::kSrc_Mode, alpha);
34 run_test(&srcOverMode, SkXfermode::kSrcOver_Mode, alpha);
35 REPORTER_ASSERT(r, srcMode.getOffset() == srcOverMode.getOffset());
36 // The two PDFs should be equal because they have an opaque alpha.
37
38 srcMode.reset();
39 srcOverMode.reset();
40
41 alpha = 0x80;
42 run_test(&srcMode, SkXfermode::kSrc_Mode, alpha);
43 run_test(&srcOverMode, SkXfermode::kSrcOver_Mode, alpha);
44 REPORTER_ASSERT(r, srcMode.getOffset() > srcOverMode.getOffset());
45 // The two PDFs should not be equal because they have a non-opaque alpha.
46 }
OLDNEW
« src/core/SkXfermodeInterpretation.h ('K') | « src/pdf/SkPDFDevice.cpp ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698