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

Side by Side Diff: Source/platform/DragImage.h

Issue 886323005: Pass InterpolationQuality into DragImage to respect image-rendering:pixelated. (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Created 5 years, 10 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) 2007 Apple Inc. All rights reserved. 2 * Copyright (C) 2007 Apple 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 11 matching lines...) Expand all
22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24 */ 24 */
25 25
26 #ifndef DragImage_h 26 #ifndef DragImage_h
27 #define DragImage_h 27 #define DragImage_h
28 28
29 #include "platform/geometry/IntSize.h" 29 #include "platform/geometry/IntSize.h"
30 #include "platform/graphics/ImageOrientation.h" 30 #include "platform/graphics/ImageOrientation.h"
31 #include "platform/graphics/paint/DisplayItemClient.h" 31 #include "platform/graphics/paint/DisplayItemClient.h"
32 #include "skia/ext/image_operations.h"
Justin Novosad 2015/02/05 05:06:24 I realize this dependency is not new to this patch
jackhou1 2015/02/10 01:53:56 Done.
32 #include "third_party/skia/include/core/SkBitmap.h" 33 #include "third_party/skia/include/core/SkBitmap.h"
33 #include "wtf/Forward.h" 34 #include "wtf/Forward.h"
34 35
35 namespace blink { 36 namespace blink {
36 37
37 class FontDescription; 38 class FontDescription;
38 class Image; 39 class Image;
39 class KURL; 40 class KURL;
40 41
41 class PLATFORM_EXPORT DragImage { 42 class PLATFORM_EXPORT DragImage {
42 public: 43 public:
43 static PassOwnPtr<DragImage> create(Image*, RespectImageOrientationEnum = Do NotRespectImageOrientation, float deviceScaleFactor = 1); 44 typedef skia::ImageOperations::ResizeMethod ResizeMethod;
45
46 static PassOwnPtr<DragImage> create(Image*, RespectImageOrientationEnum = Do NotRespectImageOrientation, float deviceScaleFactor = 1, ResizeMethod = ResizeMe thod::RESIZE_LANCZOS3);
44 static PassOwnPtr<DragImage> create(const KURL&, const String& label, const FontDescription& systemFont, float deviceScaleFactor); 47 static PassOwnPtr<DragImage> create(const KURL&, const String& label, const FontDescription& systemFont, float deviceScaleFactor);
45 ~DragImage(); 48 ~DragImage();
46 49
47 const SkBitmap& bitmap() { return m_bitmap; } 50 const SkBitmap& bitmap() { return m_bitmap; }
48 float resolutionScale() const { return m_resolutionScale; } 51 float resolutionScale() const { return m_resolutionScale; }
49 IntSize size() const { return IntSize(m_bitmap.width(), m_bitmap.height()); } 52 IntSize size() const { return IntSize(m_bitmap.width(), m_bitmap.height()); }
50 53
51 void fitToMaxSize(const IntSize& srcSize, const IntSize& maxSize); 54 void fitToMaxSize(const IntSize& srcSize, const IntSize& maxSize);
52 void scale(float scaleX, float scaleY); 55 void scale(float scaleX, float scaleY);
53 void dissolveToFraction(float fraction); 56 void dissolveToFraction(float fraction);
54 57
55 private: 58 private:
56 DragImage(const SkBitmap&, float resolutionScale); 59 DragImage(const SkBitmap&, float resolutionScale, ResizeMethod);
57 60
58 DisplayItemClient displayItemClient() const { return toDisplayItemClient(thi s); } 61 DisplayItemClient displayItemClient() const { return toDisplayItemClient(thi s); }
59 62
60 SkBitmap m_bitmap; 63 SkBitmap m_bitmap;
61 float m_resolutionScale; 64 float m_resolutionScale;
65 ResizeMethod m_resizeMethod;
62 }; 66 };
63 67
64 } 68 }
65 69
66 #endif // DragImage_h 70 #endif // DragImage_h
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698