Index: tools/json/SkJSONCanvas.cpp |
diff --git a/tools/json/SkJSONCanvas.cpp b/tools/json/SkJSONCanvas.cpp |
index f60ee27a277a105b1635fc060d1e0b9bf1706126..4bd23db4fd60ef8799a7d1f4c4d599bca150dcfe 100644 |
--- a/tools/json/SkJSONCanvas.cpp |
+++ b/tools/json/SkJSONCanvas.cpp |
@@ -8,291 +8,286 @@ |
#include "SkJSONCanvas.h" |
#include "SkPath.h" |
#include "SkRRect.h" |
-#include "stdio.h" |
-#include "stdlib.h" |
SkJSONCanvas::SkJSONCanvas(int width, int height, SkWStream& out) |
- : INHERITED(width, height) |
- , fOut(out) |
- , fFirstCommand(true) { |
- fOut.writeText("{\"" SKJSONCANVAS_VERSION "\":1, \"" SKJSONCANVAS_COMMANDS |
- "\":["); |
+ : INHERITED(width, height) |
+ , fOut(out) |
+ , fRoot(Json::objectValue) |
+ , fCommands(Json::arrayValue) { |
+ fRoot[SKJSONCANVAS_VERSION] = Json::Value(1); |
} |
void SkJSONCanvas::finish() { |
- fOut.writeText("]}"); |
+ fRoot[SKJSONCANVAS_COMMANDS] = fCommands; |
+ fOut.writeText(Json::FastWriter().write(fRoot).c_str()); |
} |
-void SkJSONCanvas::writef(const char* format, ...) { |
- va_list args; |
- va_start(args, format); |
- SkString s; |
- s.appendVAList(format, args); |
- fOut.writeText(s.c_str()); |
+Json::Value SkJSONCanvas::makePoint(const SkPoint& point) { |
+ Json::Value result(Json::arrayValue); |
+ result.append(Json::Value(point.x())); |
+ result.append(Json::Value(point.y())); |
+ return result; |
} |
-void SkJSONCanvas::open(const char* name) { |
- if (fFirstCommand) { |
- fFirstCommand = false; |
- } |
- else { |
- fOut.writeText(","); |
- } |
- this->writef("{\"" SKJSONCANVAS_COMMAND "\":\"%s\"", name); |
+Json::Value SkJSONCanvas::makePoint(SkScalar x, SkScalar y) { |
+ Json::Value result(Json::arrayValue); |
+ result.append(Json::Value(x)); |
+ result.append(Json::Value(y)); |
+ return result; |
} |
-void SkJSONCanvas::close() { |
- fOut.writeText("}"); |
+Json::Value SkJSONCanvas::makeRect(const SkRect& rect) { |
+ Json::Value result(Json::arrayValue); |
+ result.append(Json::Value(rect.left())); |
+ result.append(Json::Value(rect.top())); |
+ result.append(Json::Value(rect.right())); |
+ result.append(Json::Value(rect.bottom())); |
+ return result; |
} |
-void SkJSONCanvas::writeString(const char* name, const char* text) { |
- this->writeString(name, text, strlen(text)); |
+Json::Value SkJSONCanvas::makeRRect(const SkRRect& rrect) { |
+ Json::Value result(Json::arrayValue); |
+ result.append(this->makeRect(rrect.rect())); |
+ result.append(this->makePoint(rrect.radii(SkRRect::kUpperLeft_Corner))); |
+ result.append(this->makePoint(rrect.radii(SkRRect::kUpperRight_Corner))); |
+ result.append(this->makePoint(rrect.radii(SkRRect::kLowerLeft_Corner))); |
+ result.append(this->makePoint(rrect.radii(SkRRect::kLowerRight_Corner))); |
+ return result; |
} |
-void SkJSONCanvas::writeString(const char* name, const void* text, size_t length) { |
- // TODO: escaping |
- this->writef(",\"%s\":\"", name); |
- fOut.write(text, length); |
- fOut.writeText("\""); |
-} |
- |
-void SkJSONCanvas::writePoint(const char* name, const SkPoint& point) { |
- this->writef(",\"%s\":[%f, %f]", name, point.x(), point.y()); |
-} |
- |
-void SkJSONCanvas::writeRect(const char* name, const SkRect& rect) { |
- this->writef(",\"%s\":[%f, %f, %f, %f]", name, rect.left(), rect.top(), rect.right(), |
- rect.bottom()); |
-} |
- |
-void SkJSONCanvas::writeRRect(const char* name, const SkRRect& rrect) { |
- SkRect rect = rrect.rect(); |
- SkVector corner1 = rrect.radii(SkRRect::kUpperLeft_Corner); |
- SkVector corner2 = rrect.radii(SkRRect::kUpperRight_Corner); |
- SkVector corner3 = rrect.radii(SkRRect::kLowerLeft_Corner); |
- SkVector corner4 = rrect.radii(SkRRect::kLowerRight_Corner); |
- this->writef(",\"%s\":[[%f, %f, %f, %f],[%f, %f],[%f, %f],[%f, %f],[%f, %f]]", name, |
- rect.left(), rect.top(), rect.right(), rect.bottom(), corner1.x(), corner1.y(), |
- corner2.x(), corner2.y(), corner3.x(), corner3.y(), corner4.x(), corner4.y()); |
-} |
- |
-void SkJSONCanvas::writePath(const char* name, const SkPath& path) { |
- SkString text("["); |
+Json::Value SkJSONCanvas::makePath(const SkPath& path) { |
+ Json::Value result(Json::arrayValue); |
SkPath::Iter iter(path, false); |
SkPoint pts[4]; |
- bool first = true; |
SkPath::Verb verb; |
while ((verb = iter.next(pts)) != SkPath::kDone_Verb) { |
- if (first) { |
- first = false; |
- } |
- else { |
- text.append(","); |
- } |
switch (verb) { |
- case SkPath::kLine_Verb: |
- text.appendf("{\"" SKJSONCANVAS_VERB_LINE "\":[%f,%f]}", pts[1].x(), pts[1].y()); |
+ case SkPath::kLine_Verb: { |
+ Json::Value line(Json::objectValue); |
+ line[SKJSONCANVAS_VERB_LINE] = this->makePoint(pts[1]); |
+ result.append(line); |
break; |
- case SkPath::kQuad_Verb: |
- text.appendf("{\"" SKJSONCANVAS_VERB_QUAD "\":[[%f,%f],[%f,%f]]}", pts[1].x(), |
- pts[1].y(), pts[2].x(), pts[2].y()); |
+ } |
+ case SkPath::kQuad_Verb: { |
+ Json::Value quad(Json::objectValue); |
+ Json::Value coords(Json::arrayValue); |
+ coords.append(this->makePoint(pts[1])); |
+ coords.append(this->makePoint(pts[2])); |
+ quad[SKJSONCANVAS_VERB_QUAD] = coords; |
+ result.append(quad); |
break; |
- case SkPath::kCubic_Verb: |
- text.appendf("{\"" SKJSONCANVAS_VERB_CUBIC "\":[[%f,%f],[%f,%f],[%f,%f]]}", |
- pts[1].x(), pts[1].y(), pts[2].x(), pts[2].y(), pts[3].x(), |
- pts[3].y()); |
+ } |
+ case SkPath::kCubic_Verb: { |
+ Json::Value cubic(Json::objectValue); |
+ Json::Value coords(Json::arrayValue); |
+ coords.append(this->makePoint(pts[1])); |
+ coords.append(this->makePoint(pts[2])); |
+ coords.append(this->makePoint(pts[3])); |
+ cubic[SKJSONCANVAS_VERB_CUBIC] = coords; |
+ result.append(cubic); |
break; |
- case SkPath::kConic_Verb: |
- text.appendf("{\"" SKJSONCANVAS_VERB_CONIC "\":[[%f,%f],[%f,%f],%f]}", pts[1].x(), |
- pts[1].y(), pts[2].x(), pts[2].y(), iter.conicWeight()); |
+ } |
+ case SkPath::kConic_Verb: { |
+ Json::Value conic(Json::objectValue); |
+ Json::Value coords(Json::arrayValue); |
+ coords.append(this->makePoint(pts[1])); |
+ coords.append(this->makePoint(pts[2])); |
+ coords.append(Json::Value(iter.conicWeight())); |
+ conic[SKJSONCANVAS_VERB_CONIC] = coords; |
+ result.append(conic); |
break; |
- case SkPath::kMove_Verb: |
- text.appendf("{\"" SKJSONCANVAS_VERB_MOVE "\":[%f,%f]}", pts[0].x(), pts[0].y()); |
+ } |
+ case SkPath::kMove_Verb: { |
+ Json::Value move(Json::objectValue); |
+ move[SKJSONCANVAS_VERB_MOVE] = this->makePoint(pts[0]); |
+ result.append(move); |
break; |
+ } |
case SkPath::kClose_Verb: |
- text.appendf("\"" SKJSONCANVAS_VERB_CLOSE "\""); |
+ result.append(Json::Value(SKJSONCANVAS_VERB_CLOSE)); |
break; |
case SkPath::kDone_Verb: |
break; |
} |
} |
- text.appendf("]"); |
- this->writef(",\"" SKJSONCANVAS_ATTRIBUTE_PATH "\":%s", text.c_str()); |
+ return result; |
} |
-void SkJSONCanvas::writeRegion(const char* name, const SkRegion& region) { |
- this->writef(",\"%s\":\"<unimplemented>\"", name); |
+Json::Value SkJSONCanvas::makeRegion(const SkRegion& region) { |
+ return Json::Value("<unimplemented>"); |
} |
-void SkJSONCanvas::writePaint(const SkPaint& paint) { |
- this->writef(",\"" SKJSONCANVAS_ATTRIBUTE_PAINT "\":{"); |
- SkColor color = paint.getColor(); |
- bool first = true; |
- if (color != SK_ColorBLACK) { |
- this->writef("\"" SKJSONCANVAS_ATTRIBUTE_COLOR "\":[%d,%d,%d,%d]", SkColorGetA(color), |
- SkColorGetR(color), SkColorGetG(color), SkColorGetB(color)); |
- first = false; |
- } |
+Json::Value SkJSONCanvas::makePaint(const SkPaint& paint) { |
+ Json::Value result(Json::objectValue); |
+ SkColor color = paint.getColor(); |
+ if (color != SK_ColorBLACK) { |
+ Json::Value colorValue(Json::arrayValue); |
+ colorValue.append(Json::Value(SkColorGetA(color))); |
+ colorValue.append(Json::Value(SkColorGetR(color))); |
+ colorValue.append(Json::Value(SkColorGetG(color))); |
+ colorValue.append(Json::Value(SkColorGetB(color))); |
+ result[SKJSONCANVAS_ATTRIBUTE_COLOR] = colorValue;; |
+ } |
SkPaint::Style style = paint.getStyle(); |
if (style != SkPaint::kFill_Style) { |
- if (first) { |
- first = false; |
- } |
- else { |
- fOut.writeText(","); |
- } |
switch (style) { |
- case SkPaint::kStroke_Style: |
- fOut.writeText("\"" SKJSONCANVAS_ATTRIBUTE_STYLE "\":\"" |
- SKJSONCANVAS_STYLE_STROKE "\""); |
+ case SkPaint::kStroke_Style: { |
+ Json::Value stroke(SKJSONCANVAS_STYLE_STROKE); |
+ result[SKJSONCANVAS_ATTRIBUTE_STYLE] = stroke; |
break; |
- case SkPaint::kStrokeAndFill_Style: |
- fOut.writeText("\"" SKJSONCANVAS_ATTRIBUTE_STYLE "\":\"" |
- SKJSONCANVAS_STYLE_STROKEANDFILL "\""); |
+ } |
+ case SkPaint::kStrokeAndFill_Style: { |
+ Json::Value strokeAndFill(SKJSONCANVAS_STYLE_STROKEANDFILL); |
+ result[SKJSONCANVAS_ATTRIBUTE_STYLE] = strokeAndFill; |
break; |
+ } |
default: SkASSERT(false); |
} |
} |
SkScalar strokeWidth = paint.getStrokeWidth(); |
if (strokeWidth != 0.0f) { |
- if (first) { |
- first = false; |
- } |
- else { |
- fOut.writeText(","); |
- } |
- this->writef("\"" SKJSONCANVAS_ATTRIBUTE_STROKEWIDTH "\":%f", strokeWidth); |
+ result[SKJSONCANVAS_ATTRIBUTE_STROKEWIDTH] = Json::Value(strokeWidth); |
} |
if (paint.isAntiAlias()) { |
- if (first) { |
- first = false; |
- } |
- else { |
- fOut.writeText(","); |
- } |
- fOut.writeText("\"" SKJSONCANVAS_ATTRIBUTE_ANTIALIAS "\":true"); |
+ result[SKJSONCANVAS_ATTRIBUTE_ANTIALIAS] = Json::Value(true); |
} |
- fOut.writeText("}"); |
-} |
- |
-void SkJSONCanvas::writeMatrix(const char* name, const SkMatrix& matrix) { |
- this->writef(",\"%s\":[[%f,%f,%f],[%f,%f,%f],[%f,%f,%f]]", name, |
- matrix[0], matrix[1], matrix[2], |
- matrix[3], matrix[4], matrix[5], |
- matrix[6], matrix[7], matrix[8]); |
-} |
- |
-void SkJSONCanvas::writeRegionOp(const char* name, SkRegion::Op op) { |
- this->writef(",\"%s\":\"", name); |
- switch (op) { |
+ return result; |
+} |
+ |
+Json::Value SkJSONCanvas::makeMatrix(const SkMatrix& matrix) { |
+ Json::Value result(Json::arrayValue); |
+ Json::Value row1(Json::arrayValue); |
+ row1.append(Json::Value(matrix[0])); |
+ row1.append(Json::Value(matrix[1])); |
+ row1.append(Json::Value(matrix[2])); |
+ result.append(row1); |
+ Json::Value row2(Json::arrayValue); |
+ row2.append(Json::Value(matrix[3])); |
+ row2.append(Json::Value(matrix[4])); |
+ row2.append(Json::Value(matrix[5])); |
+ result.append(row2); |
+ Json::Value row3(Json::arrayValue); |
+ row3.append(Json::Value(matrix[6])); |
+ row3.append(Json::Value(matrix[7])); |
+ row3.append(Json::Value(matrix[8])); |
+ result.append(row3); |
+ return result; |
+} |
+ |
+Json::Value SkJSONCanvas::makeRegionOp(SkRegion::Op op) { |
+ switch (op) { |
case SkRegion::kDifference_Op: |
- fOut.writeText(SKJSONCANVAS_REGIONOP_DIFFERENCE); |
- break; |
+ return Json::Value(SKJSONCANVAS_REGIONOP_DIFFERENCE); |
case SkRegion::kIntersect_Op: |
- fOut.writeText(SKJSONCANVAS_REGIONOP_INTERSECT); |
- break; |
+ return Json::Value(SKJSONCANVAS_REGIONOP_INTERSECT); |
case SkRegion::kUnion_Op: |
- fOut.writeText(SKJSONCANVAS_REGIONOP_UNION); |
- break; |
+ return Json::Value(SKJSONCANVAS_REGIONOP_UNION); |
case SkRegion::kXOR_Op: |
- fOut.writeText(SKJSONCANVAS_REGIONOP_XOR); |
- break; |
+ return Json::Value(SKJSONCANVAS_REGIONOP_XOR); |
case SkRegion::kReverseDifference_Op: |
- fOut.writeText(SKJSONCANVAS_REGIONOP_REVERSE_DIFFERENCE); |
- break; |
+ return Json::Value(SKJSONCANVAS_REGIONOP_REVERSE_DIFFERENCE); |
case SkRegion::kReplace_Op: |
- fOut.writeText(SKJSONCANVAS_REGIONOP_REPLACE); |
- break; |
+ return Json::Value(SKJSONCANVAS_REGIONOP_REPLACE); |
default: |
SkASSERT(false); |
+ return Json::Value("<invalid region op>"); |
}; |
- fOut.writeText("\""); |
} |
-void SkJSONCanvas::writeEdgeStyle(const char* name, SkCanvas::ClipEdgeStyle edgeStyle) { |
- this->writef(",\"%s\":\"", name); |
- switch (edgeStyle) { |
- case SkCanvas::kHard_ClipEdgeStyle: fOut.writeText(SKJSONCANVAS_EDGESTYLE_HARD); break; |
- case SkCanvas::kSoft_ClipEdgeStyle: fOut.writeText(SKJSONCANVAS_EDGESTYLE_SOFT); break; |
- default: SkASSERT(false); |
+Json::Value SkJSONCanvas::makeEdgeStyle(SkCanvas::ClipEdgeStyle edgeStyle) { |
+ switch (edgeStyle) { |
+ case SkCanvas::kHard_ClipEdgeStyle: |
+ return Json::Value(SKJSONCANVAS_EDGESTYLE_HARD); |
+ case SkCanvas::kSoft_ClipEdgeStyle: |
+ return Json::Value(SKJSONCANVAS_EDGESTYLE_SOFT); |
+ default: |
+ SkASSERT(false); |
+ return Json::Value("<invalid edge style>"); |
}; |
- fOut.writeText("\""); |
} |
-void SkJSONCanvas::writePointMode(const char* name, SkCanvas::PointMode mode) { |
- this->writef(",\"%s\":\"", name); |
+Json::Value SkJSONCanvas::makePointMode(SkCanvas::PointMode mode) { |
switch (mode) { |
- case SkCanvas::kPoints_PointMode: fOut.writeText(SKJSONCANVAS_POINTMODE_POINTS); break; |
- case SkCanvas::kLines_PointMode: fOut.writeText(SKJSONCANVAS_POINTMODE_LINES); break; |
- case SkCanvas::kPolygon_PointMode: fOut.writeText(SKJSONCANVAS_POINTMODE_POLYGON); break; |
- default: SkASSERT(false); |
+ case SkCanvas::kPoints_PointMode: |
+ return Json::Value(SKJSONCANVAS_POINTMODE_POINTS); |
+ case SkCanvas::kLines_PointMode: |
+ return Json::Value(SKJSONCANVAS_POINTMODE_LINES); |
+ case SkCanvas::kPolygon_PointMode: |
+ return Json::Value(SKJSONCANVAS_POINTMODE_POLYGON); |
+ default: |
+ SkASSERT(false); |
+ return Json::Value("<invalid point mode>"); |
}; |
- fOut.writeText("\""); |
} |
void SkJSONCanvas::updateMatrix() { |
- const SkMatrix& matrix = this->getTotalMatrix(); |
- if (matrix != fLastMatrix) { |
- this->open(SKJSONCANVAS_COMMAND_MATRIX); |
- this->writeMatrix(SKJSONCANVAS_ATTRIBUTE_MATRIX, matrix); |
- fLastMatrix = matrix; |
- this->close(); |
- } |
+ const SkMatrix& matrix = this->getTotalMatrix(); |
+ if (matrix != fLastMatrix) { |
+ Json::Value command(Json::objectValue); |
+ command[SKJSONCANVAS_COMMAND] = Json::Value(SKJSONCANVAS_COMMAND_MATRIX); |
+ command[SKJSONCANVAS_ATTRIBUTE_MATRIX] = this->makeMatrix(matrix); |
+ fCommands.append(command); |
+ fLastMatrix = matrix; |
+ } |
} |
void SkJSONCanvas::onDrawPaint(const SkPaint& paint) { |
- this->open(SKJSONCANVAS_COMMAND_PAINT); |
- this->writePaint(paint); |
- this->close(); |
+ Json::Value command(Json::objectValue); |
+ command[SKJSONCANVAS_COMMAND] = Json::Value(SKJSONCANVAS_COMMAND_PAINT); |
+ command[SKJSONCANVAS_ATTRIBUTE_PAINT] = this->makePaint(paint); |
+ fCommands.append(command); |
} |
void SkJSONCanvas::onDrawRect(const SkRect& rect, const SkPaint& paint) { |
- this->updateMatrix(); |
- this->open(SKJSONCANVAS_COMMAND_RECT); |
- this->writeRect(SKJSONCANVAS_ATTRIBUTE_COORDS, rect); |
- this->writePaint(paint); |
- this->close(); |
+ this->updateMatrix(); |
+ Json::Value command(Json::objectValue); |
+ command[SKJSONCANVAS_COMMAND] = Json::Value(SKJSONCANVAS_COMMAND_RECT); |
+ command[SKJSONCANVAS_ATTRIBUTE_COORDS] = this->makeRect(rect); |
+ command[SKJSONCANVAS_ATTRIBUTE_PAINT] = this->makePaint(paint); |
+ fCommands.append(command); |
} |
void SkJSONCanvas::onDrawOval(const SkRect& rect, const SkPaint& paint) { |
- this->updateMatrix(); |
- this->open(SKJSONCANVAS_COMMAND_OVAL); |
- this->writeRect(SKJSONCANVAS_ATTRIBUTE_COORDS, rect); |
- this->writePaint(paint); |
- this->close(); |
+ this->updateMatrix(); |
+ Json::Value command(Json::objectValue); |
+ command[SKJSONCANVAS_COMMAND] = Json::Value(SKJSONCANVAS_COMMAND_OVAL); |
+ command[SKJSONCANVAS_ATTRIBUTE_COORDS] = this->makeRect(rect); |
+ command[SKJSONCANVAS_ATTRIBUTE_PAINT] = this->makePaint(paint); |
+ fCommands.append(command); |
} |
void SkJSONCanvas::onDrawRRect(const SkRRect& rrect, const SkPaint& paint) { |
- this->updateMatrix(); |
- this->open(SKJSONCANVAS_COMMAND_RRECT); |
- this->writeRRect(SKJSONCANVAS_ATTRIBUTE_COORDS, rrect); |
- this->writePaint(paint); |
- this->close();} |
+ this->updateMatrix(); |
+ Json::Value command(Json::objectValue); |
+ command[SKJSONCANVAS_COMMAND] = Json::Value(SKJSONCANVAS_COMMAND_RRECT); |
+ command[SKJSONCANVAS_ATTRIBUTE_COORDS] = this->makeRRect(rrect); |
+ command[SKJSONCANVAS_ATTRIBUTE_PAINT] = this->makePaint(paint); |
+ fCommands.append(command); |
+} |
void SkJSONCanvas::onDrawDRRect(const SkRRect& outer, const SkRRect& inner, const SkPaint& paint) { |
this->updateMatrix(); |
- this->open(SKJSONCANVAS_COMMAND_DRRECT); |
- this->writeRRect(SKJSONCANVAS_ATTRIBUTE_OUTER, outer); |
- this->writeRRect(SKJSONCANVAS_ATTRIBUTE_INNER, inner); |
- this->writePaint(paint); |
- this->close(); |
+ Json::Value command(Json::objectValue); |
+ command[SKJSONCANVAS_COMMAND] = Json::Value(SKJSONCANVAS_COMMAND_RRECT); |
+ command[SKJSONCANVAS_ATTRIBUTE_INNER] = this->makeRRect(inner); |
+ command[SKJSONCANVAS_ATTRIBUTE_OUTER] = this->makeRRect(outer); |
+ command[SKJSONCANVAS_ATTRIBUTE_PAINT] = this->makePaint(paint); |
+ fCommands.append(command); |
} |
void SkJSONCanvas::onDrawPoints(SkCanvas::PointMode mode, size_t count, const SkPoint pts[], |
- const SkPaint& paint) { |
+ const SkPaint& paint) { |
this->updateMatrix(); |
- this->open(SKJSONCANVAS_COMMAND_POINTS); |
- this->writePointMode(SKJSONCANVAS_ATTRIBUTE_MODE, mode); |
- fOut.writeText(",\"" SKJSONCANVAS_ATTRIBUTE_POINTS "\":["); |
+ Json::Value command(Json::objectValue); |
+ command[SKJSONCANVAS_COMMAND] = Json::Value(SKJSONCANVAS_COMMAND_POINTS); |
+ command[SKJSONCANVAS_ATTRIBUTE_MODE] = this->makePointMode(mode); |
+ Json::Value points(Json::arrayValue); |
for (size_t i = 0; i < count; i++) { |
- if (i != 0) { |
- fOut.writeText(","); |
- } |
- this->writef("[%f,%f]", pts[i].x(), pts[i].y()); |
+ points.append(this->makePoint(pts[i])); |
} |
- fOut.writeText("]"); |
- this->writePaint(paint); |
- this->close(); |
+ command[SKJSONCANVAS_ATTRIBUTE_POINTS] = points; |
+ command[SKJSONCANVAS_ATTRIBUTE_PAINT] = this->makePaint(paint); |
+ fCommands.append(command); |
} |
void SkJSONCanvas::onDrawVertices(SkCanvas::VertexMode, int vertexCount, const SkPoint vertices[], |
@@ -307,11 +302,13 @@ void SkJSONCanvas::onDrawAtlas(const SkImage*, const SkRSXform[], const SkRect[] |
} |
void SkJSONCanvas::onDrawPath(const SkPath& path, const SkPaint& paint) { |
- this->updateMatrix(); |
- this->open(SKJSONCANVAS_COMMAND_PATH); |
- this->writePath(SKJSONCANVAS_ATTRIBUTE_PATH, path); |
- this->writePaint(paint); |
- this->close();} |
+ this->updateMatrix(); |
+ Json::Value command(Json::objectValue); |
+ command[SKJSONCANVAS_COMMAND] = Json::Value(SKJSONCANVAS_COMMAND_PATH); |
+ command[SKJSONCANVAS_ATTRIBUTE_PATH] = this->makePath(path); |
+ command[SKJSONCANVAS_ATTRIBUTE_PAINT] = this->makePaint(paint); |
+ fCommands.append(command); |
+} |
void SkJSONCanvas::onDrawImage(const SkImage*, SkScalar dx, SkScalar dy, const SkPaint*) { |
SkDebugf("unsupported: drawImage\n"); |
@@ -344,11 +341,13 @@ void SkJSONCanvas::onDrawBitmapNine(const SkBitmap&, const SkIRect& center, cons |
void SkJSONCanvas::onDrawText(const void* text, size_t byteLength, SkScalar x, |
SkScalar y, const SkPaint& paint) { |
this->updateMatrix(); |
- this->open(SKJSONCANVAS_COMMAND_TEXT); |
- this->writeString(SKJSONCANVAS_ATTRIBUTE_TEXT, text, byteLength); |
- this->writePoint(SKJSONCANVAS_ATTRIBUTE_COORDS, { x, y }); |
- this->writePaint(paint); |
- this->close(); |
+ Json::Value command(Json::objectValue); |
+ command[SKJSONCANVAS_COMMAND] = Json::Value(SKJSONCANVAS_COMMAND_TEXT); |
+ command[SKJSONCANVAS_ATTRIBUTE_TEXT] = Json::Value((const char*) text, |
+ ((const char*) text) + byteLength); |
+ command[SKJSONCANVAS_ATTRIBUTE_COORDS] = this->makePoint(x, y); |
+ command[SKJSONCANVAS_ATTRIBUTE_PAINT] = this->makePaint(paint); |
+ fCommands.append(command); |
} |
void SkJSONCanvas::onDrawPosText(const void* text, size_t byteLength, |
@@ -384,45 +383,52 @@ void SkJSONCanvas::onDrawDrawable(SkDrawable*, const SkMatrix*) { |
} |
void SkJSONCanvas::onClipRect(const SkRect& rect, SkRegion::Op op, ClipEdgeStyle edgeStyle) { |
- this->updateMatrix(); |
- this->open(SKJSONCANVAS_COMMAND_CLIPRECT); |
- this->writeRect(SKJSONCANVAS_ATTRIBUTE_COORDS, rect); |
- this->writeRegionOp(SKJSONCANVAS_ATTRIBUTE_REGIONOP, op); |
- this->writeEdgeStyle(SKJSONCANVAS_ATTRIBUTE_EDGESTYLE, edgeStyle); |
- this->close(); |
+ this->updateMatrix(); |
+ Json::Value command(Json::objectValue); |
+ command[SKJSONCANVAS_COMMAND] = Json::Value(SKJSONCANVAS_COMMAND_CLIPRECT); |
+ command[SKJSONCANVAS_ATTRIBUTE_COORDS] = this->makeRect(rect); |
+ command[SKJSONCANVAS_ATTRIBUTE_REGIONOP] = this->makeRegionOp(op); |
+ command[SKJSONCANVAS_ATTRIBUTE_EDGESTYLE] = this->makeEdgeStyle(edgeStyle); |
+ fCommands.append(command); |
} |
void SkJSONCanvas::onClipRRect(const SkRRect& rrect, SkRegion::Op op, ClipEdgeStyle edgeStyle) { |
- this->updateMatrix(); |
- this->open(SKJSONCANVAS_COMMAND_CLIPRRECT); |
- this->writeRRect(SKJSONCANVAS_ATTRIBUTE_COORDS, rrect); |
- this->writeRegionOp(SKJSONCANVAS_ATTRIBUTE_REGIONOP, op); |
- this->writeEdgeStyle(SKJSONCANVAS_ATTRIBUTE_EDGESTYLE, edgeStyle); |
- this->close(); |
+ this->updateMatrix(); |
+ Json::Value command(Json::objectValue); |
+ command[SKJSONCANVAS_COMMAND] = Json::Value(SKJSONCANVAS_COMMAND_CLIPRRECT); |
+ command[SKJSONCANVAS_ATTRIBUTE_COORDS] = this->makeRRect(rrect); |
+ command[SKJSONCANVAS_ATTRIBUTE_REGIONOP] = this->makeRegionOp(op); |
+ command[SKJSONCANVAS_ATTRIBUTE_EDGESTYLE] = this->makeEdgeStyle(edgeStyle); |
+ fCommands.append(command); |
} |
void SkJSONCanvas::onClipPath(const SkPath& path, SkRegion::Op op, ClipEdgeStyle edgeStyle) { |
- updateMatrix(); |
- this->open(SKJSONCANVAS_COMMAND_CLIPPATH); |
- this->writePath(SKJSONCANVAS_ATTRIBUTE_PATH, path); |
- this->writeRegionOp(SKJSONCANVAS_ATTRIBUTE_REGIONOP, op); |
- this->writeEdgeStyle(SKJSONCANVAS_ATTRIBUTE_EDGESTYLE, edgeStyle); |
- this->close(); |
+ this->updateMatrix(); |
+ Json::Value command(Json::objectValue); |
+ command[SKJSONCANVAS_COMMAND] = Json::Value(SKJSONCANVAS_COMMAND_CLIPPATH); |
+ command[SKJSONCANVAS_ATTRIBUTE_PATH] = this->makePath(path); |
+ command[SKJSONCANVAS_ATTRIBUTE_REGIONOP] = this->makeRegionOp(op); |
+ command[SKJSONCANVAS_ATTRIBUTE_EDGESTYLE] = this->makeEdgeStyle(edgeStyle); |
+ fCommands.append(command); |
} |
void SkJSONCanvas::onClipRegion(const SkRegion& deviceRgn, SkRegion::Op op) { |
- this->open(SKJSONCANVAS_COMMAND_CLIPREGION); |
- this->writeRegion(SKJSONCANVAS_ATTRIBUTE_DEVICEREGION, deviceRgn); |
- this->writeRegionOp(SKJSONCANVAS_ATTRIBUTE_REGIONOP, op); |
- this->close(); |
+ this->updateMatrix(); |
+ Json::Value command(Json::objectValue); |
+ command[SKJSONCANVAS_COMMAND] = Json::Value(SKJSONCANVAS_COMMAND_CLIPREGION); |
+ command[SKJSONCANVAS_ATTRIBUTE_REGION] = this->makeRegion(deviceRgn); |
+ command[SKJSONCANVAS_ATTRIBUTE_REGIONOP] = this->makeRegionOp(op); |
+ fCommands.append(command); |
} |
void SkJSONCanvas::willSave() { |
- this->open(SKJSONCANVAS_COMMAND_SAVE); |
- this->close(); |
+ Json::Value command(Json::objectValue); |
+ command[SKJSONCANVAS_COMMAND] = Json::Value(SKJSONCANVAS_COMMAND_SAVE); |
+ fCommands.append(command); |
} |
void SkJSONCanvas::willRestore() { |
- this->open(SKJSONCANVAS_COMMAND_RESTORE); |
- this->close(); |
+ Json::Value command(Json::objectValue); |
+ command[SKJSONCANVAS_COMMAND] = Json::Value(SKJSONCANVAS_COMMAND_RESTORE); |
+ fCommands.append(command); |
} |