1 /*
2  * Copyright 2014 Google Inc.
3  *
4  * Use of this source code is governed by a BSD-style license that can be
5  * found in the LICENSE file.
6  *
7  * Simple tool to generate SKP files for testing.
8  */
9 
10 #include "SkCanvas.h"
11 #include "SkColor.h"
12 #include "SkCommandLineFlags.h"
13 #include "SkPaint.h"
14 #include "SkPicture.h"
15 #include "SkPictureRecorder.h"
16 #include "SkScalar.h"
17 #include "SkStream.h"
18 
19 // Flags used by this file, alphabetically:
20 DEFINE_int32(blue, 128, "Value of blue color channel in image, 0-255.");
21 DEFINE_int32(border, 4, "Width of the black border around the image.");
22 DEFINE_int32(green, 128, "Value of green color channel in image, 0-255.");
23 DEFINE_int32(height, 200, "Height of canvas to create.");
24 DEFINE_int32(red, 128, "Value of red color channel in image, 0-255.");
25 DEFINE_int32(width, 300, "Width of canvas to create.");
26 DEFINE_string(writePath, "", "Filepath to write the SKP into.");
27 
28 // Create a 'width' by 'height' skp with a 'border'-wide black border around
29 // a 'color' rectangle.
make_skp(SkScalar width,SkScalar height,SkScalar border,SkColor color,const char * writePath)30 static void make_skp(SkScalar width, SkScalar height, SkScalar border, SkColor color,
31                      const char *writePath) {
32     SkPictureRecorder recorder;
33     SkCanvas* canvas = recorder.beginRecording(width, height, NULL, 0);
34     SkPaint paint;
35     paint.setStyle(SkPaint::kFill_Style);
36     paint.setColor(SK_ColorBLACK);
37     SkRect r = SkRect::MakeWH(width, height);
38     canvas->drawRect(r, paint);
39     paint.setColor(color);
40     r.inset(border, border);
41     canvas->drawRect(r, paint);
42     SkAutoTUnref<SkPicture> pict(recorder.endRecording());
43     SkFILEWStream stream(writePath);
44     pict->serialize(&stream);
45 }
46 
47 int tool_main(int argc, char** argv);
tool_main(int argc,char ** argv)48 int tool_main(int argc, char** argv) {
49     SkCommandLineFlags::SetUsage("Creates a simple .skp file for testing.");
50     SkCommandLineFlags::Parse(argc, argv);
51 
52     // Validate flags.
53     if ((FLAGS_blue < 0) || (FLAGS_blue > 255)) {
54         SkDebugf("--blue must be within range [0,255]\n");
55         exit(-1);
56     }
57     if ((FLAGS_green < 0) || (FLAGS_green > 255)) {
58         SkDebugf("--green must be within range [0,255]\n");
59         exit(-1);
60     }
61     if (FLAGS_height <= 0) {
62         SkDebugf("--height must be >0\n");
63         exit(-1);
64     }
65     if ((FLAGS_red < 0) || (FLAGS_red > 255)) {
66         SkDebugf("--red must be within range [0,255]\n");
67         exit(-1);
68     }
69     if (FLAGS_width <= 0) {
70         SkDebugf("--width must be >0\n");
71         exit(-1);
72     }
73     if (FLAGS_writePath.isEmpty()) {
74         SkDebugf("--writePath must be nonempty\n");
75         exit(-1);
76     }
77 
78     SkColor color = SkColorSetRGB(FLAGS_red, FLAGS_green, FLAGS_blue);
79     make_skp(SkIntToScalar(FLAGS_width),
80              SkIntToScalar(FLAGS_height),
81              SkIntToScalar(FLAGS_border),
82              color, FLAGS_writePath[0]);
83     return 0;
84 }
85 
86 #if !defined SK_BUILD_FOR_IOS
main(int argc,char * const argv[])87 int main(int argc, char * const argv[]) {
88     return tool_main(argc, (char**) argv);
89 }
90 #endif
91