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

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

Issue 1164373003: Revert of change SkDraw and all Blitters to use pixmap instead of bitmap (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: Created 5 years, 6 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 | « src/core/SkCoreBlitters.h ('k') | src/core/SkDeviceLooper.cpp » ('j') | 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 2013 Google Inc. 2 * Copyright 2013 Google Inc.
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 SkDeviceLooper_DEFINED 8 #ifndef SkDeviceLooper_DEFINED
9 #define SkDeviceLooper_DEFINED 9 #define SkDeviceLooper_DEFINED
10 10
(...skipping 12 matching lines...) Expand all
23 * add/subtract two fixed values and still be in range. If we're drawing AA, 23 * add/subtract two fixed values and still be in range. If we're drawing AA,
24 * then we reduce that size by the amount that the supersampler scan converter 24 * then we reduce that size by the amount that the supersampler scan converter
25 * needs (at the moment, that is 4X, so the "safe" range is +- 4K). 25 * needs (at the moment, that is 4X, so the "safe" range is +- 4K).
26 * 26 *
27 * For performance reasons, the class first checks to see if any help is needed 27 * For performance reasons, the class first checks to see if any help is needed
28 * at all, and if not (i.e. the specified bounds and base bitmap area already 28 * at all, and if not (i.e. the specified bounds and base bitmap area already
29 * in the safe-zone, then the class does nothing (effectively). 29 * in the safe-zone, then the class does nothing (effectively).
30 */ 30 */
31 class SkDeviceLooper { 31 class SkDeviceLooper {
32 public: 32 public:
33 SkDeviceLooper(const SkPixmap& base, const SkRasterClip&, const SkIRect& bou nds, bool aa); 33 SkDeviceLooper(const SkBitmap& base, const SkRasterClip&,
34 const SkIRect& bounds, bool aa);
34 ~SkDeviceLooper(); 35 ~SkDeviceLooper();
35 36
36 const SkPixmap& getPixmap() const { 37 const SkBitmap& getBitmap() const {
37 SkASSERT(kDone_State != fState); 38 SkASSERT(kDone_State != fState);
38 SkASSERT(fCurrDst); 39 SkASSERT(fCurrBitmap);
39 return *fCurrDst; 40 return *fCurrBitmap;
40 } 41 }
41 42
42 const SkRasterClip& getRC() const { 43 const SkRasterClip& getRC() const {
43 SkASSERT(kDone_State != fState); 44 SkASSERT(kDone_State != fState);
44 SkASSERT(fCurrRC); 45 SkASSERT(fCurrRC);
45 return *fCurrRC; 46 return *fCurrRC;
46 } 47 }
47 48
48 void mapRect(SkRect* dst, const SkRect& src) const; 49 void mapRect(SkRect* dst, const SkRect& src) const;
49 void mapMatrix(SkMatrix* dst, const SkMatrix& src) const; 50 void mapMatrix(SkMatrix* dst, const SkMatrix& src) const;
50 51
51 /** 52 /**
52 * Call next to setup the looper to return a valid coordinate chunk. 53 * Call next to setup the looper to return a valid coordinate chunk.
53 * Each time this returns true, it is safe to call mapRect() and 54 * Each time this returns true, it is safe to call mapRect() and
54 * mapMatrix(), to convert from "global" coordinate values to ones that 55 * mapMatrix(), to convert from "global" coordinate values to ones that
55 * are local to this chunk. 56 * are local to this chunk.
56 * 57 *
57 * When next() returns false, the list of chunks is done, and mapRect() 58 * When next() returns false, the list of chunks is done, and mapRect()
58 * and mapMatrix() should no longer be called. 59 * and mapMatrix() should no longer be called.
59 */ 60 */
60 bool next(); 61 bool next();
61 62
62 private: 63 private:
63 const SkPixmap& fBaseDst; 64 const SkBitmap& fBaseBitmap;
64 const SkRasterClip& fBaseRC; 65 const SkRasterClip& fBaseRC;
65 66
66 enum State { 67 enum State {
67 kDone_State, // iteration is complete, getters will assert 68 kDone_State, // iteration is complete, getters will assert
68 kSimple_State, // no translate/clip mods needed 69 kSimple_State, // no translate/clip mods needed
69 kComplex_State 70 kComplex_State
70 }; 71 };
71 72
72 // storage for our tiled versions. Perhaps could use SkTLazy 73 // storage for our tiled versions. Perhaps could use SkTLazy
73 SkPixmap fSubsetDst; 74 SkBitmap fSubsetBitmap;
74 SkRasterClip fSubsetRC; 75 SkRasterClip fSubsetRC;
75 76
76 const SkPixmap* fCurrDst; 77 const SkBitmap* fCurrBitmap;
77 const SkRasterClip* fCurrRC; 78 const SkRasterClip* fCurrRC;
78 SkIRect fClippedBounds; 79 SkIRect fClippedBounds;
79 SkIPoint fCurrOffset; 80 SkIPoint fCurrOffset;
80 int fDelta; 81 int fDelta;
81 State fState; 82 State fState;
82 83
83 enum Delta { 84 enum Delta {
84 kBW_Delta = 1 << 14, // 16K, gives room to spare for fixedpoint 85 kBW_Delta = 1 << 14, // 16K, gives room to spare for fixedpoint
85 kAA_Delta = kBW_Delta >> 2 // supersample 4x 86 kAA_Delta = kBW_Delta >> 2 // supersample 4x
86 }; 87 };
87 88
88 bool fitsInDelta(const SkIRect& r) const { 89 bool fitsInDelta(const SkIRect& r) const {
89 return r.right() < fDelta && r.bottom() < fDelta; 90 return r.right() < fDelta && r.bottom() < fDelta;
90 } 91 }
91 92
92 bool computeCurrBitmapAndClip(); 93 bool computeCurrBitmapAndClip();
93 }; 94 };
94 95
95 #endif 96 #endif
OLDNEW
« no previous file with comments | « src/core/SkCoreBlitters.h ('k') | src/core/SkDeviceLooper.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698