2010-12-22 21:39:39 +00:00
|
|
|
/*
|
|
|
|
Copyright 2010 Google Inc.
|
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef GrClipIterator_DEFINED
|
|
|
|
#define GrClipIterator_DEFINED
|
|
|
|
|
2011-03-03 13:54:13 +00:00
|
|
|
#include "GrPath.h"
|
2010-12-22 21:39:39 +00:00
|
|
|
#include "GrRect.h"
|
|
|
|
|
2011-03-03 13:54:13 +00:00
|
|
|
/**
|
|
|
|
* A clip is a list of paths and/or rects with set operations to combine them.
|
|
|
|
*/
|
2010-12-22 21:39:39 +00:00
|
|
|
class GrClipIterator {
|
|
|
|
public:
|
|
|
|
virtual ~GrClipIterator() {}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns true if there are no more rects to process
|
|
|
|
*/
|
2011-03-03 13:54:13 +00:00
|
|
|
virtual bool isDone() const = 0;
|
2010-12-22 21:39:39 +00:00
|
|
|
|
|
|
|
/**
|
2011-03-03 13:54:13 +00:00
|
|
|
* Rewind the iterator to replay the set of clip elements again
|
2010-12-22 21:39:39 +00:00
|
|
|
*/
|
|
|
|
virtual void rewind() = 0;
|
|
|
|
|
|
|
|
/**
|
2011-03-03 13:54:13 +00:00
|
|
|
* Get the type of the current clip element
|
2010-12-22 21:39:39 +00:00
|
|
|
*/
|
2011-03-03 13:54:13 +00:00
|
|
|
virtual GrClipType getType() const = 0;
|
2010-12-22 21:39:39 +00:00
|
|
|
|
|
|
|
/**
|
2011-03-03 13:54:13 +00:00
|
|
|
* Return the current path. It is an error to call this when isDone() is
|
|
|
|
* true or when getType() is kRect_Type.
|
2010-12-22 21:39:39 +00:00
|
|
|
*/
|
2011-05-16 17:21:57 +00:00
|
|
|
virtual const GrPath* getPath() = 0;
|
2010-12-22 21:39:39 +00:00
|
|
|
|
|
|
|
/**
|
2011-03-03 13:54:13 +00:00
|
|
|
* Return the fill rule for the path. It is an error to call this when
|
|
|
|
* isDone() is true or when getType is kRect_Type.
|
2010-12-22 21:39:39 +00:00
|
|
|
*/
|
2011-03-03 13:54:13 +00:00
|
|
|
virtual GrPathFill getPathFill() const = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the current rect. It is an error to call this when isDone is true
|
|
|
|
* or when getType() is kPath_Type.
|
|
|
|
*/
|
|
|
|
virtual void getRect(GrRect* rect) const = 0;
|
2010-12-22 21:39:39 +00:00
|
|
|
|
|
|
|
/**
|
2011-03-03 13:54:13 +00:00
|
|
|
* Gets the operation used to apply the current item to previously iterated
|
|
|
|
* items. Iterators should not produce a Replace op.
|
2010-12-22 21:39:39 +00:00
|
|
|
*/
|
2011-03-03 13:54:13 +00:00
|
|
|
virtual GrSetOp getOp() const = 0;
|
2010-12-22 21:39:39 +00:00
|
|
|
|
2011-03-03 13:54:13 +00:00
|
|
|
/**
|
2011-03-04 20:29:08 +00:00
|
|
|
* Call to move to the next element in the list, previous path iter can be
|
|
|
|
* made invalid.
|
2011-03-03 13:54:13 +00:00
|
|
|
*/
|
|
|
|
virtual void next() = 0;
|
2010-12-22 21:39:39 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Call to rewind iter, first checking to see if iter is NULL
|
|
|
|
*/
|
|
|
|
static inline void GrSafeRewind(GrClipIterator* iter) {
|
|
|
|
if (iter) {
|
|
|
|
iter->rewind();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|