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 | 10 |
(...skipping 15 matching lines...) Expand all Loading... |
26 | 26 |
27 protected: | 27 protected: |
28 virtual SkString onShortName() { | 28 virtual SkString onShortName() { |
29 return SkString("strokerects"); | 29 return SkString("strokerects"); |
30 } | 30 } |
31 | 31 |
32 virtual SkISize onISize() { | 32 virtual SkISize onISize() { |
33 return make_isize(W*2, H*2); | 33 return make_isize(W*2, H*2); |
34 } | 34 } |
35 | 35 |
36 static void rnd_rect(SkRect* r, SkRandom& rand) { | 36 static void rnd_rect(SkRect* r, SkLCGRandom& rand) { |
37 SkScalar x = rand.nextUScalar1() * W; | 37 SkScalar x = rand.nextUScalar1() * W; |
38 SkScalar y = rand.nextUScalar1() * H; | 38 SkScalar y = rand.nextUScalar1() * H; |
39 SkScalar w = rand.nextUScalar1() * (W >> 2); | 39 SkScalar w = rand.nextUScalar1() * (W >> 2); |
40 SkScalar h = rand.nextUScalar1() * (H >> 2); | 40 SkScalar h = rand.nextUScalar1() * (H >> 2); |
41 SkScalar hoffset = rand.nextSScalar1(); | 41 SkScalar hoffset = rand.nextSScalar1(); |
42 SkScalar woffset = rand.nextSScalar1(); | 42 SkScalar woffset = rand.nextSScalar1(); |
43 | 43 |
44 r->set(x, y, x + w, y + h); | 44 r->set(x, y, x + w, y + h); |
45 r->offset(-w/2 + woffset, -h/2 + hoffset); | 45 r->offset(-w/2 + woffset, -h/2 + hoffset); |
46 } | 46 } |
47 | 47 |
48 virtual void onDraw(SkCanvas* canvas) { | 48 virtual void onDraw(SkCanvas* canvas) { |
49 SkPaint paint; | 49 SkPaint paint; |
50 paint.setStyle(SkPaint::kStroke_Style); | 50 paint.setStyle(SkPaint::kStroke_Style); |
51 | 51 |
52 for (int y = 0; y < 2; y++) { | 52 for (int y = 0; y < 2; y++) { |
53 paint.setAntiAlias(!!y); | 53 paint.setAntiAlias(!!y); |
54 for (int x = 0; x < 2; x++) { | 54 for (int x = 0; x < 2; x++) { |
55 paint.setStrokeWidth(x * SkIntToScalar(3)); | 55 paint.setStrokeWidth(x * SkIntToScalar(3)); |
56 | 56 |
57 SkAutoCanvasRestore acr(canvas, true); | 57 SkAutoCanvasRestore acr(canvas, true); |
58 canvas->translate(SW * x, SH * y); | 58 canvas->translate(SW * x, SH * y); |
59 canvas->clipRect(SkRect::MakeLTRB( | 59 canvas->clipRect(SkRect::MakeLTRB( |
60 SkIntToScalar(2), SkIntToScalar(2) | 60 SkIntToScalar(2), SkIntToScalar(2) |
61 , SW - SkIntToScalar(2), SH - SkIntToScalar(2) | 61 , SW - SkIntToScalar(2), SH - SkIntToScalar(2) |
62 )); | 62 )); |
63 | 63 |
64 SkRandom rand; | 64 SkLCGRandom rand; |
65 for (int i = 0; i < N; i++) { | 65 for (int i = 0; i < N; i++) { |
66 SkRect r; | 66 SkRect r; |
67 rnd_rect(&r, rand); | 67 rnd_rect(&r, rand); |
68 canvas->drawRect(r, paint); | 68 canvas->drawRect(r, paint); |
69 } | 69 } |
70 } | 70 } |
71 } | 71 } |
72 } | 72 } |
73 | 73 |
74 private: | 74 private: |
75 typedef GM INHERITED; | 75 typedef GM INHERITED; |
76 }; | 76 }; |
77 | 77 |
78 ////////////////////////////////////////////////////////////////////////////// | 78 ////////////////////////////////////////////////////////////////////////////// |
79 | 79 |
80 static GM* MyFactory(void*) { return new StrokeRectGM; } | 80 static GM* MyFactory(void*) { return new StrokeRectGM; } |
81 static GMRegistry reg(MyFactory); | 81 static GMRegistry reg(MyFactory); |
82 | 82 |
83 } | 83 } |
OLD | NEW |