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 // TODO(chudy): Refactor into non subclass model.
15 SkDrawCommand::SkDrawCommand(DrawType type)
20 SkDrawCommand::SkDrawCommand() {
24 SkDrawCommand::~SkDrawCommand() {
28 const char* SkDrawCommand::GetCommandString(DrawType type) {
30 case UNUSED: SkDEBUGFAIL("DrawType UNUSED\n"); break;
31 case DRAW_CLEAR: return "Clear";
32 case CLIP_PATH: return "Clip Path";
33 case CLIP_REGION: return "Clip Region";
34 case CLIP_RECT: return "Clip Rect";
35 case CLIP_RRECT: return "Clip RRect";
36 case CONCAT: return "Concat";
37 case DRAW_BITMAP: return "Draw Bitmap";
38 case DRAW_BITMAP_MATRIX: return "Draw Bitmap Matrix";
39 case DRAW_BITMAP_NINE: return "Draw Bitmap Nine";
40 case DRAW_BITMAP_RECT_TO_RECT: return "Draw Bitmap Rect";
41 case DRAW_DATA: return "Draw Data";
42 case DRAW_OVAL: return "Draw Oval";
43 case DRAW_PAINT: return "Draw Paint";
44 case DRAW_PATH: return "Draw Path";
45 case DRAW_PICTURE: return "Draw Picture";
46 case DRAW_POINTS: return "Draw Points";
47 case DRAW_POS_TEXT: return "Draw Pos Text";
48 case DRAW_POS_TEXT_H: return "Draw Pos Text H";
49 case DRAW_RECT: return "Draw Rect";
50 case DRAW_RRECT: return "Draw RRect";
51 case DRAW_SPRITE: return "Draw Sprite";
52 case DRAW_TEXT: return "Draw Text";
53 case DRAW_TEXT_ON_PATH: return "Draw Text On Path";
54 case DRAW_VERTICES: return "Draw Vertices";
55 case RESTORE: return "Restore";
56 case ROTATE: return "Rotate";
57 case SAVE: return "Save";
58 case SAVE_LAYER: return "Save Layer";
59 case SCALE: return "Scale";
60 case SET_MATRIX: return "Set Matrix";
61 case SKEW: return "Skew";
62 case TRANSLATE: return "Translate";
63 case NOOP: return "NoOp";
64 case BEGIN_COMMENT_GROUP: return "BeginCommentGroup";
65 case COMMENT: return "Comment";
66 case END_COMMENT_GROUP: return "EndCommentGroup";
68 SkDebugf("DrawType error 0x%08x\n", type);
72 SkDEBUGFAIL("DrawType UNUSED\n");
76 SkString SkDrawCommand::toString() {
77 return SkString(GetCommandString(fDrawType));
80 SkClearCommand::SkClearCommand(SkColor color) {
82 fDrawType = DRAW_CLEAR;
83 fInfo.push(SkObjectParser::CustomTextToString("No Parameters"));
86 void SkClearCommand::execute(SkCanvas* canvas) {
87 canvas->clear(fColor);
92 void xlate_and_scale_to_bounds(SkCanvas* canvas, const SkRect& bounds) {
93 const SkISize& size = canvas->getDeviceSize();
95 static const SkScalar kInsetFrac = 0.9f; // Leave a border around object
97 canvas->translate(size.fWidth/2.0f, size.fHeight/2.0f);
98 if (bounds.width() > bounds.height()) {
99 canvas->scale(SkDoubleToScalar((kInsetFrac*size.fWidth)/bounds.width()),
100 SkDoubleToScalar((kInsetFrac*size.fHeight)/bounds.width()));
102 canvas->scale(SkDoubleToScalar((kInsetFrac*size.fWidth)/bounds.height()),
103 SkDoubleToScalar((kInsetFrac*size.fHeight)/bounds.height()));
105 canvas->translate(-bounds.centerX(), -bounds.centerY());
109 void render_path(SkCanvas* canvas, const SkPath& path) {
110 canvas->clear(0xFFFFFFFF);
113 const SkRect& bounds = path.getBounds();
115 xlate_and_scale_to_bounds(canvas, bounds);
118 p.setColor(SK_ColorBLACK);
119 p.setStyle(SkPaint::kStroke_Style);
121 canvas->drawPath(path, p);
125 void render_bitmap(SkCanvas* canvas, const SkBitmap& input, const SkRect* srcRect = NULL) {
126 const SkISize& size = canvas->getDeviceSize();
128 SkScalar xScale = SkIntToScalar(size.fWidth-2) / input.width();
129 SkScalar yScale = SkIntToScalar(size.fHeight-2) / input.height();
131 if (input.width() > input.height()) {
132 yScale *= input.height() / (float) input.width();
134 xScale *= input.width() / (float) input.height();
137 SkRect dst = SkRect::MakeXYWH(SK_Scalar1, SK_Scalar1,
138 xScale * input.width(),
139 yScale * input.height());
141 canvas->clear(0xFFFFFFFF);
142 canvas->drawBitmapRect(input, NULL, dst);
144 if (NULL != srcRect) {
145 SkRect r = SkRect::MakeLTRB(srcRect->fLeft * xScale + SK_Scalar1,
146 srcRect->fTop * yScale + SK_Scalar1,
147 srcRect->fRight * xScale + SK_Scalar1,
148 srcRect->fBottom * yScale + SK_Scalar1);
150 p.setColor(SK_ColorRED);
151 p.setStyle(SkPaint::kStroke_Style);
153 canvas->drawRect(r, p);
157 void render_rrect(SkCanvas* canvas, const SkRRect& rrect) {
158 canvas->clear(0xFFFFFFFF);
161 const SkRect& bounds = rrect.getBounds();
163 xlate_and_scale_to_bounds(canvas, bounds);
166 p.setColor(SK_ColorBLACK);
167 p.setStyle(SkPaint::kStroke_Style);
169 canvas->drawRRect(rrect, p);
176 SkClipPathCommand::SkClipPathCommand(const SkPath& path, SkRegion::Op op, bool doAA) {
180 fDrawType = CLIP_PATH;
182 fInfo.push(SkObjectParser::PathToString(path));
183 fInfo.push(SkObjectParser::RegionOpToString(op));
184 fInfo.push(SkObjectParser::BoolToString(doAA));
187 void SkClipPathCommand::execute(SkCanvas* canvas) {
188 canvas->clipPath(fPath, fOp, fDoAA);
191 bool SkClipPathCommand::render(SkCanvas* canvas) const {
192 render_path(canvas, fPath);
196 SkClipRegionCommand::SkClipRegionCommand(const SkRegion& region, SkRegion::Op op) {
199 fDrawType = CLIP_REGION;
201 fInfo.push(SkObjectParser::RegionToString(region));
202 fInfo.push(SkObjectParser::RegionOpToString(op));
205 void SkClipRegionCommand::execute(SkCanvas* canvas) {
206 canvas->clipRegion(fRegion, fOp);
209 SkClipRectCommand::SkClipRectCommand(const SkRect& rect, SkRegion::Op op, bool doAA) {
213 fDrawType = CLIP_RECT;
215 fInfo.push(SkObjectParser::RectToString(rect));
216 fInfo.push(SkObjectParser::RegionOpToString(op));
217 fInfo.push(SkObjectParser::BoolToString(doAA));
220 void SkClipRectCommand::execute(SkCanvas* canvas) {
221 canvas->clipRect(fRect, fOp, fDoAA);
224 SkClipRRectCommand::SkClipRRectCommand(const SkRRect& rrect, SkRegion::Op op, bool doAA) {
228 fDrawType = CLIP_RRECT;
230 fInfo.push(SkObjectParser::RRectToString(rrect));
231 fInfo.push(SkObjectParser::RegionOpToString(op));
232 fInfo.push(SkObjectParser::BoolToString(doAA));
235 void SkClipRRectCommand::execute(SkCanvas* canvas) {
236 canvas->clipRRect(fRRect, fOp, fDoAA);
239 bool SkClipRRectCommand::render(SkCanvas* canvas) const {
240 render_rrect(canvas, fRRect);
244 SkConcatCommand::SkConcatCommand(const SkMatrix& matrix) {
248 fInfo.push(SkObjectParser::MatrixToString(matrix));
251 void SkConcatCommand::execute(SkCanvas* canvas) {
252 canvas->concat(fMatrix);
255 SkDrawBitmapCommand::SkDrawBitmapCommand(const SkBitmap& bitmap, SkScalar left, SkScalar top,
256 const SkPaint* paint) {
266 fDrawType = DRAW_BITMAP;
268 fInfo.push(SkObjectParser::BitmapToString(bitmap));
269 fInfo.push(SkObjectParser::ScalarToString(left, "SkScalar left: "));
270 fInfo.push(SkObjectParser::ScalarToString(top, "SkScalar top: "));
272 fInfo.push(SkObjectParser::PaintToString(*paint));
276 void SkDrawBitmapCommand::execute(SkCanvas* canvas) {
277 canvas->drawBitmap(fBitmap, fLeft, fTop, fPaintPtr);
280 bool SkDrawBitmapCommand::render(SkCanvas* canvas) const {
281 render_bitmap(canvas, fBitmap);
285 SkDrawBitmapMatrixCommand::SkDrawBitmapMatrixCommand(const SkBitmap& bitmap,
286 const SkMatrix& matrix,
287 const SkPaint* paint) {
296 fDrawType = DRAW_BITMAP_MATRIX;
298 fInfo.push(SkObjectParser::BitmapToString(bitmap));
299 fInfo.push(SkObjectParser::MatrixToString(matrix));
301 fInfo.push(SkObjectParser::PaintToString(*paint));
305 void SkDrawBitmapMatrixCommand::execute(SkCanvas* canvas) {
306 canvas->drawBitmapMatrix(fBitmap, fMatrix, fPaintPtr);
309 bool SkDrawBitmapMatrixCommand::render(SkCanvas* canvas) const {
310 render_bitmap(canvas, fBitmap);
314 SkDrawBitmapNineCommand::SkDrawBitmapNineCommand(const SkBitmap& bitmap, const SkIRect& center,
315 const SkRect& dst, const SkPaint* paint) {
325 fDrawType = DRAW_BITMAP_NINE;
327 fInfo.push(SkObjectParser::BitmapToString(bitmap));
328 fInfo.push(SkObjectParser::IRectToString(center));
329 fInfo.push(SkObjectParser::RectToString(dst, "Dst: "));
331 fInfo.push(SkObjectParser::PaintToString(*paint));
335 void SkDrawBitmapNineCommand::execute(SkCanvas* canvas) {
336 canvas->drawBitmapNine(fBitmap, fCenter, fDst, fPaintPtr);
339 bool SkDrawBitmapNineCommand::render(SkCanvas* canvas) const {
340 render_bitmap(canvas, fBitmap);
344 SkDrawBitmapRectCommand::SkDrawBitmapRectCommand(const SkBitmap& bitmap, const SkRect* src,
345 const SkRect& dst, const SkPaint* paint,
346 SkCanvas::DrawBitmapRectFlags flags) {
363 fDrawType = DRAW_BITMAP_RECT_TO_RECT;
365 fInfo.push(SkObjectParser::BitmapToString(bitmap));
367 fInfo.push(SkObjectParser::RectToString(*src, "Src: "));
369 fInfo.push(SkObjectParser::RectToString(dst, "Dst: "));
371 fInfo.push(SkObjectParser::PaintToString(*paint));
373 fInfo.push(SkObjectParser::IntToString(fFlags, "Flags: "));
376 void SkDrawBitmapRectCommand::execute(SkCanvas* canvas) {
377 canvas->drawBitmapRectToRect(fBitmap, this->srcRect(), fDst, fPaintPtr, fFlags);
380 bool SkDrawBitmapRectCommand::render(SkCanvas* canvas) const {
381 render_bitmap(canvas, fBitmap, this->srcRect());
385 SkDrawDataCommand::SkDrawDataCommand(const void* data, size_t length) {
386 fData = new char[length];
387 memcpy(fData, data, length);
389 fDrawType = DRAW_DATA;
391 // TODO: add display of actual data?
392 SkString* str = new SkString;
393 str->appendf("length: %d", (int) length);
397 void SkDrawDataCommand::execute(SkCanvas* canvas) {
398 canvas->drawData(fData, fLength);
401 SkBeginCommentGroupCommand::SkBeginCommentGroupCommand(const char* description)
402 : INHERITED(BEGIN_COMMENT_GROUP)
403 , fDescription(description) {
404 SkString* temp = new SkString;
405 temp->appendf("Description: %s", description);
409 SkCommentCommand::SkCommentCommand(const char* kywd, const char* value)
413 SkString* temp = new SkString;
414 temp->appendf("%s: %s", kywd, value);
418 SkEndCommentGroupCommand::SkEndCommentGroupCommand() : INHERITED(END_COMMENT_GROUP) {
421 SkDrawOvalCommand::SkDrawOvalCommand(const SkRect& oval, const SkPaint& paint) {
424 fDrawType = DRAW_OVAL;
426 fInfo.push(SkObjectParser::RectToString(oval));
427 fInfo.push(SkObjectParser::PaintToString(paint));
430 void SkDrawOvalCommand::execute(SkCanvas* canvas) {
431 canvas->drawOval(fOval, fPaint);
434 bool SkDrawOvalCommand::render(SkCanvas* canvas) const {
435 canvas->clear(0xFFFFFFFF);
438 xlate_and_scale_to_bounds(canvas, fOval);
441 p.setColor(SK_ColorBLACK);
442 p.setStyle(SkPaint::kStroke_Style);
444 canvas->drawOval(fOval, p);
450 SkDrawPaintCommand::SkDrawPaintCommand(const SkPaint& paint) {
452 fDrawType = DRAW_PAINT;
454 fInfo.push(SkObjectParser::PaintToString(paint));
457 void SkDrawPaintCommand::execute(SkCanvas* canvas) {
458 canvas->drawPaint(fPaint);
461 bool SkDrawPaintCommand::render(SkCanvas* canvas) const {
462 canvas->clear(0xFFFFFFFF);
463 canvas->drawPaint(fPaint);
467 SkDrawPathCommand::SkDrawPathCommand(const SkPath& path, const SkPaint& paint) {
470 fDrawType = DRAW_PATH;
472 fInfo.push(SkObjectParser::PathToString(path));
473 fInfo.push(SkObjectParser::PaintToString(paint));
476 void SkDrawPathCommand::execute(SkCanvas* canvas) {
477 canvas->drawPath(fPath, fPaint);
480 bool SkDrawPathCommand::render(SkCanvas* canvas) const {
481 render_path(canvas, fPath);
485 SkDrawPictureCommand::SkDrawPictureCommand(SkPicture& picture) :
487 fDrawType = DRAW_PICTURE;
488 SkString* temp = new SkString;
489 temp->appendf("SkPicture: W: %d H: %d", picture.width(), picture.height());
493 void SkDrawPictureCommand::execute(SkCanvas* canvas) {
494 canvas->drawPicture(fPicture);
497 bool SkDrawPictureCommand::render(SkCanvas* canvas) const {
498 canvas->clear(0xFFFFFFFF);
501 SkRect bounds = SkRect::MakeWH(SkIntToScalar(fPicture.width()),
502 SkIntToScalar(fPicture.height()));
503 xlate_and_scale_to_bounds(canvas, bounds);
505 canvas->drawPicture(const_cast<SkPicture&>(fPicture));
512 SkDrawPointsCommand::SkDrawPointsCommand(SkCanvas::PointMode mode, size_t count,
513 const SkPoint pts[], const SkPaint& paint) {
516 fPts = new SkPoint[count];
517 memcpy(fPts, pts, count * sizeof(SkPoint));
519 fDrawType = DRAW_POINTS;
521 fInfo.push(SkObjectParser::PointsToString(pts, count));
522 fInfo.push(SkObjectParser::ScalarToString(SkIntToScalar((unsigned int)count),
524 fInfo.push(SkObjectParser::PointModeToString(mode));
525 fInfo.push(SkObjectParser::PaintToString(paint));
528 void SkDrawPointsCommand::execute(SkCanvas* canvas) {
529 canvas->drawPoints(fMode, fCount, fPts, fPaint);
532 bool SkDrawPointsCommand::render(SkCanvas* canvas) const {
533 canvas->clear(0xFFFFFFFF);
539 for (unsigned int i = 0; i < fCount; ++i) {
540 bounds.growToInclude(fPts[i].fX, fPts[i].fY);
543 xlate_and_scale_to_bounds(canvas, bounds);
546 p.setColor(SK_ColorBLACK);
547 p.setStyle(SkPaint::kStroke_Style);
549 canvas->drawPoints(fMode, fCount, fPts, p);
555 SkDrawPosTextCommand::SkDrawPosTextCommand(const void* text, size_t byteLength,
556 const SkPoint pos[], const SkPaint& paint) {
557 size_t numPts = paint.countText(text, byteLength);
559 fText = new char[byteLength];
560 memcpy(fText, text, byteLength);
561 fByteLength = byteLength;
563 fPos = new SkPoint[numPts];
564 memcpy(fPos, pos, numPts * sizeof(SkPoint));
567 fDrawType = DRAW_POS_TEXT;
569 fInfo.push(SkObjectParser::TextToString(text, byteLength, paint.getTextEncoding()));
570 // TODO(chudy): Test that this works.
571 fInfo.push(SkObjectParser::PointsToString(pos, 1));
572 fInfo.push(SkObjectParser::PaintToString(paint));
575 void SkDrawPosTextCommand::execute(SkCanvas* canvas) {
576 canvas->drawPosText(fText, fByteLength, fPos, fPaint);
580 SkDrawPosTextHCommand::SkDrawPosTextHCommand(const void* text, size_t byteLength,
581 const SkScalar xpos[], SkScalar constY,
582 const SkPaint& paint) {
583 size_t numPts = paint.countText(text, byteLength);
585 fText = new char[byteLength];
586 memcpy(fText, text, byteLength);
587 fByteLength = byteLength;
589 fXpos = new SkScalar[numPts];
590 memcpy(fXpos, xpos, numPts * sizeof(SkScalar));
594 fDrawType = DRAW_POS_TEXT_H;
596 fInfo.push(SkObjectParser::TextToString(text, byteLength, paint.getTextEncoding()));
597 fInfo.push(SkObjectParser::ScalarToString(xpos[0], "XPOS: "));
598 fInfo.push(SkObjectParser::ScalarToString(constY, "SkScalar constY: "));
599 fInfo.push(SkObjectParser::PaintToString(paint));
602 void SkDrawPosTextHCommand::execute(SkCanvas* canvas) {
603 canvas->drawPosTextH(fText, fByteLength, fXpos, fConstY, fPaint);
606 SkDrawRectCommand::SkDrawRectCommand(const SkRect& rect, const SkPaint& paint) {
609 fDrawType = DRAW_RECT;
611 fInfo.push(SkObjectParser::RectToString(rect));
612 fInfo.push(SkObjectParser::PaintToString(paint));
615 void SkDrawRectCommand::execute(SkCanvas* canvas) {
616 canvas->drawRect(fRect, fPaint);
619 SkDrawRRectCommand::SkDrawRRectCommand(const SkRRect& rrect, const SkPaint& paint) {
622 fDrawType = DRAW_RRECT;
624 fInfo.push(SkObjectParser::RRectToString(rrect));
625 fInfo.push(SkObjectParser::PaintToString(paint));
628 void SkDrawRRectCommand::execute(SkCanvas* canvas) {
629 canvas->drawRRect(fRRect, fPaint);
632 bool SkDrawRRectCommand::render(SkCanvas* canvas) const {
633 render_rrect(canvas, fRRect);
637 SkDrawSpriteCommand::SkDrawSpriteCommand(const SkBitmap& bitmap, int left, int top,
638 const SkPaint* paint) {
648 fDrawType = DRAW_SPRITE;
650 fInfo.push(SkObjectParser::BitmapToString(bitmap));
651 fInfo.push(SkObjectParser::IntToString(left, "Left: "));
652 fInfo.push(SkObjectParser::IntToString(top, "Top: "));
654 fInfo.push(SkObjectParser::PaintToString(*paint));
658 void SkDrawSpriteCommand::execute(SkCanvas* canvas) {
659 canvas->drawSprite(fBitmap, fLeft, fTop, fPaintPtr);
662 bool SkDrawSpriteCommand::render(SkCanvas* canvas) const {
663 render_bitmap(canvas, fBitmap);
667 SkDrawTextCommand::SkDrawTextCommand(const void* text, size_t byteLength, SkScalar x, SkScalar y,
668 const SkPaint& paint) {
669 fText = new char[byteLength];
670 memcpy(fText, text, byteLength);
671 fByteLength = byteLength;
675 fDrawType = DRAW_TEXT;
677 fInfo.push(SkObjectParser::TextToString(text, byteLength, paint.getTextEncoding()));
678 fInfo.push(SkObjectParser::ScalarToString(x, "SkScalar x: "));
679 fInfo.push(SkObjectParser::ScalarToString(y, "SkScalar y: "));
680 fInfo.push(SkObjectParser::PaintToString(paint));
683 void SkDrawTextCommand::execute(SkCanvas* canvas) {
684 canvas->drawText(fText, fByteLength, fX, fY, fPaint);
687 SkDrawTextOnPathCommand::SkDrawTextOnPathCommand(const void* text, size_t byteLength,
688 const SkPath& path, const SkMatrix* matrix,
689 const SkPaint& paint) {
690 fText = new char[byteLength];
691 memcpy(fText, text, byteLength);
692 fByteLength = byteLength;
694 if (NULL != matrix) {
697 fMatrix.setIdentity();
700 fDrawType = DRAW_TEXT_ON_PATH;
702 fInfo.push(SkObjectParser::TextToString(text, byteLength, paint.getTextEncoding()));
703 fInfo.push(SkObjectParser::PathToString(path));
704 if (NULL != matrix) {
705 fInfo.push(SkObjectParser::MatrixToString(*matrix));
707 fInfo.push(SkObjectParser::PaintToString(paint));
710 void SkDrawTextOnPathCommand::execute(SkCanvas* canvas) {
711 canvas->drawTextOnPath(fText, fByteLength, fPath,
712 fMatrix.isIdentity() ? NULL : &fMatrix,
716 SkDrawVerticesCommand::SkDrawVerticesCommand(SkCanvas::VertexMode vmode, int vertexCount,
717 const SkPoint vertices[], const SkPoint texs[],
718 const SkColor colors[], SkXfermode* xfermode,
719 const uint16_t indices[], int indexCount,
720 const SkPaint& paint) {
723 fVertexCount = vertexCount;
725 fVertices = new SkPoint[vertexCount];
726 memcpy(fVertices, vertices, vertexCount * sizeof(SkPoint));
729 fTexs = new SkPoint[vertexCount];
730 memcpy(fTexs, texs, vertexCount * sizeof(SkPoint));
735 if (NULL != colors) {
736 fColors = new SkColor[vertexCount];
737 memcpy(fColors, colors, vertexCount * sizeof(SkColor));
742 fXfermode = xfermode;
743 if (NULL != fXfermode) {
747 if (indexCount > 0) {
748 fIndices = new uint16_t[indexCount];
749 memcpy(fIndices, indices, indexCount * sizeof(uint16_t));
754 fIndexCount = indexCount;
756 fDrawType = DRAW_VERTICES;
759 fInfo.push(SkObjectParser::CustomTextToString("To be implemented."));
760 fInfo.push(SkObjectParser::PaintToString(paint));
763 SkDrawVerticesCommand::~SkDrawVerticesCommand() {
767 SkSafeUnref(fXfermode);
771 void SkDrawVerticesCommand::execute(SkCanvas* canvas) {
772 canvas->drawVertices(fVmode, fVertexCount, fVertices,
773 fTexs, fColors, fXfermode, fIndices,
774 fIndexCount, fPaint);
777 SkRestoreCommand::SkRestoreCommand() {
779 fInfo.push(SkObjectParser::CustomTextToString("No Parameters"));
782 void SkRestoreCommand::execute(SkCanvas* canvas) {
786 void SkRestoreCommand::trackSaveState(int* state) {
790 SkRotateCommand::SkRotateCommand(SkScalar degrees) {
794 fInfo.push(SkObjectParser::ScalarToString(degrees, "SkScalar degrees: "));
797 void SkRotateCommand::execute(SkCanvas* canvas) {
798 canvas->rotate(fDegrees);
801 SkSaveCommand::SkSaveCommand(SkCanvas::SaveFlags flags) {
804 fInfo.push(SkObjectParser::SaveFlagsToString(flags));
807 void SkSaveCommand::execute(SkCanvas* canvas) {
808 canvas->save(fFlags);
811 void SkSaveCommand::trackSaveState(int* state) {
815 SkSaveLayerCommand::SkSaveLayerCommand(const SkRect* bounds, const SkPaint* paint,
816 SkCanvas::SaveFlags flags) {
817 if (NULL != bounds) {
830 fDrawType = SAVE_LAYER;
832 if (NULL != bounds) {
833 fInfo.push(SkObjectParser::RectToString(*bounds, "Bounds: "));
836 fInfo.push(SkObjectParser::PaintToString(*paint));
838 fInfo.push(SkObjectParser::SaveFlagsToString(flags));
841 void SkSaveLayerCommand::execute(SkCanvas* canvas) {
842 canvas->saveLayer(fBounds.isEmpty() ? NULL : &fBounds,
847 void SkSaveLayerCommand::trackSaveState(int* state) {
851 SkScaleCommand::SkScaleCommand(SkScalar sx, SkScalar sy) {
856 fInfo.push(SkObjectParser::ScalarToString(sx, "SkScalar sx: "));
857 fInfo.push(SkObjectParser::ScalarToString(sy, "SkScalar sy: "));
860 void SkScaleCommand::execute(SkCanvas* canvas) {
861 canvas->scale(fSx, fSy);
864 SkSetMatrixCommand::SkSetMatrixCommand(const SkMatrix& matrix) {
866 fDrawType = SET_MATRIX;
868 fInfo.push(SkObjectParser::MatrixToString(matrix));
871 void SkSetMatrixCommand::execute(SkCanvas* canvas) {
872 canvas->setMatrix(fMatrix);
875 SkSkewCommand::SkSkewCommand(SkScalar sx, SkScalar sy) {
880 fInfo.push(SkObjectParser::ScalarToString(sx, "SkScalar sx: "));
881 fInfo.push(SkObjectParser::ScalarToString(sy, "SkScalar sy: "));
884 void SkSkewCommand::execute(SkCanvas* canvas) {
885 canvas->skew(fSx, fSy);
888 SkTranslateCommand::SkTranslateCommand(SkScalar dx, SkScalar dy) {
891 fDrawType = TRANSLATE;
893 fInfo.push(SkObjectParser::ScalarToString(dx, "SkScalar dx: "));
894 fInfo.push(SkObjectParser::ScalarToString(dy, "SkScalar dy: "));
897 void SkTranslateCommand::execute(SkCanvas* canvas) {
898 canvas->translate(fDx, fDy);