本文整理汇总了C++中Image::AllocateMipmaps方法的典型用法代码示例。如果您正苦于以下问题:C++ Image::AllocateMipmaps方法的具体用法?C++ Image::AllocateMipmaps怎么用?C++ Image::AllocateMipmaps使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Image
的用法示例。
在下文中一共展示了Image::AllocateMipmaps方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: ib
RADRT_API bool RADRT_CALL Decode(const void *buff, AddrSize buffLength, Image &out)
{
RAD_ASSERT(buff&&buffLength);
RAD_ASSERT(buffLength <= std::numeric_limits<stream::SPos>::max());
out.Free();
stream::MemInputBuffer ib(buff, (stream::SPos)buffLength);
stream::InputStream is(ib);
{
char sig[SigSize];
if (is.Read(sig, SigSize, 0) != SigSize)
return false;
// NOTE: png_sig_cmp() returns 0 if the sig matches the PNG sig.
if (png_sig_cmp((png_bytep)sig, 0, SigSize))
return false;
}
png_structp png;
png_infop info;
png = png_create_read_struct_2(PNG_LIBPNG_VER_STRING, 0, PNGErrorHandler, PNGWarningHandler, 0, PNGMalloc, PNGFree);
if (!png)
return false;
info = png_create_info_struct(png);
if (!info)
{
png_destroy_read_struct(&png, 0, 0);
return false;
}
png_set_read_fn(png, &is, PNGRead);
png_set_sig_bytes(png, SigSize);
try
{
png_uint_32 w, h;
int bd, color, interlace;
png_read_info(png, info);
png_get_IHDR(png, info, &w, &h, &bd, &color, &interlace, 0, 0);
if (!out.AllocateFrames(1)||!out.AllocateMipmaps(0, 1))
{
png_destroy_read_struct(&png, &info, 0);
return false;
}
Mipmap &m = out.frames[0].mipmaps[0];
out.format = Format(png, info, bd, color);
if (out.format == InvalidFormat)
{
out.Free();
png_destroy_read_struct(&png, &info, 0);
return false;
}
out.bpp = FormatBPP(out.format);
if (!out.AllocateMipmap(0, 0, w, h, w * out.bpp, w * h * out.bpp))
{
out.Free();
png_destroy_read_struct(&png, &info, 0);
return false;
}
png_set_strip_16(png);
if (color == PNG_COLOR_TYPE_PALETTE)
{
png_set_palette_to_rgb(png);
}
if (color == PNG_COLOR_TYPE_GRAY && bd < 8)
{
png_set_expand_gray_1_2_4_to_8(png);
}
if (png_get_valid(png, info, PNG_INFO_tRNS))
{
png_set_tRNS_to_alpha(png);
}
png_set_swap(png);
int passes = png_set_interlace_handling(png);
png_bytep dstRow = 0;
png_bytep imgRow = 0;
png_uint_32 stride = (png_uint_32)png_get_rowbytes(png, info);
RAD_ASSERT(stride >= m.stride);
if (stride != m.stride)
{
dstRow = (png_bytep)safe_zone_malloc(ZImageCodec, stride, 0);
}
for (int pass = 0; pass < passes; ++pass)
//.........这里部分代码省略.........