OLD | NEW |
1 /* | 1 /* |
2 * Copyright 2013 Google Inc. | 2 * Copyright 2013 Google Inc. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license that can be | 4 * Use of this source code is governed by a BSD-style license that can be |
5 * found in the LICENSE file. | 5 * found in the LICENSE file. |
6 */ | 6 */ |
7 | 7 |
8 #include "gm.h" | 8 #include "gm.h" |
9 #include "SkCanvas.h" | 9 #include "SkCanvas.h" |
10 #include "SkGraphics.h" | 10 #include "SkGraphics.h" |
11 #include "SkTypeface.h" | 11 #include "SkTypeface.h" |
12 | 12 |
13 // GM to stress the GPU font cache | 13 // GM to stress the GPU font cache |
14 | 14 |
15 const char* gFamilyNames[] = { | 15 const char* gFamilyNames[] = { |
16 "sans-serif", "serif", "monospace" | 16 "sans-serif", "serif" |
17 }; | 17 }; |
18 | 18 |
19 const SkTypeface::Style gStyles[] = { | 19 const SkTypeface::Style gStyles[] = { |
20 SkTypeface::kNormal, SkTypeface::kItalic | 20 SkTypeface::kNormal, SkTypeface::kItalic, SkTypeface::kBold |
21 }; | 21 }; |
22 | 22 |
23 const SkScalar gTextSizes[] = { | 23 const SkScalar gTextSizes[] = { |
24 12, 14, 16, 18, 20, 22, 24, 26, 28, 30 | 24 192, 194, 196, 198, 200, 202, 204, 206 |
25 }; | 25 }; |
26 | 26 |
27 #define TYPEFACE_COUNT (SK_ARRAY_COUNT(gFamilyNames)*SK_ARRAY_COUNT(gStyles)) | 27 #define TYPEFACE_COUNT (SK_ARRAY_COUNT(gFamilyNames)*SK_ARRAY_COUNT(gStyles)) |
28 | 28 |
29 static SkScalar draw_string(SkCanvas* canvas, const SkString& text, SkScalar x, | 29 static SkScalar draw_string(SkCanvas* canvas, const SkString& text, SkScalar x, |
30 SkScalar y, const SkPaint& paint) { | 30 SkScalar y, const SkPaint& paint) { |
31 canvas->drawText(text.c_str(), text.size(), x, y, paint); | 31 canvas->drawText(text.c_str(), text.size(), x, y, paint); |
32 return x + paint.measureText(text.c_str(), text.size()); | 32 return x + paint.measureText(text.c_str(), text.size()); |
33 } | 33 } |
34 | 34 |
(...skipping 10 matching lines...) Expand all Loading... |
45 SkSafeUnref(fTypefaces[i]); | 45 SkSafeUnref(fTypefaces[i]); |
46 } | 46 } |
47 } | 47 } |
48 | 48 |
49 protected: | 49 protected: |
50 virtual SkString onShortName() SK_OVERRIDE { | 50 virtual SkString onShortName() SK_OVERRIDE { |
51 return SkString("fontcache"); | 51 return SkString("fontcache"); |
52 } | 52 } |
53 | 53 |
54 virtual SkISize onISize() SK_OVERRIDE { | 54 virtual SkISize onISize() SK_OVERRIDE { |
55 return SkISize::Make(640, 320); | 55 return SkISize::Make(1280, 640); |
56 } | 56 } |
57 | 57 |
58 virtual void onOnceBeforeDraw() SK_OVERRIDE { | 58 virtual void onOnceBeforeDraw() SK_OVERRIDE { |
59 int typefaceCount = 0; | 59 int typefaceCount = 0; |
60 for (size_t i = 0; i < SK_ARRAY_COUNT(gFamilyNames); ++i) { | 60 for (size_t i = 0; i < SK_ARRAY_COUNT(gFamilyNames); ++i) { |
61 for (size_t j = 0; j < SK_ARRAY_COUNT(gStyles); ++j) { | 61 for (size_t j = 0; j < SK_ARRAY_COUNT(gStyles); ++j) { |
62 fTypefaces[typefaceCount++] = sk_tool_utils::create_portable_typ
eface(gFamilyNames[i], | 62 fTypefaces[typefaceCount++] = sk_tool_utils::create_portable_typ
eface(gFamilyNames[i], |
63 g
Styles[j]); | 63 g
Styles[j]); |
64 } | 64 } |
65 } | 65 } |
66 } | 66 } |
67 | 67 |
68 virtual void onDraw(SkCanvas* canvas) SK_OVERRIDE { | 68 virtual void onDraw(SkCanvas* canvas) SK_OVERRIDE { |
69 SkScalar y = 32; | 69 SkScalar y = 32; |
70 SkPaint paint; | 70 SkPaint paint; |
71 paint.setAntiAlias(true); | 71 paint.setAntiAlias(true); |
72 paint.setLCDRenderText(true); | 72 paint.setLCDRenderText(true); |
73 paint.setSubpixelText(true); | 73 paint.setSubpixelText(true); |
74 | 74 |
75 SkString text("Ham"); | 75 SkString text("H"); |
76 | 76 |
77 // draw some initial text to partially fill the GPU cache | 77 // draw enough to overflow the cache |
78 for (size_t i = 0; i < 2; ++i) { | |
79 paint.setTypeface(fTypefaces[i]); | |
80 SkScalar x = 20; | |
81 | |
82 for (size_t j = 0; j < SK_ARRAY_COUNT(gTextSizes); ++j) { | |
83 paint.setTextSize(gTextSizes[j]); | |
84 x = draw_string(canvas, text, x, y, paint) + 19; | |
85 } | |
86 y += 32; | |
87 } | |
88 | |
89 // force a flush | |
90 canvas->flush(); | |
91 | |
92 // draw again, and more to overflow the cache | |
93 for (size_t i = 0; i < TYPEFACE_COUNT; ++i) { | 78 for (size_t i = 0; i < TYPEFACE_COUNT; ++i) { |
94 paint.setTypeface(fTypefaces[i]); | 79 paint.setTypeface(fTypefaces[i]); |
95 SkScalar x = 20; | 80 SkScalar x = 20; |
96 | 81 |
97 for (size_t j = 0; j < SK_ARRAY_COUNT(gTextSizes); ++j) { | 82 for (size_t j = 0; j < SK_ARRAY_COUNT(gTextSizes); ++j) { |
98 paint.setTextSize(gTextSizes[j]); | 83 paint.setTextSize(gTextSizes[j]); |
99 x = draw_string(canvas, text, x, y, paint) + 19; | 84 x = draw_string(canvas, text, x, y, paint) + 10; |
100 } | 85 } |
101 y += 32; | 86 y += 128; |
102 } | 87 } |
103 | 88 |
104 } | 89 } |
105 | 90 |
106 virtual uint32_t onGetFlags() const SK_OVERRIDE { | 91 virtual uint32_t onGetFlags() const SK_OVERRIDE { |
107 // this GM is meant only for the GPU | 92 // this GM is meant only for the GPU |
108 return kGPUOnly_Flag; | 93 return kGPUOnly_Flag; |
109 } | 94 } |
110 | 95 |
111 private: | 96 private: |
112 SkTypeface* fTypefaces[TYPEFACE_COUNT]; | 97 SkTypeface* fTypefaces[TYPEFACE_COUNT]; |
113 typedef GM INHERITED; | 98 typedef GM INHERITED; |
114 }; | 99 }; |
115 | 100 |
116 | 101 |
117 ////////////////////////////////////////////////////////////////////////////// | 102 ////////////////////////////////////////////////////////////////////////////// |
118 | 103 |
119 DEF_GM( return SkNEW(FontCacheGM); ) | 104 DEF_GM( return SkNEW(FontCacheGM); ) |
OLD | NEW |