blob: 850a3f09835b33913be97e1b0ce47aa25ce8d93c (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
|
#ifndef SkClipStack_DEFINED
#define SkClipStack_DEFINED
#include "SkDeque.h"
#include "SkRegion.h"
struct SkRect;
class SkPath;
class SK_API SkClipStack {
public:
SkClipStack();
~SkClipStack() {}
void reset();
int getSaveCount() const { return fSaveCount; }
void save();
void restore();
void clipDevRect(const SkIRect& ir,
SkRegion::Op op = SkRegion::kIntersect_Op) {
SkRect r;
r.set(ir);
this->clipDevRect(r, op);
}
void clipDevRect(const SkRect&, SkRegion::Op = SkRegion::kIntersect_Op);
void clipDevPath(const SkPath&, SkRegion::Op = SkRegion::kIntersect_Op);
class B2FIter {
public:
/**
* Creates an uninitialized iterator. Must be reset()
*/
B2FIter();
B2FIter(const SkClipStack& stack);
struct Clip {
const SkRect* fRect; // if non-null, this is a rect clip
const SkPath* fPath; // if non-null, this is a path clip
SkRegion::Op fOp;
};
/**
* Return the clip for this element in the iterator. If next() returns
* NULL, then the iterator is done. The type of clip is determined by
* the pointers fRect and fPath:
*
* fRect==NULL fPath!=NULL path clip
* fRect!=NULL fPath==NULL rect clip
* fRect==NULL fPath==NULL empty clip
*/
const Clip* next();
/**
* Restarts the iterator on a clip stack.
*/
void reset(const SkClipStack& stack);
private:
Clip fClip;
SkDeque::F2BIter fIter;
};
private:
friend class B2FIter;
struct Rec;
SkDeque fDeque;
int fSaveCount;
};
#endif
|