| OLD | NEW | 
|---|
| 1 /* | 1 /* | 
| 2  * Copyright 2015 Google Inc. | 2  * Copyright 2015 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 "SkImage.h" | 10 #include "SkImage.h" | 
| (...skipping 202 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 213     { | 213     { | 
| 214         SkAutoTUnref<SkSurface> surface(SkSurface::NewRenderTarget(ctx, SkSurfac
     e::kNo_Budgeted, | 214         SkAutoTUnref<SkSurface> surface(SkSurface::NewRenderTarget(ctx, SkSurfac
     e::kNo_Budgeted, | 
| 215                                                                    info, 0)); | 215                                                                    info, 0)); | 
| 216         surface->getCanvas()->clear(0); | 216         surface->getCanvas()->clear(0); | 
| 217         surface->getCanvas()->translate(-100, -100); | 217         surface->getCanvas()->translate(-100, -100); | 
| 218         surface->getCanvas()->drawPicture(pic); | 218         surface->getCanvas()->drawPicture(pic); | 
| 219         SkAutoTUnref<SkImage> image(surface->newImageSnapshot()); | 219         SkAutoTUnref<SkImage> image(surface->newImageSnapshot()); | 
| 220         fTexture.reset(SkRef(image->getTexture())); | 220         fTexture.reset(SkRef(image->getTexture())); | 
| 221     } | 221     } | 
| 222 protected: | 222 protected: | 
| 223     GrTexture* onGenerateTexture(GrContext* ctx, SkImageUsageType, const SkIRect
     * subset) override { | 223     GrTexture* onGenerateTexture(GrContext* ctx, const GrTextureParams& params, | 
|  | 224                                  const SkIRect* subset) override { | 
| 224         if (ctx) { | 225         if (ctx) { | 
| 225             SkASSERT(ctx == fCtx.get()); | 226             SkASSERT(ctx == fCtx.get()); | 
| 226         } | 227         } | 
| 227 | 228 | 
| 228         if (!subset) { | 229         if (!subset) { | 
| 229             return SkRef(fTexture.get()); | 230             return SkRef(fTexture.get()); | 
| 230         } | 231         } | 
| 231         // need to copy the subset into a new texture | 232         // need to copy the subset into a new texture | 
| 232         GrSurfaceDesc desc = fTexture->desc(); | 233         GrSurfaceDesc desc = fTexture->desc(); | 
| 233         desc.fWidth = subset->width(); | 234         desc.fWidth = subset->width(); | 
| (...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 303 | 304 | 
| 304     static void draw_as_bitmap(SkCanvas* canvas, SkImageCacherator* cache, SkSca
     lar x, SkScalar y) { | 305     static void draw_as_bitmap(SkCanvas* canvas, SkImageCacherator* cache, SkSca
     lar x, SkScalar y) { | 
| 305         SkBitmap bitmap; | 306         SkBitmap bitmap; | 
| 306         cache->lockAsBitmap(&bitmap, nullptr); | 307         cache->lockAsBitmap(&bitmap, nullptr); | 
| 307         canvas->drawBitmap(bitmap, x, y); | 308         canvas->drawBitmap(bitmap, x, y); | 
| 308     } | 309     } | 
| 309 | 310 | 
| 310     static void draw_as_tex(SkCanvas* canvas, SkImageCacherator* cache, SkScalar
      x, SkScalar y) { | 311     static void draw_as_tex(SkCanvas* canvas, SkImageCacherator* cache, SkScalar
      x, SkScalar y) { | 
| 311 #if SK_SUPPORT_GPU | 312 #if SK_SUPPORT_GPU | 
| 312         SkAutoTUnref<GrTexture> texture(cache->lockAsTexture(canvas->getGrContex
     t(), | 313         SkAutoTUnref<GrTexture> texture(cache->lockAsTexture(canvas->getGrContex
     t(), | 
| 313                                                              kUntiled_SkImageUsa
     geType, | 314                                                              GrTextureParams::Cl
     ampBilerp(), | 
| 314                                                              nullptr)); | 315                                                              nullptr)); | 
| 315         if (!texture) { | 316         if (!texture) { | 
| 316             // show placeholder if we have no texture | 317             // show placeholder if we have no texture | 
| 317             SkPaint paint; | 318             SkPaint paint; | 
| 318             paint.setStyle(SkPaint::kStroke_Style); | 319             paint.setStyle(SkPaint::kStroke_Style); | 
| 319             SkRect r = SkRect::MakeXYWH(x, y, SkIntToScalar(cache->info().width(
     )), | 320             SkRect r = SkRect::MakeXYWH(x, y, SkIntToScalar(cache->info().width(
     )), | 
| 320                                         SkIntToScalar(cache->info().width())); | 321                                         SkIntToScalar(cache->info().width())); | 
| 321             canvas->drawRect(r, paint); | 322             canvas->drawRect(r, paint); | 
| 322             canvas->drawLine(r.left(), r.top(), r.right(), r.bottom(), paint); | 323             canvas->drawLine(r.left(), r.top(), r.right(), r.bottom(), paint); | 
| 323             canvas->drawLine(r.left(), r.bottom(), r.right(), r.top(), paint); | 324             canvas->drawLine(r.left(), r.bottom(), r.right(), r.top(), paint); | 
| (...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 370 }; | 371 }; | 
| 371 DEF_GM( return new ImageCacheratorGM("picture", make_pic_generator); ) | 372 DEF_GM( return new ImageCacheratorGM("picture", make_pic_generator); ) | 
| 372 DEF_GM( return new ImageCacheratorGM("raster", make_ras_generator); ) | 373 DEF_GM( return new ImageCacheratorGM("raster", make_ras_generator); ) | 
| 373 DEF_GM( return new ImageCacheratorGM("ctable", make_ctable_generator); ) | 374 DEF_GM( return new ImageCacheratorGM("ctable", make_ctable_generator); ) | 
| 374 #if SK_SUPPORT_GPU | 375 #if SK_SUPPORT_GPU | 
| 375     DEF_GM( return new ImageCacheratorGM("texture", make_tex_generator); ) | 376     DEF_GM( return new ImageCacheratorGM("texture", make_tex_generator); ) | 
| 376 #endif | 377 #endif | 
| 377 | 378 | 
| 378 | 379 | 
| 379 | 380 | 
| OLD | NEW | 
|---|