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

Side by Side Diff: src/core/SkDeviceImageFilterProxy.h

Issue 1012113002: imagefilters always need to disable lcd (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: Created 5 years, 9 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
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * Copyright 2012 The Android Open Source Project 2 * Copyright 2012 The Android Open Source Project
3 * 3 *
4 * Use of this source code is governed by a BSD-style license that can be 4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file. 5 * found in the LICENSE file.
6 */ 6 */
7 7
8 #ifndef SkDeviceImageFilterProxy_DEFINED 8 #ifndef SkDeviceImageFilterProxy_DEFINED
9 #define SkDeviceImageFilterProxy_DEFINED 9 #define SkDeviceImageFilterProxy_DEFINED
10 10
11 #include "SkDevice.h" 11 #include "SkDevice.h"
12 #include "SkImageFilter.h" 12 #include "SkImageFilter.h"
13 #include "SkSurfaceProps.h" 13 #include "SkSurfaceProps.h"
14 14
15 class SkDeviceImageFilterProxy : public SkImageFilter::Proxy { 15 class SkDeviceImageFilterProxy : public SkImageFilter::Proxy {
16 public: 16 public:
17 SkDeviceImageFilterProxy(SkBaseDevice* device, const SkSurfaceProps& props) 17 SkDeviceImageFilterProxy(SkBaseDevice* device, const SkSurfaceProps& props)
18 : fDevice(device) 18 : fDevice(device)
19 , fProps(props.flags(), 19 , fProps(props.flags(), kUnknown_SkPixelGeometry)
20 SkBaseDevice::CreateInfo::AdjustGeometry(SkImageInfo(),
21 SkBaseDevice::kPossibl e_TileUsage,
22 props.pixelGeometry()) )
23 {} 20 {}
24 21
25 SkBaseDevice* createDevice(int w, int h) SK_OVERRIDE { 22 SkBaseDevice* createDevice(int w, int h) SK_OVERRIDE {
26 SkBaseDevice::CreateInfo cinfo(SkImageInfo::MakeN32Premul(w, h), 23 SkBaseDevice::CreateInfo cinfo(SkImageInfo::MakeN32Premul(w, h),
27 SkBaseDevice::kPossible_TileUsage, 24 SkBaseDevice::kPossible_TileUsage,
28 kUnknown_SkPixelGeometry); 25 kUnknown_SkPixelGeometry);
29 return fDevice->onCreateDevice(cinfo, NULL); 26 return fDevice->onCreateDevice(cinfo, NULL);
30 } 27 }
31 bool canHandleImageFilter(const SkImageFilter* filter) SK_OVERRIDE { 28 bool canHandleImageFilter(const SkImageFilter* filter) SK_OVERRIDE {
32 return fDevice->canHandleImageFilter(filter); 29 return fDevice->canHandleImageFilter(filter);
33 } 30 }
34 virtual bool filterImage(const SkImageFilter* filter, const SkBitmap& src, 31 virtual bool filterImage(const SkImageFilter* filter, const SkBitmap& src,
35 const SkImageFilter::Context& ctx, 32 const SkImageFilter::Context& ctx,
36 SkBitmap* result, SkIPoint* offset) SK_OVERRIDE { 33 SkBitmap* result, SkIPoint* offset) SK_OVERRIDE {
37 return fDevice->filterImage(filter, src, ctx, result, offset); 34 return fDevice->filterImage(filter, src, ctx, result, offset);
38 } 35 }
39 36
40 const SkSurfaceProps* surfaceProps() const SK_OVERRIDE { 37 const SkSurfaceProps* surfaceProps() const SK_OVERRIDE {
41 return &fProps; 38 return &fProps;
42 } 39 }
43 40
44 private: 41 private:
45 SkBaseDevice* fDevice; 42 SkBaseDevice* fDevice;
46 const SkSurfaceProps fProps; 43 const SkSurfaceProps fProps;
47 }; 44 };
48 45
49 #endif 46 #endif
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698