/* * Copyright 2018 Google Inc. * * Use of this source code is governed by a BSD-style license that can be * found in the LICENSE file. */ #include "SkImageInfo.h" #include "SkColorSpace.h" #include "sk_imageinfo.h" #include "sk_colorspace.h" const struct { sk_colortype_t fC; SkColorType fSK; } gColorTypeMap[] = { { UNKNOWN_SK_COLORTYPE, kUnknown_SkColorType }, { RGBA_8888_SK_COLORTYPE, kRGBA_8888_SkColorType }, { BGRA_8888_SK_COLORTYPE, kBGRA_8888_SkColorType }, { ALPHA_8_SK_COLORTYPE, kAlpha_8_SkColorType }, { GRAY_8_SK_COLORTYPE, kGray_8_SkColorType }, { RGBA_F16_SK_COLORTYPE, kRGBA_F16_SkColorType }, { RGBA_F32_SK_COLORTYPE, kRGBA_F32_SkColorType }, }; const struct { sk_alphatype_t fC; SkAlphaType fSK; } gAlphaTypeMap[] = { { OPAQUE_SK_ALPHATYPE, kOpaque_SkAlphaType }, { PREMUL_SK_ALPHATYPE, kPremul_SkAlphaType }, { UNPREMUL_SK_ALPHATYPE, kUnpremul_SkAlphaType }, }; static bool from_c_colortype(sk_colortype_t cCT, SkColorType* skCT) { for (size_t i = 0; i < SK_ARRAY_COUNT(gColorTypeMap); ++i) { if (gColorTypeMap[i].fC == cCT) { if (skCT) { *skCT = gColorTypeMap[i].fSK; } return true; } } return false; } static bool to_c_colortype(SkColorType skCT, sk_colortype_t* cCT) { for (size_t i = 0; i < SK_ARRAY_COUNT(gColorTypeMap); ++i) { if (gColorTypeMap[i].fSK == skCT) { if (cCT) { *cCT = gColorTypeMap[i].fC; } return true; } } return false; } static bool from_c_alphatype(sk_alphatype_t cAT, SkAlphaType* skAT) { for (size_t i = 0; i < SK_ARRAY_COUNT(gAlphaTypeMap); ++i) { if (gAlphaTypeMap[i].fC == cAT) { if (skAT) { *skAT = gAlphaTypeMap[i].fSK; } return true; } } return false; } static bool to_c_alphatype(SkAlphaType skAT, sk_alphatype_t* cAT) { for (size_t i = 0; i < SK_ARRAY_COUNT(gAlphaTypeMap); ++i) { if (gAlphaTypeMap[i].fSK == skAT) { if (cAT) { *cAT = gAlphaTypeMap[i].fC; } return true; } } return false; } const SkImageInfo* ToImageInfo(const sk_imageinfo_t* cinfo) { return reinterpret_cast(cinfo); } ///////////////////////////////////////////////////////////////////////////////////////////// sk_imageinfo_t* sk_imageinfo_new(int w, int h, sk_colortype_t cct, sk_alphatype_t cat, sk_colorspace_t* ccs) { SkColorType ct; SkAlphaType at; if (!from_c_colortype(cct, &ct) || !from_c_alphatype(cat, &at)) { return nullptr; } SkColorSpace* cs = (SkColorSpace*)ccs; SkImageInfo* info = new SkImageInfo(SkImageInfo::Make(w, h, ct, at, sk_ref_sp(cs))); return reinterpret_cast(info); } void sk_imageinfo_delete(sk_imageinfo_t* cinfo) { delete ToImageInfo(cinfo); } int sk_imageinfo_get_width(const sk_imageinfo_t* cinfo) { return ToImageInfo(cinfo)->width(); } int sk_imageinfo_get_height(const sk_imageinfo_t* cinfo) { return ToImageInfo(cinfo)->height(); } sk_colortype_t sk_imageinfo_get_colortype(const sk_imageinfo_t* cinfo) { sk_colortype_t ct; return to_c_colortype(ToImageInfo(cinfo)->colorType(), &ct) ? ct : UNKNOWN_SK_COLORTYPE; } sk_alphatype_t sk_imageinfo_get_alphatype(const sk_imageinfo_t* cinfo) { sk_alphatype_t at; // odd that we return premul on failure... return to_c_alphatype(ToImageInfo(cinfo)->alphaType(), &at) ? at : PREMUL_SK_ALPHATYPE; } sk_colorspace_t* sk_imageinfo_get_colorspace(const sk_imageinfo_t* cinfo) { return reinterpret_cast(ToImageInfo(cinfo)->colorSpace()); } ///////////////////////////////////////////////////////////////////////////////////////////// sk_colorspace_t* sk_colorspace_new_srgb() { return reinterpret_cast(SkColorSpace::MakeSRGB().release()); } void sk_colorspace_ref(sk_colorspace_t* cs) { SkSafeRef(reinterpret_cast(cs)); } void sk_colorspace_unref(sk_colorspace_t* cs) { SkSafeUnref(reinterpret_cast(cs)); }