Chromium Code Reviews| Index: Source/core/page/ImageBitmap.cpp |
| diff --git a/Source/core/page/ImageBitmap.cpp b/Source/core/page/ImageBitmap.cpp |
| index fabe6847b5aabfeb1a3482cb5754b9cbb20caddd..9e2548cf84f54bc48a1fde5897d0b2366d24e741 100644 |
| --- a/Source/core/page/ImageBitmap.cpp |
| +++ b/Source/core/page/ImageBitmap.cpp |
| @@ -34,17 +34,20 @@ static inline PassRefPtr<BitmapImage> cropImage(Image* image, IntRect cropRect) |
| ImageBitmap::ImageBitmap(HTMLImageElement* image, IntRect cropRect) |
| : m_bitmapOffset(max(0, -cropRect.x()), max(0, -cropRect.y())) |
| - , m_size(cropRect.size()) |
| + , m_cropRect(cropRect) |
| + , m_derivedFromCanvas(0) |
|
Justin Novosad
2013/07/22 15:35:41
this is a bool, so initialize it with false instea
|
| { |
| Image* bitmapImage = image->cachedImage()->image(); |
| - m_bitmap = cropImage(bitmapImage, cropRect).get(); |
| + m_bitmap = cropImage(bitmapImage, cropRect); |
| + m_bitmapSize = IntSize(m_bitmap->size()); |
| ScriptWrappable::init(this); |
| } |
| ImageBitmap::ImageBitmap(HTMLVideoElement* video, IntRect cropRect) |
| : m_bitmapOffset(max(0, -cropRect.x()), max(0, -cropRect.y())) |
| - , m_size(cropRect.size()) |
| + , m_cropRect(cropRect) |
| + , m_derivedFromCanvas(0) |
| { |
| IntRect videoRect = IntRect(IntPoint(), video->player()->naturalSize()); |
| IntRect srcRect = intersection(cropRect, videoRect); |
| @@ -55,29 +58,27 @@ ImageBitmap::ImageBitmap(HTMLVideoElement* video, IntRect cropRect) |
| c->clip(dstRect); |
| c->translate(-srcRect.x(), -srcRect.y()); |
| video->paintCurrentFrameInContext(c, videoRect); |
| - m_bitmap = static_cast<BitmapImage*>(m_buffer->copyImage(DontCopyBackingStore).get()); |
| + m_bitmap = m_buffer->copyImage(DontCopyBackingStore); |
| + m_bitmapSize = IntSize(m_bitmap->size()); |
| ScriptWrappable::init(this); |
| } |
| ImageBitmap::ImageBitmap(HTMLCanvasElement* canvas, IntRect cropRect) |
| : m_bitmapOffset(max(0, -cropRect.x()), max(0, -cropRect.y())) |
| - , m_size(cropRect.size()) |
| + , m_cropRect(cropRect) |
| + , m_derivedFromCanvas(1) |
| + , m_bitmapSize(cropRect.size()) |
| { |
| - IntSize canvasSize = canvas->size(); |
| - IntRect srcRect = intersection(cropRect, IntRect(IntPoint(), canvasSize)); |
| - IntRect dstRect(IntPoint(), srcRect.size()); |
| - |
| - m_buffer = ImageBuffer::create(canvasSize); |
| - m_buffer->context()->drawImageBuffer(canvas->buffer(), dstRect, srcRect); |
| - m_bitmap = static_cast<BitmapImage*>(m_buffer->copyImage(DontCopyBackingStore).get()); |
| + m_bitmap = canvas->buffer()->imageSnapshot(); |
| ScriptWrappable::init(this); |
| } |
| ImageBitmap::ImageBitmap(ImageData* data, IntRect cropRect) |
| : m_bitmapOffset(max(0, -cropRect.x()), max(0, -cropRect.y())) |
| - , m_size(cropRect.size()) |
| + , m_cropRect(cropRect) |
| + , m_derivedFromCanvas(0) |
| { |
| IntRect srcRect = intersection(cropRect, IntRect(IntPoint(), data->size())); |
| @@ -85,18 +86,21 @@ ImageBitmap::ImageBitmap(ImageData* data, IntRect cropRect) |
| if (srcRect.width() > 0 && srcRect.height() > 0) |
| m_buffer->putByteArray(Unmultiplied, data->data(), data->size(), srcRect, IntPoint(min(0, -cropRect.x()), min(0, -cropRect.y()))); |
| - m_bitmap = static_cast<BitmapImage*>(m_buffer->copyImage(DontCopyBackingStore).get()); |
| + m_bitmap = m_buffer->copyImage(DontCopyBackingStore); |
| + m_bitmapSize = IntSize(m_bitmap->size()); |
| ScriptWrappable::init(this); |
| } |
| ImageBitmap::ImageBitmap(ImageBitmap* bitmap, IntRect cropRect) |
| : m_bitmapOffset(max(0, bitmap->bitmapOffset().x() - cropRect.x()), max(0, bitmap->bitmapOffset().y() - cropRect.y())) |
| - , m_size(cropRect.size()) |
| + , m_cropRect(cropRect) |
| + , m_derivedFromCanvas(0) |
| { |
| - Image* bitmapImage = bitmap->bitmapImage(); |
| + Image* bitmapImage = bitmap->bitmapImage().get(); |
| cropRect.moveBy(IntPoint(-bitmap->bitmapOffset().x(), -bitmap->bitmapOffset().y())); |
| - m_bitmap = cropImage(bitmapImage, cropRect).get(); |
| + m_bitmap = cropImage(bitmapImage, cropRect); |
| + m_bitmapSize = IntSize(m_bitmap->size()); |
| ScriptWrappable::init(this); |
| } |