| /* |
| * Copyright 2015 Google Inc. |
| * |
| * Use of this source code is governed by a BSD-style license that can be |
| * found in the LICENSE file. |
| */ |
| |
| #ifndef SkPixmap_DEFINED |
| #define SkPixmap_DEFINED |
| |
| #include "include/core/SkColor.h" |
| #include "include/core/SkColorType.h" |
| #include "include/core/SkImageInfo.h" |
| #include "include/core/SkRect.h" |
| #include "include/core/SkRefCnt.h" |
| #include "include/core/SkSamplingOptions.h" |
| #include "include/core/SkSize.h" |
| #include "include/private/base/SkAPI.h" |
| #include "include/private/base/SkAssert.h" |
| |
| #include <cstddef> |
| #include <cstdint> |
| |
| class SkColorSpace; |
| enum SkAlphaType : int; |
| struct SkMask; |
| |
| /** \class SkPixmap |
| SkPixmap provides a utility to pair SkImageInfo with pixels and row bytes. |
| SkPixmap is a low level class which provides convenience functions to access |
| raster destinations. SkCanvas can not draw SkPixmap, nor does SkPixmap provide |
| a direct drawing destination. |
| |
| Use SkBitmap to draw pixels referenced by SkPixmap; use SkSurface to draw into |
| pixels referenced by SkPixmap. |
| |
| SkPixmap does not try to manage the lifetime of the pixel memory. Use SkPixelRef |
| to manage pixel memory; SkPixelRef is safe across threads. |
| */ |
| class SK_API SkPixmap { |
| public: |
| |
| /** Creates an empty SkPixmap without pixels, with kUnknown_SkColorType, with |
| kUnknown_SkAlphaType, and with a width and height of zero. Use |
| reset() to associate pixels, SkColorType, SkAlphaType, width, and height |
| after SkPixmap has been created. |
| |
| @return empty SkPixmap |
| */ |
| SkPixmap() |
| : fPixels(nullptr), fRowBytes(0), fInfo(SkImageInfo::MakeUnknown(0, 0)) |
| {} |
| |
| /** Creates SkPixmap from info width, height, SkAlphaType, and SkColorType. |
| addr points to pixels, or nullptr. rowBytes should be info.width() times |
| info.bytesPerPixel(), or larger. |
| |
| No parameter checking is performed; it is up to the caller to ensure that |
| addr and rowBytes agree with info. |
| |
| The memory lifetime of pixels is managed by the caller. When SkPixmap goes |
| out of scope, addr is unaffected. |
| |
| SkPixmap may be later modified by reset() to change its size, pixel type, or |
| storage. |
| |
| @param info width, height, SkAlphaType, SkColorType of SkImageInfo |
| @param addr pointer to pixels allocated by caller; may be nullptr |
| @param rowBytes size of one row of addr; width times pixel size, or larger |
| @return initialized SkPixmap |
| */ |
| SkPixmap(const SkImageInfo& info, const void* addr, size_t rowBytes) |
| : fPixels(addr), fRowBytes(rowBytes), fInfo(info) |
| {} |
| |
| /** Sets width, height, row bytes to zero; pixel address to nullptr; SkColorType to |
| kUnknown_SkColorType; and SkAlphaType to kUnknown_SkAlphaType. |
| |
| The prior pixels are unaffected; it is up to the caller to release pixels |
| memory if desired. |
| |
| example: https://fiddle.skia.org/c/@Pixmap_reset |
| */ |
| void reset(); |
| |
| /** Sets width, height, SkAlphaType, and SkColorType from info. |
| Sets pixel address from addr, which may be nullptr. |
| Sets row bytes from rowBytes, which should be info.width() times |
| info.bytesPerPixel(), or larger. |
| |
| Does not check addr. Asserts if built with SK_DEBUG defined and if rowBytes is |
| too small to hold one row of pixels. |
| |
| The memory lifetime pixels are managed by the caller. When SkPixmap goes |
| out of scope, addr is unaffected. |
| |
| @param info width, height, SkAlphaType, SkColorType of SkImageInfo |
| @param addr pointer to pixels allocated by caller; may be nullptr |
| @param rowBytes size of one row of addr; width times pixel size, or larger |
| |
| example: https://fiddle.skia.org/c/@Pixmap_reset_2 |
| */ |
| void reset(const SkImageInfo& info, const void* addr, size_t rowBytes); |
| |
| /** Changes SkColorSpace in SkImageInfo; preserves width, height, SkAlphaType, and |
| SkColorType in SkImage, and leaves pixel address and row bytes unchanged. |
| SkColorSpace reference count is incremented. |
| |
| @param colorSpace SkColorSpace moved to SkImageInfo |
| |
| example: https://fiddle.skia.org/c/@Pixmap_setColorSpace |
| */ |
| void setColorSpace(sk_sp<SkColorSpace> colorSpace); |
| |
| /** Deprecated. |
| */ |
| [[nodiscard]] bool reset(const SkMask& mask); |
| |
| /** Sets subset width, height, pixel address to intersection of SkPixmap with area, |
| if intersection is not empty; and return true. Otherwise, leave subset unchanged |
| and return false. |
| |
| Failing to read the return value generates a compile time warning. |
| |
| @param subset storage for width, height, pixel address of intersection |
| @param area bounds to intersect with SkPixmap |
| @return true if intersection of SkPixmap and area is not empty |
| */ |
| [[nodiscard]] bool extractSubset(SkPixmap* subset, const SkIRect& area) const; |
| |
| /** Returns width, height, SkAlphaType, SkColorType, and SkColorSpace. |
| |
| @return reference to SkImageInfo |
| */ |
| const SkImageInfo& info() const { return fInfo; } |
| |
| /** Returns row bytes, the interval from one pixel row to the next. Row bytes |
| is at least as large as: width() * info().bytesPerPixel(). |
| |
| Returns zero if colorType() is kUnknown_SkColorType. |
| It is up to the SkBitmap creator to ensure that row bytes is a useful value. |
| |
| @return byte length of pixel row |
| */ |
| size_t rowBytes() const { return fRowBytes; } |
| |
| /** Returns pixel address, the base address corresponding to the pixel origin. |
| |
| It is up to the SkPixmap creator to ensure that pixel address is a useful value. |
| |
| @return pixel address |
| */ |
| const void* addr() const { return fPixels; } |
| |
| /** Returns pixel count in each pixel row. Should be equal or less than: |
| rowBytes() / info().bytesPerPixel(). |
| |
| @return pixel width in SkImageInfo |
| */ |
| int width() const { return fInfo.width(); } |
| |
| /** Returns pixel row count. |
| |
| @return pixel height in SkImageInfo |
| */ |
| int height() const { return fInfo.height(); } |
| |
| /** |
| * Return the dimensions of the pixmap (from its ImageInfo) |
| */ |
| SkISize dimensions() const { return fInfo.dimensions(); } |
| |
| SkColorType colorType() const { return fInfo.colorType(); } |
| |
| SkAlphaType alphaType() const { return fInfo.alphaType(); } |
| |
| /** Returns SkColorSpace, the range of colors, associated with SkImageInfo. The |
| reference count of SkColorSpace is unchanged. The returned SkColorSpace is |
| immutable. |
| |
| @return SkColorSpace in SkImageInfo, or nullptr |
| */ |
| SkColorSpace* colorSpace() const; |
| |
| /** Returns smart pointer to SkColorSpace, the range of colors, associated with |
| SkImageInfo. The smart pointer tracks the number of objects sharing this |
| SkColorSpace reference so the memory is released when the owners destruct. |
| |
| The returned SkColorSpace is immutable. |
| |
| @return SkColorSpace in SkImageInfo wrapped in a smart pointer |
| */ |
| sk_sp<SkColorSpace> refColorSpace() const; |
| |
| /** Returns true if SkAlphaType is kOpaque_SkAlphaType. |
| Does not check if SkColorType allows alpha, or if any pixel value has |
| transparency. |
| |
| @return true if SkImageInfo has opaque SkAlphaType |
| */ |
| bool isOpaque() const { return fInfo.isOpaque(); } |
| |
| /** Returns SkIRect { 0, 0, width(), height() }. |
| |
| @return integral rectangle from origin to width() and height() |
| */ |
| SkIRect bounds() const { return SkIRect::MakeWH(this->width(), this->height()); } |
| |
| /** Returns number of pixels that fit on row. Should be greater than or equal to |
| width(). |
| |
| @return maximum pixels per row |
| */ |
| int rowBytesAsPixels() const { return int(fRowBytes >> this->shiftPerPixel()); } |
| |
| /** Returns bit shift converting row bytes to row pixels. |
| Returns zero for kUnknown_SkColorType. |
| |
| @return one of: 0, 1, 2, 3; left shift to convert pixels to bytes |
| */ |
| int shiftPerPixel() const { return fInfo.shiftPerPixel(); } |
| |
| /** Returns minimum memory required for pixel storage. |
| Does not include unused memory on last row when rowBytesAsPixels() exceeds width(). |
| Returns SIZE_MAX if result does not fit in size_t. |
| Returns zero if height() or width() is 0. |
| Returns height() times rowBytes() if colorType() is kUnknown_SkColorType. |
| |
| @return size in bytes of image buffer |
| */ |
| size_t computeByteSize() const { return fInfo.computeByteSize(fRowBytes); } |
| |
| /** Returns true if all pixels are opaque. SkColorType determines how pixels |
| are encoded, and whether pixel describes alpha. Returns true for SkColorType |
| without alpha in each pixel; for other SkColorType, returns true if all |
| pixels have alpha values equivalent to 1.0 or greater. |
| |
| For SkColorType kRGB_565_SkColorType or kGray_8_SkColorType: always |
| returns true. For SkColorType kAlpha_8_SkColorType, kBGRA_8888_SkColorType, |
| kRGBA_8888_SkColorType: returns true if all pixel alpha values are 255. |
| For SkColorType kARGB_4444_SkColorType: returns true if all pixel alpha values are 15. |
| For kRGBA_F16_SkColorType: returns true if all pixel alpha values are 1.0 or |
| greater. |
| |
| Returns false for kUnknown_SkColorType. |
| |
| @return true if all pixels have opaque values or SkColorType is opaque |
| |
| example: https://fiddle.skia.org/c/@Pixmap_computeIsOpaque |
| */ |
| bool computeIsOpaque() const; |
| |
| /** Returns pixel at (x, y) as unpremultiplied color. |
| Returns black with alpha if SkColorType is kAlpha_8_SkColorType. |
| |
| Input is not validated: out of bounds values of x or y trigger an assert() if |
| built with SK_DEBUG defined; and returns undefined values or may crash if |
| SK_RELEASE is defined. Fails if SkColorType is kUnknown_SkColorType or |
| pixel address is nullptr. |
| |
| SkColorSpace in SkImageInfo is ignored. Some color precision may be lost in the |
| conversion to unpremultiplied color; original pixel data may have additional |
| precision. |
| |
| @param x column index, zero or greater, and less than width() |
| @param y row index, zero or greater, and less than height() |
| @return pixel converted to unpremultiplied color |
| |
| example: https://fiddle.skia.org/c/@Pixmap_getColor |
| */ |
| SkColor getColor(int x, int y) const; |
| |
| /** Returns pixel at (x, y) as unpremultiplied color as an SkColor4f. |
| Returns black with alpha if SkColorType is kAlpha_8_SkColorType. |
| |
| Input is not validated: out of bounds values of x or y trigger an assert() if |
| built with SK_DEBUG defined; and returns undefined values or may crash if |
| SK_RELEASE is defined. Fails if SkColorType is kUnknown_SkColorType or |
| pixel address is nullptr. |
| |
| SkColorSpace in SkImageInfo is ignored. Some color precision may be lost in the |
| conversion to unpremultiplied color; original pixel data may have additional |
| precision, though this is less likely than for getColor(). Rounding errors may |
| occur if the underlying type has lower precision. |
| |
| @param x column index, zero or greater, and less than width() |
| @param y row index, zero or greater, and less than height() |
| @return pixel converted to unpremultiplied float color |
| */ |
| SkColor4f getColor4f(int x, int y) const; |
| |
| /** Look up the pixel at (x,y) and return its alpha component, normalized to [0..1]. |
| This is roughly equivalent to SkGetColorA(getColor()), but can be more efficent |
| (and more precise if the pixels store more than 8 bits per component). |
| |
| @param x column index, zero or greater, and less than width() |
| @param y row index, zero or greater, and less than height() |
| @return alpha converted to normalized float |
| */ |
| float getAlphaf(int x, int y) const; |
| |
| /** Returns readable pixel address at (x, y). Returns nullptr if SkPixelRef is nullptr. |
| |
| Input is not validated: out of bounds values of x or y trigger an assert() if |
| built with SK_DEBUG defined. Returns nullptr if SkColorType is kUnknown_SkColorType. |
| |
| Performs a lookup of pixel size; for better performance, call |
| one of: addr8, addr16, addr32, addr64, or addrF16(). |
| |
| @param x column index, zero or greater, and less than width() |
| @param y row index, zero or greater, and less than height() |
| @return readable generic pointer to pixel |
| */ |
| const void* addr(int x, int y) const { |
| return (const char*)fPixels + fInfo.computeOffset(x, y, fRowBytes); |
| } |
| |
| /** Returns readable base pixel address. Result is addressable as unsigned 8-bit bytes. |
| Will trigger an assert() if SkColorType is not kAlpha_8_SkColorType or |
| kGray_8_SkColorType, and is built with SK_DEBUG defined. |
| |
| One byte corresponds to one pixel. |
| |
| @return readable unsigned 8-bit pointer to pixels |
| */ |
| const uint8_t* addr8() const { |
| SkASSERT(1 == fInfo.bytesPerPixel()); |
| return reinterpret_cast<const uint8_t*>(fPixels); |
| } |
| |
| /** Returns readable base pixel address. Result is addressable as unsigned 16-bit words. |
| Will trigger an assert() if SkColorType is not kRGB_565_SkColorType or |
| kARGB_4444_SkColorType, and is built with SK_DEBUG defined. |
| |
| One word corresponds to one pixel. |
| |
| @return readable unsigned 16-bit pointer to pixels |
| */ |
| const uint16_t* addr16() const { |
| SkASSERT(2 == fInfo.bytesPerPixel()); |
| return reinterpret_cast<const uint16_t*>(fPixels); |
| } |
| |
| /** Returns readable base pixel address. Result is addressable as unsigned 32-bit words. |
| Will trigger an assert() if SkColorType is not kRGBA_8888_SkColorType or |
| kBGRA_8888_SkColorType, and is built with SK_DEBUG defined. |
| |
| One word corresponds to one pixel. |
| |
| @return readable unsigned 32-bit pointer to pixels |
| */ |
| const uint32_t* addr32() const { |
| SkASSERT(4 == fInfo.bytesPerPixel()); |
| return reinterpret_cast<const uint32_t*>(fPixels); |
| } |
| |
| /** Returns readable base pixel address. Result is addressable as unsigned 64-bit words. |
| Will trigger an assert() if SkColorType is not kRGBA_F16_SkColorType and is built |
| with SK_DEBUG defined. |
| |
| One word corresponds to one pixel. |
| |
| @return readable unsigned 64-bit pointer to pixels |
| */ |
| const uint64_t* addr64() const { |
| SkASSERT(8 == fInfo.bytesPerPixel()); |
| return reinterpret_cast<const uint64_t*>(fPixels); |
| } |
| |
| /** Returns readable base pixel address. Result is addressable as unsigned 16-bit words. |
| Will trigger an assert() if SkColorType is not kRGBA_F16_SkColorType and is built |
| with SK_DEBUG defined. |
| |
| Each word represents one color component encoded as a half float. |
| Four words correspond to one pixel. |
| |
| @return readable unsigned 16-bit pointer to first component of pixels |
| */ |
| const uint16_t* addrF16() const { |
| SkASSERT(8 == fInfo.bytesPerPixel()); |
| SkASSERT(kRGBA_F16_SkColorType == fInfo.colorType() || |
| kRGBA_F16Norm_SkColorType == fInfo.colorType()); |
| return reinterpret_cast<const uint16_t*>(fPixels); |
| } |
| |
| /** Returns readable pixel address at (x, y). |
| |
| Input is not validated: out of bounds values of x or y trigger an assert() if |
| built with SK_DEBUG defined. |
| |
| Will trigger an assert() if SkColorType is not kAlpha_8_SkColorType or |
| kGray_8_SkColorType, and is built with SK_DEBUG defined. |
| |
| @param x column index, zero or greater, and less than width() |
| @param y row index, zero or greater, and less than height() |
| @return readable unsigned 8-bit pointer to pixel at (x, y) |
| */ |
| const uint8_t* addr8(int x, int y) const { |
| SkASSERT((unsigned)x < (unsigned)fInfo.width()); |
| SkASSERT((unsigned)y < (unsigned)fInfo.height()); |
| return (const uint8_t*)((const char*)this->addr8() + (size_t)y * fRowBytes + (x << 0)); |
| } |
| |
| /** Returns readable pixel address at (x, y). |
| |
| Input is not validated: out of bounds values of x or y trigger an assert() if |
| built with SK_DEBUG defined. |
| |
| Will trigger an assert() if SkColorType is not kRGB_565_SkColorType or |
| kARGB_4444_SkColorType, and is built with SK_DEBUG defined. |
| |
| @param x column index, zero or greater, and less than width() |
| @param y row index, zero or greater, and less than height() |
| @return readable unsigned 16-bit pointer to pixel at (x, y) |
| */ |
| const uint16_t* addr16(int x, int y) const { |
| SkASSERT((unsigned)x < (unsigned)fInfo.width()); |
| SkASSERT((unsigned)y < (unsigned)fInfo.height()); |
| return (const uint16_t*)((const char*)this->addr16() + (size_t)y * fRowBytes + (x << 1)); |
| } |
| |
| /** Returns readable pixel address at (x, y). |
| |
| Input is not validated: out of bounds values of x or y trigger an assert() if |
| built with SK_DEBUG defined. |
| |
| Will trigger an assert() if SkColorType is not kRGBA_8888_SkColorType or |
| kBGRA_8888_SkColorType, and is built with SK_DEBUG defined. |
| |
| @param x column index, zero or greater, and less than width() |
| @param y row index, zero or greater, and less than height() |
| @return readable unsigned 32-bit pointer to pixel at (x, y) |
| */ |
| const uint32_t* addr32(int x, int y) const { |
| SkASSERT((unsigned)x < (unsigned)fInfo.width()); |
| SkASSERT((unsigned)y < (unsigned)fInfo.height()); |
| return (const uint32_t*)((const char*)this->addr32() + (size_t)y * fRowBytes + (x << 2)); |
| } |
| |
| /** Returns readable pixel address at (x, y). |
| |
| Input is not validated: out of bounds values of x or y trigger an assert() if |
| built with SK_DEBUG defined. |
| |
| Will trigger an assert() if SkColorType is not kRGBA_F16_SkColorType and is built |
| with SK_DEBUG defined. |
| |
| @param x column index, zero or greater, and less than width() |
| @param y row index, zero or greater, and less than height() |
| @return readable unsigned 64-bit pointer to pixel at (x, y) |
| */ |
| const uint64_t* addr64(int x, int y) const { |
| SkASSERT((unsigned)x < (unsigned)fInfo.width()); |
| SkASSERT((unsigned)y < (unsigned)fInfo.height()); |
| return (const uint64_t*)((const char*)this->addr64() + (size_t)y * fRowBytes + (x << 3)); |
| } |
| |
| /** Returns readable pixel address at (x, y). |
| |
| Input is not validated: out of bounds values of x or y trigger an assert() if |
| built with SK_DEBUG defined. |
| |
| Will trigger an assert() if SkColorType is not kRGBA_F16_SkColorType and is built |
| with SK_DEBUG defined. |
| |
| Each unsigned 16-bit word represents one color component encoded as a half float. |
| Four words correspond to one pixel. |
| |
| @param x column index, zero or greater, and less than width() |
| @param y row index, zero or greater, and less than height() |
| @return readable unsigned 16-bit pointer to pixel component at (x, y) |
| */ |
| const uint16_t* addrF16(int x, int y) const { |
| SkASSERT(kRGBA_F16_SkColorType == fInfo.colorType() || |
| kRGBA_F16Norm_SkColorType == fInfo.colorType()); |
| return reinterpret_cast<const uint16_t*>(this->addr64(x, y)); |
| } |
| |
| /** Returns writable base pixel address. |
| |
| @return writable generic base pointer to pixels |
| */ |
| void* writable_addr() const { return const_cast<void*>(fPixels); } |
| |
| /** Returns writable pixel address at (x, y). |
| |
| Input is not validated: out of bounds values of x or y trigger an assert() if |
| built with SK_DEBUG defined. Returns zero if SkColorType is kUnknown_SkColorType. |
| |
| @param x column index, zero or greater, and less than width() |
| @param y row index, zero or greater, and less than height() |
| @return writable generic pointer to pixel |
| */ |
| void* writable_addr(int x, int y) const { |
| return const_cast<void*>(this->addr(x, y)); |
| } |
| |
| /** Returns writable pixel address at (x, y). Result is addressable as unsigned |
| 8-bit bytes. Will trigger an assert() if SkColorType is not kAlpha_8_SkColorType |
| or kGray_8_SkColorType, and is built with SK_DEBUG defined. |
| |
| One byte corresponds to one pixel. |
| |
| @param x column index, zero or greater, and less than width() |
| @param y row index, zero or greater, and less than height() |
| @return writable unsigned 8-bit pointer to pixels |
| */ |
| uint8_t* writable_addr8(int x, int y) const { |
| return const_cast<uint8_t*>(this->addr8(x, y)); |
| } |
| |
| /** Returns writable_addr pixel address at (x, y). Result is addressable as unsigned |
| 16-bit words. Will trigger an assert() if SkColorType is not kRGB_565_SkColorType |
| or kARGB_4444_SkColorType, and is built with SK_DEBUG defined. |
| |
| One word corresponds to one pixel. |
| |
| @param x column index, zero or greater, and less than width() |
| @param y row index, zero or greater, and less than height() |
| @return writable unsigned 16-bit pointer to pixel |
| */ |
| uint16_t* writable_addr16(int x, int y) const { |
| return const_cast<uint16_t*>(this->addr16(x, y)); |
| } |
| |
| /** Returns writable pixel address at (x, y). Result is addressable as unsigned |
| 32-bit words. Will trigger an assert() if SkColorType is not |
| kRGBA_8888_SkColorType or kBGRA_8888_SkColorType, and is built with SK_DEBUG |
| defined. |
| |
| One word corresponds to one pixel. |
| |
| @param x column index, zero or greater, and less than width() |
| @param y row index, zero or greater, and less than height() |
| @return writable unsigned 32-bit pointer to pixel |
| */ |
| uint32_t* writable_addr32(int x, int y) const { |
| return const_cast<uint32_t*>(this->addr32(x, y)); |
| } |
| |
| /** Returns writable pixel address at (x, y). Result is addressable as unsigned |
| 64-bit words. Will trigger an assert() if SkColorType is not |
| kRGBA_F16_SkColorType and is built with SK_DEBUG defined. |
| |
| One word corresponds to one pixel. |
| |
| @param x column index, zero or greater, and less than width() |
| @param y row index, zero or greater, and less than height() |
| @return writable unsigned 64-bit pointer to pixel |
| */ |
| uint64_t* writable_addr64(int x, int y) const { |
| return const_cast<uint64_t*>(this->addr64(x, y)); |
| } |
| |
| /** Returns writable pixel address at (x, y). Result is addressable as unsigned |
| 16-bit words. Will trigger an assert() if SkColorType is not |
| kRGBA_F16_SkColorType and is built with SK_DEBUG defined. |
| |
| Each word represents one color component encoded as a half float. |
| Four words correspond to one pixel. |
| |
| @param x column index, zero or greater, and less than width() |
| @param y row index, zero or greater, and less than height() |
| @return writable unsigned 16-bit pointer to first component of pixel |
| */ |
| uint16_t* writable_addrF16(int x, int y) const { |
| return reinterpret_cast<uint16_t*>(writable_addr64(x, y)); |
| } |
| |
| /** Copies a SkRect of pixels to dstPixels. Copy starts at (0, 0), and does not |
| exceed SkPixmap (width(), height()). |
| |
| dstInfo specifies width, height, SkColorType, SkAlphaType, and |
| SkColorSpace of destination. dstRowBytes specifics the gap from one destination |
| row to the next. Returns true if pixels are copied. Returns false if |
| dstInfo address equals nullptr, or dstRowBytes is less than dstInfo.minRowBytes(). |
| |
| Pixels are copied only if pixel conversion is possible. If SkPixmap colorType() is |
| kGray_8_SkColorType, or kAlpha_8_SkColorType; dstInfo.colorType() must match. |
| If SkPixmap colorType() is kGray_8_SkColorType, dstInfo.colorSpace() must match. |
| If SkPixmap alphaType() is kOpaque_SkAlphaType, dstInfo.alphaType() must |
| match. If SkPixmap colorSpace() is nullptr, dstInfo.colorSpace() must match. Returns |
| false if pixel conversion is not possible. |
| |
| Returns false if SkPixmap width() or height() is zero or negative. |
| |
| @param dstInfo destination width, height, SkColorType, SkAlphaType, SkColorSpace |
| @param dstPixels destination pixel storage |
| @param dstRowBytes destination row length |
| @return true if pixels are copied to dstPixels |
| */ |
| bool readPixels(const SkImageInfo& dstInfo, void* dstPixels, size_t dstRowBytes) const { |
| return this->readPixels(dstInfo, dstPixels, dstRowBytes, 0, 0); |
| } |
| |
| /** Copies a SkRect of pixels to dstPixels. Copy starts at (srcX, srcY), and does not |
| exceed SkPixmap (width(), height()). |
| |
| dstInfo specifies width, height, SkColorType, SkAlphaType, and |
| SkColorSpace of destination. dstRowBytes specifics the gap from one destination |
| row to the next. Returns true if pixels are copied. Returns false if |
| dstInfo address equals nullptr, or dstRowBytes is less than dstInfo.minRowBytes(). |
| |
| Pixels are copied only if pixel conversion is possible. If SkPixmap colorType() is |
| kGray_8_SkColorType, or kAlpha_8_SkColorType; dstInfo.colorType() must match. |
| If SkPixmap colorType() is kGray_8_SkColorType, dstInfo.colorSpace() must match. |
| If SkPixmap alphaType() is kOpaque_SkAlphaType, dstInfo.alphaType() must |
| match. If SkPixmap colorSpace() is nullptr, dstInfo.colorSpace() must match. Returns |
| false if pixel conversion is not possible. |
| |
| srcX and srcY may be negative to copy only top or left of source. Returns |
| false if SkPixmap width() or height() is zero or negative. Returns false if: |
| abs(srcX) >= Pixmap width(), or if abs(srcY) >= Pixmap height(). |
| |
| @param dstInfo destination width, height, SkColorType, SkAlphaType, SkColorSpace |
| @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() |
| @return true if pixels are copied to dstPixels |
| */ |
| bool readPixels(const SkImageInfo& dstInfo, void* dstPixels, size_t dstRowBytes, int srcX, |
| int srcY) const; |
| |
| /** Copies a SkRect of pixels to dst. Copy starts at (srcX, srcY), and does not |
| exceed SkPixmap (width(), height()). dst specifies width, height, SkColorType, |
| SkAlphaType, and SkColorSpace of destination. Returns true if pixels are copied. |
| Returns false if dst address equals nullptr, or dst.rowBytes() is less than |
| dst SkImageInfo::minRowBytes. |
| |
| Pixels are copied only if pixel conversion is possible. If SkPixmap colorType() is |
| kGray_8_SkColorType, or kAlpha_8_SkColorType; dst.info().colorType must match. |
| If SkPixmap colorType() is kGray_8_SkColorType, dst.info().colorSpace must match. |
| If SkPixmap alphaType() is kOpaque_SkAlphaType, dst.info().alphaType must |
| match. If SkPixmap colorSpace() is nullptr, dst.info().colorSpace must match. Returns |
| false if pixel conversion is not possible. |
| |
| srcX and srcY may be negative to copy only top or left of source. Returns |
| false SkPixmap width() or height() is zero or negative. Returns false if: |
| abs(srcX) >= Pixmap width(), or if abs(srcY) >= Pixmap height(). |
| |
| @param dst SkImageInfo and pixel address to write to |
| @param srcX column index whose absolute value is less than width() |
| @param srcY row index whose absolute value is less than height() |
| @return true if pixels are copied to dst |
| */ |
| bool readPixels(const SkPixmap& dst, int srcX, int srcY) const { |
| return this->readPixels(dst.info(), dst.writable_addr(), dst.rowBytes(), srcX, srcY); |
| } |
| |
| /** Copies pixels inside bounds() to dst. dst specifies width, height, SkColorType, |
| SkAlphaType, and SkColorSpace of destination. Returns true if pixels are copied. |
| Returns false if dst address equals nullptr, or dst.rowBytes() is less than |
| dst SkImageInfo::minRowBytes. |
| |
| Pixels are copied only if pixel conversion is possible. If SkPixmap colorType() is |
| kGray_8_SkColorType, or kAlpha_8_SkColorType; dst SkColorType must match. |
| If SkPixmap colorType() is kGray_8_SkColorType, dst SkColorSpace must match. |
| If SkPixmap alphaType() is kOpaque_SkAlphaType, dst SkAlphaType must |
| match. If SkPixmap colorSpace() is nullptr, dst SkColorSpace must match. Returns |
| false if pixel conversion is not possible. |
| |
| Returns false if SkPixmap width() or height() is zero or negative. |
| |
| @param dst SkImageInfo and pixel address to write to |
| @return true if pixels are copied to dst |
| */ |
| bool readPixels(const SkPixmap& dst) const { |
| return this->readPixels(dst.info(), dst.writable_addr(), dst.rowBytes(), 0, 0); |
| } |
| |
| /** Copies SkBitmap to dst, scaling pixels to fit dst.width() and dst.height(), and |
| converting pixels to match dst.colorType() and dst.alphaType(). Returns true if |
| pixels are copied. Returns false if dst address is nullptr, or dst.rowBytes() is |
| less than dst SkImageInfo::minRowBytes. |
| |
| Pixels are copied only if pixel conversion is possible. If SkPixmap colorType() is |
| kGray_8_SkColorType, or kAlpha_8_SkColorType; dst SkColorType must match. |
| If SkPixmap colorType() is kGray_8_SkColorType, dst SkColorSpace must match. |
| If SkPixmap alphaType() is kOpaque_SkAlphaType, dst SkAlphaType must |
| match. If SkPixmap colorSpace() is nullptr, dst SkColorSpace must match. Returns |
| false if pixel conversion is not possible. |
| |
| Returns false if SkBitmap width() or height() is zero or negative. |
| |
| @param dst SkImageInfo and pixel address to write to |
| @return true if pixels are scaled to fit dst |
| |
| example: https://fiddle.skia.org/c/@Pixmap_scalePixels |
| */ |
| bool scalePixels(const SkPixmap& dst, const SkSamplingOptions&) const; |
| |
| /** Writes color to pixels bounded by subset; returns true on success. |
| Returns false if colorType() is kUnknown_SkColorType, or if subset does |
| not intersect bounds(). |
| |
| @param color sRGB unpremultiplied color to write |
| @param subset bounding integer SkRect of written pixels |
| @return true if pixels are changed |
| |
| example: https://fiddle.skia.org/c/@Pixmap_erase |
| */ |
| bool erase(SkColor color, const SkIRect& subset) const; |
| |
| /** Writes color to pixels inside bounds(); returns true on success. |
| Returns false if colorType() is kUnknown_SkColorType, or if bounds() |
| is empty. |
| |
| @param color sRGB unpremultiplied color to write |
| @return true if pixels are changed |
| */ |
| bool erase(SkColor color) const { return this->erase(color, this->bounds()); } |
| |
| /** Writes color to pixels bounded by subset; returns true on success. |
| if subset is nullptr, writes colors pixels inside bounds(). Returns false if |
| colorType() is kUnknown_SkColorType, if subset is not nullptr and does |
| not intersect bounds(), or if subset is nullptr and bounds() is empty. |
| |
| @param color unpremultiplied color to write |
| @param subset bounding integer SkRect of pixels to write; may be nullptr |
| @return true if pixels are changed |
| */ |
| bool erase(const SkColor4f& color, const SkIRect* subset = nullptr) const; |
| |
| private: |
| const void* fPixels; |
| size_t fRowBytes; |
| SkImageInfo fInfo; |
| }; |
| |
| #endif |