git-svn-id: http://skia.googlecode.com/svn/trunk@5547 2bbb7eff-a529-9590-31e7-b0007b416f81
This commit is contained in:
rileya@google.com 2012-09-14 15:52:47 +00:00
Родитель 3a8b0d8288
Коммит 1c6307e36f
4 изменённых файлов: 20 добавлений и 6 удалений

Просмотреть файл

@ -150,6 +150,13 @@ private:
SkPictureRecord* fRecord; SkPictureRecord* fRecord;
SkPicturePlayback* fPlayback; SkPicturePlayback* fPlayback;
/** Used by the R-Tree when kOptimizeForClippedPlayback_RecordingFlag is
set, these were empirically determined to produce reasonable performance
in most cases.
*/
static const int kRTreeMinChildren = 6;
static const int kRTreeMaxChildren = 11;
friend class SkFlatPicture; friend class SkFlatPicture;
friend class SkPicturePlayback; friend class SkPicturePlayback;

Просмотреть файл

@ -188,7 +188,8 @@ SkCanvas* SkPicture::beginRecording(int width, int height,
if (recordingFlags & kOptimizeForClippedPlayback_RecordingFlag) { if (recordingFlags & kOptimizeForClippedPlayback_RecordingFlag) {
SkScalar aspectRatio = SkScalarDiv(SkIntToScalar(width), SkScalar aspectRatio = SkScalarDiv(SkIntToScalar(width),
SkIntToScalar(height)); SkIntToScalar(height));
SkRTree* tree = SkRTree::Create(6, 11, aspectRatio); SkRTree* tree = SkRTree::Create(kRTreeMinChildren, kRTreeMaxChildren,
aspectRatio);
SkASSERT(NULL != tree); SkASSERT(NULL != tree);
fRecord = SkNEW_ARGS(SkBBoxHierarchyRecord, (recordingFlags, tree)); fRecord = SkNEW_ARGS(SkBBoxHierarchyRecord, (recordingFlags, tree));
tree->unref(); tree->unref();

Просмотреть файл

@ -585,13 +585,15 @@ void SkPicturePlayback::draw(SkCanvas& canvas) {
TextContainer text; TextContainer text;
SkTDArray<void*> results; SkTDArray<void*> results;
if (fStateTree && fBoundingHierarchy) { if (NULL != fStateTree && NULL != fBoundingHierarchy) {
SkRect clipBounds; SkRect clipBounds;
if (canvas.getClipBounds(&clipBounds)) { if (canvas.getClipBounds(&clipBounds)) {
SkIRect query; SkIRect query;
clipBounds.roundOut(&query); clipBounds.roundOut(&query);
fBoundingHierarchy->search(query, &results); fBoundingHierarchy->search(query, &results);
if (results.count() == 0) { return; } if (results.count() == 0) {
return;
}
SkTQSort<SkPictureStateTree::Draw>( SkTQSort<SkPictureStateTree::Draw>(
reinterpret_cast<SkPictureStateTree::Draw**>(results.begin()), reinterpret_cast<SkPictureStateTree::Draw**>(results.begin()),
reinterpret_cast<SkPictureStateTree::Draw**>(results.end()-1)); reinterpret_cast<SkPictureStateTree::Draw**>(results.end()-1));
@ -604,7 +606,9 @@ void SkPicturePlayback::draw(SkCanvas& canvas) {
if (it.isValid()) { if (it.isValid()) {
uint32_t off = it.draw(); uint32_t off = it.draw();
if (off == SK_MaxU32) { return; } if (off == SK_MaxU32) {
return;
}
reader.setOffset(off); reader.setOffset(off);
} }
@ -857,7 +861,9 @@ void SkPicturePlayback::draw(SkCanvas& canvas) {
if (it.isValid()) { if (it.isValid()) {
uint32_t off = it.draw(); uint32_t off = it.draw();
if (off == SK_MaxU32) { break; } if (off == SK_MaxU32) {
break;
}
reader.setOffset(off); reader.setOffset(off);
} }
} }

Просмотреть файл

@ -71,7 +71,7 @@ public:
uint32_t draw(); uint32_t draw();
static const uint32_t kDrawComplete = SK_MaxU32; static const uint32_t kDrawComplete = SK_MaxU32;
Iterator() : fPlaybackMatrix(), fValid(false) { } Iterator() : fPlaybackMatrix(), fValid(false) { }
bool isValid() { return fValid; } bool isValid() const { return fValid; }
private: private:
Iterator(const SkTDArray<void*>& draws, SkCanvas* canvas, Node* root); Iterator(const SkTDArray<void*>& draws, SkCanvas* canvas, Node* root);
// The draws this iterator is associated with // The draws this iterator is associated with