OLD | NEW |
---|---|
1 | 1 |
2 /* | 2 /* |
3 * Copyright 2011 Google Inc. | 3 * Copyright 2011 Google Inc. |
4 * | 4 * |
5 * Use of this source code is governed by a BSD-style license that can be | 5 * Use of this source code is governed by a BSD-style license that can be |
6 * found in the LICENSE file. | 6 * found in the LICENSE file. |
7 */ | 7 */ |
8 | 8 |
9 | 9 |
10 #include "SkBitmapHeap.h" | 10 #include "SkBitmapHeap.h" |
11 #include "SkCanvas.h" | 11 #include "SkCanvas.h" |
12 #include "SkPaint.h" | 12 #include "SkPaint.h" |
13 #include "SkGPipe.h" | 13 #include "SkGPipe.h" |
14 #include "SkGPipePriv.h" | 14 #include "SkGPipePriv.h" |
15 #include "SkReader32.h" | 15 #include "SkReader32.h" |
16 #include "SkStream.h" | 16 #include "SkStream.h" |
17 | 17 |
18 #include "SkAnnotation.h" | |
18 #include "SkColorFilter.h" | 19 #include "SkColorFilter.h" |
19 #include "SkDrawLooper.h" | 20 #include "SkDrawLooper.h" |
20 #include "SkMaskFilter.h" | 21 #include "SkMaskFilter.h" |
21 #include "SkOrderedReadBuffer.h" | 22 #include "SkOrderedReadBuffer.h" |
22 #include "SkPathEffect.h" | 23 #include "SkPathEffect.h" |
23 #include "SkRasterizer.h" | 24 #include "SkRasterizer.h" |
24 #include "SkRRect.h" | 25 #include "SkRRect.h" |
25 #include "SkShader.h" | 26 #include "SkShader.h" |
26 #include "SkTypeface.h" | 27 #include "SkTypeface.h" |
27 #include "SkXfermode.h" | 28 #include "SkXfermode.h" |
(...skipping 18 matching lines...) Expand all Loading... | |
46 break; | 47 break; |
47 case kShader_PaintFlat: | 48 case kShader_PaintFlat: |
48 paint->setShader((SkShader*)obj); | 49 paint->setShader((SkShader*)obj); |
49 break; | 50 break; |
50 case kImageFilter_PaintFlat: | 51 case kImageFilter_PaintFlat: |
51 paint->setImageFilter((SkImageFilter*)obj); | 52 paint->setImageFilter((SkImageFilter*)obj); |
52 break; | 53 break; |
53 case kXfermode_PaintFlat: | 54 case kXfermode_PaintFlat: |
54 paint->setXfermode((SkXfermode*)obj); | 55 paint->setXfermode((SkXfermode*)obj); |
55 break; | 56 break; |
56 case kAnnotation_PaintFlat: | |
57 paint->setAnnotation((SkAnnotation*)obj); | |
58 break; | |
59 default: | 57 default: |
60 SkDEBUGFAIL("never gets here"); | 58 SkDEBUGFAIL("never gets here"); |
61 } | 59 } |
62 } | 60 } |
63 | 61 |
64 template <typename T> class SkRefCntTDArray : public SkTDArray<T> { | 62 template <typename T> class SkRefCntTDArray : public SkTDArray<T> { |
65 public: | 63 public: |
66 ~SkRefCntTDArray() { this->unrefAll(); } | 64 ~SkRefCntTDArray() { this->unrefAll(); } |
67 }; | 65 }; |
68 | 66 |
(...skipping 596 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
665 } while (reader->offset() < stop); | 663 } while (reader->offset() < stop); |
666 } | 664 } |
667 | 665 |
668 static void typeface_rp(SkCanvas*, SkReader32* reader, uint32_t, | 666 static void typeface_rp(SkCanvas*, SkReader32* reader, uint32_t, |
669 SkGPipeState* state) { | 667 SkGPipeState* state) { |
670 SkASSERT(!SkToBool(state->getFlags() & SkGPipeWriter::kCrossProcess_Flag)); | 668 SkASSERT(!SkToBool(state->getFlags() & SkGPipeWriter::kCrossProcess_Flag)); |
671 SkPaint* p = state->editPaint(); | 669 SkPaint* p = state->editPaint(); |
672 p->setTypeface(static_cast<SkTypeface*>(reader->readPtr())); | 670 p->setTypeface(static_cast<SkTypeface*>(reader->readPtr())); |
673 } | 671 } |
674 | 672 |
673 static void annotation_rp(SkCanvas*, SkReader32* reader, uint32_t, | |
674 SkGPipeState* state) { | |
675 SkPaint* p = state->editPaint(); | |
676 | |
677 size_t size = reader->readInt(); | |
scroggo
2013/10/14 18:47:19
Should this be cast from int32_t to size_t?
Also,
reed1
2013/10/14 19:38:41
const -- done
changed readInt to readU32, to match
| |
678 SkAutoMalloc storage(size); | |
679 reader->read(storage.get(), size); | |
680 SkOrderedReadBuffer buffer(storage.get(), size); | |
681 p->setAnnotation(SkNEW_ARGS(SkAnnotation, (buffer)))->unref(); | |
scroggo
2013/10/14 18:47:19
If the buffer has size 0, won't SkAnnotation's con
reed1
2013/10/14 19:38:41
Done.
| |
682 } | |
683 | |
675 /////////////////////////////////////////////////////////////////////////////// | 684 /////////////////////////////////////////////////////////////////////////////// |
676 | 685 |
677 static void def_Typeface_rp(SkCanvas*, SkReader32*, uint32_t, SkGPipeState* stat e) { | 686 static void def_Typeface_rp(SkCanvas*, SkReader32*, uint32_t, SkGPipeState* stat e) { |
678 state->addTypeface(); | 687 state->addTypeface(); |
679 } | 688 } |
680 | 689 |
681 static void def_PaintFlat_rp(SkCanvas*, SkReader32*, uint32_t op32, | 690 static void def_PaintFlat_rp(SkCanvas*, SkReader32*, uint32_t op32, |
682 SkGPipeState* state) { | 691 SkGPipeState* state) { |
683 PaintFlats pf = (PaintFlats)DrawOp_unpackFlags(op32); | 692 PaintFlats pf = (PaintFlats)DrawOp_unpackFlags(op32); |
684 unsigned index = DrawOp_unpackData(op32); | 693 unsigned index = DrawOp_unpackData(op32); |
(...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
748 rotate_rp, | 757 rotate_rp, |
749 save_rp, | 758 save_rp, |
750 saveLayer_rp, | 759 saveLayer_rp, |
751 scale_rp, | 760 scale_rp, |
752 setMatrix_rp, | 761 setMatrix_rp, |
753 skew_rp, | 762 skew_rp, |
754 translate_rp, | 763 translate_rp, |
755 | 764 |
756 paintOp_rp, | 765 paintOp_rp, |
757 typeface_rp, | 766 typeface_rp, |
767 annotation_rp, | |
768 | |
758 def_Typeface_rp, | 769 def_Typeface_rp, |
759 def_PaintFlat_rp, | 770 def_PaintFlat_rp, |
760 def_Bitmap_rp, | 771 def_Bitmap_rp, |
761 def_Factory_rp, | 772 def_Factory_rp, |
762 | 773 |
763 reportFlags_rp, | 774 reportFlags_rp, |
764 shareBitmapHeap_rp, | 775 shareBitmapHeap_rp, |
765 done_rp | 776 done_rp |
766 }; | 777 }; |
767 | 778 |
(...skipping 85 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
853 status = kReadAtom_Status; | 864 status = kReadAtom_Status; |
854 break; | 865 break; |
855 } | 866 } |
856 } | 867 } |
857 | 868 |
858 if (bytesRead) { | 869 if (bytesRead) { |
859 *bytesRead = reader.offset(); | 870 *bytesRead = reader.offset(); |
860 } | 871 } |
861 return status; | 872 return status; |
862 } | 873 } |
OLD | NEW |