Index: Source/core/page/ImageBitmap.h |
diff --git a/Source/core/page/ImageBitmap.h b/Source/core/page/ImageBitmap.h |
index 4a5833a0e3490becb034eacf18bb2122c91662c5..102fa62542e219b514d12426121c2d17085a8e52 100644 |
--- a/Source/core/page/ImageBitmap.h |
+++ b/Source/core/page/ImageBitmap.h |
@@ -6,8 +6,8 @@ |
#define ImageBitmap_h |
#include "bindings/v8/ScriptWrappable.h" |
-#include "core/dom/ScriptExecutionContext.h" |
-#include "core/platform/graphics/BitmapImage.h" |
+#include "core/html/HTMLImageElement.h" |
+#include "core/platform/graphics/Image.h" |
#include "core/platform/graphics/ImageBuffer.h" |
#include "core/platform/graphics/IntRect.h" |
#include "wtf/PassRefPtr.h" |
@@ -16,44 +16,48 @@ |
namespace WebCore { |
class HTMLCanvasElement; |
-class HTMLImageElement; |
class HTMLVideoElement; |
class ImageData; |
-class ImageBitmap : public RefCounted<ImageBitmap>, public ScriptWrappable { |
+class ImageBitmap : public RefCounted<ImageBitmap>, public ScriptWrappable, public ImageLoaderClient { |
public: |
- static PassRefPtr<ImageBitmap> create(HTMLImageElement*, IntRect); |
- static PassRefPtr<ImageBitmap> create(HTMLVideoElement*, IntRect); |
- static PassRefPtr<ImageBitmap> create(HTMLCanvasElement*, IntRect); |
- static PassRefPtr<ImageBitmap> create(ImageData*, IntRect); |
- static PassRefPtr<ImageBitmap> create(ImageBitmap*, IntRect); |
+ static PassRefPtr<ImageBitmap> create(HTMLImageElement*, const IntRect&); |
+ static PassRefPtr<ImageBitmap> create(HTMLVideoElement*, const IntRect&); |
+ static PassRefPtr<ImageBitmap> create(HTMLCanvasElement*, const IntRect&); |
+ static PassRefPtr<ImageBitmap> create(ImageData*, const IntRect&); |
+ static PassRefPtr<ImageBitmap> create(ImageBitmap*, const IntRect&); |
- BitmapImage* bitmapImage() const { return m_bitmap.get(); } |
+ PassRefPtr<Image> bitmapImage() const; |
+ PassRefPtr<HTMLImageElement> imageElement() const { return m_imageElement; } |
- int bitmapWidth() const { return m_bitmap->width(); } |
- int bitmapHeight() const { return m_bitmap->height(); } |
- IntSize bitmapSize() const { return m_bitmap->size(); } |
- IntPoint bitmapOffset() const { return m_bitmapOffset; } |
+ IntRect bitmapRect() const { return m_bitmapRect; } |
- int width() const { return m_size.width(); } |
- int height() const { return m_size.height(); } |
- IntSize size() const { return m_size; } |
+ int width() const { return m_cropRect.width(); } |
+ int height() const { return m_cropRect.height(); } |
+ IntSize size() const { return m_cropRect.size(); } |
- ~ImageBitmap() { }; |
+ ~ImageBitmap(); |
private: |
- ImageBitmap(HTMLImageElement*, IntRect); |
- ImageBitmap(HTMLVideoElement*, IntRect); |
- ImageBitmap(HTMLCanvasElement*, IntRect); |
- ImageBitmap(ImageData*, IntRect); |
- ImageBitmap(ImageBitmap*, IntRect); |
+ ImageBitmap(HTMLImageElement*, const IntRect&); |
+ ImageBitmap(HTMLVideoElement*, const IntRect&); |
+ ImageBitmap(HTMLCanvasElement*, const IntRect&); |
+ ImageBitmap(ImageData*, const IntRect&); |
+ ImageBitmap(ImageBitmap*, const IntRect&); |
- RefPtr<BitmapImage> m_bitmap; |
+ // ImageLoaderClient |
+ virtual void notifyImageSourceChanged(); |
+ virtual bool requestsHighLiveResourceCachePriority() { return true; } |
+ |
+ // ImageBitmaps constructed from HTMLImageElements hold a reference to the HTMLImageElement until |
+ // the image source changes. |
+ RefPtr<HTMLImageElement> m_imageElement; |
+ RefPtr<Image> m_bitmap; |
OwnPtr<ImageBuffer> m_buffer; |
- IntPoint m_bitmapOffset; // offset applied to the image when it is drawn to the context |
- IntSize m_size; // user defined size of the ImageBitmap |
+ IntRect m_bitmapRect; // The rect where the underlying Image should be placed in reference to the ImageBitmap. |
+ IntRect m_cropRect; |
}; |
} // namespace WebCore |