2017-11-27 15:44:06 +00:00
|
|
|
#Topic Image
|
2018-05-30 13:21:49 +00:00
|
|
|
#Alias Image_Reference ##
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Class SkImage
|
|
|
|
|
2018-10-08 18:57:48 +00:00
|
|
|
#Code
|
|
|
|
#Populate
|
|
|
|
##
|
|
|
|
|
2018-01-02 16:34:14 +00:00
|
|
|
Image describes a two dimensional array of pixels to draw. The pixels may be
|
2018-02-06 14:41:53 +00:00
|
|
|
decoded in a Raster_Bitmap, encoded in a Picture or compressed data stream,
|
2018-01-02 16:34:14 +00:00
|
|
|
or located in GPU memory as a GPU_Texture.
|
|
|
|
|
|
|
|
Image cannot be modified after it is created. Image may allocate additional
|
|
|
|
storage as needed; for instance, an encoded Image may decode when drawn.
|
|
|
|
|
|
|
|
Image width and height are greater than zero. Creating an Image with zero width
|
|
|
|
or height returns Image equal to nullptr.
|
|
|
|
|
|
|
|
Image may be created from Bitmap, Pixmap, Surface, Picture, encoded streams,
|
|
|
|
GPU_Texture, YUV_ColorSpace data, or hardware buffer. Encoded streams supported
|
2018-02-06 14:41:53 +00:00
|
|
|
include BMP, GIF, HEIF, ICO, JPEG, PNG, WBMP, WebP. Supported encoding details
|
2018-01-02 16:34:14 +00:00
|
|
|
vary with platform.
|
|
|
|
|
2018-02-01 14:37:32 +00:00
|
|
|
#Subtopic Raster_Image
|
2018-05-30 13:21:49 +00:00
|
|
|
#Alias Raster_Image ##
|
2018-02-06 14:41:53 +00:00
|
|
|
#Line # pixels decoded in Raster_Bitmap ##
|
|
|
|
Raster_Image pixels are decoded in a Raster_Bitmap. These pixels may be read
|
2018-01-02 16:34:14 +00:00
|
|
|
directly and in most cases written to, although edited pixels may not be drawn
|
|
|
|
if Image has been copied internally.
|
|
|
|
##
|
|
|
|
|
2018-02-01 14:37:32 +00:00
|
|
|
#Subtopic Texture_Image
|
|
|
|
#Line # pixels located on GPU ##
|
2018-01-02 16:34:14 +00:00
|
|
|
Texture_Image are located on GPU and pixels are not accessible. Texture_Image
|
|
|
|
are allocated optimally for best performance. Raster_Image may
|
|
|
|
be drawn to GPU_Surface, but pixels are uploaded from CPU to GPU downgrading
|
|
|
|
performance.
|
|
|
|
##
|
|
|
|
|
2018-02-01 14:37:32 +00:00
|
|
|
#Subtopic Lazy_Image
|
|
|
|
#Line # deferred pixel buffer ##
|
2018-01-02 16:34:14 +00:00
|
|
|
Lazy_Image defer allocating buffer for Image pixels and decoding stream until
|
|
|
|
Image is drawn. Lazy_Image caches result if possible to speed up repeated
|
|
|
|
drawing.
|
|
|
|
##
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method static sk_sp<SkImage> MakeRasterCopy(const SkPixmap& pixmap)
|
2018-10-08 18:57:48 +00:00
|
|
|
#In Constructors
|
2018-02-06 14:41:53 +00:00
|
|
|
#Line # creates Image from Pixmap and copied pixels ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2017-12-11 21:03:17 +00:00
|
|
|
#Height 50
|
|
|
|
#Description
|
|
|
|
Draw a five by five bitmap, and draw a copy in an Image. Editing the pixmap
|
|
|
|
alters the bitmap draw, but does not alter the Image draw since the Image
|
|
|
|
contains a copy of the pixels.
|
|
|
|
##
|
|
|
|
uint8_t storage[][5] = {{ 0xCA, 0xDA, 0xCA, 0xC9, 0xA3 },
|
|
|
|
{ 0xAC, 0xA8, 0x89, 0xA7, 0x87 },
|
|
|
|
{ 0x9B, 0xB5, 0xE5, 0x95, 0x46 },
|
|
|
|
{ 0x90, 0x81, 0xC5, 0x71, 0x33 },
|
|
|
|
{ 0x75, 0x55, 0x44, 0x40, 0x30 }};
|
|
|
|
SkImageInfo imageInfo = SkImageInfo::Make(5, 5, kGray_8_SkColorType, kOpaque_SkAlphaType);
|
|
|
|
SkPixmap pixmap(imageInfo, storage[0], sizeof(storage) / 5);
|
|
|
|
SkBitmap bitmap;
|
|
|
|
bitmap.installPixels(pixmap);
|
|
|
|
sk_sp<SkImage> image = SkImage::MakeRasterCopy(pixmap);
|
|
|
|
*pixmap.writable_addr8(2, 2) = 0x00;
|
|
|
|
canvas->scale(10, 10);
|
|
|
|
canvas->drawBitmap(bitmap, 0, 0);
|
|
|
|
canvas->drawImage(image, 10, 0);
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2017-12-01 16:49:58 +00:00
|
|
|
#SeeAlso MakeRasterData MakeFromGenerator
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
2018-05-15 20:06:12 +00:00
|
|
|
#Method static sk_sp<SkImage> MakeRasterData(const SkImageInfo& info, sk_sp<SkData> pixels, size_t rowBytes)
|
2018-10-08 18:57:48 +00:00
|
|
|
#In Constructors
|
2018-02-06 14:41:53 +00:00
|
|
|
#Line # creates Image from Image_Info and shared pixels ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2017-12-15 16:21:51 +00:00
|
|
|
#Image 3
|
|
|
|
size_t rowBytes = image->width() * SkColorTypeBytesPerPixel(kRGBA_8888_SkColorType);
|
|
|
|
sk_sp<SkData> data = SkData::MakeUninitialized(rowBytes * image->height());
|
2018-05-16 11:07:07 +00:00
|
|
|
SkImageInfo dstInfo = SkImageInfo::MakeN32(image->width(), image->height(),
|
2017-12-15 16:21:51 +00:00
|
|
|
kPremul_SkAlphaType);
|
|
|
|
image->readPixels(dstInfo, data->writable_data(), rowBytes, 0, 0, SkImage::kAllow_CachingHint);
|
|
|
|
sk_sp<SkImage> raw = SkImage::MakeRasterData(dstInfo.makeColorType(kRGBA_8888_SkColorType),
|
|
|
|
data, rowBytes);
|
|
|
|
canvas->drawImage(image, 0, 0);
|
|
|
|
canvas->drawImage(raw.get(), 128, 0);
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2017-12-01 16:49:58 +00:00
|
|
|
#SeeAlso MakeRasterCopy MakeFromGenerator
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
2017-12-01 16:49:58 +00:00
|
|
|
#Typedef void* ReleaseContext
|
2018-05-16 11:07:07 +00:00
|
|
|
#Line # parameter type for MakeFromRaster ##
|
2018-05-17 16:17:28 +00:00
|
|
|
|
|
|
|
#Code
|
2018-10-16 14:30:28 +00:00
|
|
|
#Populate
|
2018-05-17 16:17:28 +00:00
|
|
|
##
|
|
|
|
|
2017-12-01 16:49:58 +00:00
|
|
|
Caller data passed to RasterReleaseProc; may be nullptr.
|
|
|
|
|
|
|
|
#SeeAlso MakeFromRaster RasterReleaseProc
|
|
|
|
|
|
|
|
##
|
|
|
|
|
2017-11-27 15:44:06 +00:00
|
|
|
#Typedef void (*RasterReleaseProc)(const void* pixels, ReleaseContext)
|
2018-05-16 11:07:07 +00:00
|
|
|
#Line # parameter type for MakeFromRaster ##
|
2018-05-17 16:17:28 +00:00
|
|
|
|
|
|
|
#Code
|
2018-10-16 14:30:28 +00:00
|
|
|
#Populate
|
2018-05-17 16:17:28 +00:00
|
|
|
##
|
|
|
|
|
2017-12-01 16:49:58 +00:00
|
|
|
Function called when Image no longer shares pixels. ReleaseContext is
|
2018-05-16 11:07:07 +00:00
|
|
|
provided by caller when Image is created, and may be nullptr.
|
2017-12-01 16:49:58 +00:00
|
|
|
|
|
|
|
#SeeAlso ReleaseContext MakeFromRaster
|
|
|
|
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
|
|
|
#Method static sk_sp<SkImage> MakeFromRaster(const SkPixmap& pixmap,
|
|
|
|
RasterReleaseProc rasterReleaseProc,
|
|
|
|
ReleaseContext releaseContext)
|
2018-10-08 18:57:48 +00:00
|
|
|
#In Constructors
|
2018-02-06 14:41:53 +00:00
|
|
|
#Line # creates Image from Pixmap, with release ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2017-12-15 16:21:51 +00:00
|
|
|
#Function
|
|
|
|
static void releaseProc(const void* pixels, SkImage::ReleaseContext context) {
|
|
|
|
int* countPtr = static_cast<int*>(context);
|
|
|
|
*countPtr += 1;
|
|
|
|
}
|
|
|
|
##
|
|
|
|
|
|
|
|
void draw(SkCanvas* canvas) {
|
|
|
|
SkColor color = 0;
|
|
|
|
SkPixmap pixmap(SkImageInfo::MakeN32(1, 1, kPremul_SkAlphaType), &color, 4);
|
|
|
|
int releaseCount = 0;
|
|
|
|
sk_sp<SkImage> image(SkImage::MakeFromRaster(pixmap, releaseProc, &releaseCount));
|
|
|
|
SkDebugf("before reset: %d\n", releaseCount);
|
|
|
|
image.reset();
|
|
|
|
SkDebugf("after reset: %d\n", releaseCount);
|
|
|
|
}
|
|
|
|
#StdOut
|
|
|
|
before reset: 0
|
|
|
|
after reset: 1
|
|
|
|
##
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2017-12-01 16:49:58 +00:00
|
|
|
#SeeAlso MakeRasterCopy MakeRasterData MakeFromGenerator RasterReleaseProc ReleaseContext
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method static sk_sp<SkImage> MakeFromBitmap(const SkBitmap& bitmap)
|
2018-10-08 18:57:48 +00:00
|
|
|
#In Constructors
|
2018-02-06 14:41:53 +00:00
|
|
|
#Line # creates Image from Bitmap, sharing or copying pixels ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2017-12-15 16:21:51 +00:00
|
|
|
#Description
|
|
|
|
The first Bitmap is shared; writing to the pixel memory changes the first
|
|
|
|
Image.
|
|
|
|
The second Bitmap is marked immutable, and is copied; writing to the pixel
|
|
|
|
memory does not alter the second Image.
|
|
|
|
##
|
|
|
|
#Height 50
|
|
|
|
uint8_t storage[][5] = {{ 0xCA, 0xDA, 0xCA, 0xC9, 0xA3 },
|
|
|
|
{ 0xAC, 0xA8, 0x89, 0xA7, 0x87 },
|
|
|
|
{ 0x9B, 0xB5, 0xE5, 0x95, 0x46 },
|
|
|
|
{ 0x90, 0x81, 0xC5, 0x71, 0x33 },
|
|
|
|
{ 0x75, 0x55, 0x44, 0x40, 0x30 }};
|
|
|
|
SkImageInfo imageInfo = SkImageInfo::Make(5, 5, kGray_8_SkColorType, kOpaque_SkAlphaType);
|
|
|
|
SkPixmap pixmap(imageInfo, storage[0], sizeof(storage) / 5);
|
|
|
|
SkBitmap bitmap;
|
|
|
|
bitmap.installPixels(pixmap);
|
|
|
|
sk_sp<SkImage> image1 = SkImage::MakeFromBitmap(bitmap);
|
|
|
|
bitmap.setImmutable();
|
|
|
|
sk_sp<SkImage> image2 = SkImage::MakeFromBitmap(bitmap);
|
|
|
|
*pixmap.writable_addr8(2, 2) = 0x00;
|
|
|
|
canvas->scale(10, 10);
|
|
|
|
canvas->drawImage(image1, 0, 0);
|
|
|
|
canvas->drawImage(image2, 10, 0);
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2017-12-01 16:49:58 +00:00
|
|
|
#SeeAlso MakeFromRaster MakeRasterCopy MakeFromGenerator MakeRasterData
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method static sk_sp<SkImage> MakeFromGenerator(std::unique_ptr<SkImageGenerator> imageGenerator,
|
|
|
|
const SkIRect* subset = nullptr)
|
2018-10-08 18:57:48 +00:00
|
|
|
#In Constructors
|
2018-02-06 14:41:53 +00:00
|
|
|
#Line # creates Image from a stream of data ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2018-01-11 15:35:44 +00:00
|
|
|
#Height 128
|
2017-12-15 16:21:51 +00:00
|
|
|
#Description
|
|
|
|
The generator returning Picture cannot be shared; std::move transfers ownership to generated Image.
|
|
|
|
##
|
|
|
|
SkPictureRecorder recorder;
|
|
|
|
recorder.beginRecording(100, 100)->drawColor(SK_ColorRED);
|
|
|
|
auto picture = recorder.finishRecordingAsPicture();
|
|
|
|
auto gen = SkImageGenerator::MakeFromPicture({100, 100}, picture, nullptr, nullptr,
|
|
|
|
SkImage::BitDepth::kU8, SkColorSpace::MakeSRGB());
|
|
|
|
sk_sp<SkImage> image = SkImage::MakeFromGenerator(std::move(gen));
|
|
|
|
canvas->drawImage(image, 0, 0);
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2017-12-01 16:49:58 +00:00
|
|
|
#SeeAlso MakeFromEncoded
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method static sk_sp<SkImage> MakeFromEncoded(sk_sp<SkData> encoded, const SkIRect* subset = nullptr)
|
2018-10-08 18:57:48 +00:00
|
|
|
#In Constructors
|
2018-02-06 14:41:53 +00:00
|
|
|
#Line # creates Image from encoded data ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
2018-01-02 16:34:14 +00:00
|
|
|
#Example
|
|
|
|
#Image 3
|
|
|
|
int x = 0;
|
|
|
|
for (int quality : { 100, 50, 10, 1} ) {
|
|
|
|
sk_sp<SkData> encodedData = image->encodeToData(SkEncodedImageFormat::kJPEG, quality);
|
|
|
|
sk_sp<SkImage> image = SkImage::MakeFromEncoded(encodedData);
|
|
|
|
canvas->drawImage(image, x, 0);
|
|
|
|
x += 64;
|
|
|
|
}
|
2017-12-15 16:21:51 +00:00
|
|
|
##
|
|
|
|
|
2018-01-02 16:34:14 +00:00
|
|
|
#SeeAlso MakeFromGenerator
|
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Typedef void (*TextureReleaseProc)(ReleaseContext releaseContext)
|
2018-05-16 11:07:07 +00:00
|
|
|
#Line # parameter type for MakeFromTexture ##
|
2018-05-17 16:17:28 +00:00
|
|
|
|
|
|
|
#Code
|
2018-10-16 14:30:28 +00:00
|
|
|
#Populate
|
2018-05-17 16:17:28 +00:00
|
|
|
##
|
|
|
|
|
2018-05-16 11:07:07 +00:00
|
|
|
User function called when supplied texture may be deleted.
|
|
|
|
#SeeAlso MakeFromTexture
|
2018-01-02 16:34:14 +00:00
|
|
|
##
|
|
|
|
|
2017-11-27 15:44:06 +00:00
|
|
|
#Method static sk_sp<SkImage> MakeFromTexture(GrContext* context,
|
|
|
|
const GrBackendTexture& backendTexture,
|
|
|
|
GrSurfaceOrigin origin,
|
2018-01-02 16:34:14 +00:00
|
|
|
SkColorType colorType,
|
2017-11-27 15:44:06 +00:00
|
|
|
SkAlphaType alphaType,
|
|
|
|
sk_sp<SkColorSpace> colorSpace)
|
2018-10-08 18:57:48 +00:00
|
|
|
#In Constructors
|
2018-02-27 14:54:21 +00:00
|
|
|
#Line # creates Image from GPU_Texture ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2017-12-15 16:21:51 +00:00
|
|
|
#Image 3
|
|
|
|
#Platform gpu
|
|
|
|
#Height 128
|
|
|
|
#Description
|
|
|
|
A back-end texture has been created and uploaded to the GPU outside of this example.
|
|
|
|
##
|
|
|
|
GrContext* context = canvas->getGrContext();
|
|
|
|
if (!context) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
canvas->scale(.25f, .25f);
|
|
|
|
int x = 0;
|
|
|
|
for (auto origin : { kBottomLeft_GrSurfaceOrigin, kTopLeft_GrSurfaceOrigin } ) {
|
2018-01-11 15:35:44 +00:00
|
|
|
sk_sp<SkImage> image = SkImage::MakeFromTexture(context, backEndTexture,
|
2018-06-07 21:07:17 +00:00
|
|
|
origin, kRGBA_8888_SkColorType, kOpaque_SkAlphaType, nullptr);
|
2017-12-15 16:21:51 +00:00
|
|
|
canvas->drawImage(image, x, 0);
|
|
|
|
x += 512;
|
|
|
|
}
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2017-12-01 16:49:58 +00:00
|
|
|
#SeeAlso MakeFromAdoptedTexture SkSurface::MakeFromBackendTexture
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method static sk_sp<SkImage> MakeFromTexture(GrContext* context,
|
|
|
|
const GrBackendTexture& backendTexture,
|
|
|
|
GrSurfaceOrigin origin,
|
2018-01-02 16:34:14 +00:00
|
|
|
SkColorType colorType,
|
2017-11-27 15:44:06 +00:00
|
|
|
SkAlphaType alphaType,
|
|
|
|
sk_sp<SkColorSpace> colorSpace,
|
|
|
|
TextureReleaseProc textureReleaseProc,
|
|
|
|
ReleaseContext releaseContext)
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-12-15 16:21:51 +00:00
|
|
|
|
2017-11-27 15:44:06 +00:00
|
|
|
#Example
|
2018-12-13 14:10:49 +00:00
|
|
|
#Description
|
|
|
|
textureReleaseProc may be called at some later point in time. In this example,
|
|
|
|
textureReleaseProc has no effect on the drawing.
|
|
|
|
##
|
2018-01-11 15:35:44 +00:00
|
|
|
#Platform gpu
|
|
|
|
#Image 4
|
2017-12-15 16:21:51 +00:00
|
|
|
GrContext* context = canvas->getGrContext();
|
|
|
|
if (!context) {
|
|
|
|
return;
|
|
|
|
}
|
2018-01-11 15:35:44 +00:00
|
|
|
auto debugster = [](SkImage::ReleaseContext releaseContext) -> void {
|
2018-12-13 14:10:49 +00:00
|
|
|
*((int *) releaseContext) += 128;
|
2017-12-15 16:21:51 +00:00
|
|
|
};
|
2018-12-13 14:10:49 +00:00
|
|
|
int x = 0, y = 0;
|
2017-12-15 16:21:51 +00:00
|
|
|
for (auto origin : { kBottomLeft_GrSurfaceOrigin, kTopLeft_GrSurfaceOrigin } ) {
|
2018-01-11 15:35:44 +00:00
|
|
|
sk_sp<SkImage> image = SkImage::MakeFromTexture(context, backEndTexture,
|
2018-01-02 16:34:14 +00:00
|
|
|
origin, kRGBA_8888_SkColorType, kOpaque_SkAlphaType, nullptr, debugster, &x);
|
2018-12-13 14:10:49 +00:00
|
|
|
canvas->drawImage(image, x, y);
|
|
|
|
y += 128;
|
2017-12-15 16:21:51 +00:00
|
|
|
}
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2017-12-01 16:49:58 +00:00
|
|
|
#SeeAlso MakeFromAdoptedTexture SkSurface::MakeFromBackendTexture
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method static sk_sp<SkImage> MakeCrossContextFromEncoded(GrContext* context, sk_sp<SkData> data,
|
|
|
|
bool buildMips,
|
2018-04-13 19:48:26 +00:00
|
|
|
SkColorSpace* dstColorSpace,
|
|
|
|
bool limitToMaxTextureSize = false)
|
2018-10-08 18:57:48 +00:00
|
|
|
#In Constructors
|
2018-02-06 14:41:53 +00:00
|
|
|
#Line # creates Image from encoded data, and uploads to GPU ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2018-01-02 16:34:14 +00:00
|
|
|
#Image 4
|
2018-01-11 15:35:44 +00:00
|
|
|
#Height 64
|
2018-01-02 16:34:14 +00:00
|
|
|
GrContext* context = canvas->getGrContext();
|
|
|
|
sk_sp<SkData> encodedData = image->encodeToData(SkEncodedImageFormat::kJPEG, 100);
|
|
|
|
sk_sp<SkImage> image = SkImage::MakeCrossContextFromEncoded(context,
|
|
|
|
encodedData, false, nullptr);
|
|
|
|
canvas->drawImage(image, 0, 0);
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2017-12-01 16:49:58 +00:00
|
|
|
#SeeAlso MakeCrossContextFromPixmap
|
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method static sk_sp<SkImage> MakeCrossContextFromPixmap(GrContext* context, const SkPixmap& pixmap,
|
|
|
|
bool buildMips,
|
2018-04-13 19:48:26 +00:00
|
|
|
SkColorSpace* dstColorSpace,
|
|
|
|
bool limitToMaxTextureSize = false)
|
2018-10-08 18:57:48 +00:00
|
|
|
#In Constructors
|
2018-02-06 14:41:53 +00:00
|
|
|
#Line # creates Image from Pixmap, and uploads to GPU ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-12-01 16:49:58 +00:00
|
|
|
|
|
|
|
#Example
|
2018-01-02 16:34:14 +00:00
|
|
|
#Image 4
|
2018-01-11 15:35:44 +00:00
|
|
|
#Height 64
|
2018-01-02 16:34:14 +00:00
|
|
|
GrContext* context = canvas->getGrContext();
|
|
|
|
SkPixmap pixmap;
|
|
|
|
if (source.peekPixels(&pixmap)) {
|
|
|
|
sk_sp<SkImage> image = SkImage::MakeCrossContextFromPixmap(context, pixmap,
|
|
|
|
false, nullptr);
|
|
|
|
canvas->drawImage(image, 0, 0);
|
|
|
|
}
|
2017-12-01 16:49:58 +00:00
|
|
|
##
|
|
|
|
|
|
|
|
#SeeAlso MakeCrossContextFromEncoded
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
2018-01-02 16:34:14 +00:00
|
|
|
#Method static sk_sp<SkImage> MakeFromAdoptedTexture(GrContext* context,
|
|
|
|
const GrBackendTexture& backendTexture,
|
|
|
|
GrSurfaceOrigin surfaceOrigin,
|
|
|
|
SkColorType colorType,
|
|
|
|
SkAlphaType alphaType = kPremul_SkAlphaType,
|
|
|
|
sk_sp<SkColorSpace> colorSpace = nullptr)
|
2018-10-08 18:57:48 +00:00
|
|
|
#In Constructors
|
2018-02-06 14:41:53 +00:00
|
|
|
#Line # creates Image from GPU_Texture, managed internally ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2018-01-11 15:35:44 +00:00
|
|
|
#Image 5
|
|
|
|
#Platform gpu
|
2018-01-02 16:34:14 +00:00
|
|
|
if (!canvas->getGrContext()) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
canvas->scale(.5f, .5f);
|
|
|
|
canvas->clear(0x7f3f5f7f);
|
|
|
|
int x = 0, y = 0;
|
|
|
|
for (auto origin : { kBottomLeft_GrSurfaceOrigin, kTopLeft_GrSurfaceOrigin } ) {
|
|
|
|
for (auto alpha : { kOpaque_SkAlphaType, kPremul_SkAlphaType, kUnpremul_SkAlphaType } ) {
|
|
|
|
sk_sp<SkImage> image = SkImage::MakeFromAdoptedTexture(canvas->getGrContext(),
|
2018-05-16 11:07:07 +00:00
|
|
|
backEndTexture, origin,
|
2018-01-02 16:34:14 +00:00
|
|
|
kRGBA_8888_SkColorType, alpha);
|
|
|
|
canvas->drawImage(image, x, y);
|
|
|
|
x += 160;
|
|
|
|
}
|
|
|
|
x -= 160 * 3;
|
|
|
|
y += 256;
|
|
|
|
}
|
|
|
|
##
|
|
|
|
|
|
|
|
#SeeAlso MakeFromTexture MakeFromYUVTexturesCopy
|
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
2018-10-05 14:31:34 +00:00
|
|
|
#Method static sk_sp<SkImage> MakeFromYUVATexturesCopy(GrContext* context,
|
|
|
|
SkYUVColorSpace yuvColorSpace,
|
|
|
|
const GrBackendTexture yuvaTextures[],
|
|
|
|
const SkYUVAIndex yuvaIndices[4],
|
|
|
|
SkISize imageSize,
|
|
|
|
GrSurfaceOrigin imageOrigin,
|
|
|
|
sk_sp<SkColorSpace> imageColorSpace = nullptr)
|
|
|
|
#In Constructor
|
|
|
|
#Line # creates Image from YUV_ColorSpace data ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2018-10-05 14:31:34 +00:00
|
|
|
|
|
|
|
#NoExample
|
|
|
|
##
|
|
|
|
|
2018-10-31 01:10:03 +00:00
|
|
|
#SeeAlso MakeFromYUVATexturesCopyWithExternalBackend MakeFromYUVATextures
|
2018-10-05 14:31:34 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
2018-10-31 01:10:03 +00:00
|
|
|
#Method static sk_sp<SkImage> MakeFromYUVATextures(GrContext* context,
|
|
|
|
SkYUVColorSpace yuvColorSpace,
|
|
|
|
const GrBackendTexture yuvaTextures[],
|
|
|
|
const SkYUVAIndex yuvaIndices[4],
|
|
|
|
SkISize imageSize,
|
|
|
|
GrSurfaceOrigin imageOrigin,
|
|
|
|
sk_sp<SkColorSpace> imageColorSpace = nullptr);
|
|
|
|
|
|
|
|
#In Constructor
|
|
|
|
#Line # creates Image from YUV_ColorSpace data ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2018-10-31 01:10:03 +00:00
|
|
|
|
|
|
|
#NoExample
|
|
|
|
##
|
|
|
|
|
|
|
|
#SeeAlso MakeFromYUVATexturesCopy MakeFromYUVATexturesCopyWithExternalBackend
|
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
2018-11-20 16:12:37 +00:00
|
|
|
#Method static sk_sp<SkImage> MakeFromYUVAPixmaps(
|
|
|
|
GrContext* context,
|
|
|
|
SkYUVColorSpace yuvColorSpace,
|
|
|
|
const SkPixmap yuvaPixmaps[],
|
|
|
|
const SkYUVAIndex yuvaIndices[4],
|
|
|
|
SkISize imageSize,
|
|
|
|
GrSurfaceOrigin imageOrigin,
|
|
|
|
bool buildMips,
|
|
|
|
bool limitToMaxTextureSize = false,
|
|
|
|
sk_sp<SkColorSpace> imageColorSpace = nullptr);
|
|
|
|
|
|
|
|
#In Constructor
|
|
|
|
#Line # creates Image from YUV_ColorSpace data ##
|
|
|
|
#Populate
|
|
|
|
|
|
|
|
#NoExample
|
|
|
|
##
|
|
|
|
|
|
|
|
#SeeAlso MakeFromYUVATextures
|
|
|
|
|
|
|
|
#Method ##
|
2018-10-31 01:10:03 +00:00
|
|
|
|
2018-10-05 14:31:34 +00:00
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method static sk_sp<SkImage> MakeFromYUVATexturesCopyWithExternalBackend(
|
|
|
|
GrContext* context,
|
|
|
|
SkYUVColorSpace yuvColorSpace,
|
|
|
|
const GrBackendTexture yuvaTextures[],
|
|
|
|
const SkYUVAIndex yuvaIndices[4],
|
|
|
|
SkISize imageSize,
|
|
|
|
GrSurfaceOrigin imageOrigin,
|
|
|
|
const GrBackendTexture& backendTexture,
|
|
|
|
sk_sp<SkColorSpace> imageColorSpace = nullptr)
|
|
|
|
#In Constructor
|
|
|
|
#Line # creates Image from planar YUV_ColorSpace, stored in texture ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2018-10-05 14:31:34 +00:00
|
|
|
|
|
|
|
#NoExample
|
|
|
|
##
|
|
|
|
|
2018-10-31 01:10:03 +00:00
|
|
|
#SeeAlso MakeFromYUVATexturesCopy MakeFromYUVATextures
|
2018-10-05 14:31:34 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
2018-01-02 16:34:14 +00:00
|
|
|
#Method static sk_sp<SkImage> MakeFromYUVTexturesCopy(GrContext* context, SkYUVColorSpace yuvColorSpace,
|
2018-03-15 16:16:02 +00:00
|
|
|
const GrBackendTexture yuvTextures[3],
|
2018-10-05 14:31:34 +00:00
|
|
|
GrSurfaceOrigin imageOrigin,
|
|
|
|
sk_sp<SkColorSpace> imageColorSpace = nullptr)
|
2018-10-08 18:57:48 +00:00
|
|
|
#In Constructors
|
2018-02-06 14:41:53 +00:00
|
|
|
#Line # creates Image from YUV_ColorSpace data in three planes ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2018-01-02 16:34:14 +00:00
|
|
|
|
|
|
|
#NoExample
|
|
|
|
##
|
|
|
|
|
2018-10-05 14:31:34 +00:00
|
|
|
#SeeAlso MakeFromYUVTexturesCopyWithExternalBackend MakeFromNV12TexturesCopy MakeFromYUVATexturesCopy
|
2018-09-18 11:31:37 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
2018-10-05 14:31:34 +00:00
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
2018-09-18 11:31:37 +00:00
|
|
|
#Method static sk_sp<SkImage> MakeFromYUVTexturesCopyWithExternalBackend(
|
|
|
|
GrContext* context, SkYUVColorSpace yuvColorSpace,
|
2018-10-05 14:31:34 +00:00
|
|
|
const GrBackendTexture yuvTextures[3], GrSurfaceOrigin imageOrigin,
|
|
|
|
const GrBackendTexture& backendTexture, sk_sp<SkColorSpace> imageColorSpace = nullptr);
|
2018-10-08 18:57:48 +00:00
|
|
|
#In Constructors
|
2018-09-18 11:31:37 +00:00
|
|
|
#Line # creates Image from planar YUV_ColorSpace, stored in texture ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2018-09-18 11:31:37 +00:00
|
|
|
|
|
|
|
#NoExample
|
|
|
|
##
|
|
|
|
|
2018-10-05 14:31:34 +00:00
|
|
|
#SeeAlso MakeFromYUVTexturesCopy MakeFromNV12TexturesCopy MakeFromYUVATexturesCopyWithExternalBackend
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method static sk_sp<SkImage> MakeFromNV12TexturesCopy(GrContext* context,
|
|
|
|
SkYUVColorSpace yuvColorSpace,
|
2018-03-15 16:16:02 +00:00
|
|
|
const GrBackendTexture nv12Textures[2],
|
2018-10-05 14:31:34 +00:00
|
|
|
GrSurfaceOrigin imageOrigin,
|
|
|
|
sk_sp<SkColorSpace> imageColorSpace = nullptr)
|
2018-10-08 18:57:48 +00:00
|
|
|
#In Constructors
|
2018-03-15 16:16:02 +00:00
|
|
|
#Line # creates Image from YUV_ColorSpace data in three planes ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
2018-01-02 16:34:14 +00:00
|
|
|
#NoExample
|
|
|
|
##
|
|
|
|
|
2018-10-05 14:31:34 +00:00
|
|
|
#SeeAlso MakeFromNV12TexturesCopyWithExternalBackend MakeFromYUVTexturesCopy MakeFromYUVATexturesCopy
|
2018-09-18 11:31:37 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
#Method static sk_sp<SkImage> MakeFromNV12TexturesCopyWithExternalBackend(
|
|
|
|
GrContext* context,
|
|
|
|
SkYUVColorSpace yuvColorSpace,
|
|
|
|
const GrBackendTexture nv12Textures[2],
|
2018-10-05 14:31:34 +00:00
|
|
|
GrSurfaceOrigin imageOrigin,
|
|
|
|
const GrBackendTexture& backendTexture,
|
|
|
|
sk_sp<SkColorSpace> imageColorSpace = nullptr);
|
2018-10-08 18:57:48 +00:00
|
|
|
#In Constructors
|
2018-09-18 11:31:37 +00:00
|
|
|
#Line # creates Image from planar YUV_ColorSpace, stored in texture ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2018-09-18 11:31:37 +00:00
|
|
|
|
|
|
|
#NoExample
|
|
|
|
##
|
|
|
|
|
2018-10-05 14:31:34 +00:00
|
|
|
#SeeAlso MakeFromNV12TexturesCopy MakeFromYUVTexturesCopy MakeFromYUVATexturesCopyWithExternalBackend
|
2018-01-02 16:34:14 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
2018-02-06 14:41:53 +00:00
|
|
|
# currently uncalled by any test or client ##
|
2018-01-02 16:34:14 +00:00
|
|
|
#Bug 7424
|
|
|
|
|
2018-02-08 19:45:18 +00:00
|
|
|
#EnumClass BitDepth
|
2018-05-16 11:07:07 +00:00
|
|
|
#Line # options for MakeFromPicture ##
|
2017-11-27 15:44:06 +00:00
|
|
|
#Code
|
2018-10-16 14:30:28 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
|
|
|
#Const kU8 0
|
2018-05-16 11:07:07 +00:00
|
|
|
#Line # uses 8-bit unsigned int per Color component ##
|
2018-05-17 16:17:28 +00:00
|
|
|
Use 8 bits per ARGB component using unsigned integer format.
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
#Const kF16 1
|
2018-05-16 11:07:07 +00:00
|
|
|
#Line # uses 16-bit float per Color component ##
|
2018-05-17 16:17:28 +00:00
|
|
|
Use 16 bits per ARGB component using half-precision floating point format.
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-01-02 16:34:14 +00:00
|
|
|
#NoExample
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-01-02 16:34:14 +00:00
|
|
|
#SeeAlso MakeFromPicture
|
2017-11-27 15:44:06 +00:00
|
|
|
|
2018-02-08 19:45:18 +00:00
|
|
|
#EnumClass ##
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method static sk_sp<SkImage> MakeFromPicture(sk_sp<SkPicture> picture, const SkISize& dimensions,
|
|
|
|
const SkMatrix* matrix, const SkPaint* paint,
|
|
|
|
BitDepth bitDepth,
|
|
|
|
sk_sp<SkColorSpace> colorSpace)
|
2018-10-08 18:57:48 +00:00
|
|
|
#In Constructors
|
2018-02-06 14:41:53 +00:00
|
|
|
#Line # creates Image from Picture ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
2018-01-02 16:34:14 +00:00
|
|
|
#Example
|
|
|
|
SkPaint paint;
|
|
|
|
SkPictureRecorder recorder;
|
|
|
|
SkCanvas* recordingCanvas = recorder.beginRecording(50, 50);
|
|
|
|
for (auto color : { SK_ColorRED, SK_ColorBLUE, 0xff007f00 } ) {
|
|
|
|
paint.setColor(color);
|
|
|
|
recordingCanvas->drawRect({10, 10, 30, 40}, paint);
|
|
|
|
recordingCanvas->translate(10, 10);
|
|
|
|
recordingCanvas->scale(1.2f, 1.4f);
|
|
|
|
}
|
|
|
|
sk_sp<SkPicture> playback = recorder.finishRecordingAsPicture();
|
|
|
|
int x = 0, y = 0;
|
|
|
|
for (auto alpha : { 70, 140, 210 } ) {
|
|
|
|
paint.setAlpha(alpha);
|
|
|
|
auto srgbColorSpace = SkColorSpace::MakeSRGB();
|
|
|
|
sk_sp<SkImage> image = SkImage::MakeFromPicture(playback, {50, 50}, nullptr, &paint,
|
|
|
|
SkImage::BitDepth::kU8, srgbColorSpace);
|
|
|
|
canvas->drawImage(image, x, y);
|
|
|
|
x += 70; y += 70;
|
|
|
|
}
|
|
|
|
##
|
|
|
|
|
|
|
|
#SeeAlso SkCanvas::drawPicture
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
2018-09-13 19:26:33 +00:00
|
|
|
#Method static sk_sp<SkImage> MakeFromAHardwareBuffer(
|
|
|
|
AHardwareBuffer* hardwareBuffer,
|
|
|
|
SkAlphaType alphaType = kPremul_SkAlphaType,
|
|
|
|
sk_sp<SkColorSpace> colorSpace = nullptr,
|
|
|
|
GrSurfaceOrigin surfaceOrigin = kTopLeft_GrSurfaceOrigin)
|
2018-10-08 18:57:48 +00:00
|
|
|
#In Constructors
|
2018-02-06 14:41:53 +00:00
|
|
|
#Line # creates Image from Android hardware buffer ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
2018-01-02 16:34:14 +00:00
|
|
|
#NoExample
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-01-02 16:34:14 +00:00
|
|
|
#SeeAlso MakeFromRaster
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
2018-02-06 14:41:53 +00:00
|
|
|
#Subtopic Property
|
|
|
|
#Line # values and attributes ##
|
|
|
|
##
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method int width() const
|
2018-02-06 14:41:53 +00:00
|
|
|
#In Property
|
|
|
|
#Line # returns pixel column count ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2018-01-02 16:34:14 +00:00
|
|
|
#Image 4
|
2018-01-11 15:35:44 +00:00
|
|
|
#Height 96
|
2018-01-02 16:34:14 +00:00
|
|
|
canvas->translate(10, 10);
|
|
|
|
canvas->drawImage(image, 0, 0);
|
|
|
|
canvas->translate(0, image->height());
|
|
|
|
SkPaint paint;
|
|
|
|
canvas->drawLine(0, 10, image->width(), 10, paint);
|
2018-10-30 00:33:51 +00:00
|
|
|
canvas->drawString("width", image->width() / 2 - 15, 25, paint);
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-01-02 16:34:14 +00:00
|
|
|
#SeeAlso dimensions() height()
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method int height() const
|
2018-02-06 14:41:53 +00:00
|
|
|
#In Property
|
|
|
|
#Line # returns pixel row count ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2018-01-02 16:34:14 +00:00
|
|
|
#Image 4
|
2018-01-11 15:35:44 +00:00
|
|
|
#Height 96
|
2018-01-02 16:34:14 +00:00
|
|
|
canvas->translate(10, 10);
|
|
|
|
canvas->drawImage(image, 0, 0);
|
|
|
|
canvas->translate(image->width(), 0);
|
|
|
|
SkPaint paint;
|
|
|
|
canvas->drawLine(10, 0, 10, image->height(), paint);
|
2018-10-25 12:15:36 +00:00
|
|
|
canvas->drawString("height", 34, image->height() / 2, paint);
|
2018-01-11 15:35:44 +00:00
|
|
|
##
|
2018-01-02 16:34:14 +00:00
|
|
|
|
|
|
|
#SeeAlso dimensions() width()
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method SkISize dimensions() const
|
2018-02-06 14:41:53 +00:00
|
|
|
#In Property
|
|
|
|
#Line # returns width() and height() ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2018-01-02 16:34:14 +00:00
|
|
|
#Image 4
|
|
|
|
SkISize dimensions = image->dimensions();
|
|
|
|
SkIRect bounds = image->bounds();
|
|
|
|
SkIRect dimensionsAsBounds = SkIRect::MakeSize(dimensions);
|
|
|
|
SkDebugf("dimensionsAsBounds %c= bounds\n", dimensionsAsBounds == bounds ? '=' : '!');
|
2018-03-16 15:34:15 +00:00
|
|
|
#StdOut
|
|
|
|
dimensionsAsBounds == bounds
|
|
|
|
##
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-01-02 16:34:14 +00:00
|
|
|
#SeeAlso height() width() bounds()
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method SkIRect bounds() const
|
2018-02-06 14:41:53 +00:00
|
|
|
#In Property
|
|
|
|
#Line # returns width() and height() as Rectangle ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2018-01-02 16:34:14 +00:00
|
|
|
#Height 128
|
|
|
|
#Image 4
|
|
|
|
SkIRect bounds = image->bounds();
|
2018-01-11 15:35:44 +00:00
|
|
|
for (int x : { 0, bounds.width() } ) {
|
|
|
|
for (int y : { 0, bounds.height() } ) {
|
2018-01-02 16:34:14 +00:00
|
|
|
canvas->drawImage(image, x, y);
|
|
|
|
}
|
|
|
|
}
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-05-16 11:07:07 +00:00
|
|
|
#SeeAlso dimensions()
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method uint32_t uniqueID() const
|
2018-02-06 14:41:53 +00:00
|
|
|
#In Property
|
2018-05-16 11:07:07 +00:00
|
|
|
#Line # returns identifier for Image ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2018-01-02 16:34:14 +00:00
|
|
|
#Image 5
|
|
|
|
#Height 156
|
|
|
|
sk_sp<SkImage> subset = image->makeSubset({10, 20, 90, 100});
|
|
|
|
canvas->drawImage(image, 0, 0);
|
|
|
|
canvas->drawImage(subset, 128, 0);
|
|
|
|
SkPaint paint;
|
|
|
|
SkString s;
|
|
|
|
s.printf("original id: %d", image->uniqueID());
|
|
|
|
canvas->drawString(s, 20, image->height() + 20, paint);
|
|
|
|
s.printf("subset id: %d", subset->uniqueID());
|
|
|
|
canvas->drawString(s, 148, subset->height() + 20, paint);
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-01-02 16:34:14 +00:00
|
|
|
#SeeAlso isLazyGenerated
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method SkAlphaType alphaType() const
|
2018-02-06 14:41:53 +00:00
|
|
|
#In Property
|
|
|
|
#Line # returns Alpha_Type ##
|
2018-03-16 15:34:15 +00:00
|
|
|
Returns Alpha_Type, one of: #list_of_alpha_types#.
|
2018-01-02 16:34:14 +00:00
|
|
|
|
|
|
|
Alpha_Type returned was a parameter to an Image constructor,
|
|
|
|
or was parsed from encoded data.
|
|
|
|
|
|
|
|
#Return Alpha_Type in Image ##
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2018-01-02 16:34:14 +00:00
|
|
|
#Image 4
|
2018-01-11 15:35:44 +00:00
|
|
|
#Height 96
|
2018-01-02 16:34:14 +00:00
|
|
|
const char* alphaTypeStr[] = { "Unknown", "Opaque", "Premul", "Unpremul" };
|
|
|
|
SkAlphaType alphaType = image->alphaType();
|
2018-01-11 15:35:44 +00:00
|
|
|
canvas->drawImage(image, 16, 0);
|
2018-05-17 16:17:28 +00:00
|
|
|
canvas->drawString(alphaTypeStr[(int) alphaType], 20, image->height() + 20, SkPaint());
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-01-02 16:34:14 +00:00
|
|
|
#SeeAlso SkImageInfo::alphaType
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
2018-03-14 19:33:42 +00:00
|
|
|
#Method SkColorType colorType() const
|
|
|
|
#In Property
|
|
|
|
#Line # returns Color_Type ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2018-03-14 19:33:42 +00:00
|
|
|
|
|
|
|
#Example
|
2018-05-17 16:17:28 +00:00
|
|
|
#Image 4
|
|
|
|
#Height 96
|
|
|
|
const char* colors[] = { "Unknown", "Alpha_8", "RGB_565", "ARGB_4444", "RGBA_8888", "RGB_888x",
|
|
|
|
"BGRA_8888", "RGBA_1010102", "RGB_101010x", "Gray_8", "RGBA_F16" };
|
|
|
|
SkColorType colorType = image->colorType();
|
|
|
|
canvas->drawImage(image, 16, 0);
|
|
|
|
canvas->drawString(colors[(int) colorType], 20, image->height() + 20, SkPaint());
|
2018-03-14 19:33:42 +00:00
|
|
|
##
|
|
|
|
|
|
|
|
#SeeAlso SkImageInfo::colorType
|
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
2017-11-27 15:44:06 +00:00
|
|
|
#Method SkColorSpace* colorSpace() const
|
2018-02-06 14:41:53 +00:00
|
|
|
#In Property
|
|
|
|
#Line # returns Color_Space ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2018-01-03 13:37:53 +00:00
|
|
|
#Image 3
|
|
|
|
#Set sRGB
|
|
|
|
SkPixmap pixmap;
|
|
|
|
source.peekPixels(&pixmap);
|
|
|
|
canvas->scale(.25f, .25f);
|
|
|
|
int y = 0;
|
|
|
|
for (auto gamma : { SkColorSpace::kLinear_RenderTargetGamma,
|
|
|
|
SkColorSpace::kSRGB_RenderTargetGamma } ) {
|
|
|
|
int x = 0;
|
|
|
|
sk_sp<SkColorSpace> colorSpace = SkColorSpace::MakeRGB(gamma, SkColorSpace::kSRGB_Gamut);
|
|
|
|
for (int index = 0; index < 2; ++index) {
|
|
|
|
pixmap.setColorSpace(colorSpace);
|
|
|
|
sk_sp<SkImage> image = SkImage::MakeRasterCopy(pixmap);
|
|
|
|
canvas->drawImage(image, x, y);
|
|
|
|
colorSpace = image->colorSpace()->makeColorSpin();
|
|
|
|
x += 512;
|
|
|
|
}
|
|
|
|
y += 512;
|
|
|
|
}
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-01-03 13:37:53 +00:00
|
|
|
#SeeAlso refColorSpace makeColorSpace
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method sk_sp<SkColorSpace> refColorSpace() const
|
2018-02-06 14:41:53 +00:00
|
|
|
#In Property
|
|
|
|
#Line # returns Image_Info Color_Space ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2018-01-03 13:37:53 +00:00
|
|
|
#Image 3
|
|
|
|
#Set sRGB
|
|
|
|
SkPixmap pixmap;
|
|
|
|
source.peekPixels(&pixmap);
|
|
|
|
canvas->scale(.25f, .25f);
|
|
|
|
int y = 0;
|
|
|
|
for (auto gamma : { SkColorSpace::kLinear_RenderTargetGamma,
|
|
|
|
SkColorSpace::kSRGB_RenderTargetGamma } ) {
|
|
|
|
int x = 0;
|
|
|
|
sk_sp<SkColorSpace> colorSpace = SkColorSpace::MakeRGB(gamma, SkColorSpace::kSRGB_Gamut);
|
|
|
|
for (int index = 0; index < 2; ++index) {
|
|
|
|
pixmap.setColorSpace(colorSpace);
|
|
|
|
sk_sp<SkImage> image = SkImage::MakeRasterCopy(pixmap);
|
|
|
|
canvas->drawImage(image, x, y);
|
|
|
|
colorSpace = image->refColorSpace()->makeColorSpin();
|
|
|
|
x += 512;
|
|
|
|
}
|
|
|
|
y += 512;
|
|
|
|
}
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-01-03 13:37:53 +00:00
|
|
|
#SeeAlso colorSpace makeColorSpace
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method bool isAlphaOnly() const
|
2018-02-06 14:41:53 +00:00
|
|
|
#In Property
|
|
|
|
#Line # returns if pixels represent a transparency mask ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2018-01-03 13:37:53 +00:00
|
|
|
uint8_t pmColors = 0;
|
|
|
|
sk_sp<SkImage> image = SkImage::MakeRasterCopy({SkImageInfo::MakeA8(1, 1), &pmColors, 1});
|
|
|
|
SkDebugf("alphaOnly = %s\n", image->isAlphaOnly() ? "true" : "false");
|
|
|
|
#StdOut
|
|
|
|
alphaOnly = true
|
|
|
|
##
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-01-03 13:37:53 +00:00
|
|
|
#SeeAlso alphaType isOpaque
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method bool isOpaque() const
|
2018-02-06 14:41:53 +00:00
|
|
|
#In Property
|
|
|
|
#Line # returns if Alpha_Type is kOpaque_SkAlphaType ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2018-01-03 13:37:53 +00:00
|
|
|
auto check_isopaque = [](const SkImageInfo& imageInfo) -> void {
|
|
|
|
auto surface(SkSurface::MakeRaster(imageInfo));
|
|
|
|
auto image(surface->makeImageSnapshot());
|
|
|
|
SkDebugf("isOpaque = %s\n", image->isOpaque() ? "true" : "false");
|
|
|
|
};
|
|
|
|
|
|
|
|
check_isopaque(SkImageInfo::MakeN32Premul(5, 5));
|
|
|
|
check_isopaque(SkImageInfo::MakeN32(5, 5, kOpaque_SkAlphaType));
|
|
|
|
#StdOut
|
|
|
|
isOpaque = false
|
|
|
|
isOpaque = true
|
|
|
|
##
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-01-03 13:37:53 +00:00
|
|
|
#SeeAlso alphaType isAlphaOnly
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method sk_sp<SkShader> makeShader(SkShader::TileMode tileMode1, SkShader::TileMode tileMode2,
|
|
|
|
const SkMatrix* localMatrix = nullptr) const
|
2018-10-08 18:57:48 +00:00
|
|
|
#In Constructors
|
2018-02-06 14:41:53 +00:00
|
|
|
#Line # creates Shader, Paint element that can tile Image ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2018-01-03 13:37:53 +00:00
|
|
|
#Image 4
|
|
|
|
SkMatrix matrix;
|
|
|
|
matrix.setRotate(45);
|
|
|
|
SkPaint paint;
|
|
|
|
paint.setShader(image->makeShader(SkShader::kRepeat_TileMode, SkShader::kMirror_TileMode,
|
|
|
|
&matrix));
|
|
|
|
canvas->drawPaint(paint);
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-01-03 13:37:53 +00:00
|
|
|
#SeeAlso scalePixels
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method sk_sp<SkShader> makeShader(const SkMatrix* localMatrix = nullptr) const
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2018-01-03 13:37:53 +00:00
|
|
|
#Image 5
|
|
|
|
SkMatrix matrix;
|
|
|
|
matrix.setRotate(45);
|
|
|
|
matrix.postTranslate(125, 30);
|
|
|
|
SkPaint paint;
|
|
|
|
paint.setShader(image->makeShader(&matrix));
|
|
|
|
canvas->drawPaint(paint);
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-01-05 17:10:09 +00:00
|
|
|
#SeeAlso scalePixels
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
2018-02-07 12:27:09 +00:00
|
|
|
#Subtopic Pixels
|
|
|
|
#Line # read and write pixel values ##
|
|
|
|
##
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method bool peekPixels(SkPixmap* pixmap) const
|
2018-02-07 12:27:09 +00:00
|
|
|
#In Pixels
|
2018-02-06 14:41:53 +00:00
|
|
|
#Line # returns Pixmap if possible ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2018-01-05 17:10:09 +00:00
|
|
|
SkBitmap bitmap;
|
|
|
|
bitmap.allocPixels(SkImageInfo::MakeN32Premul(12, 11));
|
|
|
|
SkCanvas offscreen(bitmap);
|
|
|
|
offscreen.clear(SK_ColorWHITE);
|
|
|
|
SkPaint paint;
|
|
|
|
offscreen.drawString("%", 1, 10, paint);
|
|
|
|
sk_sp<SkImage> image = SkImage::MakeFromBitmap(bitmap);
|
|
|
|
SkPixmap pixmap;
|
|
|
|
if (image->peekPixels(&pixmap)) {
|
|
|
|
const SkPMColor* pixels = pixmap.addr32();
|
|
|
|
SkPMColor pmWhite = pixels[0];
|
|
|
|
for (int y = 0; y < image->height(); ++y) {
|
|
|
|
for (int x = 0; x < image->width(); ++x) {
|
|
|
|
SkDebugf("%c", *pixels++ == pmWhite ? '-' : 'x');
|
|
|
|
}
|
|
|
|
SkDebugf("\n");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#StdOut
|
|
|
|
------------
|
|
|
|
--xx----x---
|
|
|
|
-x--x--x----
|
|
|
|
-x--x--x----
|
|
|
|
-x--x-x-----
|
|
|
|
--xx-xx-xx--
|
|
|
|
-----x-x--x-
|
|
|
|
----x--x--x-
|
|
|
|
----x--x--x-
|
|
|
|
---x----xx--
|
|
|
|
------------
|
|
|
|
##
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-01-05 17:10:09 +00:00
|
|
|
#SeeAlso readPixels
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method bool isTextureBacked() const
|
2018-02-07 12:27:09 +00:00
|
|
|
#In Property
|
2018-02-06 14:41:53 +00:00
|
|
|
#Line # returns if Image was created from GPU_Texture ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2018-01-05 17:10:09 +00:00
|
|
|
#Image 5
|
|
|
|
#Platform gpu
|
|
|
|
auto drawImage = [=](sk_sp<SkImage> image, const char* label) -> void {
|
|
|
|
if (nullptr == image) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
SkPaint paint;
|
|
|
|
paint.setAntiAlias(true);
|
|
|
|
canvas->drawImage(image, 0, 0);
|
2018-10-30 00:33:51 +00:00
|
|
|
canvas->drawString(label, 30, image->height() / 4, paint);
|
2018-01-05 17:10:09 +00:00
|
|
|
canvas->drawString(image->isTextureBacked() ? "is GPU texture" : "not GPU texture",
|
2018-10-30 00:33:51 +00:00
|
|
|
20, image->height() * 3 / 4, paint);
|
2018-01-05 17:10:09 +00:00
|
|
|
};
|
|
|
|
sk_sp<SkImage> bitmapImage(SkImage::MakeFromBitmap(source));
|
|
|
|
sk_sp<SkImage> textureImage(SkImage::MakeFromTexture(canvas->getGrContext(), backEndTexture,
|
2018-06-07 21:07:17 +00:00
|
|
|
kTopLeft_GrSurfaceOrigin, kRGBA_8888_SkColorType,
|
|
|
|
kOpaque_SkAlphaType, nullptr));
|
2018-01-05 17:10:09 +00:00
|
|
|
drawImage(image, "image");
|
|
|
|
canvas->translate(image->width(), 0);
|
|
|
|
drawImage(bitmapImage, "source");
|
|
|
|
canvas->translate(-image->width(), image->height());
|
|
|
|
drawImage(textureImage, "backEndTexture");
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-01-05 17:10:09 +00:00
|
|
|
#SeeAlso MakeFromTexture isValid
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method bool isValid(GrContext* context) const
|
2018-02-06 14:41:53 +00:00
|
|
|
#In Property
|
|
|
|
#Line # returns if Image can draw to Raster_Surface or GPU_Context ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2018-01-05 17:10:09 +00:00
|
|
|
#Image 5
|
|
|
|
#Platform gpu
|
|
|
|
auto drawImage = [=](sk_sp<SkImage> image, const char* label) -> void {
|
|
|
|
if (nullptr == image) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
SkPaint paint;
|
|
|
|
paint.setAntiAlias(true);
|
|
|
|
canvas->drawImage(image, 0, 0);
|
|
|
|
canvas->drawString(label, image->width() / 2, image->height() / 4, paint);
|
|
|
|
if (canvas->getGrContext()) {
|
|
|
|
canvas->drawString(image->isValid(canvas->getGrContext()) ? "is valid on GPU" :
|
2018-10-30 00:33:51 +00:00
|
|
|
"not valid on GPU", 20, image->height() * 5 / 8, paint);
|
2018-01-05 17:10:09 +00:00
|
|
|
}
|
|
|
|
canvas->drawString(image->isValid(nullptr) ? "is valid on CPU" :
|
2018-10-30 00:33:51 +00:00
|
|
|
"not valid on CPU", 20, image->height() * 7 / 8, paint);
|
2018-01-05 17:10:09 +00:00
|
|
|
};
|
|
|
|
sk_sp<SkImage> bitmapImage(SkImage::MakeFromBitmap(source));
|
|
|
|
sk_sp<SkImage> textureImage(SkImage::MakeFromTexture(canvas->getGrContext(), backEndTexture,
|
2018-06-07 21:07:17 +00:00
|
|
|
kTopLeft_GrSurfaceOrigin, kRGBA_8888_SkColorType,
|
|
|
|
kOpaque_SkAlphaType, nullptr));
|
2018-01-05 17:10:09 +00:00
|
|
|
drawImage(image, "image");
|
|
|
|
canvas->translate(image->width(), 0);
|
|
|
|
drawImage(bitmapImage, "source");
|
|
|
|
canvas->translate(-image->width(), image->height());
|
|
|
|
drawImage(textureImage, "backEndTexture");
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-01-05 17:10:09 +00:00
|
|
|
#SeeAlso isTextureBacked isLazyGenerated
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
2018-05-10 22:04:08 +00:00
|
|
|
|
2018-04-04 19:54:55 +00:00
|
|
|
#Method GrBackendTexture getBackendTexture(bool flushPendingGrContextIO,
|
|
|
|
GrSurfaceOrigin* origin = nullptr) const
|
|
|
|
#In Property
|
|
|
|
#Line # returns GPU reference to Image as texture ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2018-04-04 19:54:55 +00:00
|
|
|
|
2018-04-05 12:18:41 +00:00
|
|
|
#Example
|
|
|
|
#Image 3
|
|
|
|
#Platform gpu
|
2018-04-13 19:48:26 +00:00
|
|
|
GrContext* grContext = canvas->getGrContext();
|
|
|
|
if (!grContext) {
|
|
|
|
canvas->drawString("GPU only!", 20, 40, SkPaint());
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
sk_sp<SkImage> imageFromBackend = SkImage::MakeFromAdoptedTexture(grContext, backEndTexture,
|
|
|
|
kBottomLeft_GrSurfaceOrigin, kRGBA_8888_SkColorType, kOpaque_SkAlphaType);
|
|
|
|
GrBackendTexture textureFromImage = imageFromBackend->getBackendTexture(false);
|
|
|
|
if (!textureFromImage.isValid()) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
sk_sp<SkImage> imageFromTexture = SkImage::MakeFromAdoptedTexture(grContext, textureFromImage,
|
|
|
|
kTopLeft_GrSurfaceOrigin, kRGBA_8888_SkColorType, kOpaque_SkAlphaType);
|
|
|
|
canvas->drawImage(imageFromTexture, 0, 0);
|
2018-04-05 12:18:41 +00:00
|
|
|
canvas->drawImage(imageFromBackend, 128, 128);
|
2018-04-04 19:54:55 +00:00
|
|
|
##
|
|
|
|
|
|
|
|
#SeeAlso MakeFromTexture isTextureBacked
|
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
2017-11-27 15:44:06 +00:00
|
|
|
#Enum CachingHint
|
2018-05-16 11:07:07 +00:00
|
|
|
#Line # options for readPixels and scalePixels ##
|
2017-11-27 15:44:06 +00:00
|
|
|
#Code
|
2018-10-16 14:30:28 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-01-11 15:35:44 +00:00
|
|
|
CachingHint selects whether Skia may internally cache Bitmaps generated by
|
|
|
|
decoding Image, or by copying Image from GPU to CPU. The default behavior
|
2018-05-16 11:07:07 +00:00
|
|
|
allows caching Bitmaps.
|
2018-01-11 15:35:44 +00:00
|
|
|
|
|
|
|
Choose kDisallow_CachingHint if Image pixels are to be used only once, or
|
|
|
|
if Image pixels reside in a cache outside of Skia, or to reduce memory pressure.
|
|
|
|
|
|
|
|
Choosing kAllow_CachingHint does not ensure that pixels will be cached.
|
|
|
|
Image pixels may not be cached if memory requirements are too large or
|
|
|
|
pixels are not accessible.
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Const kAllow_CachingHint 0
|
2018-05-16 11:07:07 +00:00
|
|
|
#Line # allows internally caching decoded and copied pixels ##
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
#Const kDisallow_CachingHint 1
|
2018-05-16 11:07:07 +00:00
|
|
|
#Line # disallows internally caching decoded and copied pixels ##
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-01-11 15:35:44 +00:00
|
|
|
#NoExample
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-01-11 15:35:44 +00:00
|
|
|
#SeeAlso readPixels scalePixels
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Enum ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method bool readPixels(const SkImageInfo& dstInfo, void* dstPixels, size_t dstRowBytes,
|
|
|
|
int srcX, int srcY, CachingHint cachingHint = kAllow_CachingHint) const
|
2018-02-07 12:27:09 +00:00
|
|
|
#In Pixels
|
2018-02-06 14:41:53 +00:00
|
|
|
#Line # copies and converts pixels ##
|
2017-11-27 15:44:06 +00:00
|
|
|
|
2018-01-11 15:35:44 +00:00
|
|
|
Copies Rect of pixels from Image to dstPixels. Copy starts at offset (srcX, srcY),
|
2018-05-16 11:07:07 +00:00
|
|
|
and does not exceed Image (width(), height()).
|
2018-01-11 15:35:44 +00:00
|
|
|
|
|
|
|
dstInfo specifies width, height, Color_Type, Alpha_Type, and Color_Space of
|
|
|
|
destination. dstRowBytes specifics the gap from one destination row to the next.
|
|
|
|
Returns true if pixels are copied. Returns false if:
|
|
|
|
#List
|
2018-11-07 19:59:03 +00:00
|
|
|
# dstInfo has no address ##
|
|
|
|
# dstRowBytes is less than dstInfo.minRowBytes() ##
|
2018-01-11 15:35:44 +00:00
|
|
|
# Pixel_Ref is nullptr ##
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-01-11 15:35:44 +00:00
|
|
|
Pixels are copied only if pixel conversion is possible. If Image Color_Type is
|
2018-11-07 19:59:03 +00:00
|
|
|
kGray_8_SkColorType, or kAlpha_8_SkColorType; dstInfo.colorType() must match.
|
|
|
|
If Image Color_Type is kGray_8_SkColorType, dstInfo.colorSpace() must match.
|
|
|
|
If Image Alpha_Type is kOpaque_SkAlphaType, dstInfo.alphaType() must
|
|
|
|
match. If Image Color_Space is nullptr, dstInfo.colorSpace() must match. Returns
|
2018-01-11 15:35:44 +00:00
|
|
|
false if pixel conversion is not possible.
|
2017-11-27 15:44:06 +00:00
|
|
|
|
2018-01-11 15:35:44 +00:00
|
|
|
srcX and srcY may be negative to copy only top or left of source. Returns
|
2018-05-16 11:07:07 +00:00
|
|
|
false if width() or height() is zero or negative.
|
Condense embedded formulas.
Bookmaker delimits formulas and equations to allow
representing variables and symbols without tripping
up reference lookup, spell checking, and comment
generation.
Before, formulas were represented with:
some text
#Formula
(x + y, 0)
##
, and more text
This made it difficult to know when spacing should
be preserved before and after the formula. Now,
formulas are represented with:
some text #Formula # (x + y, 0) ##, and more text
The presence or absence of a space between ## and ,
is now significant (before it was not).
Also, formulas are bracketed by <code> in markdown
generation, so that variables stand out better.
See:
https://skia.org/user/api/SkBlendMode_Reference?cl=152781#Dst_Out
for an example.
Also fixed 100 column offenders and added a code
check to identify them. For the moment, 100 column
offenders are outed with SkDebugf but their presence
does not cause bookmaker to fail.
TBR=caryclark@google.com
Docs-Preview: https://skia.org/?cl=152781
Bug: skia:6898
Change-Id: If92a65a234f5d616bf4485984a8d219a6f04821a
Reviewed-on: https://skia-review.googlesource.com/152781
Commit-Queue: Cary Clark <caryclark@skia.org>
Auto-Submit: Cary Clark <caryclark@skia.org>
Reviewed-by: Cary Clark <caryclark@skia.org>
2018-09-13 16:04:30 +00:00
|
|
|
Returns false if #Formula # abs(srcX) >= Image width() ##, or if #Formula # abs(srcY) >= Image height() ##.
|
2017-11-27 15:44:06 +00:00
|
|
|
|
2018-01-11 15:35:44 +00:00
|
|
|
If cachingHint is kAllow_CachingHint, pixels may be retained locally.
|
|
|
|
If cachingHint is kDisallow_CachingHint, pixels are not added to the local cache.
|
|
|
|
|
|
|
|
#Param dstInfo destination width, height, Color_Type, Alpha_Type, Color_Space ##
|
|
|
|
#Param dstPixels destination pixel storage ##
|
|
|
|
#Param dstRowBytes destination row length ##
|
|
|
|
#Param srcX column index whose absolute value is less than width() ##
|
|
|
|
#Param srcY row index whose absolute value is less than height() ##
|
|
|
|
#Param cachingHint one of: kAllow_CachingHint, kDisallow_CachingHint ##
|
|
|
|
|
|
|
|
#Return true if pixels are copied to dstPixels ##
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2018-01-11 15:35:44 +00:00
|
|
|
#Image 3
|
|
|
|
canvas->scale(.5f, .5f);
|
|
|
|
const int width = 32;
|
|
|
|
const int height = 32;
|
|
|
|
std::vector<int32_t> dstPixels;
|
|
|
|
dstPixels.resize(height * width * 4);
|
|
|
|
SkImageInfo info = SkImageInfo::MakeN32Premul(width, height);
|
|
|
|
for (int y = 0; y < 512; y += height ) {
|
|
|
|
for (int x = 0; x < 512; x += width ) {
|
|
|
|
if (image->readPixels(info, &dstPixels.front(), width * 4, x, y)) {
|
|
|
|
SkPixmap dstPixmap(info, &dstPixels.front(), width * 4);
|
|
|
|
SkBitmap bitmap;
|
|
|
|
bitmap.installPixels(dstPixmap);
|
|
|
|
canvas->drawBitmap(bitmap, 0, 0);
|
|
|
|
}
|
|
|
|
canvas->translate(48, 0);
|
|
|
|
}
|
|
|
|
canvas->translate(-16 * 48, 48);
|
|
|
|
}
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-01-11 15:35:44 +00:00
|
|
|
#SeeAlso scalePixels SkBitmap::readPixels SkPixmap::readPixels SkCanvas::readPixels SkSurface::readPixels
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method bool readPixels(const SkPixmap& dst, int srcX, int srcY,
|
|
|
|
CachingHint cachingHint = kAllow_CachingHint) const
|
|
|
|
|
2018-01-11 15:35:44 +00:00
|
|
|
Copies a Rect of pixels from Image to dst. Copy starts at (srcX, srcY), and
|
2018-05-16 11:07:07 +00:00
|
|
|
does not exceed Image (width(), height()).
|
2017-11-27 15:44:06 +00:00
|
|
|
|
2018-01-11 15:35:44 +00:00
|
|
|
dst specifies width, height, Color_Type, Alpha_Type, Color_Space, pixel storage,
|
2018-11-07 19:59:03 +00:00
|
|
|
and row bytes of destination. dst.rowBytes() specifics the gap from one destination
|
2018-01-11 15:35:44 +00:00
|
|
|
row to the next. Returns true if pixels are copied. Returns false if:
|
|
|
|
#List
|
|
|
|
# dst pixel storage equals nullptr ##
|
2018-11-07 19:59:03 +00:00
|
|
|
# dst.rowBytes() is less than SkImageInfo::minRowBytes ##
|
2018-01-11 15:35:44 +00:00
|
|
|
# Pixel_Ref is nullptr ##
|
|
|
|
##
|
|
|
|
|
|
|
|
Pixels are copied only if pixel conversion is possible. If Image Color_Type is
|
2018-11-07 19:59:03 +00:00
|
|
|
kGray_8_SkColorType, or kAlpha_8_SkColorType; dst.colorType() must match.
|
|
|
|
If Image Color_Type is kGray_8_SkColorType, dst.colorSpace() must match.
|
|
|
|
If Image Alpha_Type is kOpaque_SkAlphaType, dst.alphaType() must
|
|
|
|
match. If Image Color_Space is nullptr, dst.colorSpace() must match. Returns
|
2018-01-11 15:35:44 +00:00
|
|
|
false if pixel conversion is not possible.
|
2018-05-16 11:07:07 +00:00
|
|
|
|
2018-01-11 15:35:44 +00:00
|
|
|
srcX and srcY may be negative to copy only top or left of source. Returns
|
2018-05-16 11:07:07 +00:00
|
|
|
false if width() or height() is zero or negative.
|
Condense embedded formulas.
Bookmaker delimits formulas and equations to allow
representing variables and symbols without tripping
up reference lookup, spell checking, and comment
generation.
Before, formulas were represented with:
some text
#Formula
(x + y, 0)
##
, and more text
This made it difficult to know when spacing should
be preserved before and after the formula. Now,
formulas are represented with:
some text #Formula # (x + y, 0) ##, and more text
The presence or absence of a space between ## and ,
is now significant (before it was not).
Also, formulas are bracketed by <code> in markdown
generation, so that variables stand out better.
See:
https://skia.org/user/api/SkBlendMode_Reference?cl=152781#Dst_Out
for an example.
Also fixed 100 column offenders and added a code
check to identify them. For the moment, 100 column
offenders are outed with SkDebugf but their presence
does not cause bookmaker to fail.
TBR=caryclark@google.com
Docs-Preview: https://skia.org/?cl=152781
Bug: skia:6898
Change-Id: If92a65a234f5d616bf4485984a8d219a6f04821a
Reviewed-on: https://skia-review.googlesource.com/152781
Commit-Queue: Cary Clark <caryclark@skia.org>
Auto-Submit: Cary Clark <caryclark@skia.org>
Reviewed-by: Cary Clark <caryclark@skia.org>
2018-09-13 16:04:30 +00:00
|
|
|
Returns false if #Formula # abs(srcX) >= Image width() ##, or if #Formula # abs(srcY) >= Image height() ##.
|
2018-01-11 15:35:44 +00:00
|
|
|
|
|
|
|
If cachingHint is kAllow_CachingHint, pixels may be retained locally.
|
|
|
|
If cachingHint is kDisallow_CachingHint, pixels are not added to the local cache.
|
|
|
|
|
|
|
|
#Param dst destination Pixmap: Image_Info, pixels, row bytes ##
|
|
|
|
#Param srcX column index whose absolute value is less than width() ##
|
|
|
|
#Param srcY row index whose absolute value is less than height() ##
|
|
|
|
#Param cachingHint one of: kAllow_CachingHint, kDisallow_CachingHint ##
|
|
|
|
|
|
|
|
#Return true if pixels are copied to dst ##
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2018-01-11 15:35:44 +00:00
|
|
|
#Image 3
|
|
|
|
std::vector<int32_t> srcPixels;
|
|
|
|
int rowBytes = image->width() * 4;
|
|
|
|
int quarterWidth = image->width() / 4;
|
|
|
|
int quarterHeight = image->height() / 4;
|
|
|
|
srcPixels.resize(image->height() * rowBytes);
|
|
|
|
for (int y = 0; y < 4; ++y) {
|
|
|
|
for (int x = 0; x < 4; ++x) {
|
|
|
|
SkPixmap pixmap(SkImageInfo::MakeN32Premul(quarterWidth, quarterHeight),
|
|
|
|
&srcPixels.front() + x * image->height() * quarterWidth +
|
|
|
|
y * quarterWidth, rowBytes);
|
|
|
|
image->readPixels(pixmap, x * quarterWidth, y * quarterHeight);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
canvas->scale(.5f, .5f);
|
|
|
|
SkBitmap bitmap;
|
|
|
|
bitmap.installPixels(SkImageInfo::MakeN32Premul(image->width(), image->height()),
|
|
|
|
&srcPixels.front(), rowBytes);
|
|
|
|
canvas->drawBitmap(bitmap, 0, 0);
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-01-11 15:35:44 +00:00
|
|
|
#SeeAlso scalePixels SkBitmap::readPixels SkPixmap::readPixels SkCanvas::readPixels SkSurface::readPixels
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method bool scalePixels(const SkPixmap& dst, SkFilterQuality filterQuality,
|
|
|
|
CachingHint cachingHint = kAllow_CachingHint) const
|
2018-02-07 12:27:09 +00:00
|
|
|
#In Pixels
|
2018-02-06 14:41:53 +00:00
|
|
|
#Line # scales and converts one Image to another ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2018-01-11 15:35:44 +00:00
|
|
|
#Image 3
|
|
|
|
#Height 128
|
|
|
|
std::vector<int32_t> srcPixels;
|
|
|
|
int quarterWidth = image->width() / 16;
|
|
|
|
int rowBytes = quarterWidth * 4;
|
|
|
|
int quarterHeight = image->height() / 16;
|
|
|
|
srcPixels.resize(quarterHeight * rowBytes);
|
|
|
|
SkPixmap pixmap(SkImageInfo::MakeN32Premul(quarterWidth, quarterHeight),
|
|
|
|
&srcPixels.front(), rowBytes);
|
|
|
|
canvas->scale(4, 4);
|
|
|
|
SkFilterQuality qualities[] = { kNone_SkFilterQuality, kLow_SkFilterQuality,
|
|
|
|
kMedium_SkFilterQuality, kHigh_SkFilterQuality };
|
|
|
|
for (unsigned index = 0; index < SK_ARRAY_COUNT(qualities); ++index) {
|
|
|
|
image->scalePixels(pixmap, qualities[index]);
|
|
|
|
sk_sp<SkImage> filtered = SkImage::MakeFromRaster(pixmap, nullptr, nullptr);
|
|
|
|
canvas->drawImage(filtered, 16 * index, 0);
|
|
|
|
}
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-01-11 15:35:44 +00:00
|
|
|
#SeeAlso SkCanvas::drawImage readPixels SkPixmap::scalePixels
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method sk_sp<SkData> encodeToData(SkEncodedImageFormat encodedImageFormat, int quality) const
|
2018-02-07 12:27:09 +00:00
|
|
|
#In Utility
|
2018-02-06 14:41:53 +00:00
|
|
|
#Line # returns encoded Image as SkData ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2018-01-11 15:35:44 +00:00
|
|
|
#Image 3
|
|
|
|
canvas->scale(4, 4);
|
|
|
|
SkIRect subset = {0, 0, 16, 64};
|
|
|
|
int x = 0;
|
|
|
|
for (int quality : { 0, 10, 50, 100 } ) {
|
|
|
|
sk_sp<SkData> data(image->encodeToData(SkEncodedImageFormat::kJPEG, quality));
|
|
|
|
sk_sp<SkImage> filtered = SkImage::MakeFromEncoded(data, &subset);
|
|
|
|
canvas->drawImage(filtered, x, 0);
|
|
|
|
x += 16;
|
|
|
|
}
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-01-11 15:35:44 +00:00
|
|
|
#SeeAlso refEncodedData MakeFromEncoded
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
2018-01-02 16:34:14 +00:00
|
|
|
#Method sk_sp<SkData> encodeToData() const
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2018-01-11 15:35:44 +00:00
|
|
|
#Image 3
|
|
|
|
canvas->scale(4, 4);
|
|
|
|
SkIRect subset = {136, 32, 200, 96};
|
|
|
|
sk_sp<SkData> data(image->encodeToData());
|
|
|
|
sk_sp<SkImage> eye = SkImage::MakeFromEncoded(data, &subset);
|
|
|
|
canvas->drawImage(eye, 0, 0);
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-01-11 15:35:44 +00:00
|
|
|
#SeeAlso refEncodedData MakeFromEncoded
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method sk_sp<SkData> refEncodedData() const
|
2018-02-07 12:27:09 +00:00
|
|
|
#In Utility
|
2018-02-06 14:41:53 +00:00
|
|
|
#Line # returns Image encoded in SkData if present ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2018-01-11 15:35:44 +00:00
|
|
|
#Image 3
|
|
|
|
#Platform gpu
|
|
|
|
struct {
|
|
|
|
const char* name;
|
|
|
|
sk_sp<SkImage> image;
|
|
|
|
} tests[] = { { "image", image }, { "bitmap", SkImage::MakeFromBitmap(source) },
|
|
|
|
{ "texture", SkImage::MakeFromTexture(canvas->getGrContext(), backEndTexture,
|
2018-06-07 21:07:17 +00:00
|
|
|
kTopLeft_GrSurfaceOrigin, kRGBA_8888_SkColorType,
|
|
|
|
kOpaque_SkAlphaType, nullptr) } };
|
2018-01-11 15:35:44 +00:00
|
|
|
SkString string;
|
|
|
|
SkPaint paint;
|
|
|
|
for (const auto& test : tests ) {
|
|
|
|
if (!test.image) {
|
|
|
|
string.printf("no %s", test.name);
|
|
|
|
} else {
|
|
|
|
string.printf("%s" "encoded %s", test.image->refEncodedData() ? "" : "no ", test.name);
|
|
|
|
}
|
|
|
|
canvas->drawString(string, 10, 20, paint);
|
|
|
|
canvas->translate(0, 20);
|
|
|
|
}
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-01-11 15:35:44 +00:00
|
|
|
#SeeAlso encodeToData MakeFromEncoded
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
2018-02-06 14:41:53 +00:00
|
|
|
#Subtopic Utility
|
|
|
|
#Line # rarely called management functions ##
|
|
|
|
##
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method sk_sp<SkImage> makeSubset(const SkIRect& subset) const
|
2018-10-08 18:57:48 +00:00
|
|
|
#In Constructors
|
2018-02-06 14:41:53 +00:00
|
|
|
#Line # creates Image containing part of original ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2018-01-11 15:35:44 +00:00
|
|
|
#Image 3
|
|
|
|
canvas->scale(.5f, .5f);
|
2018-07-24 12:09:27 +00:00
|
|
|
const int width = 64;
|
|
|
|
const int height = 64;
|
2018-01-11 15:35:44 +00:00
|
|
|
for (int y = 0; y < 512; y += height ) {
|
|
|
|
for (int x = 0; x < 512; x += width ) {
|
|
|
|
sk_sp<SkImage> subset(image->makeSubset({x, y, x + width, y + height}));
|
|
|
|
canvas->drawImage(subset, x * 3 / 2, y * 3 / 2);
|
|
|
|
}
|
|
|
|
}
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-01-11 15:35:44 +00:00
|
|
|
#SeeAlso MakeFromEncoded
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
2018-06-12 20:39:59 +00:00
|
|
|
#Method sk_sp<SkImage> makeTextureImage(GrContext* context, SkColorSpace* dstColorSpace,
|
|
|
|
GrMipMapped mipMapped = GrMipMapped::kNo) const
|
2018-10-08 18:57:48 +00:00
|
|
|
#In Constructors
|
2018-02-06 14:41:53 +00:00
|
|
|
#Line # creates Image matching Color_Space if possible ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2018-01-11 15:35:44 +00:00
|
|
|
#Platform gpu
|
|
|
|
#Image 5
|
|
|
|
auto drawImage = [=](sk_sp<SkImage> image, GrContext* context, const char* label) -> void {
|
|
|
|
if (nullptr == image || nullptr == context) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
SkPaint paint;
|
|
|
|
paint.setAntiAlias(true);
|
|
|
|
sk_sp<SkImage> texture(image->makeTextureImage(context, nullptr));
|
|
|
|
canvas->drawImage(texture, 0, 0);
|
2018-10-30 00:33:51 +00:00
|
|
|
canvas->drawString(label, 20, texture->height() / 4, paint);
|
2018-01-11 15:35:44 +00:00
|
|
|
};
|
|
|
|
sk_sp<SkImage> bitmapImage(SkImage::MakeFromBitmap(source));
|
|
|
|
GrContext* context = canvas->getGrContext();
|
|
|
|
sk_sp<SkImage> textureImage(SkImage::MakeFromTexture(context, backEndTexture,
|
2018-06-07 21:07:17 +00:00
|
|
|
kTopLeft_GrSurfaceOrigin, kRGBA_8888_SkColorType,
|
|
|
|
kOpaque_SkAlphaType, nullptr));
|
2018-01-11 15:35:44 +00:00
|
|
|
drawImage(image, context, "image");
|
|
|
|
canvas->translate(image->width(), 0);
|
|
|
|
drawImage(bitmapImage, context, "source");
|
|
|
|
canvas->translate(-image->width(), image->height());
|
|
|
|
drawImage(textureImage, context, "backEndTexture");
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-01-11 15:35:44 +00:00
|
|
|
#SeeAlso MakeFromTexture
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method sk_sp<SkImage> makeNonTextureImage() const
|
2018-10-08 18:57:48 +00:00
|
|
|
#In Constructors
|
2018-02-06 14:41:53 +00:00
|
|
|
#Line # creates Image without dependency on GPU_Texture ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2018-01-02 16:34:14 +00:00
|
|
|
|
|
|
|
#Example
|
2018-01-11 15:35:44 +00:00
|
|
|
#Image 5
|
|
|
|
#Platform gpu
|
|
|
|
auto drawImage = [=](sk_sp<SkImage> image, const char* label) -> void {
|
|
|
|
if (nullptr == image) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
SkPaint paint;
|
|
|
|
paint.setAntiAlias(true);
|
|
|
|
sk_sp<SkImage> nonTexture(image->makeNonTextureImage());
|
|
|
|
canvas->drawImage(nonTexture, 0, 0);
|
2018-10-30 00:33:51 +00:00
|
|
|
canvas->drawString(label, 20, nonTexture->height() / 4, paint);
|
2018-01-11 15:35:44 +00:00
|
|
|
};
|
|
|
|
sk_sp<SkImage> bitmapImage(SkImage::MakeFromBitmap(source));
|
|
|
|
sk_sp<SkImage> textureImage(SkImage::MakeFromTexture(canvas->getGrContext(), backEndTexture,
|
2018-06-07 21:07:17 +00:00
|
|
|
kTopLeft_GrSurfaceOrigin, kRGBA_8888_SkColorType,
|
|
|
|
kOpaque_SkAlphaType, nullptr));
|
2018-01-11 15:35:44 +00:00
|
|
|
drawImage(image, "image");
|
|
|
|
canvas->translate(image->width(), 0);
|
|
|
|
drawImage(bitmapImage, "source");
|
|
|
|
canvas->translate(-image->width(), image->height());
|
|
|
|
drawImage(textureImage, "backEndTexture");
|
2018-01-02 16:34:14 +00:00
|
|
|
##
|
|
|
|
|
2018-02-08 19:45:18 +00:00
|
|
|
#SeeAlso makeTextureImage makeRasterImage MakeBackendTextureFromSkImage
|
2018-01-02 16:34:14 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method sk_sp<SkImage> makeRasterImage() const
|
2018-10-08 18:57:48 +00:00
|
|
|
#In Constructors
|
2018-02-06 14:41:53 +00:00
|
|
|
#Line # creates Image compatible with Raster_Surface if possible ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2018-01-11 15:35:44 +00:00
|
|
|
|
2017-11-27 15:44:06 +00:00
|
|
|
#Example
|
2018-01-11 15:35:44 +00:00
|
|
|
#Image 5
|
|
|
|
#Platform gpu
|
|
|
|
auto drawImage = [=](sk_sp<SkImage> image, const char* label) -> void {
|
|
|
|
if (nullptr == image) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
SkPaint paint;
|
|
|
|
paint.setAntiAlias(true);
|
|
|
|
sk_sp<SkImage> raster(image->makeRasterImage());
|
|
|
|
canvas->drawImage(raster, 0, 0);
|
2018-10-30 00:33:51 +00:00
|
|
|
canvas->drawString(label, 20, raster->height() / 4, paint);
|
2018-01-11 15:35:44 +00:00
|
|
|
};
|
|
|
|
sk_sp<SkImage> bitmapImage(SkImage::MakeFromBitmap(source));
|
|
|
|
sk_sp<SkImage> textureImage(SkImage::MakeFromTexture(canvas->getGrContext(), backEndTexture,
|
2018-06-07 21:07:17 +00:00
|
|
|
kTopLeft_GrSurfaceOrigin, kRGBA_8888_SkColorType,
|
|
|
|
kOpaque_SkAlphaType, nullptr));
|
2018-01-11 15:35:44 +00:00
|
|
|
drawImage(image, "image");
|
|
|
|
canvas->translate(image->width(), 0);
|
|
|
|
drawImage(bitmapImage, "source");
|
|
|
|
canvas->translate(-image->width(), image->height());
|
|
|
|
drawImage(textureImage, "backEndTexture");
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-01-11 15:35:44 +00:00
|
|
|
#SeeAlso isTextureBacked isLazyGenerated MakeFromRaster
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method sk_sp<SkImage> makeWithFilter(const SkImageFilter* filter, const SkIRect& subset,
|
|
|
|
const SkIRect& clipBounds, SkIRect* outSubset,
|
|
|
|
SkIPoint* offset) const
|
2018-10-08 18:57:48 +00:00
|
|
|
#In Constructors
|
2018-02-06 14:41:53 +00:00
|
|
|
#Line # creates filtered, clipped Image ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2018-01-11 15:35:44 +00:00
|
|
|
#Description
|
|
|
|
In each frame of the animation, filtered Image is drawn in a different location.
|
|
|
|
By translating canvas by returned offset, Image appears stationary.
|
|
|
|
##
|
|
|
|
#Image 5
|
|
|
|
#Platform gpu
|
2018-09-21 15:36:41 +00:00
|
|
|
#Duration 1
|
2018-01-11 15:35:44 +00:00
|
|
|
sk_sp<SkImageFilter> shadowFilter = SkDropShadowImageFilter::Make(
|
|
|
|
-10.0f * frame, 5.0f * frame, 3.0f, 3.0f, SK_ColorBLUE,
|
|
|
|
SkDropShadowImageFilter::kDrawShadowAndForeground_ShadowMode,
|
|
|
|
nullptr);
|
|
|
|
sk_sp<SkImageFilter> offsetFilter = SkOffsetImageFilter::Make(40, 40, shadowFilter, nullptr);
|
|
|
|
SkIRect subset = image->bounds();
|
|
|
|
SkIRect clipBounds = image->bounds();
|
|
|
|
clipBounds.outset(60, 60);
|
|
|
|
SkIRect outSubset;
|
|
|
|
SkIPoint offset;
|
|
|
|
sk_sp<SkImage> filtered(image->makeWithFilter(offsetFilter.get(), subset, clipBounds,
|
|
|
|
&outSubset, &offset));
|
|
|
|
SkPaint paint;
|
|
|
|
paint.setAntiAlias(true);
|
|
|
|
paint.setStyle(SkPaint::kStroke_Style);
|
|
|
|
canvas->drawLine(0, 0, offset.fX, offset.fY, paint);
|
|
|
|
canvas->translate(offset.fX, offset.fY);
|
|
|
|
canvas->drawImage(filtered, 0, 0);
|
2018-03-16 15:34:15 +00:00
|
|
|
canvas->drawRect(SkRect::Make(outSubset), paint);
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-02-08 19:45:18 +00:00
|
|
|
#SeeAlso makeShader SkPaint::setImageFilter
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Typedef std::function<void(GrBackendTexture)> BackendTextureReleaseProc
|
2018-05-16 11:07:07 +00:00
|
|
|
#Line # parameter type for MakeBackendTextureFromSkImage ##
|
2018-05-17 16:17:28 +00:00
|
|
|
|
|
|
|
#Code
|
2018-10-16 14:30:28 +00:00
|
|
|
#Populate
|
2018-05-17 16:17:28 +00:00
|
|
|
##
|
|
|
|
|
2018-06-07 13:59:07 +00:00
|
|
|
Defines a callback function, taking one parameter of type GrBackendTexture with
|
|
|
|
no return value. Function is called when back-end texture is to be released.
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method static bool MakeBackendTextureFromSkImage(GrContext* context,
|
|
|
|
sk_sp<SkImage> image,
|
|
|
|
GrBackendTexture* backendTexture,
|
|
|
|
BackendTextureReleaseProc* backendTextureReleaseProc)
|
2018-10-08 18:57:48 +00:00
|
|
|
#In Constructors
|
2018-02-06 14:41:53 +00:00
|
|
|
#Line # creates GPU_Texture from Image ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2018-02-08 19:45:18 +00:00
|
|
|
#Platform gpu
|
|
|
|
#Height 64
|
|
|
|
#Function
|
2018-02-09 13:50:22 +00:00
|
|
|
static sk_sp<SkImage> create_gpu_image(GrContext* grContext) {
|
|
|
|
const SkImageInfo info = SkImageInfo::MakeN32(20, 20, kOpaque_SkAlphaType);
|
|
|
|
auto surface(SkSurface::MakeRenderTarget(grContext, SkBudgeted::kNo, info));
|
|
|
|
SkCanvas* canvas = surface->getCanvas();
|
|
|
|
canvas->clear(SK_ColorWHITE);
|
|
|
|
SkPaint paint;
|
|
|
|
paint.setColor(SK_ColorBLACK);
|
|
|
|
canvas->drawRect(SkRect::MakeXYWH(5, 5, 10, 10), paint);
|
|
|
|
return surface->makeImageSnapshot();
|
|
|
|
}
|
|
|
|
##
|
|
|
|
|
2018-05-16 11:07:07 +00:00
|
|
|
void draw(SkCanvas* canvas) {
|
2018-02-09 13:50:22 +00:00
|
|
|
GrContext* grContext = canvas->getGrContext();
|
|
|
|
if (!grContext) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
sk_sp<SkImage> backEndImage = create_gpu_image(grContext);
|
|
|
|
canvas->drawImage(backEndImage, 0, 0);
|
|
|
|
GrBackendTexture texture;
|
|
|
|
SkImage::BackendTextureReleaseProc proc;
|
|
|
|
if (!SkImage::MakeBackendTextureFromSkImage(grContext, std::move(backEndImage),
|
|
|
|
&texture, &proc)) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
sk_sp<SkImage> i2 = SkImage::MakeFromTexture(grContext, texture, kTopLeft_GrSurfaceOrigin,
|
|
|
|
kN32_SkColorType, kOpaque_SkAlphaType, nullptr);
|
|
|
|
canvas->drawImage(i2, 30, 30);
|
2018-02-08 19:45:18 +00:00
|
|
|
}
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-02-08 19:45:18 +00:00
|
|
|
#SeeAlso MakeFromTexture makeTextureImage
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#Method bool isLazyGenerated() const
|
2018-02-06 14:41:53 +00:00
|
|
|
#In Property
|
|
|
|
#Line # returns if Image is created as needed ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2017-12-11 21:03:17 +00:00
|
|
|
#Height 80
|
|
|
|
#Function
|
|
|
|
class TestImageGenerator : public SkImageGenerator {
|
|
|
|
public:
|
|
|
|
TestImageGenerator() : SkImageGenerator(SkImageInfo::MakeN32Premul(10, 10)) {}
|
|
|
|
~TestImageGenerator() override {}
|
|
|
|
protected:
|
|
|
|
bool onGetPixels(const SkImageInfo& info, void* pixelPtr, size_t rowBytes,
|
|
|
|
const Options& options) override {
|
|
|
|
SkPMColor* pixels = static_cast<SkPMColor*>(pixelPtr);
|
|
|
|
for (int y = 0; y < info.height(); ++y) {
|
|
|
|
for (int x = 0; x < info.width(); ++x) {
|
|
|
|
pixels[y * info.width() + x] = 0xff223344 + y * 0x000C0811;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
##
|
|
|
|
void draw(SkCanvas* canvas) {
|
|
|
|
auto gen = std::unique_ptr<TestImageGenerator>(new TestImageGenerator());
|
|
|
|
sk_sp<SkImage> image(SkImage::MakeFromGenerator(std::move(gen)));
|
|
|
|
SkString lazy(image->isLazyGenerated() ? "is lazy" : "not lazy");
|
|
|
|
canvas->scale(8, 8);
|
|
|
|
canvas->drawImage(image, 0, 0, nullptr);
|
|
|
|
SkPaint paint;
|
|
|
|
paint.setTextSize(4);
|
|
|
|
canvas->drawString(lazy, 2, 5, paint);
|
|
|
|
}
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-01-05 17:10:09 +00:00
|
|
|
#Example
|
|
|
|
#Image 5
|
|
|
|
#Platform gpu
|
|
|
|
void draw(SkCanvas* canvas) {
|
|
|
|
auto drawImage = [=](sk_sp<SkImage> image, const char* label) -> void {
|
|
|
|
if (nullptr == image) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
SkPaint paint;
|
|
|
|
paint.setAntiAlias(true);
|
|
|
|
canvas->drawImage(image, 0, 0);
|
2018-10-30 00:33:51 +00:00
|
|
|
canvas->drawString(label, 30, image->height() / 4, paint);
|
2018-01-05 17:10:09 +00:00
|
|
|
canvas->drawString(
|
|
|
|
image->isLazyGenerated() ? "is lazily generated" : "not lazily generated",
|
2018-10-30 00:33:51 +00:00
|
|
|
20, image->height() * 3 / 4, paint);
|
2018-01-05 17:10:09 +00:00
|
|
|
};
|
|
|
|
sk_sp<SkImage> bitmapImage(SkImage::MakeFromBitmap(source));
|
|
|
|
sk_sp<SkImage> textureImage(SkImage::MakeFromTexture(canvas->getGrContext(), backEndTexture,
|
2018-06-07 21:07:17 +00:00
|
|
|
kTopLeft_GrSurfaceOrigin, kRGBA_8888_SkColorType,
|
|
|
|
kOpaque_SkAlphaType, nullptr));
|
2018-01-05 17:10:09 +00:00
|
|
|
drawImage(image, "image");
|
|
|
|
canvas->translate(image->width(), 0);
|
|
|
|
drawImage(bitmapImage, "source");
|
|
|
|
canvas->translate(-image->width(), image->height());
|
|
|
|
drawImage(textureImage, "backEndTexture");
|
|
|
|
}
|
|
|
|
##
|
|
|
|
|
2018-11-07 19:59:03 +00:00
|
|
|
#SeeAlso isTextureBacked makeNonTextureImage
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
2018-07-17 17:19:56 +00:00
|
|
|
#Method sk_sp<SkImage> makeColorSpace(sk_sp<SkColorSpace> target) const
|
2018-10-08 18:57:48 +00:00
|
|
|
#In Constructors
|
2018-02-06 14:41:53 +00:00
|
|
|
#Line # creates Image matching Color_Space if possible ##
|
2018-10-31 16:14:03 +00:00
|
|
|
#Populate
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Example
|
2018-01-11 15:35:44 +00:00
|
|
|
#Image 5
|
|
|
|
#Set sRGB
|
|
|
|
sk_sp<SkColorSpace> normalColorSpace = SkColorSpace::MakeRGB(
|
|
|
|
SkColorSpace::kSRGB_RenderTargetGamma, SkColorSpace::kSRGB_Gamut);
|
|
|
|
sk_sp<SkColorSpace> wackyColorSpace = normalColorSpace->makeColorSpin();
|
|
|
|
for (auto colorSpace : { normalColorSpace, wackyColorSpace } ) {
|
2018-07-18 13:25:15 +00:00
|
|
|
sk_sp<SkImage> colorSpaced = image->makeColorSpace(colorSpace);
|
|
|
|
canvas->drawImage(colorSpaced, 0, 0);
|
|
|
|
canvas->translate(128, 0);
|
2018-01-11 15:35:44 +00:00
|
|
|
}
|
2017-11-27 15:44:06 +00:00
|
|
|
##
|
|
|
|
|
2018-11-07 19:59:03 +00:00
|
|
|
#SeeAlso MakeFromPicture MakeFromTexture
|
2017-11-27 15:44:06 +00:00
|
|
|
|
|
|
|
#Method ##
|
|
|
|
|
|
|
|
#Class SkImage ##
|
|
|
|
|
|
|
|
#Topic Image ##
|