OLD | NEW |
---|---|
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 18 matching lines...) Expand all Loading... | |
29 #include "core/svg/graphics/SVGImage.h" | 29 #include "core/svg/graphics/SVGImage.h" |
30 #include "platform/geometry/FloatRect.h" | 30 #include "platform/geometry/FloatRect.h" |
31 #include "platform/geometry/FloatSize.h" | 31 #include "platform/geometry/FloatSize.h" |
32 #include "platform/graphics/Image.h" | 32 #include "platform/graphics/Image.h" |
33 #include "platform/weborigin/KURL.h" | 33 #include "platform/weborigin/KURL.h" |
34 | 34 |
35 namespace blink { | 35 namespace blink { |
36 | 36 |
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, const KURL& urlWithFragment) |
40 { | 40 { |
41 return adoptRef(new SVGImageForContainer(image, containerSize, zoom)); | 41 return adoptRef(new SVGImageForContainer(image, containerSize, zoom, url WithFragment)); |
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) 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&, SkXfermode::Mode, const FloatRect&, const IntSize& repeatSpacing) 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, const KURL& urlWithFragment) |
68 : m_image(image) | 67 : m_image(image) |
69 , m_containerSize(containerSize) | 68 , m_containerSize(containerSize) |
70 , m_zoom(zoom) | 69 , m_zoom(zoom) |
70 , m_urlWithFragment(urlWithFragment) | |
71 { | 71 { |
72 } | 72 } |
73 | 73 |
74 void destroyDecodedData(bool) override { } | 74 void destroyDecodedData(bool) override { } |
75 | 75 |
76 SVGImage* m_image; | 76 SVGImage* m_image; |
77 const FloatSize m_containerSize; | 77 const FloatSize m_containerSize; |
78 const float m_zoom; | 78 const float m_zoom; |
79 KURL m_urlWithFragment; | |
davve
2015/09/09 14:22:53
I've come to realize that associating url fragment
| |
79 }; | 80 }; |
81 | |
80 } | 82 } |
81 | 83 |
82 #endif // SVGImageForContainer_h | 84 #endif // SVGImageForContainer_h |
OLD | NEW |