翻译 官方 ImageIO(一)

字数 622阅读 376

使用ImageIO的基础

ImageIO 框架提供了不透明数据类型来对图片数据进行读取从一个(CGImageSourceRef)和把一个image数据写到目标(CGImageDestionationRef)。它支持广泛的图像类型,包括标准的网络图片、高动态图、相机原始数据。ImageIO框架有其他的功能例如:

  • 对于Mac平台,最快速的图像解码和编码;
  • 能够逐渐地加载图片;
  • 支持图片的元数据;
  • 有效的缓存;
    你可以创建image source 和 image destination 对象从下面的对象中:
  • URL。图像的资源位置被一个URL所指定,那么它可以作为一个图像数据的接受商或者供应商。URL的类型是CFURLRef
  • CFDataRef 或者 CFMutalbleDataRef
  • 消费者 CGDataConsumerRef 和 数据提供者 CGDataProviderRef

在你的应用中使用ImageIO框架

导入ImageIO 框架,之后再代码文件中引入头文件 #import <ImageIO/ImageIO.h>

支持的图片格式
ImageIO框架支持大多常用的图片格式:JPEG /JPEG2000 RAW TIFF BMP PNG .每个平台支持的格式都不一样。如果你想要获取最新的ImageIO支持的图片文件类型,你可以调用这些方法:

  • CGImageSourceCopyTeypIdentifiers 返回一个数组。数据里面还有“唯一类型标识”来表示imageIO支持的图片文件类型。文件数据可以作为image source
  • CGImageDestionationCopyTypeIdentifiers:返回一个数组,数组中包含着一系列“位置类型标识”用来标识可以左右image destination的图片文件类型。
    你可以只用是CFShow方法把数组中的数据打印在Xcode控制台中。展示如代码1-1.数组中的字符串类似这种形式:com.apple.pict, public.jpeg,public.tif等等。你可以查看列表1-1,表中显示了许多关于图片的唯一类型标示字符。OSX 和iOS定义了许多常用的图片文件类型标示。定义在UICoreType.h文件中。当你需要确定一个图片的类型时,你可以使用这些常量。无论这些类型是作为source image 还是 destination image

代码1-1生成和打印支持的UTIs

    CFArrayRef mySourceTypes = CGImageSourceCopyTypeIdentifiers();
    CFShow(mySourceTypes);
    CFArrayRef myDestinationTypes = CGImageDestinationCopyTypeIdentifiers();
    CFShow(myDestinationTypes);

输出结果:

(
    "public.jpeg",
    "public.png",
    "com.compuserve.gif",
    "com.canon.tif-raw-image",
    "com.adobe.raw-image",
    "com.dxo.raw-image",
    "com.canon.cr2-raw-image",
    "com.leafamerica.raw-image",
    "com.hasselblad.fff-raw-image",
    "com.hasselblad.3fr-raw-image",
    "com.nikon.raw-image",
    "com.nikon.nrw-raw-image",
    "com.pentax.raw-image",
    "com.samsung.raw-image",
    "com.sony.raw-image",
    "com.sony.sr2-raw-image",
    "com.sony.arw-raw-image",
    "com.epson.raw-image",
    "com.kodak.raw-image",
    "public.tiff",
    "com.canon.crw-raw-image",
    "com.fuji.raw-image",
    "com.panasonic.raw-image",
    "com.panasonic.rw2-raw-image",
    "com.leica.raw-image",
    "com.leica.rwl-raw-image",
    "com.konicaminolta.raw-image",
    "com.olympus.sr-raw-image",
    "com.olympus.or-raw-image",
    "com.olympus.raw-image",
    "public.jpeg-2000",
    "com.microsoft.ico",
    "com.microsoft.bmp",
    "com.adobe.photoshop-image",
    "com.microsoft.cur",
    "com.truevision.tga-image",
    "com.ilm.openexr-image",
    "public.radiance",
    "public.mpo-image",
    "public.pbm",
    "public.pvr",
    "org.khronos.astc",
    "org.khronos.ktx",
    "com.microsoft.dds",
    "com.apple.rjpeg"
)
(
    "public.jpeg",
    "public.png",
    "com.compuserve.gif",
    "public.tiff",
    "public.jpeg-2000",
    "com.microsoft.ico",
    "com.microsoft.bmp",
    "com.adobe.photoshop-image",
    "com.adobe.pdf",
    "com.truevision.tga-image",
    "com.ilm.openexr-image",
    "public.pbm",
    "public.pvr",
    "org.khronos.astc",
    "org.khronos.ktx",
    "com.microsoft.dds",
    "com.apple.rjpeg"
)

通过打印出来的结果发现source image 支持的图像类型要比destination image 支持的图像类型多

表格1-1UTIs的常量

唯一类型标识 图片类型常量
public.image kUTTypeImage
public.png kUTTypePNG
public.jpeg kUTTypeJPEG
public.jpeg-2000(OS ) kUTTypeJPEG2000
public.tiff kUTTypeTIFF
com.apple.pict(OS) kUTTypePICT
com.compuserve.gif kUTTypeGIF

推荐阅读更多精彩内容