Index: Source/core/html/canvas/CanvasRenderingContext2D.cpp |
diff --git a/Source/core/html/canvas/CanvasRenderingContext2D.cpp b/Source/core/html/canvas/CanvasRenderingContext2D.cpp |
index 3be4886c56fbd74719de8c2337fa555192e23d18..da3411eef632d136638cb9b1ff6afe4c2e07caee 100644 |
--- a/Source/core/html/canvas/CanvasRenderingContext2D.cpp |
+++ b/Source/core/html/canvas/CanvasRenderingContext2D.cpp |
@@ -59,7 +59,6 @@ |
#include "core/platform/graphics/DrawLooper.h" |
#include "core/platform/graphics/FontCache.h" |
#include "core/platform/graphics/GraphicsContextStateSaver.h" |
-#include "core/rendering/RenderImage.h" |
#include "core/rendering/RenderLayer.h" |
#include "core/rendering/RenderTheme.h" |
#include "platform/geometry/FloatQuad.h" |
@@ -1213,22 +1212,11 @@ bool CanvasRenderingContext2D::shouldDrawShadows() const |
return alphaChannel(state().m_shadowColor) && (state().m_shadowBlur || !state().m_shadowOffset.isZero()); |
} |
-enum ImageSizeType { |
- ImageSizeAfterDevicePixelRatio, |
- ImageSizeBeforeDevicePixelRatio |
-}; |
- |
-static LayoutSize sizeFor(HTMLImageElement* image, ImageSizeType sizeType) |
+static LayoutSize sizeFor(HTMLImageElement* image) |
{ |
- LayoutSize size; |
- ImageResource* cachedImage = image->cachedImage(); |
- if (cachedImage) { |
- size = cachedImage->imageSizeForRenderer(image->renderer(), 1.0f); // FIXME: Not sure about this. |
- |
- if (sizeType == ImageSizeAfterDevicePixelRatio && image->renderer() && image->renderer()->isRenderImage() && cachedImage->image() && !cachedImage->image()->hasRelativeWidth()) |
- size.scale(toRenderImage(image->renderer())->imageDevicePixelRatio()); |
- } |
- return size; |
+ if (ImageResource* cachedImage = image->cachedImage()) |
+ return cachedImage->imageSizeForRenderer(image->renderer(), 1.0f); // FIXME: Not sure about this. |
+ return IntSize(); |
} |
static IntSize sizeFor(HTMLVideoElement* video) |
@@ -1379,8 +1367,8 @@ void CanvasRenderingContext2D::drawImage(HTMLImageElement* image, float x, float |
es.throwUninformativeAndGenericDOMException(TypeMismatchError); |
return; |
} |
- LayoutSize destRectSize = sizeFor(image, ImageSizeAfterDevicePixelRatio); |
- drawImage(image, x, y, destRectSize.width(), destRectSize.height(), es); |
+ LayoutSize size = sizeFor(image); |
+ drawImage(image, x, y, size.width(), size.height(), es); |
} |
void CanvasRenderingContext2D::drawImage(HTMLImageElement* image, |
@@ -1390,8 +1378,8 @@ void CanvasRenderingContext2D::drawImage(HTMLImageElement* image, |
es.throwUninformativeAndGenericDOMException(TypeMismatchError); |
return; |
} |
- LayoutSize sourceRectSize = sizeFor(image, ImageSizeBeforeDevicePixelRatio); |
- drawImage(image, FloatRect(0, 0, sourceRectSize.width(), sourceRectSize.height()), FloatRect(x, y, width, height), es); |
+ LayoutSize size = sizeFor(image); |
+ drawImage(image, FloatRect(0, 0, size.width(), size.height()), FloatRect(x, y, width, height), es); |
} |
void CanvasRenderingContext2D::drawImage(HTMLImageElement* image, |
@@ -1421,7 +1409,7 @@ void CanvasRenderingContext2D::drawImage(HTMLImageElement* image, const FloatRec |
if (!cachedImage || !image->complete()) |
return; |
- LayoutSize size = sizeFor(image, ImageSizeBeforeDevicePixelRatio); |
+ LayoutSize size = sizeFor(image); |
if (!size.width() || !size.height()) { |
es.throwUninformativeAndGenericDOMException(InvalidStateError); |
return; |