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

Unified Diff: third_party/WebKit/Source/modules/canvas2d/BaseRenderingContext2D.h

Issue 2523673004: [NOT FOR COMMIT] Fully replace SkCanvas uses.
Patch Set: Support Android build. Created 4 years 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 side-by-side diff with in-line comments
Download patch
Index: third_party/WebKit/Source/modules/canvas2d/BaseRenderingContext2D.h
diff --git a/third_party/WebKit/Source/modules/canvas2d/BaseRenderingContext2D.h b/third_party/WebKit/Source/modules/canvas2d/BaseRenderingContext2D.h
index db7605d57280e023ef49e0a396b360534cd0e98f..2e4fd8815ead829b009b2d27fb1c0f01f312f742 100644
--- a/third_party/WebKit/Source/modules/canvas2d/BaseRenderingContext2D.h
+++ b/third_party/WebKit/Source/modules/canvas2d/BaseRenderingContext2D.h
@@ -14,6 +14,7 @@
#include "modules/canvas2d/CanvasRenderingContext2DState.h"
#include "modules/canvas2d/CanvasStyle.h"
#include "platform/graphics/ExpensiveCanvasHeuristicParameters.h"
+#include "skia/ext/cdl_canvas.h"
#include "third_party/skia/include/core/SkCanvas.h"
#include "third_party/skia/include/effects/SkComposeImageFilter.h"
@@ -221,8 +222,8 @@ class MODULES_EXPORT BaseRenderingContext2D : public GarbageCollectedMixin,
virtual bool parseColorOrCurrentColor(Color&,
const String& colorString) const = 0;
- virtual SkCanvas* drawingCanvas() const = 0;
- virtual SkCanvas* existingDrawingCanvas() const = 0;
+ virtual CdlCanvas* drawingCanvas() const = 0;
+ virtual CdlCanvas* existingDrawingCanvas() const = 0;
virtual void disableDeferral(DisableDeferralReason) = 0;
virtual AffineTransform baseTransform() const = 0;
@@ -239,7 +240,7 @@ class MODULES_EXPORT BaseRenderingContext2D : public GarbageCollectedMixin,
virtual bool isContextLost() const = 0;
- void restoreMatrixClipStack(SkCanvas*) const;
+ void restoreMatrixClipStack(CdlCanvas*) const;
DECLARE_VIRTUAL_TRACE();
@@ -322,7 +323,7 @@ class MODULES_EXPORT BaseRenderingContext2D : public GarbageCollectedMixin,
};
void checkOverdraw(const SkRect&,
- const SkPaint*,
+ const CdlPaint*,
CanvasRenderingContext2DState::ImageType,
DrawType);
@@ -347,12 +348,12 @@ class MODULES_EXPORT BaseRenderingContext2D : public GarbageCollectedMixin,
void drawPathInternal(const Path&,
CanvasRenderingContext2DState::PaintType,
SkPath::FillType = SkPath::kWinding_FillType);
- void drawImageInternal(SkCanvas*,
+ void drawImageInternal(CdlCanvas*,
CanvasImageSource*,
Image*,
const FloatRect& srcRect,
const FloatRect& dstRect,
- const SkPaint*);
+ const CdlPaint*);
void clipInternal(const Path&, const String& windingRuleString);
bool isPointInPathInternal(const Path&,
@@ -365,7 +366,7 @@ class MODULES_EXPORT BaseRenderingContext2D : public GarbageCollectedMixin,
template <typename DrawFunc>
void compositedDraw(const DrawFunc&,
- SkCanvas*,
+ CdlCanvas*,
CanvasRenderingContext2DState::PaintType,
CanvasRenderingContext2DState::ImageType);
@@ -401,14 +402,14 @@ bool BaseRenderingContext2D::draw(
didDraw(clipBounds);
} else if (state().globalComposite() == SkBlendMode::kSrc) {
clearCanvas(); // takes care of checkOverdraw()
- const SkPaint* paint =
+ const CdlPaint* paint =
state().getPaint(paintType, DrawForegroundOnly, imageType);
drawFunc(drawingCanvas(), paint);
didDraw(clipBounds);
} else {
SkIRect dirtyRect;
if (computeDirtyRect(bounds, clipBounds, &dirtyRect)) {
- const SkPaint* paint =
+ const CdlPaint* paint =
state().getPaint(paintType, DrawShadowAndForeground, imageType);
if (paintType != CanvasRenderingContext2DState::StrokePaintType &&
drawCoversClipBounds(clipBounds))
@@ -423,22 +424,22 @@ bool BaseRenderingContext2D::draw(
template <typename DrawFunc>
void BaseRenderingContext2D::compositedDraw(
const DrawFunc& drawFunc,
- SkCanvas* c,
+ CdlCanvas* c,
CanvasRenderingContext2DState::PaintType paintType,
CanvasRenderingContext2DState::ImageType imageType) {
sk_sp<SkImageFilter> filter = stateGetFilter();
ASSERT(isFullCanvasCompositeMode(state().globalComposite()) || filter);
SkMatrix ctm = c->getTotalMatrix();
c->resetMatrix();
- SkPaint compositePaint;
+ CdlPaint compositePaint;
compositePaint.setBlendMode((SkBlendMode)state().globalComposite());
if (state().shouldDrawShadows()) {
// unroll into two independently composited passes if drawing shadows
- SkPaint shadowPaint =
+ CdlPaint shadowPaint =
*state().getPaint(paintType, DrawShadowOnly, imageType);
int saveCount = c->getSaveCount();
if (filter) {
- SkPaint foregroundPaint =
+ CdlPaint foregroundPaint =
*state().getPaint(paintType, DrawForegroundOnly, imageType);
sk_sp<SkImageFilter> composedFilter =
sk_ref_sp(foregroundPaint.getImageFilter());
@@ -461,7 +462,7 @@ void BaseRenderingContext2D::compositedDraw(
compositePaint.setImageFilter(std::move(filter));
c->saveLayer(nullptr, &compositePaint);
- SkPaint foregroundPaint =
+ CdlPaint foregroundPaint =
*state().getPaint(paintType, DrawForegroundOnly, imageType);
foregroundPaint.setBlendMode(SkBlendMode::kSrcOver);
c->setMatrix(ctm);

Powered by Google App Engine
This is Rietveld 408576698