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

Side by Side Diff: Source/core/svg/graphics/SVGImageForContainer.h

Issue 1334703002: NOT FOR LANDING Pass URL to Image::draw (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Created 5 years, 3 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 unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright (C) 2013 Google Inc. All rights reserved. 2 * Copyright (C) 2013 Google Inc. All rights reserved.
3 * 3 *
4 * Redistribution and use in source and binary forms, with or without 4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions 5 * modification, are permitted provided that the following conditions
6 * are met: 6 * are met:
7 * 1. Redistributions of source code must retain the above copyright 7 * 1. Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer. 8 * notice, this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright 9 * 2. Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the 10 * notice, this list of conditions and the following disclaimer in the
(...skipping 26 matching lines...) Expand all
37 class SVGImageForContainer final : public Image { 37 class SVGImageForContainer final : public Image {
38 public: 38 public:
39 static PassRefPtr<SVGImageForContainer> create(SVGImage* image, const FloatS ize& containerSize, float zoom) 39 static PassRefPtr<SVGImageForContainer> create(SVGImage* image, const FloatS ize& containerSize, float zoom)
40 { 40 {
41 return adoptRef(new SVGImageForContainer(image, containerSize, zoom)); 41 return adoptRef(new SVGImageForContainer(image, containerSize, zoom));
42 } 42 }
43 43
44 bool isSVGImage() const override { return true; } 44 bool isSVGImage() const override { return true; }
45 45
46 IntSize size() const override; 46 IntSize size() const override;
47 void setURL(const KURL& url) { m_image->setURL(url); }
48 47
49 bool usesContainerSize() const override { return m_image->usesContainerSize( ); } 48 bool usesContainerSize() const override { return m_image->usesContainerSize( ); }
50 bool hasRelativeWidth() const override { return m_image->hasRelativeWidth(); } 49 bool hasRelativeWidth() const override { return m_image->hasRelativeWidth(); }
51 bool hasRelativeHeight() const override { return m_image->hasRelativeHeight( ); } 50 bool hasRelativeHeight() const override { return m_image->hasRelativeHeight( ); }
52 void computeIntrinsicDimensions(Length& intrinsicWidth, Length& intrinsicHei ght, FloatSize& intrinsicRatio) override 51 void computeIntrinsicDimensions(Length& intrinsicWidth, Length& intrinsicHei ght, FloatSize& intrinsicRatio) override
53 { 52 {
54 m_image->computeIntrinsicDimensions(intrinsicWidth, intrinsicHeight, int rinsicRatio); 53 m_image->computeIntrinsicDimensions(intrinsicWidth, intrinsicHeight, int rinsicRatio);
55 } 54 }
56 55
57 void draw(SkCanvas*, const SkPaint&, const FloatRect&, const FloatRect&, Res pectImageOrientationEnum, ImageClampingMode) override; 56 void draw(SkCanvas*, const SkPaint&, const FloatRect&, const FloatRect&, Res pectImageOrientationEnum, ImageClampingMode, const KURL&) override;
58 57
59 void drawPattern(GraphicsContext*, const FloatRect&, const FloatSize&, const FloatPoint&, SkXfermode::Mode, const FloatRect&, const IntSize& repeatSpacing) override; 58 void drawPattern(GraphicsContext*, const FloatRect&, const FloatSize&, const FloatPoint&, const KURL&, SkXfermode::Mode, const FloatRect&, const IntSize& re peatSpacing) override;
60 59
61 // FIXME: Implement this to be less conservative. 60 // FIXME: Implement this to be less conservative.
62 bool currentFrameKnownToBeOpaque() override { return false; } 61 bool currentFrameKnownToBeOpaque() override { return false; }
63 62
64 PassRefPtr<SkImage> imageForCurrentFrame() override; 63 PassRefPtr<SkImage> imageForCurrentFrame() override;
65 64
66 private: 65 private:
67 SVGImageForContainer(SVGImage* image, const FloatSize& containerSize, float zoom) 66 SVGImageForContainer(SVGImage* image, const FloatSize& containerSize, float zoom)
68 : m_image(image) 67 : m_image(image)
69 , m_containerSize(containerSize) 68 , m_containerSize(containerSize)
70 , m_zoom(zoom) 69 , m_zoom(zoom)
71 { 70 {
72 } 71 }
73 72
74 void destroyDecodedData(bool) override { } 73 void destroyDecodedData(bool) override { }
75 74
76 SVGImage* m_image; 75 SVGImage* m_image;
77 const FloatSize m_containerSize; 76 const FloatSize m_containerSize;
78 const float m_zoom; 77 const float m_zoom;
79 }; 78 };
79
80 } 80 }
81 81
82 #endif // SVGImageForContainer_h 82 #endif // SVGImageForContainer_h
OLDNEW
« no previous file with comments | « Source/core/svg/graphics/SVGImage.cpp ('k') | Source/core/svg/graphics/SVGImageForContainer.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698