3 * Copyright 2012 Google Inc.
5 * Use of this source code is governed by a BSD-style license that can be
6 * found in the LICENSE file.
10 #include "SkDrawCommand.h"
11 #include "SkObjectParser.h"
13 #include "SkTextBlob.h"
15 // TODO(chudy): Refactor into non subclass model.
17 SkDrawCommand::SkDrawCommand(DrawType type)
23 SkDrawCommand::SkDrawCommand() {
28 SkDrawCommand::~SkDrawCommand() {
32 const char* SkDrawCommand::GetCommandString(DrawType type) {
34 case UNUSED: SkDEBUGFAIL("DrawType UNUSED\n"); break;
35 case DRAW_CLEAR: return "Clear";
36 case CLIP_PATH: return "Clip Path";
37 case CLIP_REGION: return "Clip Region";
38 case CLIP_RECT: return "Clip Rect";
39 case CLIP_RRECT: return "Clip RRect";
40 case CONCAT: return "Concat";
41 case DRAW_BITMAP: return "Draw Bitmap";
42 case DRAW_BITMAP_MATRIX: return "Draw Bitmap Matrix";
43 case DRAW_BITMAP_NINE: return "Draw Bitmap Nine";
44 case DRAW_BITMAP_RECT_TO_RECT: return "Draw Bitmap Rect";
45 case DRAW_DATA: return "Draw Data";
46 case DRAW_OVAL: return "Draw Oval";
47 case DRAW_PAINT: return "Draw Paint";
48 case DRAW_PATH: return "Draw Path";
49 case DRAW_PICTURE: return "Draw Picture";
50 case DRAW_POINTS: return "Draw Points";
51 case DRAW_POS_TEXT: return "Draw Pos Text";
52 case DRAW_POS_TEXT_H: return "Draw Pos Text H";
53 case DRAW_RECT: return "Draw Rect";
54 case DRAW_RRECT: return "Draw RRect";
55 case DRAW_SPRITE: return "Draw Sprite";
56 case DRAW_TEXT: return "Draw Text";
57 case DRAW_TEXT_BLOB: return "Draw Text Blob";
58 case DRAW_TEXT_ON_PATH: return "Draw Text On Path";
59 case DRAW_VERTICES: return "Draw Vertices";
60 case RESTORE: return "Restore";
61 case ROTATE: return "Rotate";
62 case SAVE: return "Save";
63 case SAVE_LAYER: return "Save Layer";
64 case SCALE: return "Scale";
65 case SET_MATRIX: return "Set Matrix";
66 case SKEW: return "Skew";
67 case TRANSLATE: return "Translate";
68 case NOOP: return "NoOp";
69 case BEGIN_COMMENT_GROUP: return "BeginCommentGroup";
70 case COMMENT: return "Comment";
71 case END_COMMENT_GROUP: return "EndCommentGroup";
72 case DRAW_DRRECT: return "Draw DRRect";
73 case PUSH_CULL: return "PushCull";
74 case POP_CULL: return "PopCull";
76 SkDebugf("DrawType error 0x%08x\n", type);
80 SkDEBUGFAIL("DrawType UNUSED\n");
84 SkString SkDrawCommand::toString() {
85 return SkString(GetCommandString(fDrawType));
88 SkClearCommand::SkClearCommand(SkColor color) : INHERITED(DRAW_CLEAR) {
90 fInfo.push(SkObjectParser::CustomTextToString("No Parameters"));
93 void SkClearCommand::execute(SkCanvas* canvas) {
94 canvas->clear(fColor);
99 void xlate_and_scale_to_bounds(SkCanvas* canvas, const SkRect& bounds) {
100 const SkISize& size = canvas->getDeviceSize();
102 static const SkScalar kInsetFrac = 0.9f; // Leave a border around object
104 canvas->translate(size.fWidth/2.0f, size.fHeight/2.0f);
105 if (bounds.width() > bounds.height()) {
106 canvas->scale(SkDoubleToScalar((kInsetFrac*size.fWidth)/bounds.width()),
107 SkDoubleToScalar((kInsetFrac*size.fHeight)/bounds.width()));
109 canvas->scale(SkDoubleToScalar((kInsetFrac*size.fWidth)/bounds.height()),
110 SkDoubleToScalar((kInsetFrac*size.fHeight)/bounds.height()));
112 canvas->translate(-bounds.centerX(), -bounds.centerY());
116 void render_path(SkCanvas* canvas, const SkPath& path) {
117 canvas->clear(0xFFFFFFFF);
120 const SkRect& bounds = path.getBounds();
122 xlate_and_scale_to_bounds(canvas, bounds);
125 p.setColor(SK_ColorBLACK);
126 p.setStyle(SkPaint::kStroke_Style);
128 canvas->drawPath(path, p);
132 void render_bitmap(SkCanvas* canvas, const SkBitmap& input, const SkRect* srcRect = NULL) {
133 const SkISize& size = canvas->getDeviceSize();
135 SkScalar xScale = SkIntToScalar(size.fWidth-2) / input.width();
136 SkScalar yScale = SkIntToScalar(size.fHeight-2) / input.height();
138 if (input.width() > input.height()) {
139 yScale *= input.height() / (float) input.width();
141 xScale *= input.width() / (float) input.height();
144 SkRect dst = SkRect::MakeXYWH(SK_Scalar1, SK_Scalar1,
145 xScale * input.width(),
146 yScale * input.height());
148 canvas->clear(0xFFFFFFFF);
149 canvas->drawBitmapRect(input, NULL, dst);
152 SkRect r = SkRect::MakeLTRB(srcRect->fLeft * xScale + SK_Scalar1,
153 srcRect->fTop * yScale + SK_Scalar1,
154 srcRect->fRight * xScale + SK_Scalar1,
155 srcRect->fBottom * yScale + SK_Scalar1);
157 p.setColor(SK_ColorRED);
158 p.setStyle(SkPaint::kStroke_Style);
160 canvas->drawRect(r, p);
164 void render_rrect(SkCanvas* canvas, const SkRRect& rrect) {
165 canvas->clear(0xFFFFFFFF);
168 const SkRect& bounds = rrect.getBounds();
170 xlate_and_scale_to_bounds(canvas, bounds);
173 p.setColor(SK_ColorBLACK);
174 p.setStyle(SkPaint::kStroke_Style);
176 canvas->drawRRect(rrect, p);
180 void render_drrect(SkCanvas* canvas, const SkRRect& outer, const SkRRect& inner) {
181 canvas->clear(0xFFFFFFFF);
184 const SkRect& bounds = outer.getBounds();
186 xlate_and_scale_to_bounds(canvas, bounds);
189 p.setColor(SK_ColorBLACK);
190 p.setStyle(SkPaint::kStroke_Style);
192 canvas->drawDRRect(outer, inner, p);
199 SkClipPathCommand::SkClipPathCommand(const SkPath& path, SkRegion::Op op, bool doAA)
200 : INHERITED(CLIP_PATH) {
205 fInfo.push(SkObjectParser::PathToString(path));
206 fInfo.push(SkObjectParser::RegionOpToString(op));
207 fInfo.push(SkObjectParser::BoolToString(doAA));
210 void SkClipPathCommand::execute(SkCanvas* canvas) {
211 canvas->clipPath(fPath, fOp, fDoAA);
214 bool SkClipPathCommand::render(SkCanvas* canvas) const {
215 render_path(canvas, fPath);
219 SkClipRegionCommand::SkClipRegionCommand(const SkRegion& region, SkRegion::Op op)
220 : INHERITED(CLIP_REGION) {
224 fInfo.push(SkObjectParser::RegionToString(region));
225 fInfo.push(SkObjectParser::RegionOpToString(op));
228 void SkClipRegionCommand::execute(SkCanvas* canvas) {
229 canvas->clipRegion(fRegion, fOp);
232 SkClipRectCommand::SkClipRectCommand(const SkRect& rect, SkRegion::Op op, bool doAA)
233 : INHERITED(CLIP_RECT) {
238 fInfo.push(SkObjectParser::RectToString(rect));
239 fInfo.push(SkObjectParser::RegionOpToString(op));
240 fInfo.push(SkObjectParser::BoolToString(doAA));
243 void SkClipRectCommand::execute(SkCanvas* canvas) {
244 canvas->clipRect(fRect, fOp, fDoAA);
247 SkClipRRectCommand::SkClipRRectCommand(const SkRRect& rrect, SkRegion::Op op, bool doAA)
248 : INHERITED(CLIP_RRECT) {
253 fInfo.push(SkObjectParser::RRectToString(rrect));
254 fInfo.push(SkObjectParser::RegionOpToString(op));
255 fInfo.push(SkObjectParser::BoolToString(doAA));
258 void SkClipRRectCommand::execute(SkCanvas* canvas) {
259 canvas->clipRRect(fRRect, fOp, fDoAA);
262 bool SkClipRRectCommand::render(SkCanvas* canvas) const {
263 render_rrect(canvas, fRRect);
267 SkConcatCommand::SkConcatCommand(const SkMatrix& matrix)
268 : INHERITED(CONCAT) {
271 fInfo.push(SkObjectParser::MatrixToString(matrix));
274 void SkConcatCommand::execute(SkCanvas* canvas) {
275 canvas->concat(fMatrix);
278 SkDrawBitmapCommand::SkDrawBitmapCommand(const SkBitmap& bitmap, SkScalar left, SkScalar top,
279 const SkPaint* paint)
280 : INHERITED(DRAW_BITMAP) {
291 fInfo.push(SkObjectParser::BitmapToString(bitmap));
292 fInfo.push(SkObjectParser::ScalarToString(left, "SkScalar left: "));
293 fInfo.push(SkObjectParser::ScalarToString(top, "SkScalar top: "));
295 fInfo.push(SkObjectParser::PaintToString(*paint));
299 void SkDrawBitmapCommand::execute(SkCanvas* canvas) {
300 canvas->drawBitmap(fBitmap, fLeft, fTop, fPaintPtr);
303 bool SkDrawBitmapCommand::render(SkCanvas* canvas) const {
304 render_bitmap(canvas, fBitmap);
308 SkDrawBitmapMatrixCommand::SkDrawBitmapMatrixCommand(const SkBitmap& bitmap,
309 const SkMatrix& matrix,
310 const SkPaint* paint)
311 : INHERITED(DRAW_BITMAP_MATRIX) {
321 fInfo.push(SkObjectParser::BitmapToString(bitmap));
322 fInfo.push(SkObjectParser::MatrixToString(matrix));
324 fInfo.push(SkObjectParser::PaintToString(*paint));
328 void SkDrawBitmapMatrixCommand::execute(SkCanvas* canvas) {
329 canvas->drawBitmapMatrix(fBitmap, fMatrix, fPaintPtr);
332 bool SkDrawBitmapMatrixCommand::render(SkCanvas* canvas) const {
333 render_bitmap(canvas, fBitmap);
337 SkDrawBitmapNineCommand::SkDrawBitmapNineCommand(const SkBitmap& bitmap, const SkIRect& center,
338 const SkRect& dst, const SkPaint* paint)
339 : INHERITED(DRAW_BITMAP_NINE) {
350 fInfo.push(SkObjectParser::BitmapToString(bitmap));
351 fInfo.push(SkObjectParser::IRectToString(center));
352 fInfo.push(SkObjectParser::RectToString(dst, "Dst: "));
354 fInfo.push(SkObjectParser::PaintToString(*paint));
358 void SkDrawBitmapNineCommand::execute(SkCanvas* canvas) {
359 canvas->drawBitmapNine(fBitmap, fCenter, fDst, fPaintPtr);
362 bool SkDrawBitmapNineCommand::render(SkCanvas* canvas) const {
363 render_bitmap(canvas, fBitmap);
367 SkDrawBitmapRectCommand::SkDrawBitmapRectCommand(const SkBitmap& bitmap, const SkRect* src,
368 const SkRect& dst, const SkPaint* paint,
369 SkCanvas::DrawBitmapRectFlags flags)
370 : INHERITED(DRAW_BITMAP_RECT_TO_RECT) {
387 fInfo.push(SkObjectParser::BitmapToString(bitmap));
389 fInfo.push(SkObjectParser::RectToString(*src, "Src: "));
391 fInfo.push(SkObjectParser::RectToString(dst, "Dst: "));
393 fInfo.push(SkObjectParser::PaintToString(*paint));
395 fInfo.push(SkObjectParser::IntToString(fFlags, "Flags: "));
398 void SkDrawBitmapRectCommand::execute(SkCanvas* canvas) {
399 canvas->drawBitmapRectToRect(fBitmap, this->srcRect(), fDst, fPaintPtr, fFlags);
402 bool SkDrawBitmapRectCommand::render(SkCanvas* canvas) const {
403 render_bitmap(canvas, fBitmap, this->srcRect());
407 SkDrawDataCommand::SkDrawDataCommand(const void* data, size_t length)
408 : INHERITED(DRAW_DATA) {
409 fData = new char[length];
410 memcpy(fData, data, length);
413 // TODO: add display of actual data?
414 SkString* str = new SkString;
415 str->appendf("length: %d", (int) length);
419 void SkDrawDataCommand::execute(SkCanvas* canvas) {
420 canvas->drawData(fData, fLength);
423 SkBeginCommentGroupCommand::SkBeginCommentGroupCommand(const char* description)
424 : INHERITED(BEGIN_COMMENT_GROUP)
425 , fDescription(description) {
426 SkString* temp = new SkString;
427 temp->appendf("Description: %s", description);
431 SkCommentCommand::SkCommentCommand(const char* kywd, const char* value)
435 SkString* temp = new SkString;
436 temp->appendf("%s: %s", kywd, value);
440 SkEndCommentGroupCommand::SkEndCommentGroupCommand()
441 : INHERITED(END_COMMENT_GROUP) {
444 SkDrawOvalCommand::SkDrawOvalCommand(const SkRect& oval, const SkPaint& paint)
445 : INHERITED(DRAW_OVAL) {
449 fInfo.push(SkObjectParser::RectToString(oval));
450 fInfo.push(SkObjectParser::PaintToString(paint));
453 void SkDrawOvalCommand::execute(SkCanvas* canvas) {
454 canvas->drawOval(fOval, fPaint);
457 bool SkDrawOvalCommand::render(SkCanvas* canvas) const {
458 canvas->clear(0xFFFFFFFF);
461 xlate_and_scale_to_bounds(canvas, fOval);
464 p.setColor(SK_ColorBLACK);
465 p.setStyle(SkPaint::kStroke_Style);
467 canvas->drawOval(fOval, p);
473 SkDrawPaintCommand::SkDrawPaintCommand(const SkPaint& paint)
474 : INHERITED(DRAW_PAINT) {
477 fInfo.push(SkObjectParser::PaintToString(paint));
480 void SkDrawPaintCommand::execute(SkCanvas* canvas) {
481 canvas->drawPaint(fPaint);
484 bool SkDrawPaintCommand::render(SkCanvas* canvas) const {
485 canvas->clear(0xFFFFFFFF);
486 canvas->drawPaint(fPaint);
490 SkDrawPathCommand::SkDrawPathCommand(const SkPath& path, const SkPaint& paint)
491 : INHERITED(DRAW_PATH) {
495 fInfo.push(SkObjectParser::PathToString(path));
496 fInfo.push(SkObjectParser::PaintToString(paint));
499 void SkDrawPathCommand::execute(SkCanvas* canvas) {
500 canvas->drawPath(fPath, fPaint);
503 bool SkDrawPathCommand::render(SkCanvas* canvas) const {
504 render_path(canvas, fPath);
508 SkDrawPictureCommand::SkDrawPictureCommand(const SkPicture* picture,
509 const SkMatrix* matrix,
510 const SkPaint* paint)
511 : INHERITED(DRAW_PICTURE)
512 , fPicture(SkRef(picture))
518 fMatrixPtr = &fMatrix;
525 SkString* temp = new SkString;
526 temp->appendf("SkPicture: L: %f T: %f R: %f B: %f",
527 picture->cullRect().fLeft, picture->cullRect().fTop,
528 picture->cullRect().fRight, picture->cullRect().fBottom);
531 fInfo.push(SkObjectParser::MatrixToString(*matrix));
534 fInfo.push(SkObjectParser::PaintToString(*paint));
538 void SkDrawPictureCommand::execute(SkCanvas* canvas) {
539 canvas->drawPicture(fPicture, fMatrixPtr, fPaintPtr);
542 bool SkDrawPictureCommand::render(SkCanvas* canvas) const {
543 canvas->clear(0xFFFFFFFF);
546 xlate_and_scale_to_bounds(canvas, fPicture->cullRect());
548 canvas->drawPicture(fPicture.get());
555 SkDrawPointsCommand::SkDrawPointsCommand(SkCanvas::PointMode mode, size_t count,
556 const SkPoint pts[], const SkPaint& paint)
557 : INHERITED(DRAW_POINTS) {
560 fPts = new SkPoint[count];
561 memcpy(fPts, pts, count * sizeof(SkPoint));
564 fInfo.push(SkObjectParser::PointsToString(pts, count));
565 fInfo.push(SkObjectParser::ScalarToString(SkIntToScalar((unsigned int)count),
567 fInfo.push(SkObjectParser::PointModeToString(mode));
568 fInfo.push(SkObjectParser::PaintToString(paint));
571 void SkDrawPointsCommand::execute(SkCanvas* canvas) {
572 canvas->drawPoints(fMode, fCount, fPts, fPaint);
575 bool SkDrawPointsCommand::render(SkCanvas* canvas) const {
576 canvas->clear(0xFFFFFFFF);
582 for (unsigned int i = 0; i < fCount; ++i) {
583 bounds.growToInclude(fPts[i].fX, fPts[i].fY);
586 xlate_and_scale_to_bounds(canvas, bounds);
589 p.setColor(SK_ColorBLACK);
590 p.setStyle(SkPaint::kStroke_Style);
592 canvas->drawPoints(fMode, fCount, fPts, p);
598 SkDrawPosTextCommand::SkDrawPosTextCommand(const void* text, size_t byteLength,
599 const SkPoint pos[], const SkPaint& paint)
600 : INHERITED(DRAW_POS_TEXT) {
601 size_t numPts = paint.countText(text, byteLength);
603 fText = new char[byteLength];
604 memcpy(fText, text, byteLength);
605 fByteLength = byteLength;
607 fPos = new SkPoint[numPts];
608 memcpy(fPos, pos, numPts * sizeof(SkPoint));
612 fInfo.push(SkObjectParser::TextToString(text, byteLength, paint.getTextEncoding()));
613 // TODO(chudy): Test that this works.
614 fInfo.push(SkObjectParser::PointsToString(pos, 1));
615 fInfo.push(SkObjectParser::PaintToString(paint));
618 void SkDrawPosTextCommand::execute(SkCanvas* canvas) {
619 canvas->drawPosText(fText, fByteLength, fPos, fPaint);
623 SkDrawPosTextHCommand::SkDrawPosTextHCommand(const void* text, size_t byteLength,
624 const SkScalar xpos[], SkScalar constY,
625 const SkPaint& paint)
626 : INHERITED(DRAW_POS_TEXT_H) {
627 size_t numPts = paint.countText(text, byteLength);
629 fText = new char[byteLength];
630 memcpy(fText, text, byteLength);
631 fByteLength = byteLength;
633 fXpos = new SkScalar[numPts];
634 memcpy(fXpos, xpos, numPts * sizeof(SkScalar));
639 fInfo.push(SkObjectParser::TextToString(text, byteLength, paint.getTextEncoding()));
640 fInfo.push(SkObjectParser::ScalarToString(xpos[0], "XPOS: "));
641 fInfo.push(SkObjectParser::ScalarToString(constY, "SkScalar constY: "));
642 fInfo.push(SkObjectParser::PaintToString(paint));
645 void SkDrawPosTextHCommand::execute(SkCanvas* canvas) {
646 canvas->drawPosTextH(fText, fByteLength, fXpos, fConstY, fPaint);
649 SkDrawTextBlobCommand::SkDrawTextBlobCommand(const SkTextBlob* blob, SkScalar x, SkScalar y,
650 const SkPaint& paint)
651 : INHERITED(DRAW_TEXT_BLOB)
659 // FIXME: push blob info
660 fInfo.push(SkObjectParser::ScalarToString(x, "XPOS: "));
661 fInfo.push(SkObjectParser::ScalarToString(x, "YPOS: "));
662 fInfo.push(SkObjectParser::PaintToString(paint));
665 void SkDrawTextBlobCommand::execute(SkCanvas* canvas) {
666 canvas->drawTextBlob(fBlob, fXPos, fYPos, fPaint);
669 bool SkDrawTextBlobCommand::render(SkCanvas* canvas) const {
670 canvas->clear(SK_ColorWHITE);
673 SkRect bounds = fBlob->bounds().makeOffset(fXPos, fYPos);
674 xlate_and_scale_to_bounds(canvas, bounds);
676 canvas->drawTextBlob(fBlob.get(), fXPos, fYPos, fPaint);
683 SkDrawRectCommand::SkDrawRectCommand(const SkRect& rect, const SkPaint& paint)
684 : INHERITED(DRAW_RECT) {
688 fInfo.push(SkObjectParser::RectToString(rect));
689 fInfo.push(SkObjectParser::PaintToString(paint));
692 void SkDrawRectCommand::execute(SkCanvas* canvas) {
693 canvas->drawRect(fRect, fPaint);
696 SkDrawRRectCommand::SkDrawRRectCommand(const SkRRect& rrect, const SkPaint& paint)
697 : INHERITED(DRAW_RRECT) {
701 fInfo.push(SkObjectParser::RRectToString(rrect));
702 fInfo.push(SkObjectParser::PaintToString(paint));
705 void SkDrawRRectCommand::execute(SkCanvas* canvas) {
706 canvas->drawRRect(fRRect, fPaint);
709 bool SkDrawRRectCommand::render(SkCanvas* canvas) const {
710 render_rrect(canvas, fRRect);
714 SkDrawDRRectCommand::SkDrawDRRectCommand(const SkRRect& outer,
715 const SkRRect& inner,
716 const SkPaint& paint)
717 : INHERITED(DRAW_DRRECT) {
722 fInfo.push(SkObjectParser::RRectToString(outer));
723 fInfo.push(SkObjectParser::RRectToString(inner));
724 fInfo.push(SkObjectParser::PaintToString(paint));
727 void SkDrawDRRectCommand::execute(SkCanvas* canvas) {
728 canvas->drawDRRect(fOuter, fInner, fPaint);
731 bool SkDrawDRRectCommand::render(SkCanvas* canvas) const {
732 render_drrect(canvas, fOuter, fInner);
736 SkDrawSpriteCommand::SkDrawSpriteCommand(const SkBitmap& bitmap, int left, int top,
737 const SkPaint* paint)
738 : INHERITED(DRAW_SPRITE) {
749 fInfo.push(SkObjectParser::BitmapToString(bitmap));
750 fInfo.push(SkObjectParser::IntToString(left, "Left: "));
751 fInfo.push(SkObjectParser::IntToString(top, "Top: "));
753 fInfo.push(SkObjectParser::PaintToString(*paint));
757 void SkDrawSpriteCommand::execute(SkCanvas* canvas) {
758 canvas->drawSprite(fBitmap, fLeft, fTop, fPaintPtr);
761 bool SkDrawSpriteCommand::render(SkCanvas* canvas) const {
762 render_bitmap(canvas, fBitmap);
766 SkDrawTextCommand::SkDrawTextCommand(const void* text, size_t byteLength, SkScalar x, SkScalar y,
767 const SkPaint& paint)
768 : INHERITED(DRAW_TEXT) {
769 fText = new char[byteLength];
770 memcpy(fText, text, byteLength);
771 fByteLength = byteLength;
776 fInfo.push(SkObjectParser::TextToString(text, byteLength, paint.getTextEncoding()));
777 fInfo.push(SkObjectParser::ScalarToString(x, "SkScalar x: "));
778 fInfo.push(SkObjectParser::ScalarToString(y, "SkScalar y: "));
779 fInfo.push(SkObjectParser::PaintToString(paint));
782 void SkDrawTextCommand::execute(SkCanvas* canvas) {
783 canvas->drawText(fText, fByteLength, fX, fY, fPaint);
786 SkDrawTextOnPathCommand::SkDrawTextOnPathCommand(const void* text, size_t byteLength,
787 const SkPath& path, const SkMatrix* matrix,
788 const SkPaint& paint)
789 : INHERITED(DRAW_TEXT_ON_PATH) {
790 fText = new char[byteLength];
791 memcpy(fText, text, byteLength);
792 fByteLength = byteLength;
797 fMatrix.setIdentity();
801 fInfo.push(SkObjectParser::TextToString(text, byteLength, paint.getTextEncoding()));
802 fInfo.push(SkObjectParser::PathToString(path));
804 fInfo.push(SkObjectParser::MatrixToString(*matrix));
806 fInfo.push(SkObjectParser::PaintToString(paint));
809 void SkDrawTextOnPathCommand::execute(SkCanvas* canvas) {
810 canvas->drawTextOnPath(fText, fByteLength, fPath,
811 fMatrix.isIdentity() ? NULL : &fMatrix,
815 SkDrawVerticesCommand::SkDrawVerticesCommand(SkCanvas::VertexMode vmode, int vertexCount,
816 const SkPoint vertices[], const SkPoint texs[],
817 const SkColor colors[], SkXfermode* xfermode,
818 const uint16_t indices[], int indexCount,
819 const SkPaint& paint)
820 : INHERITED(DRAW_VERTICES) {
823 fVertexCount = vertexCount;
825 fVertices = new SkPoint[vertexCount];
826 memcpy(fVertices, vertices, vertexCount * sizeof(SkPoint));
829 fTexs = new SkPoint[vertexCount];
830 memcpy(fTexs, texs, vertexCount * sizeof(SkPoint));
836 fColors = new SkColor[vertexCount];
837 memcpy(fColors, colors, vertexCount * sizeof(SkColor));
842 fXfermode = xfermode;
847 if (indexCount > 0) {
848 fIndices = new uint16_t[indexCount];
849 memcpy(fIndices, indices, indexCount * sizeof(uint16_t));
854 fIndexCount = indexCount;
858 fInfo.push(SkObjectParser::CustomTextToString("To be implemented."));
859 fInfo.push(SkObjectParser::PaintToString(paint));
862 SkDrawVerticesCommand::~SkDrawVerticesCommand() {
866 SkSafeUnref(fXfermode);
870 void SkDrawVerticesCommand::execute(SkCanvas* canvas) {
871 canvas->drawVertices(fVmode, fVertexCount, fVertices,
872 fTexs, fColors, fXfermode, fIndices,
873 fIndexCount, fPaint);
876 SkRestoreCommand::SkRestoreCommand()
877 : INHERITED(RESTORE) {
878 fInfo.push(SkObjectParser::CustomTextToString("No Parameters"));
881 void SkRestoreCommand::execute(SkCanvas* canvas) {
885 void SkRestoreCommand::trackSaveState(int* state) {
889 SkRotateCommand::SkRotateCommand(SkScalar degrees)
890 : INHERITED(ROTATE) {
893 fInfo.push(SkObjectParser::ScalarToString(degrees, "SkScalar degrees: "));
896 void SkRotateCommand::execute(SkCanvas* canvas) {
897 canvas->rotate(fDegrees);
900 SkSaveCommand::SkSaveCommand()
904 void SkSaveCommand::execute(SkCanvas* canvas) {
908 void SkSaveCommand::trackSaveState(int* state) {
912 SkSaveLayerCommand::SkSaveLayerCommand(const SkRect* bounds, const SkPaint* paint,
913 SkCanvas::SaveFlags flags)
914 : INHERITED(SAVE_LAYER) {
930 fInfo.push(SkObjectParser::RectToString(*bounds, "Bounds: "));
933 fInfo.push(SkObjectParser::PaintToString(*paint));
935 fInfo.push(SkObjectParser::SaveFlagsToString(flags));
938 void SkSaveLayerCommand::execute(SkCanvas* canvas) {
939 canvas->saveLayer(fBounds.isEmpty() ? NULL : &fBounds,
944 void SkSaveLayerCommand::vizExecute(SkCanvas* canvas) {
948 void SkSaveLayerCommand::trackSaveState(int* state) {
952 SkScaleCommand::SkScaleCommand(SkScalar sx, SkScalar sy)
957 fInfo.push(SkObjectParser::ScalarToString(sx, "SkScalar sx: "));
958 fInfo.push(SkObjectParser::ScalarToString(sy, "SkScalar sy: "));
961 void SkScaleCommand::execute(SkCanvas* canvas) {
962 canvas->scale(fSx, fSy);
965 SkSetMatrixCommand::SkSetMatrixCommand(const SkMatrix& matrix)
966 : INHERITED(SET_MATRIX) {
970 fInfo.push(SkObjectParser::MatrixToString(matrix));
973 void SkSetMatrixCommand::setUserMatrix(const SkMatrix& userMatrix) {
974 fUserMatrix = userMatrix;
977 void SkSetMatrixCommand::execute(SkCanvas* canvas) {
978 SkMatrix temp = SkMatrix::Concat(fUserMatrix, fMatrix);
979 canvas->setMatrix(temp);
982 SkSkewCommand::SkSkewCommand(SkScalar sx, SkScalar sy)
987 fInfo.push(SkObjectParser::ScalarToString(sx, "SkScalar sx: "));
988 fInfo.push(SkObjectParser::ScalarToString(sy, "SkScalar sy: "));
991 void SkSkewCommand::execute(SkCanvas* canvas) {
992 canvas->skew(fSx, fSy);
995 SkTranslateCommand::SkTranslateCommand(SkScalar dx, SkScalar dy)
996 : INHERITED(TRANSLATE) {
1000 fInfo.push(SkObjectParser::ScalarToString(dx, "SkScalar dx: "));
1001 fInfo.push(SkObjectParser::ScalarToString(dy, "SkScalar dy: "));
1004 void SkTranslateCommand::execute(SkCanvas* canvas) {
1005 canvas->translate(fDx, fDy);
1008 SkPushCullCommand::SkPushCullCommand(const SkRect& cullRect)
1009 : INHERITED(PUSH_CULL)
1010 , fCullRect(cullRect) {
1011 fInfo.push(SkObjectParser::RectToString(cullRect));
1014 void SkPushCullCommand::execute(SkCanvas* canvas) {
1015 canvas->pushCull(fCullRect);
1018 void SkPushCullCommand::vizExecute(SkCanvas* canvas) {
1019 canvas->pushCull(fCullRect);
1022 p.setColor(SK_ColorCYAN);
1023 p.setStyle(SkPaint::kStroke_Style);
1024 canvas->drawRect(fCullRect, p);
1027 SkPopCullCommand::SkPopCullCommand() : INHERITED(POP_CULL) { }
1029 void SkPopCullCommand::execute(SkCanvas* canvas) {