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

Side by Side Diff: src/core/SkPaintPriv.h

Issue 1228853005: rename utility to see if a paint will overwrite its pixels (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: Created 5 years, 5 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
« no previous file with comments | « no previous file | src/core/SkPaintPriv.cpp » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * Copyright 2013 Google Inc. 2 * Copyright 2013 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 #ifndef SkPaintPriv_DEFINED 8 #ifndef SkPaintPriv_DEFINED
9 #define SkPaintPriv_DEFINED 9 #define SkPaintPriv_DEFINED
10 10
11 #include "SkTypes.h" 11 #include "SkTypes.h"
12 12
13 class SkBitmap; 13 class SkBitmap;
14 class SkImage; 14 class SkImage;
15 class SkPaint; 15 class SkPaint;
16 16
17 enum SkPaintBitmapOpacity { 17 class SkPaintPriv {
18 // No content replaces the paint's color 18 public:
19 kNoBitmap_SkPaintBitmapOpacity = 0, 19 /**
20 // The color replacement is known to be opaque 20 * Returns true if drawing with this paint (or NULL) will ovewrite all affe cted pixels.
21 kOpaque_SkPaintBitmapOpacity = 1, 21 *
22 // We have no information about the color or it is transparent 22 * Note: returns conservative true, meaning it may return false even though the paint might
23 kUnknown_SkPaintBitmapOpacity = 2 23 * in fact overwrite its pixels.
24 */
25 static bool Overwrites(const SkPaint& paint);
26
27 /**
28 * Returns true if drawing this bitmap with this paint (or NULL) will ovewr ite all affected
29 * pixels.
30 */
31 static bool Overwrites(const SkBitmap&, const SkPaint* paint);
32
33 /**
34 * Returns true if drawing this image with this paint (or NULL) will ovewri te all affected
35 * pixels.
36 */
37 static bool Overwrites(const SkImage*, const SkPaint* paint);
24 }; 38 };
25 39
26 /** Returns true if draw calls that use the paint will completely occlude
27 canvas contents that are covered by the draw.
28 @param paint The paint to be analyzed, NULL is equivalent to
29 the default paint.
30 @param contentType The type of the content that will be drawn,
31 kNoBitmap_SkPaintBitmapOpacity if there is no content in adition to the paint.
32 @return true if paint is opaque
33 */
34 bool isPaintOpaque(const SkPaint* paint, SkPaintBitmapOpacity contentType);
35
36 /** Returns true if draw calls that use the paint will completely occlude
37 canvas contents that are covered by the draw.
38 @param paint The paint to be analyzed, NULL is equivalent to
39 the default paint.
40 @param bmpReplacesShader a bitmap to be used in place of the paint's
41 shader.
42 @return true if paint is opaque
43 */
44 bool isPaintOpaque(const SkPaint* paint, const SkBitmap* bmpReplacesShader = NUL L);
45 bool isPaintOpaque(const SkPaint* paint, const SkImage* image);
46
47 #endif 40 #endif
OLDNEW
« no previous file with comments | « no previous file | src/core/SkPaintPriv.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698