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

Unified Diff: Source/platform/graphics/Image.h

Issue 1093673002: Removing the dependency on GraphicsContext for drawing images in 2D canvas (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: rebase Created 5 years, 7 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 side-by-side diff with in-line comments
Download patch
Index: Source/platform/graphics/Image.h
diff --git a/Source/platform/graphics/Image.h b/Source/platform/graphics/Image.h
index fb4929bc5a88d80dc91cf095ea92203b3c11fdf8..bdf45f537ae714b2ea7f728c6423f685a54d6d5f 100644
--- a/Source/platform/graphics/Image.h
+++ b/Source/platform/graphics/Image.h
@@ -33,7 +33,7 @@
#include "platform/graphics/GraphicsTypes.h"
#include "platform/graphics/ImageAnimationPolicy.h"
#include "platform/graphics/ImageOrientation.h"
-#include "third_party/skia/include/core/SkXfermode.h"
+#include "third_party/skia/include/core/SkCanvas.h"
#include "wtf/Assertions.h"
#include "wtf/PassRefPtr.h"
#include "wtf/RefCounted.h"
@@ -52,6 +52,7 @@ class FloatSize;
class GraphicsContext;
class Length;
class SharedBuffer;
+class Image;
// This class gets notified when an image creates or destroys decoded frames and when it advances animation frames.
class ImageObserver;
@@ -70,6 +71,8 @@ public:
virtual bool isSVGImage() const { return false; }
virtual bool isBitmapImage() const { return false; }
+ virtual bool isLazyDecodedBitmap() { return false; }
+ virtual bool isImmutableBitmap() { return false; }
virtual bool currentFrameKnownToBeOpaque() = 0;
virtual PassRefPtr<SkImage> skImage();
@@ -139,13 +142,18 @@ public:
virtual bool notSolidColor() { return true; }
#endif
+ enum ImageClampingMode {
+ ClampImageToSourceRect,
+ DoNotClampImageToSourceRect
+ };
+
+ virtual void draw(SkCanvas*, const SkPaint&, const FloatRect& dstRect, const FloatRect& srcRect, RespectImageOrientationEnum, ImageClampingMode) = 0;
+
protected:
Image(ImageObserver* = 0);
static void fillWithSolidColor(GraphicsContext*, const FloatRect& dstRect, const Color&, SkXfermode::Mode);
- static FloatRect adjustForNegativeSize(const FloatRect&); // A helper method for translating negative width and height values.
- virtual void draw(GraphicsContext*, const FloatRect& dstRect, const FloatRect& srcRect, SkXfermode::Mode, RespectImageOrientationEnum) = 0;
void drawTiled(GraphicsContext*, const FloatRect& dstRect, const FloatPoint& srcPoint, const FloatSize& tileSize,
SkXfermode::Mode, const IntSize& repeatSpacing);
void drawTiled(GraphicsContext*, const FloatRect& dstRect, const FloatRect& srcRect, const FloatSize& tileScaleFactor, TileRule hRule, TileRule vRule, SkXfermode::Mode);

Powered by Google App Engine
This is Rietveld 408576698