| 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 "SkDevice.h" | 9 #include "SkDevice.h" |
| 10 #include "SkImage_Base.h" | 10 #include "SkImage_Base.h" |
| 11 #include "SkPatchUtils.h" | 11 #include "SkPatchUtils.h" |
| 12 #include "SkPixelRef.h" | 12 #include "SkPixelRef.h" |
| 13 #include "SkRRect.h" | 13 #include "SkRRect.h" |
| 14 #include "SkRSXform.h" |
| 14 #include "SkTextBlob.h" | 15 #include "SkTextBlob.h" |
| 15 #include "SkTSearch.h" | 16 #include "SkTSearch.h" |
| 16 | 17 |
| 17 #define HEAP_BLOCK_SIZE 4096 | 18 #define HEAP_BLOCK_SIZE 4096 |
| 18 | 19 |
| 19 enum { | 20 enum { |
| 20 // just need a value that save or getSaveCount would never return | 21 // just need a value that save or getSaveCount would never return |
| 21 kNoInitialSave = -1, | 22 kNoInitialSave = -1, |
| 22 }; | 23 }; |
| 23 | 24 |
| (...skipping 68 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 92 0, // COMMENT - no paint | 93 0, // COMMENT - no paint |
| 93 0, // END_GROUP - no paint | 94 0, // END_GROUP - no paint |
| 94 1, // DRAWDRRECT - right after op code | 95 1, // DRAWDRRECT - right after op code |
| 95 0, // PUSH_CULL - no paint | 96 0, // PUSH_CULL - no paint |
| 96 0, // POP_CULL - no paint | 97 0, // POP_CULL - no paint |
| 97 1, // DRAW_PATCH - right after op code | 98 1, // DRAW_PATCH - right after op code |
| 98 1, // DRAW_PICTURE_MATRIX_PAINT - right after op code | 99 1, // DRAW_PICTURE_MATRIX_PAINT - right after op code |
| 99 1, // DRAW_TEXT_BLOB- right after op code | 100 1, // DRAW_TEXT_BLOB- right after op code |
| 100 1, // DRAW_IMAGE - right after op code | 101 1, // DRAW_IMAGE - right after op code |
| 101 1, // DRAW_IMAGE_RECT - right after op code | 102 1, // DRAW_IMAGE_RECT - right after op code |
| 103 1, // DRAW_ATLAS - right after op code |
| 102 }; | 104 }; |
| 103 | 105 |
| 104 SK_COMPILE_ASSERT(sizeof(gPaintOffsets) == LAST_DRAWTYPE_ENUM + 1, | 106 SK_COMPILE_ASSERT(sizeof(gPaintOffsets) == LAST_DRAWTYPE_ENUM + 1, |
| 105 need_to_be_in_sync); | 107 need_to_be_in_sync); |
| 106 SkASSERT((unsigned)op <= (unsigned)LAST_DRAWTYPE_ENUM); | 108 SkASSERT((unsigned)op <= (unsigned)LAST_DRAWTYPE_ENUM); |
| 107 | 109 |
| 108 int overflow = 0; | 110 int overflow = 0; |
| 109 if (0 != (opSize & ~MASK_24) || opSize == MASK_24) { | 111 if (0 != (opSize & ~MASK_24) || opSize == MASK_24) { |
| 110 // This op's size overflows so an extra uint32_t will be written | 112 // This op's size overflows so an extra uint32_t will be written |
| 111 // after the op code | 113 // after the op code |
| (...skipping 715 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 827 fWriter.write(texCoords, SkPatchUtils::kNumCorners * sizeof(SkPoint)); | 829 fWriter.write(texCoords, SkPatchUtils::kNumCorners * sizeof(SkPoint)); |
| 828 } | 830 } |
| 829 if (flag & DRAW_VERTICES_HAS_XFER) { | 831 if (flag & DRAW_VERTICES_HAS_XFER) { |
| 830 SkXfermode::Mode mode = SkXfermode::kModulate_Mode; | 832 SkXfermode::Mode mode = SkXfermode::kModulate_Mode; |
| 831 xmode->asMode(&mode); | 833 xmode->asMode(&mode); |
| 832 this->addInt(mode); | 834 this->addInt(mode); |
| 833 } | 835 } |
| 834 this->validate(initialOffset, size); | 836 this->validate(initialOffset, size); |
| 835 } | 837 } |
| 836 | 838 |
| 839 void SkPictureRecord::onDrawAtlas(const SkImage* atlas, const SkRSXform xform[],
const SkRect tex[], |
| 840 const SkColor colors[], int count, SkXfermode:
:Mode mode, |
| 841 const SkRect* cull, const SkPaint* paint) { |
| 842 // [op + paint-index + atlas-index + flags + count] + [xform] + [tex] + [*co
lors + mode] + cull |
| 843 size_t size = 5 * kUInt32Size + count * sizeof(SkRSXform) + count * sizeof(S
kRect); |
| 844 uint32_t flags = 0; |
| 845 if (colors) { |
| 846 flags |= DRAW_ATLAS_HAS_COLORS; |
| 847 size += count * sizeof(SkColor); |
| 848 size += sizeof(uint32_t); // xfermode::mode |
| 849 } |
| 850 if (cull) { |
| 851 flags |= DRAW_ATLAS_HAS_CULL; |
| 852 size += sizeof(SkRect); |
| 853 } |
| 854 |
| 855 size_t initialOffset = this->addDraw(DRAW_ATLAS, &size); |
| 856 SkASSERT(initialOffset+get_paint_offset(DRAW_ATLAS, size) == fWriter.bytesWr
itten()); |
| 857 this->addPaintPtr(paint); |
| 858 this->addImage(atlas); |
| 859 this->addInt(flags); |
| 860 this->addInt(count); |
| 861 fWriter.write(xform, count * sizeof(SkRSXform)); |
| 862 fWriter.write(tex, count * sizeof(SkRect)); |
| 863 |
| 864 // write optional parameters |
| 865 if (colors) { |
| 866 fWriter.write(colors, count * sizeof(SkColor)); |
| 867 this->addInt(mode); |
| 868 } |
| 869 if (cull) { |
| 870 fWriter.write(cull, sizeof(SkRect)); |
| 871 } |
| 872 this->validate(initialOffset, size); |
| 873 } |
| 874 |
| 837 /////////////////////////////////////////////////////////////////////////////// | 875 /////////////////////////////////////////////////////////////////////////////// |
| 838 | 876 |
| 839 SkSurface* SkPictureRecord::onNewSurface(const SkImageInfo& info, const SkSurfac
eProps&) { | 877 SkSurface* SkPictureRecord::onNewSurface(const SkImageInfo& info, const SkSurfac
eProps&) { |
| 840 return NULL; | 878 return NULL; |
| 841 } | 879 } |
| 842 | 880 |
| 843 // If we already have a stored, can we reuse it instead of also storing b? | 881 // If we already have a stored, can we reuse it instead of also storing b? |
| 844 static bool equivalent(const SkBitmap& a, const SkBitmap& b) { | 882 static bool equivalent(const SkBitmap& a, const SkBitmap& b) { |
| 845 if (a.info() != b.info() || a.pixelRefOrigin() != b.pixelRefOrigin()) { | 883 if (a.info() != b.info() || a.pixelRefOrigin() != b.pixelRefOrigin()) { |
| 846 // Requiring a.info() == b.info() may be overkill in some cases (alphaty
pe mismatch), | 884 // Requiring a.info() == b.info() may be overkill in some cases (alphaty
pe mismatch), |
| (...skipping 163 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1010 void SkPictureRecord::addTextBlob(const SkTextBlob *blob) { | 1048 void SkPictureRecord::addTextBlob(const SkTextBlob *blob) { |
| 1011 int index = fTextBlobRefs.count(); | 1049 int index = fTextBlobRefs.count(); |
| 1012 *fTextBlobRefs.append() = blob; | 1050 *fTextBlobRefs.append() = blob; |
| 1013 blob->ref(); | 1051 blob->ref(); |
| 1014 // follow the convention of recording a 1-based index | 1052 // follow the convention of recording a 1-based index |
| 1015 this->addInt(index + 1); | 1053 this->addInt(index + 1); |
| 1016 } | 1054 } |
| 1017 | 1055 |
| 1018 /////////////////////////////////////////////////////////////////////////////// | 1056 /////////////////////////////////////////////////////////////////////////////// |
| 1019 | 1057 |
| OLD | NEW |