OLD | NEW |
1 /* | 1 /* |
2 * Copyright 2012 The Android Open Source Project | 2 * Copyright 2012 The Android Open Source Project |
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 "SkBitmap.h" | 8 #include "SkBitmap.h" |
9 #include "SkMagnifierImageFilter.h" | 9 #include "SkMagnifierImageFilter.h" |
10 #include "SkColorPriv.h" | 10 #include "SkColorPriv.h" |
(...skipping 194 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
205 GrTexture** textures) { | 205 GrTexture** textures) { |
206 const int kMaxWidth = 200; | 206 const int kMaxWidth = 200; |
207 const int kMaxHeight = 200; | 207 const int kMaxHeight = 200; |
208 const int kMaxInset = 20; | 208 const int kMaxInset = 20; |
209 uint32_t width = random->nextULessThan(kMaxWidth); | 209 uint32_t width = random->nextULessThan(kMaxWidth); |
210 uint32_t height = random->nextULessThan(kMaxHeight); | 210 uint32_t height = random->nextULessThan(kMaxHeight); |
211 uint32_t x = random->nextULessThan(kMaxWidth - width); | 211 uint32_t x = random->nextULessThan(kMaxWidth - width); |
212 uint32_t y = random->nextULessThan(kMaxHeight - height); | 212 uint32_t y = random->nextULessThan(kMaxHeight - height); |
213 SkScalar inset = SkIntToScalar(random->nextULessThan(kMaxInset)); | 213 SkScalar inset = SkIntToScalar(random->nextULessThan(kMaxInset)); |
214 | 214 |
215 SkAutoTUnref<SkImageFilter> filter( | 215 SkAutoTUnref<SkMagnifierImageFilter> filter( |
216 new SkMagnifierImageFilter( | 216 new SkMagnifierImageFilter( |
217 SkRect::MakeXYWH(SkIntToScalar(x), SkIntToScalar(y), | 217 SkRect::MakeXYWH(SkIntToScalar(x), SkIntToScalar(y), |
218 SkIntToScalar(width), SkIntToScalar(height)), | 218 SkIntToScalar(width), SkIntToScalar(height)), |
219 inset)); | 219 inset)); |
220 GrEffectRef* effect; | 220 GrEffectRef* effect; |
221 filter->asNewEffect(&effect, textures[0]); | 221 filter->asNewEffect(&effect, textures[0]); |
222 GrAssert(NULL != effect); | 222 GrAssert(NULL != effect); |
223 return effect; | 223 return effect; |
224 } | 224 } |
225 | 225 |
(...skipping 30 matching lines...) Expand all Loading... |
256 fSrcRect = SkRect::MakeXYWH(x, y, width, height); | 256 fSrcRect = SkRect::MakeXYWH(x, y, width, height); |
257 fInset = buffer.readScalar(); | 257 fInset = buffer.readScalar(); |
258 } | 258 } |
259 | 259 |
260 // FIXME: implement single-input semantics | 260 // FIXME: implement single-input semantics |
261 SkMagnifierImageFilter::SkMagnifierImageFilter(SkRect srcRect, SkScalar inset) | 261 SkMagnifierImageFilter::SkMagnifierImageFilter(SkRect srcRect, SkScalar inset) |
262 : INHERITED(0), fSrcRect(srcRect), fInset(inset) { | 262 : INHERITED(0), fSrcRect(srcRect), fInset(inset) { |
263 SkASSERT(srcRect.x() >= 0 && srcRect.y() >= 0 && inset >= 0); | 263 SkASSERT(srcRect.x() >= 0 && srcRect.y() >= 0 && inset >= 0); |
264 } | 264 } |
265 | 265 |
| 266 #if SK_SUPPORT_GPU |
266 bool SkMagnifierImageFilter::asNewEffect(GrEffectRef** effect, GrTexture* textur
e) const { | 267 bool SkMagnifierImageFilter::asNewEffect(GrEffectRef** effect, GrTexture* textur
e) const { |
267 #if SK_SUPPORT_GPU | |
268 if (effect) { | 268 if (effect) { |
269 *effect = GrMagnifierEffect::Create(texture, | 269 *effect = GrMagnifierEffect::Create(texture, |
270 fSrcRect.x() / texture->width(), | 270 fSrcRect.x() / texture->width(), |
271 fSrcRect.y() / texture->height(), | 271 fSrcRect.y() / texture->height(), |
272 texture->width() / fSrcRect.width(), | 272 texture->width() / fSrcRect.width(), |
273 texture->height() / fSrcRect.height(), | 273 texture->height() / fSrcRect.height(
), |
274 fInset / texture->width(), | 274 fInset / texture->width(), |
275 fInset / texture->height()); | 275 fInset / texture->height()); |
276 } | 276 } |
277 return true; | 277 return true; |
278 #else | 278 } |
279 return false; | |
280 #endif | 279 #endif |
281 } | |
282 | 280 |
283 void SkMagnifierImageFilter::flatten(SkFlattenableWriteBuffer& buffer) const { | 281 void SkMagnifierImageFilter::flatten(SkFlattenableWriteBuffer& buffer) const { |
284 this->INHERITED::flatten(buffer); | 282 this->INHERITED::flatten(buffer); |
285 buffer.writeScalar(fSrcRect.x()); | 283 buffer.writeScalar(fSrcRect.x()); |
286 buffer.writeScalar(fSrcRect.y()); | 284 buffer.writeScalar(fSrcRect.y()); |
287 buffer.writeScalar(fSrcRect.width()); | 285 buffer.writeScalar(fSrcRect.width()); |
288 buffer.writeScalar(fSrcRect.height()); | 286 buffer.writeScalar(fSrcRect.height()); |
289 buffer.writeScalar(fInset); | 287 buffer.writeScalar(fInset); |
290 } | 288 } |
291 | 289 |
(...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
347 | 345 |
348 int x_val = SkMin32(SkScalarFloorToInt(x_interp), width - 1); | 346 int x_val = SkMin32(SkScalarFloorToInt(x_interp), width - 1); |
349 int y_val = SkMin32(SkScalarFloorToInt(y_interp), height - 1); | 347 int y_val = SkMin32(SkScalarFloorToInt(y_interp), height - 1); |
350 | 348 |
351 *dptr = sptr[y_val * width + x_val]; | 349 *dptr = sptr[y_val * width + x_val]; |
352 dptr++; | 350 dptr++; |
353 } | 351 } |
354 } | 352 } |
355 return true; | 353 return true; |
356 } | 354 } |
OLD | NEW |