| 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 #include <new> | 7 #include <new> |
| 8 #include "SkBBoxHierarchy.h" | 8 #include "SkBBoxHierarchy.h" |
| 9 #include "SkOffsetTable.h" | 9 #include "SkOffsetTable.h" |
| 10 #include "SkPicturePlayback.h" | 10 #include "SkPicturePlayback.h" |
| (...skipping 747 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 758 *size = 0; | 758 *size = 0; |
| 759 } else { | 759 } else { |
| 760 UNPACK_8_24(temp, op, *size); | 760 UNPACK_8_24(temp, op, *size); |
| 761 if (MASK_24 == *size) { | 761 if (MASK_24 == *size) { |
| 762 *size = reader->readInt(); | 762 *size = reader->readInt(); |
| 763 } | 763 } |
| 764 } | 764 } |
| 765 return (DrawType) op; | 765 return (DrawType) op; |
| 766 } | 766 } |
| 767 | 767 |
| 768 // The activeOps parameter is actually "const SkTDArray<SkPictureStateTree::Draw
*>&". | |
| 769 // It represents the operations about to be drawn, as generated by some spatial | |
| 770 // subdivision helper class. It should already be in 'fOffset' sorted order. | |
| 771 void SkPicturePlayback::preLoadBitmaps(const SkTDArray<void*>* activeOps) { | |
| 772 if ((NULL != activeOps && 0 == activeOps->count()) || NULL == fBitmapUseOffs
ets) { | |
| 773 return; | |
| 774 } | |
| 775 | |
| 776 if (NULL == activeOps) { | |
| 777 // going to need everything | |
| 778 return; | |
| 779 } | |
| 780 | |
| 781 SkTDArray<int> active; | |
| 782 | |
| 783 SkAutoTDeleteArray<bool> needToCheck(new bool[fBitmapUseOffsets->numIDs()]); | |
| 784 for (int i = 0; i < fBitmapUseOffsets->numIDs(); ++i) { | |
| 785 needToCheck.get()[i] = true; | |
| 786 } | |
| 787 | |
| 788 uint32_t max = ((SkPictureStateTree::Draw*)(*activeOps)[(*activeOps).count()
-1])->fOffset; | |
| 789 | |
| 790 for (int i = 0; i < activeOps->count(); ++i) { | |
| 791 SkPictureStateTree::Draw* draw = (SkPictureStateTree::Draw*) (*activeOps
)[i]; | |
| 792 | |
| 793 for (int j = 0; j < fBitmapUseOffsets->numIDs(); ++j) { | |
| 794 if (!needToCheck.get()[j]) { | |
| 795 continue; | |
| 796 } | |
| 797 | |
| 798 if (!fBitmapUseOffsets->overlap(j, draw->fOffset, max)) { | |
| 799 needToCheck.get()[j] = false; | |
| 800 continue; | |
| 801 } | |
| 802 | |
| 803 if (!fBitmapUseOffsets->includes(j, draw->fOffset)) { | |
| 804 continue; | |
| 805 } | |
| 806 | |
| 807 *active.append() = j; | |
| 808 needToCheck.get()[j] = false; | |
| 809 } | |
| 810 } | |
| 811 | |
| 812 for (int i = 0; i < active.count(); ++i) { | |
| 813 SkDebugf("preload texture %d\n", active[i]); | |
| 814 } | |
| 815 } | |
| 816 | |
| 817 uint32_t SkPicturePlayback::CachedOperationList::offset(int index) const { | 768 uint32_t SkPicturePlayback::CachedOperationList::offset(int index) const { |
| 818 SkASSERT(index < fOps.count()); | 769 SkASSERT(index < fOps.count()); |
| 819 return ((SkPictureStateTree::Draw*)fOps[index])->fOffset; | 770 return ((SkPictureStateTree::Draw*)fOps[index])->fOffset; |
| 820 } | 771 } |
| 821 | 772 |
| 822 const SkMatrix& SkPicturePlayback::CachedOperationList::matrix(int index) const
{ | 773 const SkMatrix& SkPicturePlayback::CachedOperationList::matrix(int index) const
{ |
| 823 SkASSERT(index < fOps.count()); | 774 SkASSERT(index < fOps.count()); |
| 824 return *((SkPictureStateTree::Draw*)fOps[index])->fMatrix; | 775 return *((SkPictureStateTree::Draw*)fOps[index])->fMatrix; |
| 825 } | 776 } |
| 826 | 777 |
| (...skipping 84 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 911 fStateTree->getIterator(*activeOps, &canvas); | 862 fStateTree->getIterator(*activeOps, &canvas); |
| 912 | 863 |
| 913 if (it.isValid()) { | 864 if (it.isValid()) { |
| 914 uint32_t skipTo = it.draw(); | 865 uint32_t skipTo = it.draw(); |
| 915 if (kDrawComplete == skipTo) { | 866 if (kDrawComplete == skipTo) { |
| 916 return; | 867 return; |
| 917 } | 868 } |
| 918 reader.setOffset(skipTo); | 869 reader.setOffset(skipTo); |
| 919 } | 870 } |
| 920 | 871 |
| 921 this->preLoadBitmaps(activeOps); | |
| 922 | |
| 923 // Record this, so we can concat w/ it if we encounter a setMatrix() | 872 // Record this, so we can concat w/ it if we encounter a setMatrix() |
| 924 SkMatrix initialMatrix = canvas.getTotalMatrix(); | 873 SkMatrix initialMatrix = canvas.getTotalMatrix(); |
| 925 int originalSaveCount = canvas.getSaveCount(); | 874 int originalSaveCount = canvas.getSaveCount(); |
| 926 | 875 |
| 927 #ifdef SK_BUILD_FOR_ANDROID | 876 #ifdef SK_BUILD_FOR_ANDROID |
| 928 fAbortCurrentPlayback = false; | 877 fAbortCurrentPlayback = false; |
| 929 #endif | 878 #endif |
| 930 | 879 |
| 931 #ifdef SK_DEVELOPER | 880 #ifdef SK_DEVELOPER |
| 932 int opIndex = -1; | 881 int opIndex = -1; |
| (...skipping 900 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1833 for (index = 0; index < fPictureCount; index++) | 1782 for (index = 0; index < fPictureCount; index++) |
| 1834 bufferPtr += snprintf(bufferPtr, DUMP_BUFFER_SIZE - (bufferPtr - pBuffer
), | 1783 bufferPtr += snprintf(bufferPtr, DUMP_BUFFER_SIZE - (bufferPtr - pBuffer
), |
| 1835 "picture%p, ", fPictureRefs[index]); | 1784 "picture%p, ", fPictureRefs[index]); |
| 1836 if (fPictureCount > 0) | 1785 if (fPictureCount > 0) |
| 1837 SkDebugf("%s0};\n", pBuffer); | 1786 SkDebugf("%s0};\n", pBuffer); |
| 1838 | 1787 |
| 1839 const_cast<SkPicturePlayback*>(this)->dumpStream(); | 1788 const_cast<SkPicturePlayback*>(this)->dumpStream(); |
| 1840 } | 1789 } |
| 1841 | 1790 |
| 1842 #endif | 1791 #endif |
| OLD | NEW |