OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright 2011 Google Inc. | 2 * Copyright 2011 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 "SkSurface.h" | 9 #include "SkSurface.h" |
10 #include "SkCanvas.h" | 10 #include "SkCanvas.h" |
(...skipping 18 matching lines...) Expand all Loading... | |
29 stream.read(mem, size); | 29 stream.read(mem, size); |
30 return SkData::NewFromMalloc(mem, size); | 30 return SkData::NewFromMalloc(mem, size); |
31 } | 31 } |
32 | 32 |
33 static void drawJpeg(SkCanvas* canvas, const SkISize& size) { | 33 static void drawJpeg(SkCanvas* canvas, const SkISize& size) { |
34 // TODO: Make this draw a file that is checked in, so it can | 34 // TODO: Make this draw a file that is checked in, so it can |
35 // be exercised on machines other than mike's. Will require a | 35 // be exercised on machines other than mike's. Will require a |
36 // rebaseline. | 36 // rebaseline. |
37 SkAutoDataUnref data(fileToData("/Users/mike/Downloads/skia.google.jpeg")); | 37 SkAutoDataUnref data(fileToData("/Users/mike/Downloads/skia.google.jpeg")); |
38 SkImage* image = SkImage::NewEncodedData(data); | 38 SkImage* image = SkImage::NewEncodedData(data); |
39 | |
39 if (image) { | 40 if (image) { |
41 SkRect* src = NULL; | |
42 SkRect dst; | |
43 src->set(0, 0, image->width(), image->height()); | |
reed1
2013/07/22 17:04:12
Yikes! We are calling set() on src when we know th
| |
44 dst.set(0, 0, size.width(), size.height()); | |
reed1
2013/07/22 17:04:12
This, and the call above, are generating warnings
| |
45 | |
40 SkAutoCanvasRestore acr(canvas, true); | 46 SkAutoCanvasRestore acr(canvas, true); |
41 canvas->scale(size.width() * 1.0f / image->width(), | 47 canvas->scale(size.width() * 1.0f / image->width(), |
42 size.height() * 1.0f / image->height()); | 48 size.height() * 1.0f / image->height()); |
43 image->draw(canvas,0, 0, NULL); | 49 image->draw(canvas, 0, 0, NULL); |
50 image->draw(canvas, src, dst, NULL); | |
44 image->unref(); | 51 image->unref(); |
45 } | 52 } |
46 } | 53 } |
47 | 54 |
48 static void drawContents(SkSurface* surface, SkColor fillC) { | 55 static void drawContents(SkSurface* surface, SkColor fillC) { |
49 SkSize size = SkSize::Make(SkIntToScalar(surface->width()), | 56 SkSize size = SkSize::Make(SkIntToScalar(surface->width()), |
50 SkIntToScalar(surface->height())); | 57 SkIntToScalar(surface->height())); |
51 SkCanvas* canvas = surface->getCanvas(); | 58 SkCanvas* canvas = surface->getCanvas(); |
52 | 59 |
53 SkScalar stroke = size.fWidth / 10; | 60 SkScalar stroke = size.fWidth / 10; |
54 SkScalar radius = (size.fWidth - stroke) / 2; | 61 SkScalar radius = (size.fWidth - stroke) / 2; |
55 | 62 |
56 SkPaint paint; | 63 SkPaint paint; |
57 | 64 |
58 paint.setAntiAlias(true); | 65 paint.setAntiAlias(true); |
59 paint.setColor(fillC); | 66 paint.setColor(fillC); |
60 canvas->drawCircle(size.fWidth/2, size.fHeight/2, radius, paint); | 67 canvas->drawCircle(size.fWidth/2, size.fHeight/2, radius, paint); |
61 | 68 |
62 paint.setStyle(SkPaint::kStroke_Style); | 69 paint.setStyle(SkPaint::kStroke_Style); |
63 paint.setStrokeWidth(stroke); | 70 paint.setStrokeWidth(stroke); |
64 paint.setColor(SK_ColorBLACK); | 71 paint.setColor(SK_ColorBLACK); |
65 canvas->drawCircle(size.fWidth/2, size.fHeight/2, radius, paint); | 72 canvas->drawCircle(size.fWidth/2, size.fHeight/2, radius, paint); |
66 } | 73 } |
67 | 74 |
68 static void test_surface(SkCanvas* canvas, SkSurface* surf) { | 75 static void test_surface(SkCanvas* canvas, SkSurface* surf, bool usePaint) { |
69 drawContents(surf, SK_ColorRED); | 76 drawContents(surf, SK_ColorRED); |
70 SkImage* imgR = surf->newImageSnapshot(); | 77 SkImage* imgR = surf->newImageSnapshot(); |
71 | 78 |
72 if (true) { | 79 if (true) { |
73 SkImage* imgR2 = surf->newImageSnapshot(); | 80 SkImage* imgR2 = surf->newImageSnapshot(); |
74 SkASSERT(imgR == imgR2); | 81 SkASSERT(imgR == imgR2); |
75 imgR2->unref(); | 82 imgR2->unref(); |
76 } | 83 } |
77 | 84 |
78 drawContents(surf, SK_ColorGREEN); | 85 drawContents(surf, SK_ColorGREEN); |
79 SkImage* imgG = surf->newImageSnapshot(); | 86 SkImage* imgG = surf->newImageSnapshot(); |
80 | 87 |
81 // since we've drawn after we snapped imgR, imgG will be a different obj | 88 // since we've drawn after we snapped imgR, imgG will be a different obj |
82 SkASSERT(imgR != imgG); | 89 SkASSERT(imgR != imgG); |
83 | 90 |
84 drawContents(surf, SK_ColorBLUE); | 91 drawContents(surf, SK_ColorBLUE); |
85 | 92 |
86 SkPaint paint; | 93 SkPaint paint; |
87 // paint.setFilterBitmap(true); | 94 // paint.setFilterBitmap(true); |
88 // paint.setAlpha(0x80); | 95 // paint.setAlpha(0x80); |
89 | 96 |
90 imgR->draw(canvas, 0, 0, &paint); | 97 imgR->draw(canvas, 0, 0, usePaint ? &paint : NULL); |
91 imgG->draw(canvas, 0, 80, &paint); | 98 imgG->draw(canvas, 0, 80, usePaint ? &paint : NULL); |
92 surf->draw(canvas, 0, 160, &paint); | 99 surf->draw(canvas, 0, 160, usePaint ? &paint : NULL); |
100 | |
101 SkRect src1, src2, src3; | |
102 src1.set(0, 0, surf->width(), surf->height()); | |
103 src2.set(-surf->width() / 2, -surf->height() / 2, | |
104 surf->width(), surf->height()); | |
105 src3.set(0, 0, surf->width() / 2, surf->height() / 2); | |
106 | |
107 SkRect dst1, dst2, dst3, dst4; | |
108 dst1.set(0, 240, 65, 305); | |
109 dst2.set(0, 320, 65, 385); | |
110 dst3.set(0, 400, 65, 465); | |
111 dst4.set(0, 480, 65, 545); | |
112 | |
113 imgR->draw(canvas, &src1, dst1, usePaint ? &paint : NULL); | |
114 imgG->draw(canvas, &src2, dst2, usePaint ? &paint : NULL); | |
115 imgR->draw(canvas, &src3, dst3, usePaint ? &paint : NULL); | |
116 imgG->draw(canvas, NULL, dst4, usePaint ? &paint : NULL); | |
93 | 117 |
94 imgG->unref(); | 118 imgG->unref(); |
95 imgR->unref(); | 119 imgR->unref(); |
96 } | 120 } |
97 | 121 |
98 class ImageGM : public skiagm::GM { | 122 class ImageGM : public skiagm::GM { |
99 void* fBuffer; | 123 void* fBuffer; |
100 size_t fBufferSize; | 124 size_t fBufferSize; |
101 SkSize fSize; | 125 SkSize fSize; |
102 enum { | 126 enum { |
(...skipping 12 matching lines...) Expand all Loading... | |
115 sk_free(fBuffer); | 139 sk_free(fBuffer); |
116 } | 140 } |
117 | 141 |
118 | 142 |
119 protected: | 143 protected: |
120 virtual SkString onShortName() { | 144 virtual SkString onShortName() { |
121 return SkString("image-surface"); | 145 return SkString("image-surface"); |
122 } | 146 } |
123 | 147 |
124 virtual SkISize onISize() { | 148 virtual SkISize onISize() { |
125 return SkISize::Make(800, 500); | 149 return SkISize::Make(960, 1200); |
126 } | 150 } |
127 | 151 |
128 virtual void onDraw(SkCanvas* canvas) { | 152 virtual void onDraw(SkCanvas* canvas) { |
129 drawJpeg(canvas, this->getISize()); | 153 drawJpeg(canvas, this->getISize()); |
130 | 154 |
131 canvas->scale(2, 2); | 155 canvas->scale(2, 2); |
132 | 156 |
133 static const char* kLabel1 = "Original Img"; | 157 static const char* kLabel1 = "Original Img"; |
134 static const char* kLabel2 = "Modified Img"; | 158 static const char* kLabel2 = "Modified Img"; |
135 static const char* kLabel3 = "Cur Surface"; | 159 static const char* kLabel3 = "Cur Surface"; |
160 static const char* kLabel4 = "Full Crop"; | |
161 static const char* kLabel5 = "Over-crop"; | |
162 static const char* kLabel6 = "Upper-left"; | |
163 static const char* kLabel7 = "No Crop"; | |
136 | 164 |
137 static const char* kLabel4 = "Pre-Alloc Img"; | 165 static const char* kLabel8 = "Pre-Alloc Img"; |
138 static const char* kLabel5 = "New Alloc Img"; | 166 static const char* kLabel9 = "New Alloc Img"; |
139 static const char* kLabel6 = "SkPicture"; | 167 static const char* kLabel10 = "SkPicture"; |
140 static const char* kLabel7 = "GPU"; | 168 static const char* kLabel11 = "Null Paint"; |
169 static const char* kLabel12 = "GPU"; | |
141 | 170 |
142 SkPaint textPaint; | 171 SkPaint textPaint; |
143 | 172 |
144 canvas->drawText(kLabel1, strlen(kLabel1), 10, 60, textPaint); | 173 canvas->drawText(kLabel1, strlen(kLabel1), 10, 60, textPaint); |
145 canvas->drawText(kLabel2, strlen(kLabel2), 10, 140, textPaint); | 174 canvas->drawText(kLabel2, strlen(kLabel2), 10, 140, textPaint); |
146 canvas->drawText(kLabel3, strlen(kLabel3), 10, 220, textPaint); | 175 canvas->drawText(kLabel3, strlen(kLabel3), 10, 220, textPaint); |
176 canvas->drawText(kLabel4, strlen(kLabel4), 10, 300, textPaint); | |
177 canvas->drawText(kLabel5, strlen(kLabel5), 10, 380, textPaint); | |
178 canvas->drawText(kLabel6, strlen(kLabel6), 10, 460, textPaint); | |
179 canvas->drawText(kLabel7, strlen(kLabel7), 10, 540, textPaint); | |
147 | 180 |
148 canvas->drawText(kLabel4, strlen(kLabel4), 80, 10, textPaint); | 181 canvas->drawText(kLabel8, strlen(kLabel8), 80, 10, textPaint); |
149 canvas->drawText(kLabel5, strlen(kLabel5), 160, 10, textPaint); | 182 canvas->drawText(kLabel9, strlen(kLabel9), 160, 10, textPaint); |
150 canvas->drawText(kLabel6, strlen(kLabel6), 250, 10, textPaint); | 183 canvas->drawText(kLabel10, strlen(kLabel10), 250, 10, textPaint); |
151 canvas->drawText(kLabel7, strlen(kLabel7), 340, 10, textPaint); | 184 canvas->drawText(kLabel11, strlen(kLabel11), 320, 10, textPaint); |
185 canvas->drawText(kLabel12, strlen(kLabel12), 410, 10, textPaint); | |
152 | 186 |
153 canvas->translate(80, 20); | 187 canvas->translate(80, 20); |
154 | 188 |
155 // since we draw into this directly, we need to start fresh | 189 // since we draw into this directly, we need to start fresh |
156 sk_bzero(fBuffer, fBufferSize); | 190 sk_bzero(fBuffer, fBufferSize); |
157 | 191 |
158 SkImage::Info info; | 192 SkImage::Info info; |
159 | 193 |
160 info.fWidth = W; | 194 info.fWidth = W; |
161 info.fHeight = H; | 195 info.fHeight = H; |
162 info.fColorType = SkImage::kPMColor_ColorType; | 196 info.fColorType = SkImage::kPMColor_ColorType; |
163 info.fAlphaType = SkImage::kPremul_AlphaType; | 197 info.fAlphaType = SkImage::kPremul_AlphaType; |
164 SkAutoTUnref<SkSurface> surf0(SkSurface::NewRasterDirect(info, fBuffer, RB)); | 198 SkAutoTUnref<SkSurface> surf0(SkSurface::NewRasterDirect(info, fBuffer, RB)); |
165 SkAutoTUnref<SkSurface> surf1(SkSurface::NewRaster(info)); | 199 SkAutoTUnref<SkSurface> surf1(SkSurface::NewRaster(info)); |
166 SkAutoTUnref<SkSurface> surf2(SkSurface::NewPicture(info.fWidth, info.fH eight)); | 200 SkAutoTUnref<SkSurface> surf2(SkSurface::NewPicture(info.fWidth, info.fH eight)); |
201 SkAutoTUnref<SkSurface> surf3(SkSurface::NewPicture(info.fWidth, info.fH eight)); | |
167 #if SK_SUPPORT_GPU | 202 #if SK_SUPPORT_GPU |
168 GrContext* ctx = skiagm::GetGr(); | 203 GrContext* ctx = skiagm::GetGr(); |
169 | 204 |
170 SkAutoTUnref<SkSurface> surf3(SkSurface::NewRenderTarget(ctx, info, 0)); | 205 SkAutoTUnref<SkSurface> surf4(SkSurface::NewRenderTarget(ctx, info, 0)); |
171 #endif | 206 #endif |
172 | 207 |
173 test_surface(canvas, surf0); | 208 test_surface(canvas, surf0, true); |
174 canvas->translate(80, 0); | 209 canvas->translate(80, 0); |
175 test_surface(canvas, surf1); | 210 test_surface(canvas, surf1, true); |
176 canvas->translate(80, 0); | 211 canvas->translate(80, 0); |
177 test_surface(canvas, surf2); | 212 test_surface(canvas, surf2, true); |
213 canvas->translate(80, 0); | |
214 test_surface(canvas, surf3, false); | |
178 #if SK_SUPPORT_GPU | 215 #if SK_SUPPORT_GPU |
179 if (NULL != ctx) { | 216 if (NULL != ctx) { |
180 canvas->translate(80, 0); | 217 canvas->translate(80, 0); |
181 test_surface(canvas, surf3); | 218 test_surface(canvas, surf4, true); |
182 } | 219 } |
183 #endif | 220 #endif |
184 } | 221 } |
185 | 222 |
186 virtual uint32_t onGetFlags() const SK_OVERRIDE { | 223 virtual uint32_t onGetFlags() const SK_OVERRIDE { |
187 return GM::kSkipPicture_Flag | GM::kSkipPipe_Flag; | 224 return GM::kSkipPicture_Flag | GM::kSkipPipe_Flag; |
188 } | 225 } |
189 | 226 |
190 private: | 227 private: |
191 typedef skiagm::GM INHERITED; | 228 typedef skiagm::GM INHERITED; |
192 }; | 229 }; |
193 | 230 |
194 ////////////////////////////////////////////////////////////////////////////// | 231 ////////////////////////////////////////////////////////////////////////////// |
195 | 232 |
196 static skiagm::GM* MyFactory(void*) { return new ImageGM; } | 233 static skiagm::GM* MyFactory(void*) { return new ImageGM; } |
197 static skiagm::GMRegistry reg(MyFactory); | 234 static skiagm::GMRegistry reg(MyFactory); |
OLD | NEW |