Home | History | Annotate | Download | only in gm
      1 /*
      2  * Copyright 2017 Google Inc.
      3  *
      4  * Use of this source code is governed by a BSD-style license that can be
      5  * found in the LICENSE file.
      6  */
      7 
      8 #include "gm.h"
      9 #include "Resources.h"
     10 
     11 #include "GrContext.h"
     12 #include "SkImage.h"
     13 
     14 DEF_SIMPLE_GM(cross_context_image, canvas, 512 * 3 + 60, 512 + 128 + 30) {
     15     GrContext* context = canvas->getGrContext();
     16     if (!context) {
     17         skiagm::GM::DrawGpuOnlyMessage(canvas);
     18         return;
     19     }
     20 
     21     sk_sp<SkData> encodedData = GetResourceAsData("images/mandrill_512.png");
     22     if (!encodedData) {
     23         return;
     24     }
     25 
     26     sk_sp<SkImage> encodedImage = SkImage::MakeFromEncoded(encodedData);
     27     canvas->drawImage(encodedImage, 10, 10);
     28 
     29     sk_sp<SkImage> crossContextImage = SkImage::MakeCrossContextFromEncoded(
     30             context, encodedData, false, canvas->imageInfo().colorSpace());
     31     canvas->drawImage(crossContextImage, 512 + 30, 10);
     32 
     33     SkBitmap bmp;
     34     SkPixmap pixmap;
     35     SkAssertResult(encodedImage->asLegacyBitmap(&bmp) &&
     36                    bmp.peekPixels(&pixmap));
     37 
     38     sk_sp<SkImage> crossContextRaster = SkImage::MakeCrossContextFromPixmap(
     39             context, pixmap, false, canvas->imageInfo().colorSpace());
     40     canvas->drawImage(crossContextRaster, 512 + 512 + 60, 10);
     41 
     42     SkIRect subset = SkIRect::MakeXYWH(256 - 64, 256 - 64, 128, 128);
     43     sk_sp<SkImage> encodedSubset = encodedImage->makeSubset(subset);
     44     sk_sp<SkImage> crossContextSubset = crossContextImage->makeSubset(subset);
     45     sk_sp<SkImage> crossContextRasterSubset = crossContextRaster->makeSubset(subset);
     46 
     47     canvas->drawImage(encodedSubset, 10, 512 + 30);
     48     canvas->drawImage(crossContextSubset, 512 + 30, 512 + 30);
     49     canvas->drawImage(crossContextRasterSubset, 512 + 512 + 60, 512 + 30);
     50 }
     51