OLD | NEW |
1 /* | 1 /* |
2 * Copyright 2011 Google Inc. | 2 * Copyright 2011 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 #include "SkPictureRecord.h" | 8 #include "SkPictureRecord.h" |
9 #include "SkTSearch.h" | 9 #include "SkTSearch.h" |
10 #include "SkPixelRef.h" | 10 #include "SkPixelRef.h" |
(...skipping 1393 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1404 size_t size = 3 * kUInt32Size + SkAlign4(byteLength) + kUInt32Size + m.write
ToMemory(NULL); | 1404 size_t size = 3 * kUInt32Size + SkAlign4(byteLength) + kUInt32Size + m.write
ToMemory(NULL); |
1405 size_t initialOffset = this->addDraw(DRAW_TEXT_ON_PATH, &size); | 1405 size_t initialOffset = this->addDraw(DRAW_TEXT_ON_PATH, &size); |
1406 SkASSERT(initialOffset+getPaintOffset(DRAW_TEXT_ON_PATH, size) == fWriter.by
tesWritten()); | 1406 SkASSERT(initialOffset+getPaintOffset(DRAW_TEXT_ON_PATH, size) == fWriter.by
tesWritten()); |
1407 this->addPaint(paint); | 1407 this->addPaint(paint); |
1408 this->addText(text, byteLength); | 1408 this->addText(text, byteLength); |
1409 this->addPath(path); | 1409 this->addPath(path); |
1410 this->addMatrix(m); | 1410 this->addMatrix(m); |
1411 this->validate(initialOffset, size); | 1411 this->validate(initialOffset, size); |
1412 } | 1412 } |
1413 | 1413 |
1414 void SkPictureRecord::drawPicture(SkPicture& picture) { | 1414 void SkPictureRecord::onDrawPicture(const SkPicture* picture) { |
1415 | 1415 |
1416 #ifdef SK_COLLAPSE_MATRIX_CLIP_STATE | 1416 #ifdef SK_COLLAPSE_MATRIX_CLIP_STATE |
1417 fMCMgr.call(SkMatrixClipStateMgr::kOther_CallType); | 1417 fMCMgr.call(SkMatrixClipStateMgr::kOther_CallType); |
1418 #endif | 1418 #endif |
1419 | 1419 |
1420 // op + picture index | 1420 // op + picture index |
1421 size_t size = 2 * kUInt32Size; | 1421 size_t size = 2 * kUInt32Size; |
1422 size_t initialOffset = this->addDraw(DRAW_PICTURE, &size); | 1422 size_t initialOffset = this->addDraw(DRAW_PICTURE, &size); |
1423 this->addPicture(picture); | 1423 this->addPicture(picture); |
1424 this->validate(initialOffset, size); | 1424 this->validate(initialOffset, size); |
(...skipping 186 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1611 } | 1611 } |
1612 | 1612 |
1613 int SkPictureRecord::addPathToHeap(const SkPath& path) { | 1613 int SkPictureRecord::addPathToHeap(const SkPath& path) { |
1614 return fPicture->addPathToHeap(path); | 1614 return fPicture->addPathToHeap(path); |
1615 } | 1615 } |
1616 | 1616 |
1617 void SkPictureRecord::addPath(const SkPath& path) { | 1617 void SkPictureRecord::addPath(const SkPath& path) { |
1618 this->addInt(this->addPathToHeap(path)); | 1618 this->addInt(this->addPathToHeap(path)); |
1619 } | 1619 } |
1620 | 1620 |
1621 void SkPictureRecord::addPicture(SkPicture& picture) { | 1621 void SkPictureRecord::addPicture(const SkPicture* picture) { |
1622 int index = fPictureRefs.find(&picture); | 1622 int index = fPictureRefs.find(picture); |
1623 if (index < 0) { // not found | 1623 if (index < 0) { // not found |
1624 index = fPictureRefs.count(); | 1624 index = fPictureRefs.count(); |
1625 *fPictureRefs.append() = &picture; | 1625 *fPictureRefs.append() = picture; |
1626 picture.ref(); | 1626 picture->ref(); |
1627 } | 1627 } |
1628 // follow the convention of recording a 1-based index | 1628 // follow the convention of recording a 1-based index |
1629 this->addInt(index + 1); | 1629 this->addInt(index + 1); |
1630 } | 1630 } |
1631 | 1631 |
1632 void SkPictureRecord::addPoint(const SkPoint& point) { | 1632 void SkPictureRecord::addPoint(const SkPoint& point) { |
1633 #ifdef SK_DEBUG_SIZE | 1633 #ifdef SK_DEBUG_SIZE |
1634 size_t start = fWriter.bytesWritten(); | 1634 size_t start = fWriter.bytesWritten(); |
1635 #endif | 1635 #endif |
1636 fWriter.writePoint(point); | 1636 fWriter.writePoint(point); |
(...skipping 189 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1826 void SkPictureRecord::validateRegions() const { | 1826 void SkPictureRecord::validateRegions() const { |
1827 int count = fRegions.count(); | 1827 int count = fRegions.count(); |
1828 SkASSERT((unsigned) count < 0x1000); | 1828 SkASSERT((unsigned) count < 0x1000); |
1829 for (int index = 0; index < count; index++) { | 1829 for (int index = 0; index < count; index++) { |
1830 const SkFlatData* region = fRegions[index]; | 1830 const SkFlatData* region = fRegions[index]; |
1831 SkASSERT(region); | 1831 SkASSERT(region); |
1832 // region->validate(); | 1832 // region->validate(); |
1833 } | 1833 } |
1834 } | 1834 } |
1835 #endif | 1835 #endif |
OLD | NEW |