reed@android.com | f76bacf | 2009-05-13 14:00:33 +0000 | [diff] [blame] | 1 | #include "SkGroupShape.h" |
| 2 | |
| 3 | SkGroupShape::SkGroupShape() {} |
| 4 | |
| 5 | SkGroupShape::~SkGroupShape() { |
| 6 | this->removeAllShapes(); |
| 7 | } |
| 8 | |
| 9 | int SkGroupShape::countShapes() const { |
| 10 | return fList.count(); |
| 11 | } |
| 12 | |
reed@android.com | f48f281 | 2009-05-18 04:20:55 +0000 | [diff] [blame] | 13 | SkShape* SkGroupShape::getShape(int index, SkMatrixRef** mr) const { |
reed@android.com | f76bacf | 2009-05-13 14:00:33 +0000 | [diff] [blame] | 14 | if ((unsigned)index < (unsigned)fList.count()) { |
reed@android.com | f48f281 | 2009-05-18 04:20:55 +0000 | [diff] [blame] | 15 | const Rec& rec = fList[index]; |
| 16 | if (mr) { |
| 17 | *mr = rec.fMatrixRef; |
| 18 | } |
| 19 | return rec.fShape; |
reed@android.com | f76bacf | 2009-05-13 14:00:33 +0000 | [diff] [blame] | 20 | } |
| 21 | return NULL; |
| 22 | } |
| 23 | |
reed@android.com | f48f281 | 2009-05-18 04:20:55 +0000 | [diff] [blame] | 24 | void SkGroupShape::addShape(int index, SkShape* shape, SkMatrixRef* mr) { |
reed@android.com | f76bacf | 2009-05-13 14:00:33 +0000 | [diff] [blame] | 25 | int count = fList.count(); |
| 26 | if (NULL == shape || index < 0 || index > count) { |
reed@android.com | f48f281 | 2009-05-18 04:20:55 +0000 | [diff] [blame] | 27 | return; |
reed@android.com | f76bacf | 2009-05-13 14:00:33 +0000 | [diff] [blame] | 28 | } |
| 29 | |
| 30 | shape->ref(); |
reed@android.com | f48f281 | 2009-05-18 04:20:55 +0000 | [diff] [blame] | 31 | SkMatrixRef::SafeRef(mr); |
| 32 | |
| 33 | Rec* rec; |
reed@android.com | f76bacf | 2009-05-13 14:00:33 +0000 | [diff] [blame] | 34 | if (index == count) { |
reed@android.com | f48f281 | 2009-05-18 04:20:55 +0000 | [diff] [blame] | 35 | rec = fList.append(); |
reed@android.com | f76bacf | 2009-05-13 14:00:33 +0000 | [diff] [blame] | 36 | } else { |
reed@android.com | f48f281 | 2009-05-18 04:20:55 +0000 | [diff] [blame] | 37 | rec = fList.insert(index); |
reed@android.com | f76bacf | 2009-05-13 14:00:33 +0000 | [diff] [blame] | 38 | } |
reed@android.com | f48f281 | 2009-05-18 04:20:55 +0000 | [diff] [blame] | 39 | rec->fShape = shape; |
| 40 | rec->fMatrixRef = mr; |
reed@android.com | f76bacf | 2009-05-13 14:00:33 +0000 | [diff] [blame] | 41 | } |
| 42 | |
| 43 | void SkGroupShape::removeShape(int index) { |
| 44 | if ((unsigned)index < (unsigned)fList.count()) { |
reed@android.com | f48f281 | 2009-05-18 04:20:55 +0000 | [diff] [blame] | 45 | Rec& rec = fList[index]; |
| 46 | rec.fShape->unref(); |
| 47 | SkMatrixRef::SafeUnref(rec.fMatrixRef); |
reed@android.com | f76bacf | 2009-05-13 14:00:33 +0000 | [diff] [blame] | 48 | fList.remove(index); |
| 49 | } |
| 50 | } |
| 51 | |
| 52 | void SkGroupShape::removeAllShapes() { |
reed@android.com | f48f281 | 2009-05-18 04:20:55 +0000 | [diff] [blame] | 53 | Rec* rec = fList.begin(); |
| 54 | Rec* stop = fList.end(); |
| 55 | while (rec < stop) { |
| 56 | rec->fShape->unref(); |
| 57 | SkMatrixRef::SafeUnref(rec->fMatrixRef); |
| 58 | rec++; |
| 59 | } |
reed@android.com | f76bacf | 2009-05-13 14:00:33 +0000 | [diff] [blame] | 60 | fList.reset(); |
| 61 | } |
| 62 | |
| 63 | /////////////////////////////////////////////////////////////////////////////// |
| 64 | |
| 65 | void SkGroupShape::onDraw(SkCanvas* canvas) { |
reed@android.com | f48f281 | 2009-05-18 04:20:55 +0000 | [diff] [blame] | 66 | const Rec* rec = fList.begin(); |
| 67 | const Rec* stop = fList.end(); |
| 68 | while (rec < stop) { |
| 69 | SkShape* shape = rec->fShape; |
| 70 | if (rec->fMatrixRef) { |
| 71 | shape->drawMatrix(canvas, *rec->fMatrixRef); |
| 72 | } else { |
| 73 | shape->draw(canvas); |
| 74 | } |
| 75 | rec++; |
reed@android.com | f76bacf | 2009-05-13 14:00:33 +0000 | [diff] [blame] | 76 | } |
| 77 | } |
| 78 | |
| 79 | SkFlattenable::Factory SkGroupShape::getFactory() { |
| 80 | return CreateProc; |
| 81 | } |
| 82 | |
| 83 | void SkGroupShape::flatten(SkFlattenableWriteBuffer& buffer) { |
| 84 | this->INHERITED::flatten(buffer); |
| 85 | |
| 86 | int count = fList.count(); |
| 87 | buffer.write32(count); |
reed@android.com | f48f281 | 2009-05-18 04:20:55 +0000 | [diff] [blame] | 88 | const Rec* rec = fList.begin(); |
| 89 | const Rec* stop = fList.end(); |
| 90 | while (rec < stop) { |
| 91 | SkShape* shape = rec->fShape; |
| 92 | buffer.writeFunctionPtr((void*)shape->getFactory()); |
| 93 | shape->flatten(buffer); |
| 94 | // todo: flatten the matrixref if present |
reed@android.com | f76bacf | 2009-05-13 14:00:33 +0000 | [diff] [blame] | 95 | } |
| 96 | } |
| 97 | |
| 98 | SkGroupShape::SkGroupShape(SkFlattenableReadBuffer& buffer) : INHERITED(buffer){ |
| 99 | int count = buffer.readS32(); |
| 100 | for (int i = 0; i < count; i++) { |
| 101 | SkFlattenable::Factory fact = |
| 102 | (SkFlattenable::Factory)buffer.readFunctionPtr(); |
| 103 | this->appendShape((SkShape*)fact(buffer))->unref(); |
reed@android.com | f48f281 | 2009-05-18 04:20:55 +0000 | [diff] [blame] | 104 | // todo: unflatten the matrixref if present |
reed@android.com | f76bacf | 2009-05-13 14:00:33 +0000 | [diff] [blame] | 105 | } |
| 106 | } |
| 107 | |
| 108 | SkFlattenable* SkGroupShape::CreateProc(SkFlattenableReadBuffer& buffer) { |
| 109 | return SkNEW_ARGS(SkGroupShape, (buffer)); |
| 110 | } |
| 111 | |