13011 lines
422 KiB
C
Raw Permalink Normal View History

2020-04-22 12:56:21 -04:00
/*
File: ImageCompression.h
Contains: QuickTime Image Compression Interfaces.
Version: QuickTime 7.3
Copyright: (c) 2007 (c) 1990-2007 by Apple Inc., all rights reserved
Bugs?: For bug reports, consult the following page on
the World Wide Web:
http://developer.apple.com/bugreporter/
*/
#ifndef __IMAGECOMPRESSION__
#define __IMAGECOMPRESSION__
#ifndef __MACTYPES__
#include <MacTypes.h>
#endif
#ifndef __QUICKDRAW__
#include <Quickdraw.h>
#endif
#ifndef __QDOFFSCREEN__
#include <QDOffscreen.h>
#endif
#ifndef __COMPONENTS__
#include <Components.h>
#endif
#ifndef __DIALOGS__
#include <Dialogs.h>
#endif
#ifndef __STANDARDFILE__
#include <StandardFile.h>
#endif
#if TARGET_OS_MAC
#include <OpenGL/OpenGL.h>
#include <QuartzCore/CoreVideo.h>
#else
#include <CoreVideo.h>
#endif /* TARGET_OS_MAC */
#if PRAGMA_ONCE
#pragma once
#endif
#ifdef __cplusplus
extern "C" {
#endif
#if PRAGMA_IMPORT
#pragma import on
#endif
#if PRAGMA_STRUCT_ALIGN
#pragma options align=mac68k
#elif PRAGMA_STRUCT_PACKPUSH
#pragma pack(push, 2)
#elif PRAGMA_STRUCT_PACK
#pragma pack(2)
#endif
#ifndef AVAILABLE_MAC_OS_X_VERSION_10_5_AND_LATER
#define AVAILABLE_MAC_OS_X_VERSION_10_5_AND_LATER WEAK_IMPORT_ATTRIBUTE
#endif
#ifndef AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER_BUT_DEPRECATED_IN_MAC_OS_X_VERSION_10_5
#define AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER_BUT_DEPRECATED_IN_MAC_OS_X_VERSION_10_5 AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER
#endif
#ifndef AVAILABLE_MAC_OS_X_VERSION_10_1_AND_LATER_BUT_DEPRECATED_IN_MAC_OS_X_VERSION_10_5
#define AVAILABLE_MAC_OS_X_VERSION_10_1_AND_LATER_BUT_DEPRECATED_IN_MAC_OS_X_VERSION_10_5 AVAILABLE_MAC_OS_X_VERSION_10_1_AND_LATER
#endif
#ifndef AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER_BUT_DEPRECATED_IN_MAC_OS_X_VERSION_10_5
#define AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER_BUT_DEPRECATED_IN_MAC_OS_X_VERSION_10_5 AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER
#endif
#ifndef AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER_BUT_DEPRECATED_IN_MAC_OS_X_VERSION_10_5
#define AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER_BUT_DEPRECATED_IN_MAC_OS_X_VERSION_10_5 AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
#endif
#ifndef AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER_BUT_DEPRECATED_IN_MAC_OS_X_VERSION_10_5
#define AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER_BUT_DEPRECATED_IN_MAC_OS_X_VERSION_10_5 AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER
#endif
/* QuickTime is not available to 64-bit clients */
#if !__LP64__
struct MatrixRecord {
Fixed matrix[3][3];
};
typedef struct MatrixRecord MatrixRecord;
typedef MatrixRecord * MatrixRecordPtr;
enum {
kRawCodecType = FOUR_CHAR_CODE('raw '),
kCinepakCodecType = FOUR_CHAR_CODE('cvid'),
kGraphicsCodecType = FOUR_CHAR_CODE('smc '),
kAnimationCodecType = FOUR_CHAR_CODE('rle '),
kVideoCodecType = FOUR_CHAR_CODE('rpza'),
kComponentVideoCodecType = FOUR_CHAR_CODE('yuv2'),
kJPEGCodecType = FOUR_CHAR_CODE('jpeg'),
kMotionJPEGACodecType = FOUR_CHAR_CODE('mjpa'),
kMotionJPEGBCodecType = FOUR_CHAR_CODE('mjpb'),
kSGICodecType = FOUR_CHAR_CODE('.SGI'),
kPlanarRGBCodecType = FOUR_CHAR_CODE('8BPS'),
kMacPaintCodecType = FOUR_CHAR_CODE('PNTG'),
kGIFCodecType = FOUR_CHAR_CODE('gif '),
kPhotoCDCodecType = FOUR_CHAR_CODE('kpcd'),
kQuickDrawGXCodecType = FOUR_CHAR_CODE('qdgx'),
kAVRJPEGCodecType = FOUR_CHAR_CODE('avr '),
kOpenDMLJPEGCodecType = FOUR_CHAR_CODE('dmb1'),
kBMPCodecType = FOUR_CHAR_CODE('WRLE'),
kWindowsRawCodecType = FOUR_CHAR_CODE('WRAW'),
kVectorCodecType = FOUR_CHAR_CODE('path'),
kQuickDrawCodecType = FOUR_CHAR_CODE('qdrw'),
kWaterRippleCodecType = FOUR_CHAR_CODE('ripl'),
kFireCodecType = FOUR_CHAR_CODE('fire'),
kCloudCodecType = FOUR_CHAR_CODE('clou'),
kH261CodecType = FOUR_CHAR_CODE('h261'),
kH263CodecType = FOUR_CHAR_CODE('h263'),
kDVCNTSCCodecType = FOUR_CHAR_CODE('dvc '), /* DV - NTSC and DVCPRO NTSC (available in QuickTime 6.0 or later)*/
/* NOTE: kDVCProNTSCCodecType is deprecated. */
/* Use kDVCNTSCCodecType instead -- as far as the codecs are concerned, */
/* the two data formats are identical.*/
kDVCPALCodecType = FOUR_CHAR_CODE('dvcp'),
kDVCProPALCodecType = FOUR_CHAR_CODE('dvpp'), /* available in QuickTime 6.0 or later*/
kDVCPro50NTSCCodecType = FOUR_CHAR_CODE('dv5n'),
kDVCPro50PALCodecType = FOUR_CHAR_CODE('dv5p'),
kDVCPro100NTSCCodecType = FOUR_CHAR_CODE('dv1n'),
kDVCPro100PALCodecType = FOUR_CHAR_CODE('dv1p'),
kDVCPROHD720pCodecType = FOUR_CHAR_CODE('dvhp'),
kDVCPROHD1080i60CodecType = FOUR_CHAR_CODE('dvh6'),
kDVCPROHD1080i50CodecType = FOUR_CHAR_CODE('dvh5'),
kBaseCodecType = FOUR_CHAR_CODE('base'),
kFLCCodecType = FOUR_CHAR_CODE('flic'),
kTargaCodecType = FOUR_CHAR_CODE('tga '),
kPNGCodecType = FOUR_CHAR_CODE('png '),
kTIFFCodecType = FOUR_CHAR_CODE('tiff'), /* NOTE: despite what might seem obvious from the two constants*/
/* below and their names, they really are correct. 'yuvu' really */
/* does mean signed, and 'yuvs' really does mean unsigned. Really. */
kComponentVideoSigned = FOUR_CHAR_CODE('yuvu'),
kComponentVideoUnsigned = FOUR_CHAR_CODE('yuvs'),
kCMYKCodecType = FOUR_CHAR_CODE('cmyk'),
kMicrosoftVideo1CodecType = FOUR_CHAR_CODE('msvc'),
kSorensonCodecType = FOUR_CHAR_CODE('SVQ1'),
kSorenson3CodecType = FOUR_CHAR_CODE('SVQ3'), /* available in QuickTime 5 and later*/
kIndeo4CodecType = FOUR_CHAR_CODE('IV41'),
kMPEG4VisualCodecType = FOUR_CHAR_CODE('mp4v'),
k64ARGBCodecType = FOUR_CHAR_CODE('b64a'),
k48RGBCodecType = FOUR_CHAR_CODE('b48r'),
k32AlphaGrayCodecType = FOUR_CHAR_CODE('b32a'),
k16GrayCodecType = FOUR_CHAR_CODE('b16g'),
kMpegYUV420CodecType = FOUR_CHAR_CODE('myuv'),
kYUV420CodecType = FOUR_CHAR_CODE('y420'),
kSorensonYUV9CodecType = FOUR_CHAR_CODE('syv9'),
k422YpCbCr8CodecType = FOUR_CHAR_CODE('2vuy'), /* Component Y'CbCr 8-bit 4:2:2 */
k444YpCbCr8CodecType = FOUR_CHAR_CODE('v308'), /* Component Y'CbCr 8-bit 4:4:4 */
k4444YpCbCrA8CodecType = FOUR_CHAR_CODE('v408'), /* Component Y'CbCrA 8-bit 4:4:4:4 */
k422YpCbCr16CodecType = FOUR_CHAR_CODE('v216'), /* Component Y'CbCr 10,12,14,16-bit 4:2:2*/
k422YpCbCr10CodecType = FOUR_CHAR_CODE('v210'), /* Component Y'CbCr 10-bit 4:2:2 */
k444YpCbCr10CodecType = FOUR_CHAR_CODE('v410'), /* Component Y'CbCr 10-bit 4:4:4 */
k4444YpCbCrA8RCodecType = FOUR_CHAR_CODE('r408'), /* Component Y'CbCrA 8-bit 4:4:4:4, rendering format. full range alpha, zero biased yuv*/
kJPEG2000CodecType = FOUR_CHAR_CODE('mjp2'),
kPixletCodecType = FOUR_CHAR_CODE('pxlt'),
kH264CodecType = FOUR_CHAR_CODE('avc1')
};
/* one source effects */
enum {
kBlurImageFilterType = FOUR_CHAR_CODE('blur'),
kSharpenImageFilterType = FOUR_CHAR_CODE('shrp'),
kEdgeDetectImageFilterType = FOUR_CHAR_CODE('edge'),
kEmbossImageFilterType = FOUR_CHAR_CODE('embs'),
kConvolveImageFilterType = FOUR_CHAR_CODE('genk'),
kAlphaGainImageFilterType = FOUR_CHAR_CODE('gain'),
kRGBColorBalanceImageFilterType = FOUR_CHAR_CODE('rgbb'),
kHSLColorBalanceImageFilterType = FOUR_CHAR_CODE('hslb'),
kColorSyncImageFilterType = FOUR_CHAR_CODE('sync'),
kFilmNoiseImageFilterType = FOUR_CHAR_CODE('fmns'),
kSolarizeImageFilterType = FOUR_CHAR_CODE('solr'),
kColorTintImageFilterType = FOUR_CHAR_CODE('tint'),
kLensFlareImageFilterType = FOUR_CHAR_CODE('lens'),
kBrightnessContrastImageFilterType = FOUR_CHAR_CODE('brco')
};
/* two source effects */
enum {
kAlphaCompositorTransitionType = FOUR_CHAR_CODE('blnd'),
kCrossFadeTransitionType = FOUR_CHAR_CODE('dslv'),
kChannelCompositeEffectType = FOUR_CHAR_CODE('chan'),
kChromaKeyTransitionType = FOUR_CHAR_CODE('ckey'),
kImplodeTransitionType = FOUR_CHAR_CODE('mplo'),
kExplodeTransitionType = FOUR_CHAR_CODE('xplo'),
kGradientTransitionType = FOUR_CHAR_CODE('matt'),
kPushTransitionType = FOUR_CHAR_CODE('push'),
kSlideTransitionType = FOUR_CHAR_CODE('slid'),
kWipeTransitionType = FOUR_CHAR_CODE('smpt'),
kIrisTransitionType = FOUR_CHAR_CODE('smp2'),
kRadialTransitionType = FOUR_CHAR_CODE('smp3'),
kMatrixTransitionType = FOUR_CHAR_CODE('smp4'),
kZoomTransitionType = FOUR_CHAR_CODE('zoom')
};
/* three source effects */
enum {
kTravellingMatteEffectType = FOUR_CHAR_CODE('trav')
};
/* Supported by QTNewGWorld in QuickTime 4.0 and later */
enum {
kCMYKPixelFormat = FOUR_CHAR_CODE('cmyk'), /* CMYK, 8-bit */
k64ARGBPixelFormat = FOUR_CHAR_CODE('b64a'), /* ARGB, 16-bit big-endian samples */
k48RGBPixelFormat = FOUR_CHAR_CODE('b48r'), /* RGB, 16-bit big-endian samples */
k32AlphaGrayPixelFormat = FOUR_CHAR_CODE('b32a'), /* AlphaGray, 16-bit big-endian samples */
k16GrayPixelFormat = FOUR_CHAR_CODE('b16g'), /* Grayscale, 16-bit big-endian samples */
k422YpCbCr8PixelFormat = FOUR_CHAR_CODE('2vuy') /* Component Y'CbCr 8-bit 4:2:2, ordered Cb Y'0 Cr Y'1 */
};
/* Supported by QTNewGWorld in QuickTime 4.1.2 and later */
enum {
k4444YpCbCrA8PixelFormat = FOUR_CHAR_CODE('v408'), /* Component Y'CbCrA 8-bit 4:4:4:4, ordered Cb Y' Cr A */
k4444YpCbCrA8RPixelFormat = FOUR_CHAR_CODE('r408') /* Component Y'CbCrA 8-bit 4:4:4:4, rendering format. full range alpha, zero biased yuv, ordered A Y' Cb Cr */
};
/* Supported by QTNewGWorld in QuickTime 6.0 and later */
enum {
kYUV420PixelFormat = FOUR_CHAR_CODE('y420') /* Planar Component Y'CbCr 8-bit 4:2:0. PixMap baseAddr points to a big-endian PlanarPixmapInfoYUV420 struct; see ImageCodec.i. */
};
/* These are the bits that are set in the Component flags, and also in the codecInfo struct. */
enum {
codecInfoDoes1 = (1L << 0), /* codec can work with 1-bit pixels */
codecInfoDoes2 = (1L << 1), /* codec can work with 2-bit pixels */
codecInfoDoes4 = (1L << 2), /* codec can work with 4-bit pixels */
codecInfoDoes8 = (1L << 3), /* codec can work with 8-bit pixels */
codecInfoDoes16 = (1L << 4), /* codec can work with 16-bit pixels */
codecInfoDoes32 = (1L << 5), /* codec can work with 32-bit pixels */
codecInfoDoesDither = (1L << 6), /* codec can do ditherMode */
codecInfoDoesStretch = (1L << 7), /* codec can stretch to arbitrary sizes */
codecInfoDoesShrink = (1L << 8), /* codec can shrink to arbitrary sizes */
codecInfoDoesMask = (1L << 9), /* codec can mask to clipping regions */
codecInfoDoesTemporal = (1L << 10), /* codec can handle temporal redundancy */
codecInfoDoesDouble = (1L << 11), /* codec can stretch to double size exactly */
codecInfoDoesQuad = (1L << 12), /* codec can stretch to quadruple size exactly */
codecInfoDoesHalf = (1L << 13), /* codec can shrink to half size */
codecInfoDoesQuarter = (1L << 14), /* codec can shrink to quarter size */
codecInfoDoesRotate = (1L << 15), /* codec can rotate on decompress */
codecInfoDoesHorizFlip = (1L << 16), /* codec can flip horizontally on decompress */
codecInfoDoesVertFlip = (1L << 17), /* codec can flip vertically on decompress */
codecInfoHasEffectParameterList = (1L << 18), /* codec implements get effects parameter list call, once was codecInfoDoesSkew */
codecInfoDoesBlend = (1L << 19), /* codec can blend on decompress */
codecInfoDoesReorder = (1L << 19), /* codec can rearrange frames during compression */
codecInfoDoesWarp = (1L << 20), /* codec can warp arbitrarily on decompress */
codecInfoDoesMultiPass = (1L << 20), /* codec can perform multi-pass compression */
codecInfoDoesRecompress = (1L << 21), /* codec can recompress image without accumulating errors */
codecInfoDoesSpool = (1L << 22), /* codec can spool image data */
codecInfoDoesRateConstrain = (1L << 23) /* codec can data rate constrain */
};
enum {
codecInfoDepth1 = (1L << 0), /* compressed data at 1 bpp depth available */
codecInfoDepth2 = (1L << 1), /* compressed data at 2 bpp depth available */
codecInfoDepth4 = (1L << 2), /* compressed data at 4 bpp depth available */
codecInfoDepth8 = (1L << 3), /* compressed data at 8 bpp depth available */
codecInfoDepth16 = (1L << 4), /* compressed data at 16 bpp depth available */
codecInfoDepth32 = (1L << 5), /* compressed data at 32 bpp depth available */
codecInfoDepth24 = (1L << 6), /* compressed data at 24 bpp depth available */
codecInfoDepth33 = (1L << 7), /* compressed data at 1 bpp monochrome depth available */
codecInfoDepth34 = (1L << 8), /* compressed data at 2 bpp grayscale depth available */
codecInfoDepth36 = (1L << 9), /* compressed data at 4 bpp grayscale depth available */
codecInfoDepth40 = (1L << 10), /* compressed data at 8 bpp grayscale depth available */
codecInfoStoresClut = (1L << 11), /* compressed data can have custom cluts */
codecInfoDoesLossless = (1L << 12), /* compressed data can be stored in lossless format */
codecInfoSequenceSensitive = (1L << 13) /* compressed data is sensitive to out of sequence decoding */
};
/* input sequence flags*/
enum {
codecFlagUseImageBuffer = (1L << 0), /* decompress*/
codecFlagUseScreenBuffer = (1L << 1), /* decompress*/
codecFlagUpdatePrevious = (1L << 2), /* compress*/
codecFlagNoScreenUpdate = (1L << 3), /* decompress*/
codecFlagWasCompressed = (1L << 4), /* compress*/
codecFlagDontOffscreen = (1L << 5), /* decompress*/
codecFlagUpdatePreviousComp = (1L << 6), /* compress*/
codecFlagForceKeyFrame = (1L << 7), /* compress*/
codecFlagOnlyScreenUpdate = (1L << 8), /* decompress*/
codecFlagLiveGrab = (1L << 9), /* compress*/
codecFlagDiffFrame = (1L << 9), /* decompress*/
codecFlagDontUseNewImageBuffer = (1L << 10), /* decompress*/
codecFlagInterlaceUpdate = (1L << 11), /* decompress*/
codecFlagCatchUpDiff = (1L << 12), /* decompress*/
codecFlagSupportDisable = (1L << 13), /* decompress*/
codecFlagReenable = (1L << 14) /* decompress*/
};
/* output sequence flags*/
enum {
codecFlagOutUpdateOnNextIdle = (1L << 9),
codecFlagOutUpdateOnDataSourceChange = (1L << 10),
codecFlagSequenceSensitive = (1L << 11),
codecFlagOutUpdateOnTimeChange = (1L << 12),
codecFlagImageBufferNotSourceImage = (1L << 13),
codecFlagUsedNewImageBuffer = (1L << 14),
codecFlagUsedImageBuffer = (1L << 15)
};
enum {
/* The minimum data size for spooling in or out data */
codecMinimumDataSize = 32768L
};
enum {
compressorComponentType = FOUR_CHAR_CODE('imco'), /* the type for "Components" which compress images */
decompressorComponentType = FOUR_CHAR_CODE('imdc') /* the type for "Components" which decompress images */
};
typedef Component CompressorComponent;
typedef Component DecompressorComponent;
typedef Component CodecComponent;
#define anyCodec ((CodecComponent)0)
#define bestSpeedCodec ((CodecComponent)-1)
#define bestFidelityCodec ((CodecComponent)-2)
#define bestCompressionCodec ((CodecComponent)-3)
typedef OSType CodecType;
typedef unsigned short CodecFlags;
typedef unsigned long CodecQ;
enum {
codecLosslessQuality = 0x00000400,
codecMaxQuality = 0x000003FF,
codecMinQuality = 0x00000000,
codecLowQuality = 0x00000100,
codecNormalQuality = 0x00000200,
codecHighQuality = 0x00000300
};
enum {
codecLockBitsShieldCursor = (1 << 0) /* shield cursor */
};
enum {
codecCompletionSource = (1 << 0), /* asynchronous codec is done with source data */
codecCompletionDest = (1 << 1), /* asynchronous codec is done with destination data */
codecCompletionDontUnshield = (1 << 2), /* on dest complete don't unshield cursor */
codecCompletionWentOffscreen = (1 << 3), /* codec used offscreen buffer */
codecCompletionUnlockBits = (1 << 4), /* on dest complete, call ICMSequenceUnlockBits */
codecCompletionForceChainFlush = (1 << 5), /* ICM needs to flush the whole chain */
codecCompletionDropped = (1 << 6), /* codec decided to drop this frame */
codecCompletionDecoded = (1 << 10), /* codec has decoded this frame; if it is cancelled and rescheduled, set icmFrameAlreadyDecoded in ICMFrameTimeRecord.flags */
codecCompletionNotDisplayable = (1 << 11), /* the frame may still be scheduled for decode, but will not be able to be displayed because the buffer containing it will need to be recycled to display earlier frames. */
codecCompletionNotDrawn = (1 << 12) /* set in conjunction with codecCompletionDest to indicate that the frame was not drawn */
};
enum {
codecProgressOpen = 0,
codecProgressUpdatePercent = 1,
codecProgressClose = 2
};
typedef CALLBACK_API( OSErr , ICMDataProcPtr )(Ptr *dataP, long bytesNeeded, long refcon);
typedef CALLBACK_API( OSErr , ICMFlushProcPtr )(Ptr data, long bytesAdded, long refcon);
typedef CALLBACK_API( void , ICMCompletionProcPtr )(OSErr result, short flags, long refcon);
typedef CALLBACK_API( OSErr , ICMProgressProcPtr )(short message, Fixed completeness, long refcon);
typedef CALLBACK_API( void , StdPixProcPtr )(PixMap *src, Rect *srcRect, MatrixRecord *matrix, short mode, RgnHandle mask, PixMap *matte, Rect *matteRect, short flags);
typedef CALLBACK_API( void , QDPixProcPtr )(PixMap *src, Rect *srcRect, MatrixRecord *matrix, short mode, RgnHandle mask, PixMap *matte, Rect *matteRect, short flags);
typedef CALLBACK_API( void , ICMAlignmentProcPtr )(Rect *rp, long refcon);
typedef CALLBACK_API( void , ICMCursorShieldedProcPtr )(const Rect *r, void *refcon, long flags);
typedef CALLBACK_API( void , ICMMemoryDisposedProcPtr )(Ptr memoryBlock, void *refcon);
typedef void * ICMCursorNotify;
typedef CALLBACK_API( OSErr , ICMConvertDataFormatProcPtr )(void *refCon, long flags, Handle desiredFormat, Handle sourceDataFormat, void *srcData, long srcDataSize, void **dstData, long *dstDataSize);
typedef STACK_UPP_TYPE(ICMDataProcPtr) ICMDataUPP;
typedef STACK_UPP_TYPE(ICMFlushProcPtr) ICMFlushUPP;
typedef STACK_UPP_TYPE(ICMCompletionProcPtr) ICMCompletionUPP;
typedef STACK_UPP_TYPE(ICMProgressProcPtr) ICMProgressUPP;
typedef STACK_UPP_TYPE(StdPixProcPtr) StdPixUPP;
typedef STACK_UPP_TYPE(QDPixProcPtr) QDPixUPP;
typedef STACK_UPP_TYPE(ICMAlignmentProcPtr) ICMAlignmentUPP;
typedef STACK_UPP_TYPE(ICMCursorShieldedProcPtr) ICMCursorShieldedUPP;
typedef STACK_UPP_TYPE(ICMMemoryDisposedProcPtr) ICMMemoryDisposedUPP;
typedef STACK_UPP_TYPE(ICMConvertDataFormatProcPtr) ICMConvertDataFormatUPP;
typedef long ImageSequence;
typedef long ImageSequenceDataSource;
typedef long ImageTranscodeSequence;
typedef long ImageFieldSequence;
struct ICMProgressProcRecord {
ICMProgressUPP progressProc;
long progressRefCon;
};
typedef struct ICMProgressProcRecord ICMProgressProcRecord;
typedef ICMProgressProcRecord * ICMProgressProcRecordPtr;
struct ICMCompletionProcRecord {
ICMCompletionUPP completionProc;
long completionRefCon;
};
typedef struct ICMCompletionProcRecord ICMCompletionProcRecord;
typedef ICMCompletionProcRecord * ICMCompletionProcRecordPtr;
struct ICMDataProcRecord {
ICMDataUPP dataProc;
long dataRefCon;
};
typedef struct ICMDataProcRecord ICMDataProcRecord;
typedef ICMDataProcRecord * ICMDataProcRecordPtr;
struct ICMFlushProcRecord {
ICMFlushUPP flushProc;
long flushRefCon;
};
typedef struct ICMFlushProcRecord ICMFlushProcRecord;
typedef ICMFlushProcRecord * ICMFlushProcRecordPtr;
struct ICMAlignmentProcRecord {
ICMAlignmentUPP alignmentProc;
long alignmentRefCon;
};
typedef struct ICMAlignmentProcRecord ICMAlignmentProcRecord;
typedef ICMAlignmentProcRecord * ICMAlignmentProcRecordPtr;
struct DataRateParams {
long dataRate;
long dataOverrun;
long frameDuration;
long keyFrameRate;
CodecQ minSpatialQuality;
CodecQ minTemporalQuality;
};
typedef struct DataRateParams DataRateParams;
typedef DataRateParams * DataRateParamsPtr;
struct ImageDescription {
long idSize; /* total size of ImageDescription including extra data ( CLUTs and other per sequence data ) */
CodecType cType; /* what kind of codec compressed this data */
long resvd1; /* reserved for Apple use */
short resvd2; /* reserved for Apple use */
short dataRefIndex; /* set to zero */
short version; /* which version is this data */
short revisionLevel; /* what version of that codec did this */
long vendor; /* whose codec compressed this data */
CodecQ temporalQuality; /* what was the temporal quality factor */
CodecQ spatialQuality; /* what was the spatial quality factor */
short width; /* how many pixels wide is this data */
short height; /* how many pixels high is this data */
Fixed hRes; /* horizontal resolution */
Fixed vRes; /* vertical resolution */
long dataSize; /* if known, the size of data for this image descriptor */
short frameCount; /* number of frames this description applies to */
Str31 name; /* name of codec ( in case not installed ) */
short depth; /* what depth is this data (1-32) or ( 33-40 grayscale ) */
short clutID; /* clut id or if 0 clut follows or -1 if no clut */
};
typedef struct ImageDescription ImageDescription;
typedef ImageDescription * ImageDescriptionPtr;
typedef ImageDescriptionPtr * ImageDescriptionHandle;
struct CodecInfo {
Str31 typeName; /* name of the codec type i.e.: 'Apple Image Compression' */
short version; /* version of the codec data that this codec knows about */
short revisionLevel; /* revision level of this codec i.e: 0x00010001 (1.0.1) */
long vendor; /* Maker of this codec i.e: 'appl' */
long decompressFlags; /* codecInfo flags for decompression capabilities */
long compressFlags; /* codecInfo flags for compression capabilities */
long formatFlags; /* codecInfo flags for compression format details */
UInt8 compressionAccuracy; /* measure (1-255) of accuracy of this codec for compress (0 if unknown) */
UInt8 decompressionAccuracy; /* measure (1-255) of accuracy of this codec for decompress (0 if unknown) */
unsigned short compressionSpeed; /* ( millisecs for compressing 320x240 on base mac II) (0 if unknown) */
unsigned short decompressionSpeed; /* ( millisecs for decompressing 320x240 on mac II)(0 if unknown) */
UInt8 compressionLevel; /* measure (1-255) of compression level of this codec (0 if unknown) */
UInt8 resvd; /* pad */
short minimumHeight; /* minimum height of image (block size) */
short minimumWidth; /* minimum width of image (block size) */
short decompressPipelineLatency; /* in milliseconds ( for asynchronous codecs ) */
short compressPipelineLatency; /* in milliseconds ( for asynchronous codecs ) */
long privateData;
};
typedef struct CodecInfo CodecInfo;
struct CodecNameSpec {
CodecComponent codec;
CodecType cType;
Str31 typeName;
Handle name;
};
typedef struct CodecNameSpec CodecNameSpec;
struct CodecNameSpecList {
short count;
CodecNameSpec list[1];
};
typedef struct CodecNameSpecList CodecNameSpecList;
typedef CodecNameSpecList * CodecNameSpecListPtr;
enum {
defaultDither = 0,
forceDither = 1,
suppressDither = 2,
useColorMatching = 4
};
enum {
callStdBits = 1,
callOldBits = 2,
noDefaultOpcodes = 4
};
enum {
graphicsModeStraightAlpha = 256,
graphicsModePreWhiteAlpha = 257,
graphicsModePreBlackAlpha = 258,
graphicsModeComposition = 259,
graphicsModeStraightAlphaBlend = 260,
graphicsModePreMulColorAlpha = 261,
graphicsModePerComponentAlpha = 272
};
enum {
evenField1ToEvenFieldOut = 1 << 0,
evenField1ToOddFieldOut = 1 << 1,
oddField1ToEvenFieldOut = 1 << 2,
oddField1ToOddFieldOut = 1 << 3,
evenField2ToEvenFieldOut = 1 << 4,
evenField2ToOddFieldOut = 1 << 5,
oddField2ToEvenFieldOut = 1 << 6,
oddField2ToOddFieldOut = 1 << 7
};
/* Flags for ICMFrameTimeRecord.flags */
enum {
icmFrameTimeHasVirtualStartTimeAndDuration = 1 << 0,
icmFrameAlreadyDecoded = 1 << 1,
icmFrameTimeIsNonScheduledDisplayTime = 1 << 2,
icmFrameTimeHasDecodeTime = 1 << 3,
icmFrameTimeDecodeImmediately = 1 << 4,
icmFrameTimeDoNotDisplay = 1 << 5
};
struct ICMFrameTimeRecord {
wide value; /* frame display time*/
long scale; /* timescale of value/duration fields*/
void * base; /* timebase*/
long duration; /* duration frame is to be displayed (0 if unknown)*/
Fixed rate; /* rate of timebase relative to wall-time*/
long recordSize; /* total number of bytes in ICMFrameTimeRecord*/
long frameNumber; /* number of frame, zero if not known*/
long flags;
wide virtualStartTime; /* conceptual start time*/
long virtualDuration; /* conceptual duration*/
/* The following fields only exist for QuickTime 7.0 and greater. */
TimeValue64 decodeTime; /* suggested decode time, if icmFrameTimeHasDecodeTime is set in flags*/
};
typedef struct ICMFrameTimeRecord ICMFrameTimeRecord;
typedef ICMFrameTimeRecord * ICMFrameTimePtr;
#ifndef __QTUUID__
#define __QTUUID__ 1
/* QuickTime flavor of universally unique identifier (uuid)*/
struct QTUUID {
UInt32 data1;
UInt16 data2;
UInt16 data3;
UInt8 data4[8];
};
typedef struct QTUUID QTUUID;
typedef QTUUID QTMediaContextID;
#endif /* !defined(__QTUUID__) */
/* See Movies.h for the flags themselves. */
typedef UInt32 MediaSampleFlags;
/*
* NewICMDataUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( ICMDataUPP )
NewICMDataUPP(ICMDataProcPtr userRoutine);
#if !OPAQUE_UPP_TYPES
enum { uppICMDataProcInfo = 0x00000FE0 }; /* pascal 2_bytes Func(4_bytes, 4_bytes, 4_bytes) */
#ifdef __cplusplus
inline DEFINE_API_C(ICMDataUPP) NewICMDataUPP(ICMDataProcPtr userRoutine) { return (ICMDataUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppICMDataProcInfo, GetCurrentArchitecture()); }
#else
#define NewICMDataUPP(userRoutine) (ICMDataUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppICMDataProcInfo, GetCurrentArchitecture())
#endif
#endif
/*
* NewICMFlushUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( ICMFlushUPP )
NewICMFlushUPP(ICMFlushProcPtr userRoutine);
#if !OPAQUE_UPP_TYPES
enum { uppICMFlushProcInfo = 0x00000FE0 }; /* pascal 2_bytes Func(4_bytes, 4_bytes, 4_bytes) */
#ifdef __cplusplus
inline DEFINE_API_C(ICMFlushUPP) NewICMFlushUPP(ICMFlushProcPtr userRoutine) { return (ICMFlushUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppICMFlushProcInfo, GetCurrentArchitecture()); }
#else
#define NewICMFlushUPP(userRoutine) (ICMFlushUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppICMFlushProcInfo, GetCurrentArchitecture())
#endif
#endif
/*
* NewICMCompletionUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( ICMCompletionUPP )
NewICMCompletionUPP(ICMCompletionProcPtr userRoutine);
#if !OPAQUE_UPP_TYPES
enum { uppICMCompletionProcInfo = 0x00000E80 }; /* pascal no_return_value Func(2_bytes, 2_bytes, 4_bytes) */
#ifdef __cplusplus
inline DEFINE_API_C(ICMCompletionUPP) NewICMCompletionUPP(ICMCompletionProcPtr userRoutine) { return (ICMCompletionUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppICMCompletionProcInfo, GetCurrentArchitecture()); }
#else
#define NewICMCompletionUPP(userRoutine) (ICMCompletionUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppICMCompletionProcInfo, GetCurrentArchitecture())
#endif
#endif
/*
* NewICMProgressUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( ICMProgressUPP )
NewICMProgressUPP(ICMProgressProcPtr userRoutine);
#if !OPAQUE_UPP_TYPES
enum { uppICMProgressProcInfo = 0x00000FA0 }; /* pascal 2_bytes Func(2_bytes, 4_bytes, 4_bytes) */
#ifdef __cplusplus
inline DEFINE_API_C(ICMProgressUPP) NewICMProgressUPP(ICMProgressProcPtr userRoutine) { return (ICMProgressUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppICMProgressProcInfo, GetCurrentArchitecture()); }
#else
#define NewICMProgressUPP(userRoutine) (ICMProgressUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppICMProgressProcInfo, GetCurrentArchitecture())
#endif
#endif
/*
* NewStdPixUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( StdPixUPP )
NewStdPixUPP(StdPixProcPtr userRoutine);
#if !OPAQUE_UPP_TYPES
enum { uppStdPixProcInfo = 0x002FEFC0 }; /* pascal no_return_value Func(4_bytes, 4_bytes, 4_bytes, 2_bytes, 4_bytes, 4_bytes, 4_bytes, 2_bytes) */
#ifdef __cplusplus
inline DEFINE_API_C(StdPixUPP) NewStdPixUPP(StdPixProcPtr userRoutine) { return (StdPixUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppStdPixProcInfo, GetCurrentArchitecture()); }
#else
#define NewStdPixUPP(userRoutine) (StdPixUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppStdPixProcInfo, GetCurrentArchitecture())
#endif
#endif
/*
* NewQDPixUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( QDPixUPP )
NewQDPixUPP(QDPixProcPtr userRoutine);
#if !OPAQUE_UPP_TYPES
enum { uppQDPixProcInfo = 0x002FEFC0 }; /* pascal no_return_value Func(4_bytes, 4_bytes, 4_bytes, 2_bytes, 4_bytes, 4_bytes, 4_bytes, 2_bytes) */
#ifdef __cplusplus
inline DEFINE_API_C(QDPixUPP) NewQDPixUPP(QDPixProcPtr userRoutine) { return (QDPixUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppQDPixProcInfo, GetCurrentArchitecture()); }
#else
#define NewQDPixUPP(userRoutine) (QDPixUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppQDPixProcInfo, GetCurrentArchitecture())
#endif
#endif
/*
* NewICMAlignmentUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( ICMAlignmentUPP )
NewICMAlignmentUPP(ICMAlignmentProcPtr userRoutine);
#if !OPAQUE_UPP_TYPES
enum { uppICMAlignmentProcInfo = 0x000003C0 }; /* pascal no_return_value Func(4_bytes, 4_bytes) */
#ifdef __cplusplus
inline DEFINE_API_C(ICMAlignmentUPP) NewICMAlignmentUPP(ICMAlignmentProcPtr userRoutine) { return (ICMAlignmentUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppICMAlignmentProcInfo, GetCurrentArchitecture()); }
#else
#define NewICMAlignmentUPP(userRoutine) (ICMAlignmentUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppICMAlignmentProcInfo, GetCurrentArchitecture())
#endif
#endif
/*
* NewICMCursorShieldedUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( ICMCursorShieldedUPP )
NewICMCursorShieldedUPP(ICMCursorShieldedProcPtr userRoutine);
#if !OPAQUE_UPP_TYPES
enum { uppICMCursorShieldedProcInfo = 0x00000FC0 }; /* pascal no_return_value Func(4_bytes, 4_bytes, 4_bytes) */
#ifdef __cplusplus
inline DEFINE_API_C(ICMCursorShieldedUPP) NewICMCursorShieldedUPP(ICMCursorShieldedProcPtr userRoutine) { return (ICMCursorShieldedUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppICMCursorShieldedProcInfo, GetCurrentArchitecture()); }
#else
#define NewICMCursorShieldedUPP(userRoutine) (ICMCursorShieldedUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppICMCursorShieldedProcInfo, GetCurrentArchitecture())
#endif
#endif
/*
* NewICMMemoryDisposedUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( ICMMemoryDisposedUPP )
NewICMMemoryDisposedUPP(ICMMemoryDisposedProcPtr userRoutine);
#if !OPAQUE_UPP_TYPES
enum { uppICMMemoryDisposedProcInfo = 0x000003C0 }; /* pascal no_return_value Func(4_bytes, 4_bytes) */
#ifdef __cplusplus
inline DEFINE_API_C(ICMMemoryDisposedUPP) NewICMMemoryDisposedUPP(ICMMemoryDisposedProcPtr userRoutine) { return (ICMMemoryDisposedUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppICMMemoryDisposedProcInfo, GetCurrentArchitecture()); }
#else
#define NewICMMemoryDisposedUPP(userRoutine) (ICMMemoryDisposedUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppICMMemoryDisposedProcInfo, GetCurrentArchitecture())
#endif
#endif
/*
* NewICMConvertDataFormatUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( ICMConvertDataFormatUPP )
NewICMConvertDataFormatUPP(ICMConvertDataFormatProcPtr userRoutine);
#if !OPAQUE_UPP_TYPES
enum { uppICMConvertDataFormatProcInfo = 0x003FFFE0 }; /* pascal 2_bytes Func(4_bytes, 4_bytes, 4_bytes, 4_bytes, 4_bytes, 4_bytes, 4_bytes, 4_bytes) */
#ifdef __cplusplus
inline DEFINE_API_C(ICMConvertDataFormatUPP) NewICMConvertDataFormatUPP(ICMConvertDataFormatProcPtr userRoutine) { return (ICMConvertDataFormatUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppICMConvertDataFormatProcInfo, GetCurrentArchitecture()); }
#else
#define NewICMConvertDataFormatUPP(userRoutine) (ICMConvertDataFormatUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppICMConvertDataFormatProcInfo, GetCurrentArchitecture())
#endif
#endif
/*
* DisposeICMDataUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( void )
DisposeICMDataUPP(ICMDataUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(void) DisposeICMDataUPP(ICMDataUPP userUPP) { DisposeRoutineDescriptor((UniversalProcPtr)userUPP); }
#else
#define DisposeICMDataUPP(userUPP) DisposeRoutineDescriptor(userUPP)
#endif
#endif
/*
* DisposeICMFlushUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( void )
DisposeICMFlushUPP(ICMFlushUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(void) DisposeICMFlushUPP(ICMFlushUPP userUPP) { DisposeRoutineDescriptor((UniversalProcPtr)userUPP); }
#else
#define DisposeICMFlushUPP(userUPP) DisposeRoutineDescriptor(userUPP)
#endif
#endif
/*
* DisposeICMCompletionUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( void )
DisposeICMCompletionUPP(ICMCompletionUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(void) DisposeICMCompletionUPP(ICMCompletionUPP userUPP) { DisposeRoutineDescriptor((UniversalProcPtr)userUPP); }
#else
#define DisposeICMCompletionUPP(userUPP) DisposeRoutineDescriptor(userUPP)
#endif
#endif
/*
* DisposeICMProgressUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( void )
DisposeICMProgressUPP(ICMProgressUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(void) DisposeICMProgressUPP(ICMProgressUPP userUPP) { DisposeRoutineDescriptor((UniversalProcPtr)userUPP); }
#else
#define DisposeICMProgressUPP(userUPP) DisposeRoutineDescriptor(userUPP)
#endif
#endif
/*
* DisposeStdPixUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( void )
DisposeStdPixUPP(StdPixUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(void) DisposeStdPixUPP(StdPixUPP userUPP) { DisposeRoutineDescriptor((UniversalProcPtr)userUPP); }
#else
#define DisposeStdPixUPP(userUPP) DisposeRoutineDescriptor(userUPP)
#endif
#endif
/*
* DisposeQDPixUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( void )
DisposeQDPixUPP(QDPixUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(void) DisposeQDPixUPP(QDPixUPP userUPP) { DisposeRoutineDescriptor((UniversalProcPtr)userUPP); }
#else
#define DisposeQDPixUPP(userUPP) DisposeRoutineDescriptor(userUPP)
#endif
#endif
/*
* DisposeICMAlignmentUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( void )
DisposeICMAlignmentUPP(ICMAlignmentUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(void) DisposeICMAlignmentUPP(ICMAlignmentUPP userUPP) { DisposeRoutineDescriptor((UniversalProcPtr)userUPP); }
#else
#define DisposeICMAlignmentUPP(userUPP) DisposeRoutineDescriptor(userUPP)
#endif
#endif
/*
* DisposeICMCursorShieldedUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( void )
DisposeICMCursorShieldedUPP(ICMCursorShieldedUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(void) DisposeICMCursorShieldedUPP(ICMCursorShieldedUPP userUPP) { DisposeRoutineDescriptor((UniversalProcPtr)userUPP); }
#else
#define DisposeICMCursorShieldedUPP(userUPP) DisposeRoutineDescriptor(userUPP)
#endif
#endif
/*
* DisposeICMMemoryDisposedUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( void )
DisposeICMMemoryDisposedUPP(ICMMemoryDisposedUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(void) DisposeICMMemoryDisposedUPP(ICMMemoryDisposedUPP userUPP) { DisposeRoutineDescriptor((UniversalProcPtr)userUPP); }
#else
#define DisposeICMMemoryDisposedUPP(userUPP) DisposeRoutineDescriptor(userUPP)
#endif
#endif
/*
* DisposeICMConvertDataFormatUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( void )
DisposeICMConvertDataFormatUPP(ICMConvertDataFormatUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(void) DisposeICMConvertDataFormatUPP(ICMConvertDataFormatUPP userUPP) { DisposeRoutineDescriptor((UniversalProcPtr)userUPP); }
#else
#define DisposeICMConvertDataFormatUPP(userUPP) DisposeRoutineDescriptor(userUPP)
#endif
#endif
/*
* InvokeICMDataUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( OSErr )
InvokeICMDataUPP(
Ptr * dataP,
long bytesNeeded,
long refcon,
ICMDataUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(OSErr) InvokeICMDataUPP(Ptr * dataP, long bytesNeeded, long refcon, ICMDataUPP userUPP) { return (OSErr)CALL_THREE_PARAMETER_UPP(userUPP, uppICMDataProcInfo, dataP, bytesNeeded, refcon); }
#else
#define InvokeICMDataUPP(dataP, bytesNeeded, refcon, userUPP) (OSErr)CALL_THREE_PARAMETER_UPP((userUPP), uppICMDataProcInfo, (dataP), (bytesNeeded), (refcon))
#endif
#endif
/*
* InvokeICMFlushUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( OSErr )
InvokeICMFlushUPP(
Ptr data,
long bytesAdded,
long refcon,
ICMFlushUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(OSErr) InvokeICMFlushUPP(Ptr data, long bytesAdded, long refcon, ICMFlushUPP userUPP) { return (OSErr)CALL_THREE_PARAMETER_UPP(userUPP, uppICMFlushProcInfo, data, bytesAdded, refcon); }
#else
#define InvokeICMFlushUPP(data, bytesAdded, refcon, userUPP) (OSErr)CALL_THREE_PARAMETER_UPP((userUPP), uppICMFlushProcInfo, (data), (bytesAdded), (refcon))
#endif
#endif
/*
* InvokeICMCompletionUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( void )
InvokeICMCompletionUPP(
OSErr result,
short flags,
long refcon,
ICMCompletionUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(void) InvokeICMCompletionUPP(OSErr result, short flags, long refcon, ICMCompletionUPP userUPP) { CALL_THREE_PARAMETER_UPP(userUPP, uppICMCompletionProcInfo, result, flags, refcon); }
#else
#define InvokeICMCompletionUPP(result, flags, refcon, userUPP) CALL_THREE_PARAMETER_UPP((userUPP), uppICMCompletionProcInfo, (result), (flags), (refcon))
#endif
#endif
/*
* InvokeICMProgressUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( OSErr )
InvokeICMProgressUPP(
short message,
Fixed completeness,
long refcon,
ICMProgressUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(OSErr) InvokeICMProgressUPP(short message, Fixed completeness, long refcon, ICMProgressUPP userUPP) { return (OSErr)CALL_THREE_PARAMETER_UPP(userUPP, uppICMProgressProcInfo, message, completeness, refcon); }
#else
#define InvokeICMProgressUPP(message, completeness, refcon, userUPP) (OSErr)CALL_THREE_PARAMETER_UPP((userUPP), uppICMProgressProcInfo, (message), (completeness), (refcon))
#endif
#endif
/*
* InvokeStdPixUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( void )
InvokeStdPixUPP(
PixMap * src,
Rect * srcRect,
MatrixRecord * matrix,
short mode,
RgnHandle mask,
PixMap * matte,
Rect * matteRect,
short flags,
StdPixUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(void) InvokeStdPixUPP(PixMap * src, Rect * srcRect, MatrixRecord * matrix, short mode, RgnHandle mask, PixMap * matte, Rect * matteRect, short flags, StdPixUPP userUPP) { CALL_EIGHT_PARAMETER_UPP(userUPP, uppStdPixProcInfo, src, srcRect, matrix, mode, mask, matte, matteRect, flags); }
#else
#define InvokeStdPixUPP(src, srcRect, matrix, mode, mask, matte, matteRect, flags, userUPP) CALL_EIGHT_PARAMETER_UPP((userUPP), uppStdPixProcInfo, (src), (srcRect), (matrix), (mode), (mask), (matte), (matteRect), (flags))
#endif
#endif
/*
* InvokeQDPixUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( void )
InvokeQDPixUPP(
PixMap * src,
Rect * srcRect,
MatrixRecord * matrix,
short mode,
RgnHandle mask,
PixMap * matte,
Rect * matteRect,
short flags,
QDPixUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(void) InvokeQDPixUPP(PixMap * src, Rect * srcRect, MatrixRecord * matrix, short mode, RgnHandle mask, PixMap * matte, Rect * matteRect, short flags, QDPixUPP userUPP) { CALL_EIGHT_PARAMETER_UPP(userUPP, uppQDPixProcInfo, src, srcRect, matrix, mode, mask, matte, matteRect, flags); }
#else
#define InvokeQDPixUPP(src, srcRect, matrix, mode, mask, matte, matteRect, flags, userUPP) CALL_EIGHT_PARAMETER_UPP((userUPP), uppQDPixProcInfo, (src), (srcRect), (matrix), (mode), (mask), (matte), (matteRect), (flags))
#endif
#endif
/*
* InvokeICMAlignmentUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( void )
InvokeICMAlignmentUPP(
Rect * rp,
long refcon,
ICMAlignmentUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(void) InvokeICMAlignmentUPP(Rect * rp, long refcon, ICMAlignmentUPP userUPP) { CALL_TWO_PARAMETER_UPP(userUPP, uppICMAlignmentProcInfo, rp, refcon); }
#else
#define InvokeICMAlignmentUPP(rp, refcon, userUPP) CALL_TWO_PARAMETER_UPP((userUPP), uppICMAlignmentProcInfo, (rp), (refcon))
#endif
#endif
/*
* InvokeICMCursorShieldedUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( void )
InvokeICMCursorShieldedUPP(
const Rect * r,
void * refcon,
long flags,
ICMCursorShieldedUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(void) InvokeICMCursorShieldedUPP(const Rect * r, void * refcon, long flags, ICMCursorShieldedUPP userUPP) { CALL_THREE_PARAMETER_UPP(userUPP, uppICMCursorShieldedProcInfo, r, refcon, flags); }
#else
#define InvokeICMCursorShieldedUPP(r, refcon, flags, userUPP) CALL_THREE_PARAMETER_UPP((userUPP), uppICMCursorShieldedProcInfo, (r), (refcon), (flags))
#endif
#endif
/*
* InvokeICMMemoryDisposedUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( void )
InvokeICMMemoryDisposedUPP(
Ptr memoryBlock,
void * refcon,
ICMMemoryDisposedUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(void) InvokeICMMemoryDisposedUPP(Ptr memoryBlock, void * refcon, ICMMemoryDisposedUPP userUPP) { CALL_TWO_PARAMETER_UPP(userUPP, uppICMMemoryDisposedProcInfo, memoryBlock, refcon); }
#else
#define InvokeICMMemoryDisposedUPP(memoryBlock, refcon, userUPP) CALL_TWO_PARAMETER_UPP((userUPP), uppICMMemoryDisposedProcInfo, (memoryBlock), (refcon))
#endif
#endif
/*
* InvokeICMConvertDataFormatUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
*/
EXTERN_API_C( OSErr )
InvokeICMConvertDataFormatUPP(
void * refCon,
long flags,
Handle desiredFormat,
Handle sourceDataFormat,
void * srcData,
long srcDataSize,
void ** dstData,
long * dstDataSize,
ICMConvertDataFormatUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(OSErr) InvokeICMConvertDataFormatUPP(void * refCon, long flags, Handle desiredFormat, Handle sourceDataFormat, void * srcData, long srcDataSize, void ** dstData, long * dstDataSize, ICMConvertDataFormatUPP userUPP) { return (OSErr)CALL_EIGHT_PARAMETER_UPP(userUPP, uppICMConvertDataFormatProcInfo, refCon, flags, desiredFormat, sourceDataFormat, srcData, srcDataSize, dstData, dstDataSize); }
#else
#define InvokeICMConvertDataFormatUPP(refCon, flags, desiredFormat, sourceDataFormat, srcData, srcDataSize, dstData, dstDataSize, userUPP) (OSErr)CALL_EIGHT_PARAMETER_UPP((userUPP), uppICMConvertDataFormatProcInfo, (refCon), (flags), (desiredFormat), (sourceDataFormat), (srcData), (srcDataSize), (dstData), (dstDataSize))
#endif
#endif
#if CALL_NOT_IN_CARBON || OLDROUTINENAMES
/* support for pre-Carbon UPP routines: New...Proc and Call...Proc */
#define NewICMDataProc(userRoutine) NewICMDataUPP(userRoutine)
#define NewICMFlushProc(userRoutine) NewICMFlushUPP(userRoutine)
#define NewICMCompletionProc(userRoutine) NewICMCompletionUPP(userRoutine)
#define NewICMProgressProc(userRoutine) NewICMProgressUPP(userRoutine)
#define NewStdPixProc(userRoutine) NewStdPixUPP(userRoutine)
#define NewQDPixProc(userRoutine) NewQDPixUPP(userRoutine)
#define NewICMAlignmentProc(userRoutine) NewICMAlignmentUPP(userRoutine)
#define NewICMCursorShieldedProc(userRoutine) NewICMCursorShieldedUPP(userRoutine)
#define NewICMMemoryDisposedProc(userRoutine) NewICMMemoryDisposedUPP(userRoutine)
#define NewICMConvertDataFormatProc(userRoutine) NewICMConvertDataFormatUPP(userRoutine)
#define CallICMDataProc(userRoutine, dataP, bytesNeeded, refcon) InvokeICMDataUPP(dataP, bytesNeeded, refcon, userRoutine)
#define CallICMFlushProc(userRoutine, data, bytesAdded, refcon) InvokeICMFlushUPP(data, bytesAdded, refcon, userRoutine)
#define CallICMCompletionProc(userRoutine, result, flags, refcon) InvokeICMCompletionUPP(result, flags, refcon, userRoutine)
#define CallICMProgressProc(userRoutine, message, completeness, refcon) InvokeICMProgressUPP(message, completeness, refcon, userRoutine)
#define CallStdPixProc(userRoutine, src, srcRect, matrix, mode, mask, matte, matteRect, flags) InvokeStdPixUPP(src, srcRect, matrix, mode, mask, matte, matteRect, flags, userRoutine)
#define CallQDPixProc(userRoutine, src, srcRect, matrix, mode, mask, matte, matteRect, flags) InvokeQDPixUPP(src, srcRect, matrix, mode, mask, matte, matteRect, flags, userRoutine)
#define CallICMAlignmentProc(userRoutine, rp, refcon) InvokeICMAlignmentUPP(rp, refcon, userRoutine)
#define CallICMCursorShieldedProc(userRoutine, r, refcon, flags) InvokeICMCursorShieldedUPP(r, refcon, flags, userRoutine)
#define CallICMMemoryDisposedProc(userRoutine, memoryBlock, refcon) InvokeICMMemoryDisposedUPP(memoryBlock, refcon, userRoutine)
#define CallICMConvertDataFormatProc(userRoutine, refCon, flags, desiredFormat, sourceDataFormat, srcData, srcDataSize, dstData, dstDataSize) InvokeICMConvertDataFormatUPP(refCon, flags, desiredFormat, sourceDataFormat, srcData, srcDataSize, dstData, dstDataSize, userRoutine)
#endif /* CALL_NOT_IN_CARBON */
/*
* CodecManagerVersion()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
CodecManagerVersion(long * version);
/*
* GetCodecNameList()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
GetCodecNameList(
CodecNameSpecListPtr * list,
short showAll);
/*
* DisposeCodecNameList()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
DisposeCodecNameList(CodecNameSpecListPtr list);
/*
* GetCodecInfo()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
GetCodecInfo(
CodecInfo * info,
CodecType cType,
CodecComponent codec);
/*
* GetMaxCompressionSize()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
GetMaxCompressionSize(
PixMapHandle src,
const Rect * srcRect,
short colorDepth,
CodecQ quality,
CodecType cType,
CompressorComponent codec,
long * size);
/*
* GetCSequenceMaxCompressionSize()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
GetCSequenceMaxCompressionSize(
ImageSequence seqID,
PixMapHandle src,
long * size);
/*
* GetCompressionTime()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
GetCompressionTime(
PixMapHandle src,
const Rect * srcRect,
short colorDepth,
CodecType cType,
CompressorComponent codec,
CodecQ * spatialQuality,
CodecQ * temporalQuality,
unsigned long * compressTime);
/*
* CompressImage()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
CompressImage(
PixMapHandle src,
const Rect * srcRect,
CodecQ quality,
CodecType cType,
ImageDescriptionHandle desc,
Ptr data);
/*
* FCompressImage()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
FCompressImage(
PixMapHandle src,
const Rect * srcRect,
short colorDepth,
CodecQ quality,
CodecType cType,
CompressorComponent codec,
CTabHandle ctable,
CodecFlags flags,
long bufferSize,
ICMFlushProcRecordPtr flushProc,
ICMProgressProcRecordPtr progressProc,
ImageDescriptionHandle desc,
Ptr data);
/*
* DecompressImage()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
DecompressImage(
Ptr data,
ImageDescriptionHandle desc,
PixMapHandle dst,
const Rect * srcRect,
const Rect * dstRect,
short mode,
RgnHandle mask);
/*
* FDecompressImage()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
FDecompressImage(
Ptr data,
ImageDescriptionHandle desc,
PixMapHandle dst,
const Rect * srcRect,
MatrixRecordPtr matrix,
short mode,
RgnHandle mask,
PixMapHandle matte,
const Rect * matteRect,
CodecQ accuracy,
DecompressorComponent codec,
long bufferSize,
ICMDataProcRecordPtr dataProc,
ICMProgressProcRecordPtr progressProc);
/* For video compression, consider using ICMCompressionSessionCreate etc. instead of CompressSequenceBegin etc. */
/*
* CompressSequenceBegin()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
CompressSequenceBegin(
ImageSequence * seqID,
PixMapHandle src,
PixMapHandle prev,
const Rect * srcRect,
const Rect * prevRect,
short colorDepth,
CodecType cType,
CompressorComponent codec,
CodecQ spatialQuality,
CodecQ temporalQuality,
long keyFrameRate,
CTabHandle ctable,
CodecFlags flags,
ImageDescriptionHandle desc);
/*
* CompressSequenceFrame()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
CompressSequenceFrame(
ImageSequence seqID,
PixMapHandle src,
const Rect * srcRect,
CodecFlags flags,
Ptr data,
long * dataSize,
UInt8 * similarity,
ICMCompletionProcRecordPtr asyncCompletionProc);
/* For video decompression, consider using ICMDecompressionSessionCreate etc. instead of DecompressSequenceBegin etc. */
/*
* DecompressSequenceBegin()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
DecompressSequenceBegin(
ImageSequence * seqID,
ImageDescriptionHandle desc,
CGrafPtr port,
GDHandle gdh,
const Rect * srcRect,
MatrixRecordPtr matrix,
short mode,
RgnHandle mask,
CodecFlags flags,
CodecQ accuracy,
DecompressorComponent codec);
/* For video decompression, consider using ICMDecompressionSessionCreate etc. instead of DecompressSequenceBeginS etc. */
/*
* DecompressSequenceBeginS()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
DecompressSequenceBeginS(
ImageSequence * seqID,
ImageDescriptionHandle desc,
Ptr data,
long dataSize,
CGrafPtr port,
GDHandle gdh,
const Rect * srcRect,
MatrixRecordPtr matrix,
short mode,
RgnHandle mask,
CodecFlags flags,
CodecQ accuracy,
DecompressorComponent codec);
/*
* DecompressSequenceFrame()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
DecompressSequenceFrame(
ImageSequence seqID,
Ptr data,
CodecFlags inFlags,
CodecFlags * outFlags,
ICMCompletionProcRecordPtr asyncCompletionProc);
/*
* DecompressSequenceFrameS()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
DecompressSequenceFrameS(
ImageSequence seqID,
Ptr data,
long dataSize,
CodecFlags inFlags,
CodecFlags * outFlags,
ICMCompletionProcRecordPtr asyncCompletionProc);
/*
* DecompressSequenceFrameWhen()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
DecompressSequenceFrameWhen(
ImageSequence seqID,
Ptr data,
long dataSize,
CodecFlags inFlags,
CodecFlags * outFlags,
ICMCompletionProcRecordPtr asyncCompletionProc,
const ICMFrameTimeRecord * frameTime);
/*
* CDSequenceFlush()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
CDSequenceFlush(ImageSequence seqID);
/*
* SetDSequenceMatrix()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
SetDSequenceMatrix(
ImageSequence seqID,
MatrixRecordPtr matrix);
/*
* GetDSequenceMatrix()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( OSErr )
GetDSequenceMatrix(
ImageSequence seqID,
MatrixRecordPtr matrix);
/*
* SetDSequenceMatte()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
SetDSequenceMatte(
ImageSequence seqID,
PixMapHandle matte,
const Rect * matteRect);
/*
* SetDSequenceMask()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
SetDSequenceMask(
ImageSequence seqID,
RgnHandle mask);
/*
* SetDSequenceTransferMode()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
SetDSequenceTransferMode(
ImageSequence seqID,
short mode,
const RGBColor * opColor);
/*
* SetDSequenceDataProc()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
SetDSequenceDataProc(
ImageSequence seqID,
ICMDataProcRecordPtr dataProc,
long bufferSize);
/*
* SetDSequenceAccuracy()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
SetDSequenceAccuracy(
ImageSequence seqID,
CodecQ accuracy);
/*
* SetDSequenceSrcRect()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
SetDSequenceSrcRect(
ImageSequence seqID,
const Rect * srcRect);
/*
* SetDSequenceFlags()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( OSErr )
SetDSequenceFlags(
ImageSequence seqID,
long flags,
long flagsMask);
enum {
codecDSequenceDisableOverlaySurface = (1L << 5),
codecDSequenceSingleField = (1L << 6),
codecDSequenceBidirectionalPrediction = (1L << 7),
codecDSequenceFlushInsteadOfDirtying = (1L << 8),
codecDSequenceEnableSubPixelPositioning = (1L << 9),
codecDSequenceDeinterlaceFields = (1L << 10)
};
typedef CodecComponent * CodecComponentPtr;
typedef CodecComponentPtr * CodecComponentHandle;
/* selectors for ICMSequenceGet/SetInfo*/
enum {
kICMSequenceTaskWeight = FOUR_CHAR_CODE('twei'), /* data is pointer to UInt32*/
kICMSequenceTaskName = FOUR_CHAR_CODE('tnam'), /* data is pointer to OSType*/
kICMSequenceUserPreferredCodecs = FOUR_CHAR_CODE('punt') /* data is pointer to CodecComponentHandle*/
};
/*
* ICMSequenceGetInfo()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 5.0 and later
* CarbonLib: in CarbonLib 1.3 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 5.0 and later
*/
EXTERN_API( OSErr )
ICMSequenceGetInfo(
ImageSequence seqID,
OSType which,
void * data);
/*
* ICMSequenceSetInfo()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 5.0 and later
* CarbonLib: in CarbonLib 1.3 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 5.0 and later
*/
EXTERN_API( OSErr )
ICMSequenceSetInfo(
ImageSequence seqID,
OSType which,
void * data,
Size dataSize);
/*
* GetDSequenceImageBuffer()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
GetDSequenceImageBuffer(
ImageSequence seqID,
GWorldPtr * gworld);
/*
* GetDSequenceScreenBuffer()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
GetDSequenceScreenBuffer(
ImageSequence seqID,
GWorldPtr * gworld);
/*
* SetCSequenceQuality()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
SetCSequenceQuality(
ImageSequence seqID,
CodecQ spatialQuality,
CodecQ temporalQuality);
/*
* SetCSequencePrev()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
SetCSequencePrev(
ImageSequence seqID,
PixMapHandle prev,
const Rect * prevRect);
/*
* SetCSequenceFlushProc()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
SetCSequenceFlushProc(
ImageSequence seqID,
ICMFlushProcRecordPtr flushProc,
long bufferSize);
/*
* SetCSequenceKeyFrameRate()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
SetCSequenceKeyFrameRate(
ImageSequence seqID,
long keyFrameRate);
/*
* GetCSequenceKeyFrameRate()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
GetCSequenceKeyFrameRate(
ImageSequence seqID,
long * keyFrameRate);
/*
* GetCSequencePrevBuffer()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
GetCSequencePrevBuffer(
ImageSequence seqID,
GWorldPtr * gworld);
/*
* CDSequenceBusy()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
CDSequenceBusy(ImageSequence seqID);
/*
* CDSequenceEnd()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
CDSequenceEnd(ImageSequence seqID);
/*
* CDSequenceEquivalentImageDescription()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
CDSequenceEquivalentImageDescription(
ImageSequence seqID,
ImageDescriptionHandle newDesc,
Boolean * equivalent);
/*
* CDSequenceEquivalentImageDescriptionS()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 5.0 and later
* CarbonLib: in CarbonLib 1.3 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 5.0 and later
*/
EXTERN_API( OSErr )
CDSequenceEquivalentImageDescriptionS(
ImageSequence seqID,
ImageDescriptionHandle newDesc,
Boolean * equivalent,
Boolean * canSwitch);
/*
* ReplaceDSequenceImageDescription()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 5.0 and later
* CarbonLib: in CarbonLib 1.3 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 5.0 and later
*/
EXTERN_API( OSErr )
ReplaceDSequenceImageDescription(
ImageSequence seqID,
ImageDescriptionHandle newDesc);
/*
* GetCompressedImageSize()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
GetCompressedImageSize(
ImageDescriptionHandle desc,
Ptr data,
long bufferSize,
ICMDataProcRecordPtr dataProc,
long * dataSize);
/*
* GetSimilarity()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
GetSimilarity(
PixMapHandle src,
const Rect * srcRect,
ImageDescriptionHandle desc,
Ptr data,
Fixed * similarity);
enum {
kImageDescriptionSampleFormat = FOUR_CHAR_CODE('idfm'), /* image description extension describing sample format*/
kImageDescriptionClassicAtomFormat = FOUR_CHAR_CODE('atom'), /* sample contains classic atom structure (ie, GX codec and Curve codec)*/
kImageDescriptionQTAtomFormat = FOUR_CHAR_CODE('qtat'), /* sample contains QT atom structure*/
kImageDescriptionEffectDataFormat = FOUR_CHAR_CODE('fxat'), /* sample describes an effect (as QTAtoms)*/
kImageDescriptionPrivateDataFormat = FOUR_CHAR_CODE('priv'), /* sample is in a private codec specific format*/
kImageDescriptionAlternateCodec = FOUR_CHAR_CODE('subs'), /* image description extension containing the OSType of a substitute codec should the main codec not be available*/
kImageDescriptionColorSpace = FOUR_CHAR_CODE('cspc') /* image description extension containing an OSType naming the native pixel format of an image (only used for pixel formats not supported by classic Color QuickDraw)*/
};
/*
* GetImageDescriptionCTable()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
GetImageDescriptionCTable(
ImageDescriptionHandle desc,
CTabHandle * ctable);
/*
* SetImageDescriptionCTable()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
SetImageDescriptionCTable(
ImageDescriptionHandle desc,
CTabHandle ctable);
/*
* GetImageDescriptionExtension()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
GetImageDescriptionExtension(
ImageDescriptionHandle desc,
Handle * extension,
long idType,
long index);
/*
* AddImageDescriptionExtension()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
AddImageDescriptionExtension(
ImageDescriptionHandle desc,
Handle extension,
long idType);
/*
* RemoveImageDescriptionExtension()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
RemoveImageDescriptionExtension(
ImageDescriptionHandle desc,
long idType,
long index);
/*
* CountImageDescriptionExtensionType()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
CountImageDescriptionExtensionType(
ImageDescriptionHandle desc,
long idType,
long * count);
/*
* GetNextImageDescriptionExtensionType()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
GetNextImageDescriptionExtensionType(
ImageDescriptionHandle desc,
long * idType);
/*
* FindCodec()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
FindCodec(
CodecType cType,
CodecComponent specCodec,
CompressorComponent * compressor,
DecompressorComponent * decompressor);
/*
* CompressPicture()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
CompressPicture(
PicHandle srcPicture,
PicHandle dstPicture,
CodecQ quality,
CodecType cType);
/*
* FCompressPicture()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
FCompressPicture(
PicHandle srcPicture,
PicHandle dstPicture,
short colorDepth,
CTabHandle ctable,
CodecQ quality,
short doDither,
short compressAgain,
ICMProgressProcRecordPtr progressProc,
CodecType cType,
CompressorComponent codec);
/*
* CompressPictureFile()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
CompressPictureFile(
short srcRefNum,
short dstRefNum,
CodecQ quality,
CodecType cType);
/*
* FCompressPictureFile()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
FCompressPictureFile(
short srcRefNum,
short dstRefNum,
short colorDepth,
CTabHandle ctable,
CodecQ quality,
short doDither,
short compressAgain,
ICMProgressProcRecordPtr progressProc,
CodecType cType,
CompressorComponent codec);
/*
* GetPictureFileHeader()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
GetPictureFileHeader(
short refNum,
Rect * frame,
OpenCPicParams * header);
/*
* DrawPictureFile()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
DrawPictureFile(
short refNum,
const Rect * frame,
ICMProgressProcRecordPtr progressProc);
/*
* DrawTrimmedPicture()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
DrawTrimmedPicture(
PicHandle srcPicture,
const Rect * frame,
RgnHandle trimMask,
short doDither,
ICMProgressProcRecordPtr progressProc);
/*
* DrawTrimmedPictureFile()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
DrawTrimmedPictureFile(
short srcRefnum,
const Rect * frame,
RgnHandle trimMask,
short doDither,
ICMProgressProcRecordPtr progressProc);
/*
* MakeThumbnailFromPicture()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
MakeThumbnailFromPicture(
PicHandle picture,
short colorDepth,
PicHandle thumbnail,
ICMProgressProcRecordPtr progressProc);
/*
* MakeThumbnailFromPictureFile()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
MakeThumbnailFromPictureFile(
short refNum,
short colorDepth,
PicHandle thumbnail,
ICMProgressProcRecordPtr progressProc);
/*
* MakeThumbnailFromPixMap()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
MakeThumbnailFromPixMap(
PixMapHandle src,
const Rect * srcRect,
short colorDepth,
PicHandle thumbnail,
ICMProgressProcRecordPtr progressProc);
/*
* TrimImage()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
TrimImage(
ImageDescriptionHandle desc,
Ptr inData,
long inBufferSize,
ICMDataProcRecordPtr dataProc,
Ptr outData,
long outBufferSize,
ICMFlushProcRecordPtr flushProc,
Rect * trimRect,
ICMProgressProcRecordPtr progressProc);
/*
* ConvertImage()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
ConvertImage(
ImageDescriptionHandle srcDD,
Ptr srcData,
short colorDepth,
CTabHandle ctable,
CodecQ accuracy,
CodecQ quality,
CodecType cType,
CodecComponent codec,
ImageDescriptionHandle dstDD,
Ptr dstData);
/*
* GetCompressedPixMapInfo()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
GetCompressedPixMapInfo(
PixMapPtr pix,
ImageDescriptionHandle * desc,
Ptr * data,
long * bufferSize,
ICMDataProcRecord * dataProc,
ICMProgressProcRecord * progressProc);
/*
* SetCompressedPixMapInfo()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
SetCompressedPixMapInfo(
PixMapPtr pix,
ImageDescriptionHandle desc,
Ptr data,
long bufferSize,
ICMDataProcRecordPtr dataProc,
ICMProgressProcRecordPtr progressProc);
/*
* StdPix()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( void )
StdPix(
PixMapPtr src,
const Rect * srcRect,
MatrixRecordPtr matrix,
short mode,
RgnHandle mask,
PixMapPtr matte,
const Rect * matteRect,
short flags);
/*
* TransformRgn()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
TransformRgn(
MatrixRecordPtr matrix,
RgnHandle rgn);
/***********
preview stuff
***********/
#if CALL_NOT_IN_CARBON
/*
* SFGetFilePreview()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: not available
* Mac OS X: not available
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( void )
SFGetFilePreview(
Point where,
ConstStr255Param prompt,
FileFilterUPP fileFilter,
short numTypes,
ConstSFTypeListPtr typeList,
DlgHookUPP dlgHook,
SFReply * reply);
/*
* SFPGetFilePreview()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: not available
* Mac OS X: not available
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( void )
SFPGetFilePreview(
Point where,
ConstStr255Param prompt,
FileFilterUPP fileFilter,
short numTypes,
ConstSFTypeListPtr typeList,
DlgHookUPP dlgHook,
SFReply * reply,
short dlgID,
ModalFilterUPP filterProc);
/*
* StandardGetFilePreview()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: not available
* Mac OS X: not available
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( void )
StandardGetFilePreview(
FileFilterUPP fileFilter,
short numTypes,
ConstSFTypeListPtr typeList,
StandardFileReply * reply);
/*
* CustomGetFilePreview()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: not available
* Mac OS X: not available
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( void )
CustomGetFilePreview(
FileFilterYDUPP fileFilter,
short numTypes,
ConstSFTypeListPtr typeList,
StandardFileReply * reply,
short dlgID,
Point where,
DlgHookYDUPP dlgHook,
ModalFilterYDUPP filterProc,
ActivationOrderListPtr activeList,
ActivateYDUPP activateProc,
void * yourDataPtr);
#endif /* CALL_NOT_IN_CARBON */
/*
* MakeFilePreview()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
MakeFilePreview(
short resRefNum,
ICMProgressProcRecordPtr progress);
/*
* AddFilePreview()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
AddFilePreview(
short resRefNum,
OSType previewType,
Handle previewData);
enum {
sfpItemPreviewAreaUser = 11,
sfpItemPreviewStaticText = 12,
sfpItemPreviewDividerUser = 13,
sfpItemCreatePreviewButton = 14,
sfpItemShowPreviewButton = 15
};
struct PreviewResourceRecord {
unsigned long modDate;
short version;
OSType resType;
short resID;
};
typedef struct PreviewResourceRecord PreviewResourceRecord;
typedef PreviewResourceRecord * PreviewResourcePtr;
typedef PreviewResourcePtr * PreviewResource;
/*
* AlignScreenRect()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( void )
AlignScreenRect(
Rect * rp,
ICMAlignmentProcRecordPtr alignmentProc);
/*
* AlignWindow()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( void )
AlignWindow(
WindowRef wp,
Boolean front,
const Rect * alignmentRect,
ICMAlignmentProcRecordPtr alignmentProc);
/*
* DragAlignedWindow()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( void )
DragAlignedWindow(
WindowRef wp,
Point startPt,
Rect * boundsRect,
Rect * alignmentRect,
ICMAlignmentProcRecordPtr alignmentProc);
/*
* DragAlignedGrayRgn()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( long )
DragAlignedGrayRgn(
RgnHandle theRgn,
Point startPt,
Rect * boundsRect,
Rect * slopRect,
short axis,
UniversalProcPtr actionProc,
Rect * alignmentRect,
ICMAlignmentProcRecordPtr alignmentProc);
/*
* SetCSequenceDataRateParams()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
SetCSequenceDataRateParams(
ImageSequence seqID,
DataRateParamsPtr params);
/*
* SetCSequenceFrameNumber()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
SetCSequenceFrameNumber(
ImageSequence seqID,
long frameNumber);
/*
* SetCSequencePreferredPacketSize()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
SetCSequencePreferredPacketSize(
ImageSequence seqID,
long preferredPacketSizeInBytes);
/*
* NewImageGWorld()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
NewImageGWorld(
GWorldPtr * gworld,
ImageDescriptionHandle idh,
GWorldFlags flags);
/*
* GetCSequenceDataRateParams()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
GetCSequenceDataRateParams(
ImageSequence seqID,
DataRateParamsPtr params);
/*
* GetCSequenceFrameNumber()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
GetCSequenceFrameNumber(
ImageSequence seqID,
long * frameNumber);
/*
* GetBestDeviceRect()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
GetBestDeviceRect(
GDHandle * gdh,
Rect * rp);
/*
* SetSequenceProgressProc()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
SetSequenceProgressProc(
ImageSequence seqID,
ICMProgressProcRecord * progressProc);
/*
* GDHasScale()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
GDHasScale(
GDHandle gdh,
short depth,
Fixed * scale);
/*
* GDGetScale()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
GDGetScale(
GDHandle gdh,
Fixed * scale,
short * flags);
/*
* GDSetScale()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
GDSetScale(
GDHandle gdh,
Fixed scale,
short flags);
/*
* ICMShieldSequenceCursor()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
ICMShieldSequenceCursor(ImageSequence seqID);
/*
* ICMDecompressComplete()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( void )
ICMDecompressComplete(
ImageSequence seqID,
OSErr err,
short flag,
ICMCompletionProcRecordPtr completionRtn);
/*
* ICMDecompressCompleteS()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 3.0 and later
* CarbonLib: in CarbonLib 1.1 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
ICMDecompressCompleteS(
ImageSequence seqID,
OSErr err,
short flag,
ICMCompletionProcRecordPtr completionRtn);
/*
* ICMSequenceLockBits()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 3.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
ICMSequenceLockBits(
ImageSequence seqID,
PixMapPtr dst,
long flags);
/*
* ICMSequenceUnlockBits()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 3.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
ICMSequenceUnlockBits(
ImageSequence seqID,
long flags);
enum {
kICMPixelFormatIsPlanarMask = 0x0F, /* these bits in formatFlags indicate how many planes there are; they're 0 if chunky*/
kICMPixelFormatIsIndexed = (1L << 4),
kICMPixelFormatIsSupportedByQD = (1L << 5),
kICMPixelFormatIsMonochrome = (1L << 6),
kICMPixelFormatHasAlphaChannel = (1L << 7)
};
struct ICMPixelFormatInfo {
long size; /* caller MUST fill this in with sizeof(ICMPixelFormatInfo) before calling ICMGet/SetPixelFormatInfo*/
unsigned long formatFlags;
short bitsPerPixel[14]; /* list each plane's bits per pixel separately if planar*/
/* new field for QuickTime 4.1*/
Fixed defaultGammaLevel;
/* new fields for QuickTime 6.0*/
short horizontalSubsampling[14]; /* per plane; use 1 if plane is not subsampled*/
short verticalSubsampling[14]; /* per plane; use 1 if plane is not subsampled*/
/* new fields for QuickTime 6.5*/
short cmpCount; /* for use in PixMap.cmpCount*/
short cmpSize; /* for use in PixMap.cmpSize*/
};
typedef struct ICMPixelFormatInfo ICMPixelFormatInfo;
typedef ICMPixelFormatInfo * ICMPixelFormatInfoPtr;
/* IMPORTANT: Fill in theInfo->size with sizeof(ICMPixelFormatInfo) before calling ICMGetPixelFormatInfo */
/*
* ICMGetPixelFormatInfo()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 3.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
ICMGetPixelFormatInfo(
OSType PixelFormat,
ICMPixelFormatInfoPtr theInfo);
/* IMPORTANT: Fill in theInfo->size with sizeof(ICMPixelFormatInfo) before calling ICMSetPixelFormatInfo */
/*
* ICMSetPixelFormatInfo()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 3.0 and later
* CarbonLib: in CarbonLib 1.1 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
ICMSetPixelFormatInfo(
OSType PixelFormat,
ICMPixelFormatInfoPtr theInfo);
enum {
kICMGetChainUltimateParent = 0,
kICMGetChainParent = 1,
kICMGetChainChild = 2,
kICMGetChainUltimateChild = 3
};
/*
* ICMSequenceGetChainMember()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 3.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
ICMSequenceGetChainMember(
ImageSequence seqID,
ImageSequence * retSeqID,
long flags);
/*
* SetDSequenceTimeCode()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
SetDSequenceTimeCode(
ImageSequence seqID,
void * timeCodeFormat,
void * timeCodeTime);
/*
* CDSequenceNewMemory()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
CDSequenceNewMemory(
ImageSequence seqID,
Ptr * data,
Size dataSize,
long dataUse,
ICMMemoryDisposedUPP memoryGoneProc,
void * refCon);
/*
* CDSequenceDisposeMemory()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
CDSequenceDisposeMemory(
ImageSequence seqID,
Ptr data);
/*
* CDSequenceNewDataSource()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
CDSequenceNewDataSource(
ImageSequence seqID,
ImageSequenceDataSource * sourceID,
OSType sourceType,
long sourceInputNumber,
Handle dataDescription,
ICMConvertDataFormatUPP transferProc,
void * refCon);
/*
* CDSequenceDisposeDataSource()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
CDSequenceDisposeDataSource(ImageSequenceDataSource sourceID);
/*
* CDSequenceSetSourceData()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
CDSequenceSetSourceData(
ImageSequenceDataSource sourceID,
void * data,
long dataSize);
/*
* CDSequenceChangedSourceData()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
CDSequenceChangedSourceData(ImageSequenceDataSource sourceID);
/*
* CDSequenceSetSourceDataQueue()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 3.0 and later
* CarbonLib: in CarbonLib 1.1 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
CDSequenceSetSourceDataQueue(
ImageSequenceDataSource sourceID,
QHdrPtr dataQueue);
/*
* CDSequenceGetDataSource()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 3.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
CDSequenceGetDataSource(
ImageSequence seqID,
ImageSequenceDataSource * sourceID,
OSType sourceType,
long sourceInputNumber);
/*
* PtInDSequenceData()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
PtInDSequenceData(
ImageSequence seqID,
void * data,
Size dataSize,
Point where,
Boolean * hit);
/*
* HitTestDSequenceData()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 3.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
HitTestDSequenceData(
ImageSequence seqID,
void * data,
Size dataSize,
Point where,
long * hit,
long hitFlags);
/*
* SetDSequenceNonScheduledDisplayTime()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
* Windows: in qtmlClient.lib version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API( OSErr )
SetDSequenceNonScheduledDisplayTime(
ImageSequence sequence,
TimeValue64 displayTime,
TimeScale displayTimeScale,
UInt32 flags);
/*
* GetDSequenceNonScheduledDisplayTime()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
* Windows: in qtmlClient.lib version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API( OSErr )
GetDSequenceNonScheduledDisplayTime(
ImageSequence sequence,
TimeValue64 * displayTime,
TimeScale * displayTimeScale);
/*
* SetDSequenceNonScheduledDisplayDirection()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
* Windows: in qtmlClient.lib version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API( OSErr )
SetDSequenceNonScheduledDisplayDirection(
ImageSequence sequence,
Fixed rate);
/*
* GetDSequenceNonScheduledDisplayDirection()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
* Windows: in qtmlClient.lib version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API( OSErr )
GetDSequenceNonScheduledDisplayDirection(
ImageSequence sequence,
Fixed * rate);
/*
* GetGraphicsImporterForFile()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
GetGraphicsImporterForFile(
const FSSpec * theFile,
ComponentInstance * gi);
/*
* GetGraphicsImporterForDataRef()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
GetGraphicsImporterForDataRef(
Handle dataRef,
OSType dataRefType,
ComponentInstance * gi);
enum {
kDontUseValidateToFindGraphicsImporter = 1L << 0
};
/*
* GetGraphicsImporterForFileWithFlags()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 3.0 and later
* CarbonLib: in CarbonLib 1.1 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
GetGraphicsImporterForFileWithFlags(
const FSSpec * theFile,
ComponentInstance * gi,
long flags);
/*
* GetGraphicsImporterForDataRefWithFlags()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 3.0 and later
* CarbonLib: in CarbonLib 1.1 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
GetGraphicsImporterForDataRefWithFlags(
Handle dataRef,
OSType dataRefType,
ComponentInstance * gi,
long flags);
/*
* QTGetFileNameExtension()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 3.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
QTGetFileNameExtension(
ConstStrFileNameParam fileName,
OSType fileType,
OSType * extension);
/*
* ImageTranscodeSequenceBegin()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
ImageTranscodeSequenceBegin(
ImageTranscodeSequence * its,
ImageDescriptionHandle srcDesc,
OSType destType,
ImageDescriptionHandle * dstDesc,
void * data,
long dataSize);
/*
* ImageTranscodeSequenceEnd()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
ImageTranscodeSequenceEnd(ImageTranscodeSequence its);
/*
* ImageTranscodeFrame()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
ImageTranscodeFrame(
ImageTranscodeSequence its,
void * srcData,
long srcDataSize,
void ** dstData,
long * dstDataSize);
/*
* ImageTranscodeDisposeFrameData()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
ImageTranscodeDisposeFrameData(
ImageTranscodeSequence its,
void * dstData);
/*
* CDSequenceInvalidate()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
CDSequenceInvalidate(
ImageSequence seqID,
RgnHandle invalRgn);
/*
* CDSequenceSetTimeBase()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 3.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
CDSequenceSetTimeBase(
ImageSequence seqID,
void * base);
/*
* ImageFieldSequenceBegin()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
ImageFieldSequenceBegin(
ImageFieldSequence * ifs,
ImageDescriptionHandle desc1,
ImageDescriptionHandle desc2,
ImageDescriptionHandle descOut);
/*
* ImageFieldSequenceExtractCombine()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
ImageFieldSequenceExtractCombine(
ImageFieldSequence ifs,
long fieldFlags,
void * data1,
long dataSize1,
void * data2,
long dataSize2,
void * outputData,
long * outDataSize);
/*
* ImageFieldSequenceEnd()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
ImageFieldSequenceEnd(ImageFieldSequence ifs);
enum {
kICMTempThenAppMemory = 1L << 12,
kICMAppThenTempMemory = 1L << 13
};
/*
* QTNewGWorld()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 3.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
QTNewGWorld(
GWorldPtr * offscreenGWorld,
OSType PixelFormat,
const Rect * boundsRect,
CTabHandle cTable,
GDHandle aGDevice,
GWorldFlags flags);
/*
* QTNewGWorldFromPtr()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( OSErr )
QTNewGWorldFromPtr(
GWorldPtr * gw,
OSType pixelFormat,
const Rect * boundsRect,
CTabHandle cTable,
GDHandle aGDevice,
GWorldFlags flags,
void * baseAddr,
long rowBytes);
/*
* QTUpdateGWorld()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 3.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( GWorldFlags )
QTUpdateGWorld(
GWorldPtr * offscreenGWorld,
OSType PixelFormat,
const Rect * boundsRect,
CTabHandle cTable,
GDHandle aGDevice,
GWorldFlags flags);
/*
* MakeImageDescriptionForPixMap()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 3.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
MakeImageDescriptionForPixMap(
PixMapHandle pixmap,
ImageDescriptionHandle * idh);
/*
* MakeImageDescriptionForEffect()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( OSErr )
MakeImageDescriptionForEffect(
OSType effectType,
ImageDescriptionHandle * idh);
/*
* QTGetPixelSize()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 3.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( short )
QTGetPixelSize(OSType PixelFormat);
/*
* QTGetPixelFormatDepthForImageDescription()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 6.0 and later
* CarbonLib: in CarbonLib 1.6 and later
* Mac OS X: in version 10.2 and later
* Windows: in qtmlClient.lib 6.0 and later
*/
EXTERN_API( short )
QTGetPixelFormatDepthForImageDescription(OSType PixelFormat);
/*
* QTGetPixMapPtrRowBytes()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( long )
QTGetPixMapPtrRowBytes(PixMapPtr pm);
/*
* QTGetPixMapHandleRowBytes()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( long )
QTGetPixMapHandleRowBytes(PixMapHandle pm);
/*
* QTSetPixMapPtrRowBytes()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( OSErr )
QTSetPixMapPtrRowBytes(
PixMapPtr pm,
long rowBytes);
/*
* QTSetPixMapHandleRowBytes()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( OSErr )
QTSetPixMapHandleRowBytes(
PixMapHandle pm,
long rowBytes);
enum {
kQTUsePlatformDefaultGammaLevel = 0, /* When decompressing into this PixMap, gamma-correct to the platform's standard gamma. */
kQTUseSourceGammaLevel = -1L, /* When decompressing into this PixMap, don't perform gamma-correction. */
kQTCCIR601VideoGammaLevel = 0x00023333 /* 2.2, standard television video gamma.*/
};
/*
* QTGetPixMapPtrGammaLevel()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 5.0 and later
* CarbonLib: in CarbonLib 1.3 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 5.0 and later
*/
EXTERN_API( Fixed )
QTGetPixMapPtrGammaLevel(PixMapPtr pm);
/*
* QTSetPixMapPtrGammaLevel()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 5.0 and later
* CarbonLib: in CarbonLib 1.3 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 5.0 and later
*/
EXTERN_API( OSErr )
QTSetPixMapPtrGammaLevel(
PixMapPtr pm,
Fixed gammaLevel);
/*
* QTGetPixMapHandleGammaLevel()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 5.0 and later
* CarbonLib: in CarbonLib 1.3 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 5.0 and later
*/
EXTERN_API( Fixed )
QTGetPixMapHandleGammaLevel(PixMapHandle pm);
/*
* QTSetPixMapHandleGammaLevel()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 5.0 and later
* CarbonLib: in CarbonLib 1.3 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 5.0 and later
*/
EXTERN_API( OSErr )
QTSetPixMapHandleGammaLevel(
PixMapHandle pm,
Fixed gammaLevel);
/*
* QTGetPixMapPtrRequestedGammaLevel()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 5.0 and later
* CarbonLib: in CarbonLib 1.3 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 5.0 and later
*/
EXTERN_API( Fixed )
QTGetPixMapPtrRequestedGammaLevel(PixMapPtr pm);
/*
* QTSetPixMapPtrRequestedGammaLevel()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 5.0 and later
* CarbonLib: in CarbonLib 1.3 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 5.0 and later
*/
EXTERN_API( OSErr )
QTSetPixMapPtrRequestedGammaLevel(
PixMapPtr pm,
Fixed requestedGammaLevel);
/*
* QTGetPixMapHandleRequestedGammaLevel()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 5.0 and later
* CarbonLib: in CarbonLib 1.3 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 5.0 and later
*/
EXTERN_API( Fixed )
QTGetPixMapHandleRequestedGammaLevel(PixMapHandle pm);
/*
* QTSetPixMapHandleRequestedGammaLevel()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 5.0 and later
* CarbonLib: in CarbonLib 1.3 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 5.0 and later
*/
EXTERN_API( OSErr )
QTSetPixMapHandleRequestedGammaLevel(
PixMapHandle pm,
Fixed requestedGammaLevel);
/*
* QuadToQuadMatrix()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( OSErr )
QuadToQuadMatrix(
const Fixed * source,
const Fixed * dest,
MatrixRecord * map);
enum {
identityMatrixType = 0x00, /* result if matrix is identity */
translateMatrixType = 0x01, /* result if matrix translates */
scaleMatrixType = 0x02, /* result if matrix scales */
scaleTranslateMatrixType = 0x03, /* result if matrix scales and translates */
linearMatrixType = 0x04, /* result if matrix is general 2 x 2 */
linearTranslateMatrixType = 0x05, /* result if matrix is general 2 x 2 and translates */
perspectiveMatrixType = 0x06 /* result if matrix is general 3 x 3 */
};
typedef unsigned short MatrixFlags;
/*
* GetMatrixType()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( short )
GetMatrixType(const MatrixRecord * m);
/*
* CopyMatrix()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( void )
CopyMatrix(
const MatrixRecord * m1,
MatrixRecord * m2);
/*
* EqualMatrix()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( Boolean )
EqualMatrix(
const MatrixRecord * m1,
const MatrixRecord * m2);
/*
* SetIdentityMatrix()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( void )
SetIdentityMatrix(MatrixRecord * matrix);
/*
* TranslateMatrix()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( void )
TranslateMatrix(
MatrixRecord * m,
Fixed deltaH,
Fixed deltaV);
/*
* RotateMatrix()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( void )
RotateMatrix(
MatrixRecord * m,
Fixed degrees,
Fixed aboutX,
Fixed aboutY);
/*
* ScaleMatrix()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( void )
ScaleMatrix(
MatrixRecord * m,
Fixed scaleX,
Fixed scaleY,
Fixed aboutX,
Fixed aboutY);
/*
* SkewMatrix()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( void )
SkewMatrix(
MatrixRecord * m,
Fixed skewX,
Fixed skewY,
Fixed aboutX,
Fixed aboutY);
/*
* TransformFixedPoints()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
TransformFixedPoints(
const MatrixRecord * m,
FixedPoint * fpt,
long count);
/*
* TransformPoints()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( OSErr )
TransformPoints(
const MatrixRecord * mp,
Point * pt1,
long count);
/*
* TransformFixedRect()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( Boolean )
TransformFixedRect(
const MatrixRecord * m,
FixedRect * fr,
FixedPoint * fpp);
/*
* TransformRect()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( Boolean )
TransformRect(
const MatrixRecord * m,
Rect * r,
FixedPoint * fpp);
/*
* InverseMatrix()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( Boolean )
InverseMatrix(
const MatrixRecord * m,
MatrixRecord * im);
/*
* ConcatMatrix()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( void )
ConcatMatrix(
const MatrixRecord * a,
MatrixRecord * b);
/*
* RectMatrix()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( void )
RectMatrix(
MatrixRecord * matrix,
const Rect * srcRect,
const Rect * dstRect);
/*
* MapMatrix()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( void )
MapMatrix(
MatrixRecord * matrix,
const Rect * fromRect,
const Rect * toRect);
/*
* CompAdd()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( void )
CompAdd(
wide * src,
wide * dst);
/*
* CompSub()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( void )
CompSub(
wide * src,
wide * dst);
/*
* CompNeg()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( void )
CompNeg(wide * dst);
/*
* CompShift()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( void )
CompShift(
wide * src,
short shift);
/*
* CompMul()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( void )
CompMul(
long src1,
long src2,
wide * dst);
/*
* CompDiv()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( long )
CompDiv(
wide * numerator,
long denominator,
long * remainder);
/*
* CompFixMul()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( void )
CompFixMul(
wide * compSrc,
Fixed fixSrc,
wide * compDst);
/*
* CompMulDiv()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( void )
CompMulDiv(
wide * co,
long mul,
long divisor);
/*
* CompMulDivTrunc()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( void )
CompMulDivTrunc(
wide * co,
long mul,
long divisor,
long * remainder);
/*
* CompCompare()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( long )
CompCompare(
const wide * a,
const wide * minusb);
/*
* CompSquareRoot()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 3.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( unsigned long )
CompSquareRoot(const wide * src);
/*
* FixMulDiv()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( Fixed )
FixMulDiv(
Fixed src,
Fixed mul,
Fixed divisor);
/*
* UnsignedFixMulDiv()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( Fixed )
UnsignedFixMulDiv(
Fixed src,
Fixed mul,
Fixed divisor);
/*
* FracSinCos()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( Fract )
FracSinCos(
Fixed degree,
Fract * cosOut);
/*
* FixExp2()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( Fixed )
FixExp2(Fixed src);
/*
* FixLog2()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( Fixed )
FixLog2(Fixed src);
/*
* FixPow()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( Fixed )
FixPow(
Fixed base,
Fixed exp);
typedef ComponentInstance GraphicsImportComponent;
enum {
GraphicsImporterComponentType = FOUR_CHAR_CODE('grip')
};
/* Component flags for Graphics Importer components */
enum {
graphicsImporterIsBaseImporter = 1L << 0,
graphicsImporterCanValidateFile = 1L << 9,
graphicsImporterSubTypeIsFileExtension = 1L << 12,
graphicsImporterHasMIMEList = 1L << 14,
graphicsImporterUsesImageDecompressor = 1L << 23
};
/* Atom types for QuickTime Image files */
enum {
quickTimeImageFileImageDescriptionAtom = FOUR_CHAR_CODE('idsc'),
quickTimeImageFileImageDataAtom = FOUR_CHAR_CODE('idat'),
quickTimeImageFileMetaDataAtom = FOUR_CHAR_CODE('meta'),
quickTimeImageFileColorSyncProfileAtom = FOUR_CHAR_CODE('iicc')
};
/* Flags for GraphicsImportDoesDrawAllPixels */
enum {
graphicsImporterDrawsAllPixels = 0,
graphicsImporterDoesntDrawAllPixels = 1,
graphicsImporterDontKnowIfDrawAllPixels = 2
};
/* Flags for GraphicsImportSetFlags */
enum {
kGraphicsImporterDontDoGammaCorrection = 1L << 0,
kGraphicsImporterTrustResolutionFromFile = 1L << 1,
kGraphicsImporterEnableSubPixelPositioning = 1L << 2,
kGraphicsImporterDontUseColorMatching = 1L << 3 /* set this flag (*before* calling GraphicsImportGetColorSyncProfile) if you do matching yourself */
};
/* Flags for GraphicsImportCreateCGImage */
enum {
kGraphicsImportCreateCGImageUsingCurrentSettings = 1L << 0
};
enum {
kGraphicsExportGroup = FOUR_CHAR_CODE('expo'),
kGraphicsExportFileType = FOUR_CHAR_CODE('ftyp'),
kGraphicsExportMIMEType = FOUR_CHAR_CODE('mime'),
kGraphicsExportExtension = FOUR_CHAR_CODE('ext '),
kGraphicsExportDescription = FOUR_CHAR_CODE('desc')
};
/* User data types for layers of Photoshop files */
enum {
kQTPhotoshopLayerMode = FOUR_CHAR_CODE('lmod'), /* OSType */
kQTPhotoshopLayerOpacity = FOUR_CHAR_CODE('lopa'), /* UInt8, 0 = transparent .. 255 = opaque */
kQTPhotoshopLayerClipping = FOUR_CHAR_CODE('lclp'), /* UInt8, 0 = base, 1 = non-base */
kQTPhotoshopLayerFlags = FOUR_CHAR_CODE('lflg'), /* UInt8 */
kQTPhotoshopLayerName = 0xA96C6E6D, /* Text */
kQTPhotoshopLayerUnicodeName = FOUR_CHAR_CODE('luni') /* Unicode characters, not terminated */
};
/* User data returned by graphics importers to suggest intended use for indexed images */
enum {
kQTIndexedImageType = FOUR_CHAR_CODE('nth?'), /* 1 or more OSTypes, such as the following values: */
kQTIndexedImageIsThumbnail = FOUR_CHAR_CODE('n=th'), /* The image at this index is a thumbnail. */
kQTIndexedImageIsLayer = FOUR_CHAR_CODE('n=ly'), /* The image at this index is a layer. */
kQTIndexedImageIsPage = FOUR_CHAR_CODE('n=pg'), /* The image at this index is a page. */
kQTIndexedImageIsMultiResolution = FOUR_CHAR_CODE('n=rs') /* The image at this index is one of several identical images at different resolutions. */
};
/* Other user data types returned by graphics importers */
enum {
kQTTIFFUserDataPrefix = 0x74690000, /* Added to some tag values in TIFF IFDs to generate user data codes. (0x7469 is 'ti'.) */
/* For example, YCbCrPositioning is tag 0x0213, so its user data code is 0x74690213. */
kQTTIFFExifUserDataPrefix = 0x65780000, /* Added to tag values in Exif IFDs to generate user data codes. (0x6578 is 'ex'.) */
/* For example, DateTimeOriginal is tag 0x9003, so its user data code is 0x65789003. */
kQTTIFFExifGPSUserDataPrefix = 0x67700000, /* Added to tag values in Exif GPS IFDs to generate user data codes. (0x6770 is 'gp'.) */
/* For example, GPSAltitude is tag 0x0006, so its user data code is 0x6770006. */
kQTAlphaMode = FOUR_CHAR_CODE('almo'), /* UInt32; eg, graphicsModeStraightAlpha or graphicsModePreBlackAlpha */
kQTAlphaModePreMulColor = FOUR_CHAR_CODE('almp'), /* RGBColor; used if kQTAlphaMode is graphicsModePreMulColorAlpha */
kUserDataIPTC = FOUR_CHAR_CODE('iptc')
};
/* Found in TIFF and Exif JPEG files */
enum {
kQTTIFFUserDataOrientation = 0x74690112, /* 1 SHORT */
kQTTIFFUserDataTransferFunction = 0x7469012D, /* n SHORTs */
kQTTIFFUserDataWhitePoint = 0x7469013E, /* 2 RATIONALs */
kQTTIFFUserDataPrimaryChromaticities = 0x7469013F, /* 6 RATIONALs */
kQTTIFFUserDataTransferRange = 0x74690156, /* 6 SHORTs */
kQTTIFFUserDataYCbCrPositioning = 0x74690213, /* 1 SHORT */
kQTTIFFUserDataReferenceBlackWhite = 0x74690214 /* n LONGs */
};
/* Found in GeoTIFF files; defined in the GeoTIFF 1.0 spec */
enum {
kQTTIFFUserDataModelPixelScale = 0x7469830E, /* 3 DOUBLEs */
kQTTIFFUserDataModelTransformation = 0x746985D8, /* 16 DOUBLEs */
kQTTIFFUserDataModelTiepoint = 0x74698482, /* n DOUBLEs */
kQTTIFFUserDataGeoKeyDirectory = 0x746987AF, /* n SHORTs */
kQTTIFFUserDataGeoDoubleParams = 0x746987B0, /* n DOUBLEs */
kQTTIFFUserDataGeoAsciiParams = 0x746987B1, /* n ASCIIs */
kQTTIFFUserDataIntergraphMatrix = 0x74698480 /* 16 or 17 DOUBLEs */
};
/* Found in Exif TIFF and Exif JPEG files; defined in the Exif 2.1 spec */
enum {
kQTExifUserDataExifVersion = 0x65789000, /* 4 bytes (import only) */
kQTExifUserDataFlashPixVersion = 0x6578A000, /* 4 bytes */
kQTExifUserDataColorSpace = 0x6578A001, /* 1 SHORT */
kQTExifUserDataComponentsConfiguration = 0x65789101, /* 4 bytes */
kQTExifUserDataCompressedBitsPerPixel = 0x65789102, /* 1 RATIONAL */
kQTExifUserDataPixelXDimension = 0x6578A002, /* 1 SHORT or LONG */
kQTExifUserDataPixelYDimension = 0x6578A003, /* 1 SHORT or LONG */
kQTExifUserDataMakerNote = 0x6578927C, /* n bytes */
kQTExifUserDataUserComment = 0x65789286, /* n bytes (Note: this constant was erroneously 0x6578928C)*/
kQTExifUserDataRelatedSoundFile = 0x6578A004, /* 13 ASCIIs*/
kQTExifUserDataDateTimeOriginal = 0x65789003, /* 20 ASCIIs */
kQTExifUserDataDateTimeDigitized = 0x65789004, /* 20 ASCIIs */
kQTExifUserDataSubSecTime = 0x65789290, /* n ASCIIs */
kQTExifUserDataSubSecTimeOriginal = 0x65789291, /* n ASCIIs */
kQTExifUserDataSubSecTimeDigitized = 0x65789292, /* n ASCIIs */
kQTExifUserDataExposureTime = 0x6578829A, /* 1 RATIONAL */
kQTExifUserDataFNumber = 0x6578829D, /* 1 RATIONAL */
kQTExifUserDataExposureProgram = 0x65788822, /* 1 SHORT */
kQTExifUserDataSpectralSensitivity = 0x65788824, /* n ASCIIs */
kQTExifUserDataISOSpeedRatings = 0x65788827, /* n SHORTs */
kQTExifUserDataShutterSpeedValue = 0x65789201, /* 1 SIGNED RATIONAL */
kQTExifUserDataApertureValue = 0x65789202, /* 1 RATIONAL */
kQTExifUserDataBrightnessValue = 0x65789203, /* 1 SIGNED RATIONAL */
kQTExifUserDataExposureBiasValue = 0x65789204, /* 1 SIGNED RATIONAL */
kQTExifUserDataMaxApertureValue = 0x65789205, /* 1 RATIONAL */
kQTExifUserDataSubjectDistance = 0x65789206, /* 1 RATIONAL */
kQTExifUserDataMeteringMode = 0x65789207, /* 1 SHORT */
kQTExifUserDataLightSource = 0x65789208, /* 1 SHORT */
kQTExifUserDataFlash = 0x65789209, /* 1 SHORT */
kQTExifUserDataFocalLength = 0x6578920A, /* 1 RATIONAL */
kQTExifUserDataFlashEnergy = 0x6578A20B, /* 1 RATIONAL */
kQTExifUserDataFocalPlaneXResolution = 0x6578A20E, /* 1 RATIONAL */
kQTExifUserDataFocalPlaneYResolution = 0x6578A20F, /* 1 RATIONAL */
kQTExifUserDataFocalPlaneResolutionUnit = 0x6578A210, /* 1 SHORT */
kQTExifUserDataSubjectLocation = 0x6578A214, /* 1 SHORT */
kQTExifUserDataExposureIndex = 0x6578A215, /* 1 RATIONAL */
kQTExifUserDataSensingMethod = 0x6578A217, /* 1 SHORT */
kQTExifUserDataFileSource = 0x6578A300, /* 1 UNDEFINED */
kQTExifUserDataSceneType = 0x6578A301 /* 1 UNDEFINED */
};
/* Found in some Exif TIFF and Exif JPEG files; defined in the Exif 2.1 spec */
/* Note: these were wrong in the QuickTime 6.0 headers -- the high two bytes were 0x677 instead of 0x6770. */
enum {
kQTExifUserDataGPSVersionID = 0x67700000, /* 4 BYTEs */
kQTExifUserDataGPSLatitudeRef = 0x67700001, /* 2 ASCIIs*/
kQTExifUserDataGPSLatitude = 0x67700002, /* 3 RATIONALs */
kQTExifUserDataGPSLongitudeRef = 0x67700003, /* 2 ASCIIs */
kQTExifUserDataGPSLongitude = 0x67700004, /* 3 RATIONALs */
kQTExifUserDataGPSAltitudeRef = 0x67700005, /* 1 BYTE */
kQTExifUserDataGPSAltitude = 0x67700006, /* 1 RATIONAL */
kQTExifUserDataGPSTimeStamp = 0x67700007, /* 3 RATIONALs */
kQTExifUserDataGPSSatellites = 0x67700008, /* n ASCIIs */
kQTExifUserDataGPSStatus = 0x67700009, /* 2 ASCIIs */
kQTExifUserDataGPSMeasureMode = 0x6770000A, /* 2 ASCIIs */
kQTExifUserDataGPSDOP = 0x6770000B, /* 1 RATIONAL */
kQTExifUserDataGPSSpeedRef = 0x6770000C, /* 2 ASCIIs */
kQTExifUserDataGPSSpeed = 0x6770000D, /* 1 RATIONAL */
kQTExifUserDataGPSTrackRef = 0x6770000E, /* 2 ASCIIs */
kQTExifUserDataGPSTrack = 0x6770000F, /* 1 RATIONAL */
kQTExifUserDataGPSImgDirectionRef = 0x67700010, /* 2 ASCIIs */
kQTExifUserDataGPSImgDirection = 0x67700011, /* 1 RATIONAL */
kQTExifUserDataGPSMapDatum = 0x67700012, /* n ASCII */
kQTExifUserDataGPSDestLatitudeRef = 0x67700013, /* 2 ASCIIs */
kQTExifUserDataGPSDestLatitude = 0x67700014, /* 3 RATIONALs */
kQTExifUserDataGPSDestLongitudeRef = 0x67700015, /* 2 ASCIIs */
kQTExifUserDataGPSDestLongitude = 0x67700016, /* 3 RATIONALs */
kQTExifUserDataGPSDestBearingRef = 0x67700017, /* 2 ASCIIs */
kQTExifUserDataGPSDestBearing = 0x67700018, /* 1 RATIONAL */
kQTExifUserDataGPSDestDistanceRef = 0x67700019, /* 2 ASCIIs */
kQTExifUserDataGPSDestDistance = 0x6770001A /* 1 RATIONAL */
};
/** These are GraphicsImport procedures **/
/*
* GraphicsImportSetDataReference()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportSetDataReference(
GraphicsImportComponent ci,
Handle dataRef,
OSType dataReType) FIVEWORDINLINE(0x2F3C, 0x0008, 0x0001, 0x7000, 0xA82A);
/*
* GraphicsImportGetDataReference()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetDataReference(
GraphicsImportComponent ci,
Handle * dataRef,
OSType * dataReType) FIVEWORDINLINE(0x2F3C, 0x0008, 0x0002, 0x7000, 0xA82A);
/*
* GraphicsImportSetDataFile()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportSetDataFile(
GraphicsImportComponent ci,
const FSSpec * theFile) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0003, 0x7000, 0xA82A);
/*
* GraphicsImportGetDataFile()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetDataFile(
GraphicsImportComponent ci,
FSSpec * theFile) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0004, 0x7000, 0xA82A);
/*
* GraphicsImportSetDataHandle()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportSetDataHandle(
GraphicsImportComponent ci,
Handle h) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0005, 0x7000, 0xA82A);
/*
* GraphicsImportGetDataHandle()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetDataHandle(
GraphicsImportComponent ci,
Handle * h) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0006, 0x7000, 0xA82A);
/*
* GraphicsImportGetImageDescription()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetImageDescription(
GraphicsImportComponent ci,
ImageDescriptionHandle * desc) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0007, 0x7000, 0xA82A);
/*
* GraphicsImportGetDataOffsetAndSize()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetDataOffsetAndSize(
GraphicsImportComponent ci,
unsigned long * offset,
unsigned long * size) FIVEWORDINLINE(0x2F3C, 0x0008, 0x0008, 0x7000, 0xA82A);
/*
* GraphicsImportReadData()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportReadData(
GraphicsImportComponent ci,
void * dataPtr,
unsigned long dataOffset,
unsigned long dataSize) FIVEWORDINLINE(0x2F3C, 0x000C, 0x0009, 0x7000, 0xA82A);
/*
* GraphicsImportSetClip()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportSetClip(
GraphicsImportComponent ci,
RgnHandle clipRgn) FIVEWORDINLINE(0x2F3C, 0x0004, 0x000A, 0x7000, 0xA82A);
/*
* GraphicsImportGetClip()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetClip(
GraphicsImportComponent ci,
RgnHandle * clipRgn) FIVEWORDINLINE(0x2F3C, 0x0004, 0x000B, 0x7000, 0xA82A);
/*
* GraphicsImportSetSourceRect()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportSetSourceRect(
GraphicsImportComponent ci,
const Rect * sourceRect) FIVEWORDINLINE(0x2F3C, 0x0004, 0x000C, 0x7000, 0xA82A);
/*
* GraphicsImportGetSourceRect()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetSourceRect(
GraphicsImportComponent ci,
Rect * sourceRect) FIVEWORDINLINE(0x2F3C, 0x0004, 0x000D, 0x7000, 0xA82A);
/*
* GraphicsImportGetNaturalBounds()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetNaturalBounds(
GraphicsImportComponent ci,
Rect * naturalBounds) FIVEWORDINLINE(0x2F3C, 0x0004, 0x000E, 0x7000, 0xA82A);
/*
* GraphicsImportDraw()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportDraw(GraphicsImportComponent ci) FIVEWORDINLINE(0x2F3C, 0x0000, 0x000F, 0x7000, 0xA82A);
/*
* GraphicsImportSetGWorld()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportSetGWorld(
GraphicsImportComponent ci,
CGrafPtr port,
GDHandle gd) FIVEWORDINLINE(0x2F3C, 0x0008, 0x0010, 0x7000, 0xA82A);
/*
* GraphicsImportGetGWorld()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetGWorld(
GraphicsImportComponent ci,
CGrafPtr * port,
GDHandle * gd) FIVEWORDINLINE(0x2F3C, 0x0008, 0x0011, 0x7000, 0xA82A);
/*
* GraphicsImportSetMatrix()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportSetMatrix(
GraphicsImportComponent ci,
const MatrixRecord * matrix) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0012, 0x7000, 0xA82A);
/*
* GraphicsImportGetMatrix()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetMatrix(
GraphicsImportComponent ci,
MatrixRecord * matrix) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0013, 0x7000, 0xA82A);
/*
* GraphicsImportSetBoundsRect()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportSetBoundsRect(
GraphicsImportComponent ci,
const Rect * bounds) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0014, 0x7000, 0xA82A);
/*
* GraphicsImportGetBoundsRect()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetBoundsRect(
GraphicsImportComponent ci,
Rect * bounds) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0015, 0x7000, 0xA82A);
/*
* GraphicsImportSaveAsPicture()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportSaveAsPicture(
GraphicsImportComponent ci,
const FSSpec * fss,
ScriptCode scriptTag) FIVEWORDINLINE(0x2F3C, 0x0006, 0x0016, 0x7000, 0xA82A);
/*
* GraphicsImportSetGraphicsMode()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportSetGraphicsMode(
GraphicsImportComponent ci,
long graphicsMode,
const RGBColor * opColor) FIVEWORDINLINE(0x2F3C, 0x0008, 0x0017, 0x7000, 0xA82A);
/*
* GraphicsImportGetGraphicsMode()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetGraphicsMode(
GraphicsImportComponent ci,
long * graphicsMode,
RGBColor * opColor) FIVEWORDINLINE(0x2F3C, 0x0008, 0x0018, 0x7000, 0xA82A);
/*
* GraphicsImportSetQuality()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportSetQuality(
GraphicsImportComponent ci,
CodecQ quality) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0019, 0x7000, 0xA82A);
/*
* GraphicsImportGetQuality()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetQuality(
GraphicsImportComponent ci,
CodecQ * quality) FIVEWORDINLINE(0x2F3C, 0x0004, 0x001A, 0x7000, 0xA82A);
/*
* GraphicsImportSaveAsQuickTimeImageFile()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportSaveAsQuickTimeImageFile(
GraphicsImportComponent ci,
const FSSpec * fss,
ScriptCode scriptTag) FIVEWORDINLINE(0x2F3C, 0x0006, 0x001B, 0x7000, 0xA82A);
/*
* GraphicsImportSetDataReferenceOffsetAndLimit()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportSetDataReferenceOffsetAndLimit(
GraphicsImportComponent ci,
unsigned long offset,
unsigned long limit) FIVEWORDINLINE(0x2F3C, 0x0008, 0x001C, 0x7000, 0xA82A);
/*
* GraphicsImportGetDataReferenceOffsetAndLimit()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetDataReferenceOffsetAndLimit(
GraphicsImportComponent ci,
unsigned long * offset,
unsigned long * limit) FIVEWORDINLINE(0x2F3C, 0x0008, 0x001D, 0x7000, 0xA82A);
/*
* GraphicsImportGetAliasedDataReference()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetAliasedDataReference(
GraphicsImportComponent ci,
Handle * dataRef,
OSType * dataRefType) FIVEWORDINLINE(0x2F3C, 0x0008, 0x001E, 0x7000, 0xA82A);
/*
* GraphicsImportValidate()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportValidate(
GraphicsImportComponent ci,
Boolean * valid) FIVEWORDINLINE(0x2F3C, 0x0004, 0x001F, 0x7000, 0xA82A);
/*
* GraphicsImportGetMetaData()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 3.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetMetaData(
GraphicsImportComponent ci,
void * userData) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0020, 0x7000, 0xA82A);
/*
* GraphicsImportGetMIMETypeList()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 3.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetMIMETypeList(
GraphicsImportComponent ci,
void * qtAtomContainerPtr) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0021, 0x7000, 0xA82A);
/*
* GraphicsImportDoesDrawAllPixels()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 3.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportDoesDrawAllPixels(
GraphicsImportComponent ci,
short * drawsAllPixels) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0022, 0x7000, 0xA82A);
/*
* GraphicsImportGetAsPicture()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 3.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetAsPicture(
GraphicsImportComponent ci,
PicHandle * picture) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0023, 0x7000, 0xA82A);
/*
* GraphicsImportExportImageFile()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 3.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportExportImageFile(
GraphicsImportComponent ci,
OSType fileType,
OSType fileCreator,
const FSSpec * fss,
ScriptCode scriptTag) FIVEWORDINLINE(0x2F3C, 0x000E, 0x0024, 0x7000, 0xA82A);
/*
* GraphicsImportGetExportImageTypeList()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 3.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetExportImageTypeList(
GraphicsImportComponent ci,
void * qtAtomContainerPtr) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0025, 0x7000, 0xA82A);
/*
* GraphicsImportDoExportImageFileDialog()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 3.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportDoExportImageFileDialog(
GraphicsImportComponent ci,
const FSSpec * inDefaultSpec,
StringPtr prompt,
ModalFilterYDUPP filterProc,
OSType * outExportedType,
FSSpec * outExportedSpec,
ScriptCode * outScriptTag) FIVEWORDINLINE(0x2F3C, 0x0018, 0x0026, 0x7000, 0xA82A);
/*
* GraphicsImportGetExportSettingsAsAtomContainer()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 3.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetExportSettingsAsAtomContainer(
GraphicsImportComponent ci,
void * qtAtomContainerPtr) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0027, 0x7000, 0xA82A);
/*
* GraphicsImportSetExportSettingsFromAtomContainer()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 3.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportSetExportSettingsFromAtomContainer(
GraphicsImportComponent ci,
void * qtAtomContainer) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0028, 0x7000, 0xA82A);
/*
* GraphicsImportSetProgressProc()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 3.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportSetProgressProc(
GraphicsImportComponent ci,
ICMProgressProcRecordPtr progressProc) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0029, 0x7000, 0xA82A);
/*
* GraphicsImportGetProgressProc()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 3.0 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetProgressProc(
GraphicsImportComponent ci,
ICMProgressProcRecordPtr progressProc) FIVEWORDINLINE(0x2F3C, 0x0004, 0x002A, 0x7000, 0xA82A);
/*
* GraphicsImportGetImageCount()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetImageCount(
GraphicsImportComponent ci,
unsigned long * imageCount) FIVEWORDINLINE(0x2F3C, 0x0004, 0x002B, 0x7000, 0xA82A);
/*
* GraphicsImportSetImageIndex()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportSetImageIndex(
GraphicsImportComponent ci,
unsigned long imageIndex) FIVEWORDINLINE(0x2F3C, 0x0004, 0x002C, 0x7000, 0xA82A);
/*
* GraphicsImportGetImageIndex()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetImageIndex(
GraphicsImportComponent ci,
unsigned long * imageIndex) FIVEWORDINLINE(0x2F3C, 0x0004, 0x002D, 0x7000, 0xA82A);
/*
* GraphicsImportGetDataOffsetAndSize64()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetDataOffsetAndSize64(
GraphicsImportComponent ci,
wide * offset,
wide * size) FIVEWORDINLINE(0x2F3C, 0x0008, 0x002E, 0x7000, 0xA82A);
/*
* GraphicsImportReadData64()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportReadData64(
GraphicsImportComponent ci,
void * dataPtr,
const wide * dataOffset,
unsigned long dataSize) FIVEWORDINLINE(0x2F3C, 0x000C, 0x002F, 0x7000, 0xA82A);
/*
* GraphicsImportSetDataReferenceOffsetAndLimit64()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportSetDataReferenceOffsetAndLimit64(
GraphicsImportComponent ci,
const wide * offset,
const wide * limit) FIVEWORDINLINE(0x2F3C, 0x0008, 0x0030, 0x7000, 0xA82A);
/*
* GraphicsImportGetDataReferenceOffsetAndLimit64()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetDataReferenceOffsetAndLimit64(
GraphicsImportComponent ci,
wide * offset,
wide * limit) FIVEWORDINLINE(0x2F3C, 0x0008, 0x0031, 0x7000, 0xA82A);
/*
* GraphicsImportGetDefaultMatrix()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetDefaultMatrix(
GraphicsImportComponent ci,
MatrixRecord * defaultMatrix) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0032, 0x7000, 0xA82A);
/*
* GraphicsImportGetDefaultClip()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetDefaultClip(
GraphicsImportComponent ci,
RgnHandle * defaultRgn) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0033, 0x7000, 0xA82A);
/*
* GraphicsImportGetDefaultGraphicsMode()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetDefaultGraphicsMode(
GraphicsImportComponent ci,
long * defaultGraphicsMode,
RGBColor * defaultOpColor) FIVEWORDINLINE(0x2F3C, 0x0008, 0x0034, 0x7000, 0xA82A);
/*
* GraphicsImportGetDefaultSourceRect()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetDefaultSourceRect(
GraphicsImportComponent ci,
Rect * defaultSourceRect) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0035, 0x7000, 0xA82A);
/*
* GraphicsImportGetColorSyncProfile()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetColorSyncProfile(
GraphicsImportComponent ci,
Handle * profile) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0036, 0x7000, 0xA82A);
/*
* GraphicsImportSetDestRect()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportSetDestRect(
GraphicsImportComponent ci,
const Rect * destRect) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0037, 0x7000, 0xA82A);
/*
* GraphicsImportGetDestRect()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetDestRect(
GraphicsImportComponent ci,
Rect * destRect) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0038, 0x7000, 0xA82A);
/*
* GraphicsImportSetFlags()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportSetFlags(
GraphicsImportComponent ci,
long flags) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0039, 0x7000, 0xA82A);
/*
* GraphicsImportGetFlags()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetFlags(
GraphicsImportComponent ci,
long * flags) FIVEWORDINLINE(0x2F3C, 0x0004, 0x003A, 0x7000, 0xA82A);
/* 2 private selectors */
/*
* GraphicsImportGetBaseDataOffsetAndSize64()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 5.0.2 and later
* CarbonLib: in CarbonLib 1.4 and later
* Mac OS X: in version 10.1 and later
* Windows: in qtmlClient.lib 5.0.2 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetBaseDataOffsetAndSize64(
GraphicsImportComponent ci,
wide * offset,
wide * size) FIVEWORDINLINE(0x2F3C, 0x0008, 0x003D, 0x7000, 0xA82A);
/*
* GraphicsImportSetImageIndexToThumbnail()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 6.0 and later
* CarbonLib: in CarbonLib 1.6 and later
* Mac OS X: in version 10.2 and later
* Windows: in qtmlClient.lib 6.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportSetImageIndexToThumbnail(GraphicsImportComponent ci) FIVEWORDINLINE(0x2F3C, 0x0000, 0x003E, 0x7000, 0xA82A);
#if TARGET_API_MAC_OSX
/*
* GraphicsImportCreateCGImage()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
*/
EXTERN_API( ComponentResult )
GraphicsImportCreateCGImage(
GraphicsImportComponent ci,
CGImageRef * imageRefOut,
UInt32 flags) FIVEWORDINLINE(0x2F3C, 0x0008, 0x003F, 0x7000, 0xA82A);
#endif /* TARGET_API_MAC_OSX */
/*
* GraphicsImportSaveAsPictureToDataRef()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
* Windows: in qtmlClient.lib 6.5 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportSaveAsPictureToDataRef(
GraphicsImportComponent ci,
Handle dataRef,
OSType dataRefType) FIVEWORDINLINE(0x2F3C, 0x0008, 0x0040, 0x7000, 0xA82A);
/*
* GraphicsImportSaveAsQuickTimeImageFileToDataRef()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
* Windows: in qtmlClient.lib 6.5 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportSaveAsQuickTimeImageFileToDataRef(
GraphicsImportComponent ci,
Handle dataRef,
OSType dataRefType) FIVEWORDINLINE(0x2F3C, 0x0008, 0x0041, 0x7000, 0xA82A);
/*
* GraphicsImportExportImageFileToDataRef()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
* Windows: in qtmlClient.lib 6.5 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportExportImageFileToDataRef(
GraphicsImportComponent ci,
OSType fileType,
OSType fileCreator,
Handle dataRef,
OSType dataRefType) FIVEWORDINLINE(0x2F3C, 0x0010, 0x0042, 0x7000, 0xA82A);
/*
* GraphicsImportDoExportImageFileToDataRefDialog()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
* Windows: in qtmlClient.lib 6.5 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportDoExportImageFileToDataRefDialog(
GraphicsImportComponent ci,
Handle inDataRef,
OSType inDataRefType,
CFStringRef prompt,
ModalFilterYDUPP filterProc,
OSType * outExportedType,
Handle * outDataRef,
OSType * outDataRefType) FIVEWORDINLINE(0x2F3C, 0x001C, 0x0043, 0x7000, 0xA82A);
#if TARGET_API_MAC_OSX
/* NOTE: If the source override ColorSync profile is NULL, then the image's ColorSync profile may be used if available, otherwise a generic ColorSync profile may be used. */
/*
* GraphicsImportSetOverrideSourceColorSyncProfileRef()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
*/
EXTERN_API( ComponentResult )
GraphicsImportSetOverrideSourceColorSyncProfileRef(
GraphicsImportComponent ci,
CMProfileRef newOverrideSourceProfileRef) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0044, 0x7000, 0xA82A);
/*
* GraphicsImportGetOverrideSourceColorSyncProfileRef()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetOverrideSourceColorSyncProfileRef(
GraphicsImportComponent ci,
CMProfileRef * outOverrideSourceProfileRef) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0045, 0x7000, 0xA82A);
/* NOTE: If the destination ColorSync profile is NULL, then a generic ColorSync profile may be used. */
/*
* GraphicsImportSetDestinationColorSyncProfileRef()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
*/
EXTERN_API( ComponentResult )
GraphicsImportSetDestinationColorSyncProfileRef(
GraphicsImportComponent ci,
CMProfileRef newDestinationProfileRef) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0046, 0x7000, 0xA82A);
/*
* GraphicsImportGetDestinationColorSyncProfileRef()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetDestinationColorSyncProfileRef(
GraphicsImportComponent ci,
CMProfileRef * destinationProfileRef) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0047, 0x7000, 0xA82A);
#endif /* TARGET_API_MAC_OSX */
/*
* GraphicsImportWillUseColorMatching()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
* Windows: in qtmlClient.lib 6.5 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportWillUseColorMatching(
GraphicsImportComponent ci,
Boolean * outWillMatch) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0048, 0x7000, 0xA82A);
#if TARGET_API_MAC_OSX
/* This convenience API is implemented by the base graphics importer for format-specific importers. */
/*
* GraphicsImportGetGenericColorSyncProfile()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetGenericColorSyncProfile(
GraphicsImportComponent ci,
OSType pixelFormat,
void * reservedSetToNULL,
UInt32 flags,
Handle * genericColorSyncProfileOut) FIVEWORDINLINE(0x2F3C, 0x0010, 0x0049, 0x7000, 0xA82A);
#endif /* TARGET_API_MAC_OSX */
/* Format-specific importers that implement GetColorSyncProfile and that want the base graphics
importer to automatically support ColorSync matching should:
(a) implement GraphicsImportSetReturnGenericColorSyncProfile; when it is called, set an internal flag
(b) change GraphicsImportGetColorSyncProfile so that, if this internal flag is set,
when the source image file contains a profile
and the kGraphicsImporterDontUseColorMatching flag is NOT set,
it returns a generic profile of the appropriate colorspace instead.
Other importers should *not* implement GraphicsImportSetReturnGenericColorSyncProfile. */
/* WARNING: Applications should not call this API; it is internal graphics importer plumbing.
Set kGraphicsImporterDontUseColorMatching instead. */
/*
* GraphicsImportSetReturnGenericColorSyncProfile()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
* Windows: in qtmlClient.lib 6.5 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportSetReturnGenericColorSyncProfile(
GraphicsImportComponent ci,
Boolean returnGenericProfilesUnlessDontMatchFlagSet) FIVEWORDINLINE(0x2F3C, 0x0002, 0x004A, 0x7000, 0xA82A);
/* WARNING: Applications should not call this API; it is internal graphics importer plumbing. */
/*
* GraphicsImportGetReturnGenericColorSyncProfile()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
* Windows: in qtmlClient.lib 6.5 and later
*/
EXTERN_API( ComponentResult )
GraphicsImportGetReturnGenericColorSyncProfile(
GraphicsImportComponent ci,
Boolean * returnGenericProfilesUnlessDontMatchFlagSet) FIVEWORDINLINE(0x2F3C, 0x0004, 0x004B, 0x7000, 0xA82A);
typedef ComponentInstance GraphicsExportComponent;
enum {
GraphicsExporterComponentType = FOUR_CHAR_CODE('grex'),
kBaseGraphicsExporterSubType = FOUR_CHAR_CODE('base')
};
/* Component flags for Graphics Exporter components */
enum {
graphicsExporterIsBaseExporter = 1L << 0,
graphicsExporterCanTranscode = 1L << 1,
graphicsExporterUsesImageCompressor = 1L << 2
};
struct QTResolutionSettings {
Fixed horizontalResolution;
Fixed verticalResolution;
};
typedef struct QTResolutionSettings QTResolutionSettings;
struct QTTargetDataSize {
unsigned long targetDataSize;
};
typedef struct QTTargetDataSize QTTargetDataSize;
struct QTThumbnailSettings {
long enableThumbnail; /* a thoroughly padded Boolean*/
long maxThumbnailWidth; /* set to zero to let someone else decide*/
long maxThumbnailHeight; /* set to zero to let someone else decide*/
};
typedef struct QTThumbnailSettings QTThumbnailSettings;
enum {
kQTResolutionSettings = FOUR_CHAR_CODE('reso'),
kQTTargetDataSize = FOUR_CHAR_CODE('dasz'),
kQTDontRecompress = FOUR_CHAR_CODE('dntr'),
kQTInterlaceStyle = FOUR_CHAR_CODE('ilac'),
kQTColorSyncProfile = FOUR_CHAR_CODE('iccp'),
kQTThumbnailSettings = FOUR_CHAR_CODE('thum'),
kQTEnableExif = FOUR_CHAR_CODE('exif'), /* UInt8 (boolean)*/
kQTMetaData = FOUR_CHAR_CODE('meta')
};
enum {
kQTTIFFCompressionMethod = FOUR_CHAR_CODE('tifc'), /* UInt32*/
kQTTIFFCompression_None = 1,
kQTTIFFCompression_PackBits = 32773L,
kQTTIFFLittleEndian = FOUR_CHAR_CODE('tife') /* UInt8 (boolean)*/
};
enum {
kQTPNGFilterPreference = FOUR_CHAR_CODE('pngf'), /* UInt32*/
kQTPNGFilterBestForColorType = FOUR_CHAR_CODE('bflt'),
kQTPNGFilterNone = 0,
kQTPNGFilterSub = 1,
kQTPNGFilterUp = 2,
kQTPNGFilterAverage = 3,
kQTPNGFilterPaeth = 4,
kQTPNGFilterAdaptivePerRow = FOUR_CHAR_CODE('aflt'),
kQTPNGInterlaceStyle = FOUR_CHAR_CODE('ilac'), /* UInt32*/
kQTPNGInterlaceNone = 0,
kQTPNGInterlaceAdam7 = 1
};
enum {
kQTJPEGQuantizationTables = FOUR_CHAR_CODE('jpqt'),
kQTJPEGHuffmanTables = FOUR_CHAR_CODE('jpht')
};
/** These are GraphicsExport procedures **/
/* To use: set the input and output (and other settings as desired) and call GEDoExport. */
/*
* GraphicsExportDoExport()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportDoExport(
GraphicsExportComponent ci,
unsigned long * actualSizeWritten) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0001, 0x7000, 0xA82A);
/* Used for internal communication between the base and format-specific graphics exporter: */
/*
* GraphicsExportCanTranscode()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportCanTranscode(
GraphicsExportComponent ci,
Boolean * canTranscode) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0002, 0x7000, 0xA82A);
/*
* GraphicsExportDoTranscode()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportDoTranscode(GraphicsExportComponent ci) FIVEWORDINLINE(0x2F3C, 0x0000, 0x0003, 0x7000, 0xA82A);
/*
* GraphicsExportCanUseCompressor()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportCanUseCompressor(
GraphicsExportComponent ci,
Boolean * canUseCompressor,
void * codecSettingsAtomContainerPtr) FIVEWORDINLINE(0x2F3C, 0x0008, 0x0004, 0x7000, 0xA82A);
/*
* GraphicsExportDoUseCompressor()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportDoUseCompressor(
GraphicsExportComponent ci,
void * codecSettingsAtomContainer,
ImageDescriptionHandle * outDesc) FIVEWORDINLINE(0x2F3C, 0x0008, 0x0005, 0x7000, 0xA82A);
/*
* GraphicsExportDoStandaloneExport()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportDoStandaloneExport(GraphicsExportComponent ci) FIVEWORDINLINE(0x2F3C, 0x0000, 0x0006, 0x7000, 0xA82A);
/* Queries applications can make of a format-specific graphics exporter: */
/*
* GraphicsExportGetDefaultFileTypeAndCreator()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetDefaultFileTypeAndCreator(
GraphicsExportComponent ci,
OSType * fileType,
OSType * fileCreator) FIVEWORDINLINE(0x2F3C, 0x0008, 0x0007, 0x7000, 0xA82A);
/*
* GraphicsExportGetDefaultFileNameExtension()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetDefaultFileNameExtension(
GraphicsExportComponent ci,
OSType * fileNameExtension) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0008, 0x7000, 0xA82A);
/*
* GraphicsExportGetMIMETypeList()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetMIMETypeList(
GraphicsExportComponent ci,
void * qtAtomContainerPtr) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0009, 0x7000, 0xA82A);
/* (1 unused selector) */
/* Graphics exporter settings: */
/*
* GraphicsExportRequestSettings()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportRequestSettings(
GraphicsExportComponent ci,
ModalFilterYDUPP filterProc,
void * yourDataProc) FIVEWORDINLINE(0x2F3C, 0x0008, 0x000B, 0x7000, 0xA82A);
/*
* GraphicsExportSetSettingsFromAtomContainer()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetSettingsFromAtomContainer(
GraphicsExportComponent ci,
void * qtAtomContainer) FIVEWORDINLINE(0x2F3C, 0x0004, 0x000C, 0x7000, 0xA82A);
/*
* GraphicsExportGetSettingsAsAtomContainer()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetSettingsAsAtomContainer(
GraphicsExportComponent ci,
void * qtAtomContainerPtr) FIVEWORDINLINE(0x2F3C, 0x0004, 0x000D, 0x7000, 0xA82A);
/*
* GraphicsExportGetSettingsAsText()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetSettingsAsText(
GraphicsExportComponent ci,
Handle * theText) FIVEWORDINLINE(0x2F3C, 0x0004, 0x000E, 0x7000, 0xA82A);
/* Graphics exporters may implement some or none of the following: */
/*
* GraphicsExportSetDontRecompress()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetDontRecompress(
GraphicsExportComponent ci,
Boolean dontRecompress) FIVEWORDINLINE(0x2F3C, 0x0002, 0x000F, 0x7000, 0xA82A);
/*
* GraphicsExportGetDontRecompress()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetDontRecompress(
GraphicsExportComponent ci,
Boolean * dontRecompress) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0010, 0x7000, 0xA82A);
/*
* GraphicsExportSetInterlaceStyle()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetInterlaceStyle(
GraphicsExportComponent ci,
unsigned long interlaceStyle) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0011, 0x7000, 0xA82A);
/*
* GraphicsExportGetInterlaceStyle()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetInterlaceStyle(
GraphicsExportComponent ci,
unsigned long * interlaceStyle) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0012, 0x7000, 0xA82A);
/*
* GraphicsExportSetMetaData()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetMetaData(
GraphicsExportComponent ci,
void * userData) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0013, 0x7000, 0xA82A);
/*
* GraphicsExportGetMetaData()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetMetaData(
GraphicsExportComponent ci,
void * userData) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0014, 0x7000, 0xA82A);
/*
* GraphicsExportSetTargetDataSize()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetTargetDataSize(
GraphicsExportComponent ci,
unsigned long targetDataSize) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0015, 0x7000, 0xA82A);
/*
* GraphicsExportGetTargetDataSize()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetTargetDataSize(
GraphicsExportComponent ci,
unsigned long * targetDataSize) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0016, 0x7000, 0xA82A);
/*
* GraphicsExportSetCompressionMethod()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetCompressionMethod(
GraphicsExportComponent ci,
long compressionMethod) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0017, 0x7000, 0xA82A);
/*
* GraphicsExportGetCompressionMethod()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetCompressionMethod(
GraphicsExportComponent ci,
long * compressionMethod) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0018, 0x7000, 0xA82A);
/*
* GraphicsExportSetCompressionQuality()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetCompressionQuality(
GraphicsExportComponent ci,
CodecQ spatialQuality) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0019, 0x7000, 0xA82A);
/*
* GraphicsExportGetCompressionQuality()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetCompressionQuality(
GraphicsExportComponent ci,
CodecQ * spatialQuality) FIVEWORDINLINE(0x2F3C, 0x0004, 0x001A, 0x7000, 0xA82A);
/*
* GraphicsExportSetResolution()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetResolution(
GraphicsExportComponent ci,
Fixed horizontalResolution,
Fixed verticalResolution) FIVEWORDINLINE(0x2F3C, 0x0008, 0x001B, 0x7000, 0xA82A);
/*
* GraphicsExportGetResolution()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetResolution(
GraphicsExportComponent ci,
Fixed * horizontalResolution,
Fixed * verticalResolution) FIVEWORDINLINE(0x2F3C, 0x0008, 0x001C, 0x7000, 0xA82A);
/*
* GraphicsExportSetDepth()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetDepth(
GraphicsExportComponent ci,
long depth) FIVEWORDINLINE(0x2F3C, 0x0004, 0x001D, 0x7000, 0xA82A);
/*
* GraphicsExportGetDepth()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetDepth(
GraphicsExportComponent ci,
long * depth) FIVEWORDINLINE(0x2F3C, 0x0004, 0x001E, 0x7000, 0xA82A);
/* (2 unused selectors) */
/*
* GraphicsExportSetColorSyncProfile()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetColorSyncProfile(
GraphicsExportComponent ci,
Handle colorSyncProfile) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0021, 0x7000, 0xA82A);
/*
* GraphicsExportGetColorSyncProfile()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetColorSyncProfile(
GraphicsExportComponent ci,
Handle * colorSyncProfile) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0022, 0x7000, 0xA82A);
/* Always implemented by the base graphics exporter: */
/*
* GraphicsExportSetProgressProc()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetProgressProc(
GraphicsExportComponent ci,
ICMProgressProcRecordPtr progressProc) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0023, 0x7000, 0xA82A);
/*
* GraphicsExportGetProgressProc()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetProgressProc(
GraphicsExportComponent ci,
ICMProgressProcRecordPtr progressProc) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0024, 0x7000, 0xA82A);
/* Sources for the input image: */
/*
* GraphicsExportSetInputDataReference()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetInputDataReference(
GraphicsExportComponent ci,
Handle dataRef,
OSType dataRefType,
ImageDescriptionHandle desc) FIVEWORDINLINE(0x2F3C, 0x000C, 0x0025, 0x7000, 0xA82A);
/*
* GraphicsExportGetInputDataReference()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetInputDataReference(
GraphicsExportComponent ci,
Handle * dataRef,
OSType * dataRefType) FIVEWORDINLINE(0x2F3C, 0x0008, 0x0026, 0x7000, 0xA82A);
/*
* GraphicsExportSetInputFile()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetInputFile(
GraphicsExportComponent ci,
const FSSpec * theFile,
ImageDescriptionHandle desc) FIVEWORDINLINE(0x2F3C, 0x0008, 0x0027, 0x7000, 0xA82A);
/*
* GraphicsExportGetInputFile()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetInputFile(
GraphicsExportComponent ci,
FSSpec * theFile) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0028, 0x7000, 0xA82A);
/*
* GraphicsExportSetInputHandle()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetInputHandle(
GraphicsExportComponent ci,
Handle h,
ImageDescriptionHandle desc) FIVEWORDINLINE(0x2F3C, 0x0008, 0x0029, 0x7000, 0xA82A);
/*
* GraphicsExportGetInputHandle()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetInputHandle(
GraphicsExportComponent ci,
Handle * h) FIVEWORDINLINE(0x2F3C, 0x0004, 0x002A, 0x7000, 0xA82A);
/*
* GraphicsExportSetInputPtr()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetInputPtr(
GraphicsExportComponent ci,
Ptr p,
unsigned long size,
ImageDescriptionHandle desc) FIVEWORDINLINE(0x2F3C, 0x000C, 0x002B, 0x7000, 0xA82A);
/*
* GraphicsExportGetInputPtr()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetInputPtr(
GraphicsExportComponent ci,
Ptr * p,
unsigned long * size) FIVEWORDINLINE(0x2F3C, 0x0008, 0x002C, 0x7000, 0xA82A);
/*
* GraphicsExportSetInputGraphicsImporter()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetInputGraphicsImporter(
GraphicsExportComponent ci,
GraphicsImportComponent grip) FIVEWORDINLINE(0x2F3C, 0x0004, 0x002D, 0x7000, 0xA82A);
/*
* GraphicsExportGetInputGraphicsImporter()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetInputGraphicsImporter(
GraphicsExportComponent ci,
GraphicsImportComponent * grip) FIVEWORDINLINE(0x2F3C, 0x0004, 0x002E, 0x7000, 0xA82A);
/*
* GraphicsExportSetInputPicture()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetInputPicture(
GraphicsExportComponent ci,
PicHandle picture) FIVEWORDINLINE(0x2F3C, 0x0004, 0x002F, 0x7000, 0xA82A);
/*
* GraphicsExportGetInputPicture()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetInputPicture(
GraphicsExportComponent ci,
PicHandle * picture) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0030, 0x7000, 0xA82A);
/*
* GraphicsExportSetInputGWorld()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetInputGWorld(
GraphicsExportComponent ci,
GWorldPtr gworld) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0031, 0x7000, 0xA82A);
/*
* GraphicsExportGetInputGWorld()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetInputGWorld(
GraphicsExportComponent ci,
GWorldPtr * gworld) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0032, 0x7000, 0xA82A);
/*
* GraphicsExportSetInputPixmap()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetInputPixmap(
GraphicsExportComponent ci,
PixMapHandle pixmap) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0033, 0x7000, 0xA82A);
/*
* GraphicsExportGetInputPixmap()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetInputPixmap(
GraphicsExportComponent ci,
PixMapHandle * pixmap) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0034, 0x7000, 0xA82A);
/* Only applicable when the input is a data reference, file, handle or ptr: */
/*
* GraphicsExportSetInputOffsetAndLimit()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetInputOffsetAndLimit(
GraphicsExportComponent ci,
unsigned long offset,
unsigned long limit) FIVEWORDINLINE(0x2F3C, 0x0008, 0x0035, 0x7000, 0xA82A);
/*
* GraphicsExportGetInputOffsetAndLimit()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetInputOffsetAndLimit(
GraphicsExportComponent ci,
unsigned long * offset,
unsigned long * limit) FIVEWORDINLINE(0x2F3C, 0x0008, 0x0036, 0x7000, 0xA82A);
/* Used by format-specific graphics exporters when transcoding: */
/*
* GraphicsExportMayExporterReadInputData()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportMayExporterReadInputData(
GraphicsExportComponent ci,
Boolean * mayReadInputData) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0037, 0x7000, 0xA82A);
/*
* GraphicsExportGetInputDataSize()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetInputDataSize(
GraphicsExportComponent ci,
unsigned long * size) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0038, 0x7000, 0xA82A);
/*
* GraphicsExportReadInputData()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportReadInputData(
GraphicsExportComponent ci,
void * dataPtr,
unsigned long dataOffset,
unsigned long dataSize) FIVEWORDINLINE(0x2F3C, 0x000C, 0x0039, 0x7000, 0xA82A);
/* Used by format-specific graphics exporters, especially when doing standalone export: */
/*
* GraphicsExportGetInputImageDescription()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetInputImageDescription(
GraphicsExportComponent ci,
ImageDescriptionHandle * desc) FIVEWORDINLINE(0x2F3C, 0x0004, 0x003A, 0x7000, 0xA82A);
/*
* GraphicsExportGetInputImageDimensions()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetInputImageDimensions(
GraphicsExportComponent ci,
Rect * dimensions) FIVEWORDINLINE(0x2F3C, 0x0004, 0x003B, 0x7000, 0xA82A);
/*
* GraphicsExportGetInputImageDepth()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetInputImageDepth(
GraphicsExportComponent ci,
long * inputDepth) FIVEWORDINLINE(0x2F3C, 0x0004, 0x003C, 0x7000, 0xA82A);
/*
* GraphicsExportDrawInputImage()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportDrawInputImage(
GraphicsExportComponent ci,
CGrafPtr gw,
GDHandle gd,
const Rect * srcRect,
const Rect * dstRect) FIVEWORDINLINE(0x2F3C, 0x0010, 0x003D, 0x7000, 0xA82A);
/* Destinations for the output image: */
/*
* GraphicsExportSetOutputDataReference()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetOutputDataReference(
GraphicsExportComponent ci,
Handle dataRef,
OSType dataRefType) FIVEWORDINLINE(0x2F3C, 0x0008, 0x003E, 0x7000, 0xA82A);
/*
* GraphicsExportGetOutputDataReference()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetOutputDataReference(
GraphicsExportComponent ci,
Handle * dataRef,
OSType * dataRefType) FIVEWORDINLINE(0x2F3C, 0x0008, 0x003F, 0x7000, 0xA82A);
/*
* GraphicsExportSetOutputFile()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetOutputFile(
GraphicsExportComponent ci,
const FSSpec * theFile) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0040, 0x7000, 0xA82A);
/*
* GraphicsExportGetOutputFile()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetOutputFile(
GraphicsExportComponent ci,
FSSpec * theFile) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0041, 0x7000, 0xA82A);
/*
* GraphicsExportSetOutputHandle()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetOutputHandle(
GraphicsExportComponent ci,
Handle h) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0042, 0x7000, 0xA82A);
/*
* GraphicsExportGetOutputHandle()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetOutputHandle(
GraphicsExportComponent ci,
Handle * h) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0043, 0x7000, 0xA82A);
/*
* GraphicsExportSetOutputOffsetAndMaxSize()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetOutputOffsetAndMaxSize(
GraphicsExportComponent ci,
unsigned long offset,
unsigned long maxSize,
Boolean truncateFile) FIVEWORDINLINE(0x2F3C, 0x000A, 0x0044, 0x7000, 0xA82A);
/*
* GraphicsExportGetOutputOffsetAndMaxSize()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetOutputOffsetAndMaxSize(
GraphicsExportComponent ci,
unsigned long * offset,
unsigned long * maxSize,
Boolean * truncateFile) FIVEWORDINLINE(0x2F3C, 0x000C, 0x0045, 0x7000, 0xA82A);
/*
* GraphicsExportSetOutputFileTypeAndCreator()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetOutputFileTypeAndCreator(
GraphicsExportComponent ci,
OSType fileType,
OSType fileCreator) FIVEWORDINLINE(0x2F3C, 0x0008, 0x0046, 0x7000, 0xA82A);
/*
* GraphicsExportGetOutputFileTypeAndCreator()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetOutputFileTypeAndCreator(
GraphicsExportComponent ci,
OSType * fileType,
OSType * fileCreator) FIVEWORDINLINE(0x2F3C, 0x0008, 0x0047, 0x7000, 0xA82A);
/* Used by format-specific graphics exporters: */
/*
* GraphicsExportWriteOutputData()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportWriteOutputData(
GraphicsExportComponent ci,
const void * dataPtr,
unsigned long dataSize) FIVEWORDINLINE(0x2F3C, 0x0008, 0x0048, 0x7000, 0xA82A);
/*
* GraphicsExportSetOutputMark()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetOutputMark(
GraphicsExportComponent ci,
unsigned long mark) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0049, 0x7000, 0xA82A);
/*
* GraphicsExportGetOutputMark()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetOutputMark(
GraphicsExportComponent ci,
unsigned long * mark) FIVEWORDINLINE(0x2F3C, 0x0004, 0x004A, 0x7000, 0xA82A);
/*
* GraphicsExportReadOutputData()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 4.0 and later
* CarbonLib: in CarbonLib 1.0.2 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 4.0 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportReadOutputData(
GraphicsExportComponent ci,
void * dataPtr,
unsigned long dataOffset,
unsigned long dataSize) FIVEWORDINLINE(0x2F3C, 0x000C, 0x004B, 0x7000, 0xA82A);
/* Allows embedded thumbnail creation, if supported. */
/*
* GraphicsExportSetThumbnailEnabled()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 5.0.2 and later
* CarbonLib: in CarbonLib 1.4 and later
* Mac OS X: in version 10.1 and later
* Windows: in qtmlClient.lib 5.0.2 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetThumbnailEnabled(
GraphicsExportComponent ci,
Boolean enableThumbnail,
long maxThumbnailWidth,
long maxThumbnailHeight) FIVEWORDINLINE(0x2F3C, 0x000A, 0x004C, 0x7000, 0xA82A);
/*
* GraphicsExportGetThumbnailEnabled()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 5.0.2 and later
* CarbonLib: in CarbonLib 1.4 and later
* Mac OS X: in version 10.1 and later
* Windows: in qtmlClient.lib 5.0.2 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetThumbnailEnabled(
GraphicsExportComponent ci,
Boolean * thumbnailEnabled,
long * maxThumbnailWidth,
long * maxThumbnailHeight) FIVEWORDINLINE(0x2F3C, 0x000C, 0x004D, 0x7000, 0xA82A);
/* Allows export of Exif files, if supported. This disables Exif-incompatible settings such as grayscale JPEG and compressed TIFF, and enables export of Exif metadata. */
/*
* GraphicsExportSetExifEnabled()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 5.0.2 and later
* CarbonLib: in CarbonLib 1.4 and later
* Mac OS X: in version 10.1 and later
* Windows: in qtmlClient.lib 5.0.2 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetExifEnabled(
GraphicsExportComponent ci,
Boolean enableExif) FIVEWORDINLINE(0x2F3C, 0x0002, 0x004E, 0x7000, 0xA82A);
/*
* GraphicsExportGetExifEnabled()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 5.0.2 and later
* CarbonLib: in CarbonLib 1.4 and later
* Mac OS X: in version 10.1 and later
* Windows: in qtmlClient.lib 5.0.2 and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetExifEnabled(
GraphicsExportComponent ci,
Boolean * exifEnabled) FIVEWORDINLINE(0x2F3C, 0x0004, 0x004F, 0x7000, 0xA82A);
#if TARGET_API_MAC_OSX
/*
* GraphicsExportSetInputCGImage()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetInputCGImage(
GraphicsExportComponent ci,
CGImageRef imageRef) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0050, 0x7000, 0xA82A);
/*
* GraphicsExportGetInputCGImage()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetInputCGImage(
GraphicsExportComponent ci,
CGImageRef * imageRefOut) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0051, 0x7000, 0xA82A);
/*
* GraphicsExportSetInputCGBitmapContext()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetInputCGBitmapContext(
GraphicsExportComponent ci,
CGContextRef bitmapContextRef) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0052, 0x7000, 0xA82A);
/*
* GraphicsExportGetInputCGBitmapContext()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetInputCGBitmapContext(
GraphicsExportComponent ci,
CGContextRef * bitmapContextRefOut) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0053, 0x7000, 0xA82A);
#endif /* TARGET_API_MAC_OSX */
/*
* GraphicsExportSetFlags()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
*/
EXTERN_API( ComponentResult )
GraphicsExportSetFlags(
GraphicsExportComponent ci,
UInt32 flags) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0054, 0x7000, 0xA82A);
/*
* GraphicsExportGetFlags()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
*/
EXTERN_API( ComponentResult )
GraphicsExportGetFlags(
GraphicsExportComponent ci,
UInt32 * flagsOut) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0055, 0x7000, 0xA82A);
typedef ComponentInstance ImageTranscoderComponent;
enum {
ImageTranscodererComponentType = FOUR_CHAR_CODE('imtc')
};
/** These are ImageTranscoder procedures **/
/*
* ImageTranscoderBeginSequence()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
ImageTranscoderBeginSequence(
ImageTranscoderComponent itc,
ImageDescriptionHandle srcDesc,
ImageDescriptionHandle * dstDesc,
void * data,
long dataSize) FIVEWORDINLINE(0x2F3C, 0x0010, 0x0001, 0x7000, 0xA82A);
/*
* ImageTranscoderConvert()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
ImageTranscoderConvert(
ImageTranscoderComponent itc,
void * srcData,
long srcDataSize,
void ** dstData,
long * dstDataSize) FIVEWORDINLINE(0x2F3C, 0x0010, 0x0002, 0x7000, 0xA82A);
/*
* ImageTranscoderDisposeData()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
ImageTranscoderDisposeData(
ImageTranscoderComponent itc,
void * dstData) FIVEWORDINLINE(0x2F3C, 0x0004, 0x0003, 0x7000, 0xA82A);
/*
* ImageTranscoderEndSequence()
*
* Availability:
* Non-Carbon CFM: in QuickTimeLib 2.5 and later
* CarbonLib: in CarbonLib 1.0 and later
* Mac OS X: in version 10.0 and later
* Windows: in qtmlClient.lib 3.0 and later
*/
EXTERN_API( ComponentResult )
ImageTranscoderEndSequence(ImageTranscoderComponent itc) FIVEWORDINLINE(0x2F3C, 0x0000, 0x0004, 0x7000, 0xA82A);
#if (MAC_OS_X_VERSION_MAX_ALLOWED == MAC_OS_X_VERSION_10_2) || !defined(kComponentPropertyListenerCollectionContextVersion)
/* MixedMode ProcInfo constants for component property calls */
enum {
uppCallComponentGetComponentPropertyInfoProcInfo = 0x0003FFF0,
uppCallComponentGetComponentPropertyProcInfo = 0x0003FFF0,
uppCallComponentSetComponentPropertyProcInfo = 0x0000FFF0,
uppCallComponentAddComponentPropertyListenerProcInfo = 0x0000FFF0,
uppCallComponentRemoveComponentPropertyListenerProcInfo = 0x0000FFF0
};
/* == CallComponentGetComponentPropertyInfo flags == */
enum {
kComponentPropertyFlagCanSetLater = (1L << 0),
kComponentPropertyFlagCanSetNow = (1L << 1),
kComponentPropertyFlagCanGetLater = (1L << 2),
kComponentPropertyFlagCanGetNow = (1L << 3),
kComponentPropertyFlagHasExtendedInfo = (1L << 4),
kComponentPropertyFlagValueMustBeReleased = (1L << 5),
kComponentPropertyFlagValueIsCFTypeRef = (1L << 6),
kComponentPropertyFlagGetBufferMustBeInitialized = (1L << 7),
kComponentPropertyFlagWillNotifyListeners = (1L << 8)
};
typedef OSType ComponentPropertyClass;
typedef OSType ComponentPropertyID;
typedef OSType ComponentValueType;
typedef void * ComponentValuePtr;
typedef const void * ConstComponentValuePtr;
/* == standard property class constants == */
enum {
kComponentPropertyClassPropertyInfo = FOUR_CHAR_CODE('pnfo'), /* property info class */
/* property info property IDs */
kComponentPropertyInfoList = FOUR_CHAR_CODE('list'), /* array of ComponentPropertyInfo (CFData), one for each property */
kComponentPropertyCacheSeed = FOUR_CHAR_CODE('seed'), /* property cache seed value */
kComponentPropertyCacheFlags = FOUR_CHAR_CODE('flgs'), /* see kComponentPropertyCache flags */
kComponentPropertyExtendedInfo = FOUR_CHAR_CODE('meta') /* CFDictionary with extended property information*/
};
/* values for kComponentPropertyClassPropertyInfo/kComponentPropertyCacheFlags standard component property */
enum {
kComponentPropertyCacheFlagNotPersistent = (1L << 0), /* property metadata should not be saved in persistent cache*/
kComponentPropertyCacheFlagIsDynamic = (1L << 1) /* property metadata should not cached at all*/
};
struct ComponentPropertyInfo {
ComponentPropertyClass propClass;
ComponentPropertyID propID;
ComponentValueType propType;
ByteCount propSize;
UInt32 propFlags;
};
typedef struct ComponentPropertyInfo ComponentPropertyInfo;
#endif /* #MAC_OS_X_VERSION_10_3 <= MAC_OS_X_VERSION_MAX_ALLOWED */
/* == "QT" prefixed Component Property calls == */
typedef CALLBACK_API( void , QTComponentPropertyListenerProcPtr )(ComponentInstance inComponent, ComponentPropertyClass inPropClass, ComponentPropertyID inPropID, void *inUserData);
typedef STACK_UPP_TYPE(QTComponentPropertyListenerProcPtr) QTComponentPropertyListenerUPP;
/*
* QTGetComponentPropertyInfo()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
*/
EXTERN_API( ComponentResult )
QTGetComponentPropertyInfo(
ComponentInstance inComponent,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
ComponentValueType * outPropType, /* can be NULL */
ByteCount * outPropValueSize, /* can be NULL */
UInt32 * outPropertyFlags) /* can be NULL */ FIVEWORDINLINE(0x2F3C, 0x0014, 0xFFF5, 0x7000, 0xA82A);
/*
* QTGetComponentProperty()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
*/
EXTERN_API( ComponentResult )
QTGetComponentProperty(
ComponentInstance inComponent,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
ByteCount inPropValueSize,
ComponentValuePtr outPropValueAddress,
ByteCount * outPropValueSizeUsed) /* can be NULL */ FIVEWORDINLINE(0x2F3C, 0x0014, 0xFFF4, 0x7000, 0xA82A);
/*
* QTSetComponentProperty()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
*/
EXTERN_API( ComponentResult )
QTSetComponentProperty(
ComponentInstance inComponent,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
ByteCount inPropValueSize,
ConstComponentValuePtr inPropValueAddress) FIVEWORDINLINE(0x2F3C, 0x0010, 0xFFF3, 0x7000, 0xA82A);
/*
* QTAddComponentPropertyListener()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
*/
EXTERN_API( ComponentResult )
QTAddComponentPropertyListener(
ComponentInstance inComponent,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
QTComponentPropertyListenerUPP inDispatchProc,
void * inUserData) /* can be NULL */ FIVEWORDINLINE(0x2F3C, 0x0010, 0xFFF2, 0x7000, 0xA82A);
/*
* QTRemoveComponentPropertyListener()
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
*/
EXTERN_API( ComponentResult )
QTRemoveComponentPropertyListener(
ComponentInstance inComponent,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
QTComponentPropertyListenerUPP inDispatchProc,
void * inUserData) /* can be NULL */ FIVEWORDINLINE(0x2F3C, 0x0010, 0xFFF1, 0x7000, 0xA82A);
/* == "QT" prefixed Component Property Listener helpers == */
typedef CFTypeRef QTComponentPropertyListenersRef;
typedef struct QTComponentPropertyListenerCollectionContext QTComponentPropertyListenerCollectionContext;
typedef CALLBACK_API( Boolean , QTComponentPropertyListenerFilterProcPtr )(QTComponentPropertyListenersRef inCollection, const QTComponentPropertyListenerCollectionContext *inCollectionContext, ComponentInstance inNotifier, ComponentPropertyClass inPropClass, ComponentPropertyID inPropID, QTComponentPropertyListenerUPP inListenerCallbackProc, const void *inListenerProcRefCon, const void *inFilterProcRefCon);
typedef STACK_UPP_TYPE(QTComponentPropertyListenerFilterProcPtr) QTComponentPropertyListenerFilterUPP;
#define kQTComponentPropertyListenerCollectionContextVersion 1
struct QTComponentPropertyListenerCollectionContext {
UInt32 version; /* struct version */
QTComponentPropertyListenerFilterUPP filterProcUPP;
void * filterProcData;
};
#if CALL_NOT_IN_CARBON
/*
* NewQTComponentPropertyListenerUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
*/
EXTERN_API_C( QTComponentPropertyListenerUPP )
NewQTComponentPropertyListenerUPP(QTComponentPropertyListenerProcPtr userRoutine);
#if !OPAQUE_UPP_TYPES
enum { uppQTComponentPropertyListenerProcInfo = 0x00003FC0 }; /* pascal no_return_value Func(4_bytes, 4_bytes, 4_bytes, 4_bytes) */
#ifdef __cplusplus
inline DEFINE_API_C(QTComponentPropertyListenerUPP) NewQTComponentPropertyListenerUPP(QTComponentPropertyListenerProcPtr userRoutine) { return (QTComponentPropertyListenerUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppQTComponentPropertyListenerProcInfo, GetCurrentArchitecture()); }
#else
#define NewQTComponentPropertyListenerUPP(userRoutine) (QTComponentPropertyListenerUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppQTComponentPropertyListenerProcInfo, GetCurrentArchitecture())
#endif
#endif
/*
* NewQTComponentPropertyListenerFilterUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
*/
EXTERN_API_C( QTComponentPropertyListenerFilterUPP )
NewQTComponentPropertyListenerFilterUPP(QTComponentPropertyListenerFilterProcPtr userRoutine);
#if !OPAQUE_UPP_TYPES
enum { uppQTComponentPropertyListenerFilterProcInfo = 0x003FFFD0 }; /* pascal 1_byte Func(4_bytes, 4_bytes, 4_bytes, 4_bytes, 4_bytes, 4_bytes, 4_bytes, 4_bytes) */
#ifdef __cplusplus
inline DEFINE_API_C(QTComponentPropertyListenerFilterUPP) NewQTComponentPropertyListenerFilterUPP(QTComponentPropertyListenerFilterProcPtr userRoutine) { return (QTComponentPropertyListenerFilterUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppQTComponentPropertyListenerFilterProcInfo, GetCurrentArchitecture()); }
#else
#define NewQTComponentPropertyListenerFilterUPP(userRoutine) (QTComponentPropertyListenerFilterUPP)NewRoutineDescriptor((ProcPtr)(userRoutine), uppQTComponentPropertyListenerFilterProcInfo, GetCurrentArchitecture())
#endif
#endif
/*
* DisposeQTComponentPropertyListenerUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
*/
EXTERN_API_C( void )
DisposeQTComponentPropertyListenerUPP(QTComponentPropertyListenerUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(void) DisposeQTComponentPropertyListenerUPP(QTComponentPropertyListenerUPP userUPP) { DisposeRoutineDescriptor((UniversalProcPtr)userUPP); }
#else
#define DisposeQTComponentPropertyListenerUPP(userUPP) DisposeRoutineDescriptor(userUPP)
#endif
#endif
/*
* DisposeQTComponentPropertyListenerFilterUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
*/
EXTERN_API_C( void )
DisposeQTComponentPropertyListenerFilterUPP(QTComponentPropertyListenerFilterUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(void) DisposeQTComponentPropertyListenerFilterUPP(QTComponentPropertyListenerFilterUPP userUPP) { DisposeRoutineDescriptor((UniversalProcPtr)userUPP); }
#else
#define DisposeQTComponentPropertyListenerFilterUPP(userUPP) DisposeRoutineDescriptor(userUPP)
#endif
#endif
/*
* InvokeQTComponentPropertyListenerUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
*/
EXTERN_API_C( void )
InvokeQTComponentPropertyListenerUPP(
ComponentInstance inComponent,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
void * inUserData,
QTComponentPropertyListenerUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(void) InvokeQTComponentPropertyListenerUPP(ComponentInstance inComponent, ComponentPropertyClass inPropClass, ComponentPropertyID inPropID, void * inUserData, QTComponentPropertyListenerUPP userUPP) { CALL_FOUR_PARAMETER_UPP(userUPP, uppQTComponentPropertyListenerProcInfo, inComponent, inPropClass, inPropID, inUserData); }
#else
#define InvokeQTComponentPropertyListenerUPP(inComponent, inPropClass, inPropID, inUserData, userUPP) CALL_FOUR_PARAMETER_UPP((userUPP), uppQTComponentPropertyListenerProcInfo, (inComponent), (inPropClass), (inPropID), (inUserData))
#endif
#endif
/*
* InvokeQTComponentPropertyListenerFilterUPP()
*
* Availability:
* Non-Carbon CFM: available as macro/inline
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
*/
EXTERN_API_C( Boolean )
InvokeQTComponentPropertyListenerFilterUPP(
QTComponentPropertyListenersRef inCollection,
const QTComponentPropertyListenerCollectionContext * inCollectionContext,
ComponentInstance inNotifier,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
QTComponentPropertyListenerUPP inListenerCallbackProc,
const void * inListenerProcRefCon,
const void * inFilterProcRefCon,
QTComponentPropertyListenerFilterUPP userUPP);
#if !OPAQUE_UPP_TYPES
#ifdef __cplusplus
inline DEFINE_API_C(Boolean) InvokeQTComponentPropertyListenerFilterUPP(QTComponentPropertyListenersRef inCollection, const QTComponentPropertyListenerCollectionContext * inCollectionContext, ComponentInstance inNotifier, ComponentPropertyClass inPropClass, ComponentPropertyID inPropID, QTComponentPropertyListenerUPP inListenerCallbackProc, const void * inListenerProcRefCon, const void * inFilterProcRefCon, QTComponentPropertyListenerFilterUPP userUPP) { return (Boolean)CALL_EIGHT_PARAMETER_UPP(userUPP, uppQTComponentPropertyListenerFilterProcInfo, inCollection, inCollectionContext, inNotifier, inPropClass, inPropID, inListenerCallbackProc, inListenerProcRefCon, inFilterProcRefCon); }
#else
#define InvokeQTComponentPropertyListenerFilterUPP(inCollection, inCollectionContext, inNotifier, inPropClass, inPropID, inListenerCallbackProc, inListenerProcRefCon, inFilterProcRefCon, userUPP) (Boolean)CALL_EIGHT_PARAMETER_UPP((userUPP), uppQTComponentPropertyListenerFilterProcInfo, (inCollection), (inCollectionContext), (inNotifier), (inPropClass), (inPropID), (inListenerCallbackProc), (inListenerProcRefCon), (inFilterProcRefCon))
#endif
#endif
#endif /* CALL_NOT_IN_CARBON */
#if CALL_NOT_IN_CARBON || OLDROUTINENAMES
/* support for pre-Carbon UPP routines: New...Proc and Call...Proc */
#define NewQTComponentPropertyListenerProc(userRoutine) NewQTComponentPropertyListenerUPP(userRoutine)
#define NewQTComponentPropertyListenerFilterProc(userRoutine) NewQTComponentPropertyListenerFilterUPP(userRoutine)
#define CallQTComponentPropertyListenerProc(userRoutine, inComponent, inPropClass, inPropID, inUserData) InvokeQTComponentPropertyListenerUPP(inComponent, inPropClass, inPropID, inUserData, userRoutine)
#define CallQTComponentPropertyListenerFilterProc(userRoutine, inCollection, inCollectionContext, inNotifier, inPropClass, inPropID, inListenerCallbackProc, inListenerProcRefCon, inFilterProcRefCon) InvokeQTComponentPropertyListenerFilterUPP(inCollection, inCollectionContext, inNotifier, inPropClass, inPropID, inListenerCallbackProc, inListenerProcRefCon, inFilterProcRefCon, userRoutine)
#endif /* CALL_NOT_IN_CARBON */
/*
* QTComponentPropertyListenerCollectionCreate()
*
* Summary:
* Create a collection to use with the functions
* ComponentPropertyListenerCollectionAddListener,
* ComponentPropertyListenerCollectionRemoveListener,
* ComponentPropertyListenerCollectionNotifyListeners,
* ComponentPropertyListenerCollectionIsEmpty, and
* ComponentPropertyListenerCollectionHasListenersForProperty.
*
* Parameters:
*
* outCollection:
* Returns the new, empty, listener collection.
*
* inAllocator:
* Allocator used to create the collection and it's contents.
*
* inContext:
* The listener collection context. May be NULL. A copy of the
* contents of the structure is made, so a pointer to a structure
* on the stack can be passed.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
*/
EXTERN_API_C( OSStatus )
QTComponentPropertyListenerCollectionCreate(
CFAllocatorRef inAllocator, /* can be NULL */
const QTComponentPropertyListenerCollectionContext * inContext, /* can be NULL */
QTComponentPropertyListenersRef * outCollection);
/*
* QTComponentPropertyListenerCollectionAddListener()
*
* Summary:
* Add a listener callback for the specified property class and ID
* to a property listener collection.
*
* Parameters:
*
* inCollection:
* The property listener collection.
*
* inPropClass:
* The property class.
*
* inPropID:
* The property ID.
*
* inListenerProc:
* The property listener callback function.
*
* inListenerProcRefCon:
* The data parameter to pass to the listener callback function.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
*/
EXTERN_API_C( OSStatus )
QTComponentPropertyListenerCollectionAddListener(
QTComponentPropertyListenersRef inCollection,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
QTComponentPropertyListenerUPP inListenerProc,
const void * inListenerProcRefCon);
/*
* QTComponentPropertyListenerCollectionRemoveListener()
*
* Summary:
* Remove a listener callback for the specified property class and
* ID from a property listener collection.
*
* Parameters:
*
* inCollection:
* The property listener collection.
*
* inPropClass:
* The property class.
*
* inPropID:
* The property ID.
*
* inListenerProc:
* The property listener callback function.
*
* inListenerProcRefCon:
* The data parameter to pass to the listener callback function.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
*/
EXTERN_API_C( OSStatus )
QTComponentPropertyListenerCollectionRemoveListener(
QTComponentPropertyListenersRef inCollection,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
QTComponentPropertyListenerUPP inListenerProc,
const void * inListenerProcRefCon);
/*
* QTComponentPropertyListenerCollectionNotifyListeners()
*
* Summary:
* Call all listener callbacks in the collection registered for the
* specified property class and ID.
*
* Discussion:
* If the "filterProcUPP" in the collection's context is non-NULL,
* the filter function will be called before each registered
* listener that matches the specified property class and ID. If the
* filter function return false, the listener proc will not be
* called. This is intended to allow a component to change the
* calling semantics (call another thread, etc), to use a different
* listener callback signature, etc.
*
* Parameters:
*
* inCollection:
* The property listener collection.
*
* inNotifier:
* The calling ComponentInstance.
*
* inPropClass:
* The property class.
*
* inPropID:
* The property ID.
*
* inFilterProcRefCon:
* The data parameter to pass to the filter function.
*
* inFlags:
* Flags. Must be set to 0.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
*/
EXTERN_API_C( OSStatus )
QTComponentPropertyListenerCollectionNotifyListeners(
QTComponentPropertyListenersRef inCollection,
ComponentInstance inNotifier,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
const void * inFilterProcRefCon, /* can be NULL */
UInt32 inFlags);
/*
* QTComponentPropertyListenerCollectionIsEmpty()
*
* Summary:
* Return true if the listener collection is empty.
*
* Parameters:
*
* inCollection:
* The property listener collection.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
*/
EXTERN_API_C( Boolean )
QTComponentPropertyListenerCollectionIsEmpty(QTComponentPropertyListenersRef inCollection);
/*
* QTComponentPropertyListenerCollectionHasListenersForProperty()
*
* Summary:
* Returns true if there are any listeners registered for the
* specified property class and ID.
*
* Parameters:
*
* inCollection:
* The property listener collection.
*
* inPropClass:
* The property class.
*
* inPropID:
* The property ID.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.3 (or QuickTime 6.4) and later
*/
EXTERN_API_C( Boolean )
QTComponentPropertyListenerCollectionHasListenersForProperty(
QTComponentPropertyListenersRef inCollection,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID);
/* DRM properties*/
enum {
kQTPropertyClass_DRM = FOUR_CHAR_CODE('drm ')
};
enum {
kQTDRMPropertyID_InteractWithUser = FOUR_CHAR_CODE('shui'), /* Boolean**/
kQTDRMPropertyID_IsProtected = FOUR_CHAR_CODE('prot'), /* Boolean**/
kQTDRMPropertyID_IsAuthorized = FOUR_CHAR_CODE('auth') /* Boolean**/
};
/* UPP call backs */
/* selectors for component calls */
enum {
kGraphicsImportSetDataReferenceSelect = 0x0001,
kGraphicsImportGetDataReferenceSelect = 0x0002,
kGraphicsImportSetDataFileSelect = 0x0003,
kGraphicsImportGetDataFileSelect = 0x0004,
kGraphicsImportSetDataHandleSelect = 0x0005,
kGraphicsImportGetDataHandleSelect = 0x0006,
kGraphicsImportGetImageDescriptionSelect = 0x0007,
kGraphicsImportGetDataOffsetAndSizeSelect = 0x0008,
kGraphicsImportReadDataSelect = 0x0009,
kGraphicsImportSetClipSelect = 0x000A,
kGraphicsImportGetClipSelect = 0x000B,
kGraphicsImportSetSourceRectSelect = 0x000C,
kGraphicsImportGetSourceRectSelect = 0x000D,
kGraphicsImportGetNaturalBoundsSelect = 0x000E,
kGraphicsImportDrawSelect = 0x000F,
kGraphicsImportSetGWorldSelect = 0x0010,
kGraphicsImportGetGWorldSelect = 0x0011,
kGraphicsImportSetMatrixSelect = 0x0012,
kGraphicsImportGetMatrixSelect = 0x0013,
kGraphicsImportSetBoundsRectSelect = 0x0014,
kGraphicsImportGetBoundsRectSelect = 0x0015,
kGraphicsImportSaveAsPictureSelect = 0x0016,
kGraphicsImportSetGraphicsModeSelect = 0x0017,
kGraphicsImportGetGraphicsModeSelect = 0x0018,
kGraphicsImportSetQualitySelect = 0x0019,
kGraphicsImportGetQualitySelect = 0x001A,
kGraphicsImportSaveAsQuickTimeImageFileSelect = 0x001B,
kGraphicsImportSetDataReferenceOffsetAndLimitSelect = 0x001C,
kGraphicsImportGetDataReferenceOffsetAndLimitSelect = 0x001D,
kGraphicsImportGetAliasedDataReferenceSelect = 0x001E,
kGraphicsImportValidateSelect = 0x001F,
kGraphicsImportGetMetaDataSelect = 0x0020,
kGraphicsImportGetMIMETypeListSelect = 0x0021,
kGraphicsImportDoesDrawAllPixelsSelect = 0x0022,
kGraphicsImportGetAsPictureSelect = 0x0023,
kGraphicsImportExportImageFileSelect = 0x0024,
kGraphicsImportGetExportImageTypeListSelect = 0x0025,
kGraphicsImportDoExportImageFileDialogSelect = 0x0026,
kGraphicsImportGetExportSettingsAsAtomContainerSelect = 0x0027,
kGraphicsImportSetExportSettingsFromAtomContainerSelect = 0x0028,
kGraphicsImportSetProgressProcSelect = 0x0029,
kGraphicsImportGetProgressProcSelect = 0x002A,
kGraphicsImportGetImageCountSelect = 0x002B,
kGraphicsImportSetImageIndexSelect = 0x002C,
kGraphicsImportGetImageIndexSelect = 0x002D,
kGraphicsImportGetDataOffsetAndSize64Select = 0x002E,
kGraphicsImportReadData64Select = 0x002F,
kGraphicsImportSetDataReferenceOffsetAndLimit64Select = 0x0030,
kGraphicsImportGetDataReferenceOffsetAndLimit64Select = 0x0031,
kGraphicsImportGetDefaultMatrixSelect = 0x0032,
kGraphicsImportGetDefaultClipSelect = 0x0033,
kGraphicsImportGetDefaultGraphicsModeSelect = 0x0034,
kGraphicsImportGetDefaultSourceRectSelect = 0x0035,
kGraphicsImportGetColorSyncProfileSelect = 0x0036,
kGraphicsImportSetDestRectSelect = 0x0037,
kGraphicsImportGetDestRectSelect = 0x0038,
kGraphicsImportSetFlagsSelect = 0x0039,
kGraphicsImportGetFlagsSelect = 0x003A,
kGraphicsImportGetBaseDataOffsetAndSize64Select = 0x003D,
kGraphicsImportSetImageIndexToThumbnailSelect = 0x003E,
kGraphicsImportCreateCGImageSelect = 0x003F,
kGraphicsImportSaveAsPictureToDataRefSelect = 0x0040,
kGraphicsImportSaveAsQuickTimeImageFileToDataRefSelect = 0x0041,
kGraphicsImportExportImageFileToDataRefSelect = 0x0042,
kGraphicsImportDoExportImageFileToDataRefDialogSelect = 0x0043,
kGraphicsImportSetOverrideSourceColorSyncProfileRefSelect = 0x0044,
kGraphicsImportGetOverrideSourceColorSyncProfileRefSelect = 0x0045,
kGraphicsImportSetDestinationColorSyncProfileRefSelect = 0x0046,
kGraphicsImportGetDestinationColorSyncProfileRefSelect = 0x0047,
kGraphicsImportWillUseColorMatchingSelect = 0x0048,
kGraphicsImportGetGenericColorSyncProfileSelect = 0x0049,
kGraphicsImportSetReturnGenericColorSyncProfileSelect = 0x004A,
kGraphicsImportGetReturnGenericColorSyncProfileSelect = 0x004B,
kGraphicsExportDoExportSelect = 0x0001,
kGraphicsExportCanTranscodeSelect = 0x0002,
kGraphicsExportDoTranscodeSelect = 0x0003,
kGraphicsExportCanUseCompressorSelect = 0x0004,
kGraphicsExportDoUseCompressorSelect = 0x0005,
kGraphicsExportDoStandaloneExportSelect = 0x0006,
kGraphicsExportGetDefaultFileTypeAndCreatorSelect = 0x0007,
kGraphicsExportGetDefaultFileNameExtensionSelect = 0x0008,
kGraphicsExportGetMIMETypeListSelect = 0x0009,
kGraphicsExportRequestSettingsSelect = 0x000B,
kGraphicsExportSetSettingsFromAtomContainerSelect = 0x000C,
kGraphicsExportGetSettingsAsAtomContainerSelect = 0x000D,
kGraphicsExportGetSettingsAsTextSelect = 0x000E,
kGraphicsExportSetDontRecompressSelect = 0x000F,
kGraphicsExportGetDontRecompressSelect = 0x0010,
kGraphicsExportSetInterlaceStyleSelect = 0x0011,
kGraphicsExportGetInterlaceStyleSelect = 0x0012,
kGraphicsExportSetMetaDataSelect = 0x0013,
kGraphicsExportGetMetaDataSelect = 0x0014,
kGraphicsExportSetTargetDataSizeSelect = 0x0015,
kGraphicsExportGetTargetDataSizeSelect = 0x0016,
kGraphicsExportSetCompressionMethodSelect = 0x0017,
kGraphicsExportGetCompressionMethodSelect = 0x0018,
kGraphicsExportSetCompressionQualitySelect = 0x0019,
kGraphicsExportGetCompressionQualitySelect = 0x001A,
kGraphicsExportSetResolutionSelect = 0x001B,
kGraphicsExportGetResolutionSelect = 0x001C,
kGraphicsExportSetDepthSelect = 0x001D,
kGraphicsExportGetDepthSelect = 0x001E,
kGraphicsExportSetColorSyncProfileSelect = 0x0021,
kGraphicsExportGetColorSyncProfileSelect = 0x0022,
kGraphicsExportSetProgressProcSelect = 0x0023,
kGraphicsExportGetProgressProcSelect = 0x0024,
kGraphicsExportSetInputDataReferenceSelect = 0x0025,
kGraphicsExportGetInputDataReferenceSelect = 0x0026,
kGraphicsExportSetInputFileSelect = 0x0027,
kGraphicsExportGetInputFileSelect = 0x0028,
kGraphicsExportSetInputHandleSelect = 0x0029,
kGraphicsExportGetInputHandleSelect = 0x002A,
kGraphicsExportSetInputPtrSelect = 0x002B,
kGraphicsExportGetInputPtrSelect = 0x002C,
kGraphicsExportSetInputGraphicsImporterSelect = 0x002D,
kGraphicsExportGetInputGraphicsImporterSelect = 0x002E,
kGraphicsExportSetInputPictureSelect = 0x002F,
kGraphicsExportGetInputPictureSelect = 0x0030,
kGraphicsExportSetInputGWorldSelect = 0x0031,
kGraphicsExportGetInputGWorldSelect = 0x0032,
kGraphicsExportSetInputPixmapSelect = 0x0033,
kGraphicsExportGetInputPixmapSelect = 0x0034,
kGraphicsExportSetInputOffsetAndLimitSelect = 0x0035,
kGraphicsExportGetInputOffsetAndLimitSelect = 0x0036,
kGraphicsExportMayExporterReadInputDataSelect = 0x0037,
kGraphicsExportGetInputDataSizeSelect = 0x0038,
kGraphicsExportReadInputDataSelect = 0x0039,
kGraphicsExportGetInputImageDescriptionSelect = 0x003A,
kGraphicsExportGetInputImageDimensionsSelect = 0x003B,
kGraphicsExportGetInputImageDepthSelect = 0x003C,
kGraphicsExportDrawInputImageSelect = 0x003D,
kGraphicsExportSetOutputDataReferenceSelect = 0x003E,
kGraphicsExportGetOutputDataReferenceSelect = 0x003F,
kGraphicsExportSetOutputFileSelect = 0x0040,
kGraphicsExportGetOutputFileSelect = 0x0041,
kGraphicsExportSetOutputHandleSelect = 0x0042,
kGraphicsExportGetOutputHandleSelect = 0x0043,
kGraphicsExportSetOutputOffsetAndMaxSizeSelect = 0x0044,
kGraphicsExportGetOutputOffsetAndMaxSizeSelect = 0x0045,
kGraphicsExportSetOutputFileTypeAndCreatorSelect = 0x0046,
kGraphicsExportGetOutputFileTypeAndCreatorSelect = 0x0047,
kGraphicsExportWriteOutputDataSelect = 0x0048,
kGraphicsExportSetOutputMarkSelect = 0x0049,
kGraphicsExportGetOutputMarkSelect = 0x004A,
kGraphicsExportReadOutputDataSelect = 0x004B,
kGraphicsExportSetThumbnailEnabledSelect = 0x004C,
kGraphicsExportGetThumbnailEnabledSelect = 0x004D,
kGraphicsExportSetExifEnabledSelect = 0x004E,
kGraphicsExportGetExifEnabledSelect = 0x004F,
kGraphicsExportSetInputCGImageSelect = 0x0050,
kGraphicsExportGetInputCGImageSelect = 0x0051,
kGraphicsExportSetInputCGBitmapContextSelect = 0x0052,
kGraphicsExportGetInputCGBitmapContextSelect = 0x0053,
kGraphicsExportSetFlagsSelect = 0x0054,
kGraphicsExportGetFlagsSelect = 0x0055,
kImageTranscoderBeginSequenceSelect = 0x0001,
kImageTranscoderConvertSelect = 0x0002,
kImageTranscoderDisposeDataSelect = 0x0003,
kImageTranscoderEndSequenceSelect = 0x0004,
kQTGetComponentPropertyInfoSelect = -11,
kQTGetComponentPropertySelect = -12,
kQTSetComponentPropertySelect = -13,
kQTAddComponentPropertyListenerSelect = -14,
kQTRemoveComponentPropertyListenerSelect = -15
};
/* Aperture modes */
/*
* Summary:
* Aperture modes
*
* Discussion:
* You can set the aperture mode property on a movie to indicate
* whether aspect ratio and clean aperture correction should be
* performed (kQTPropertyClass_Visual /
* kQTVisualPropertyID_ApertureMode). When a movie is in clean,
* production or encoded pixels aperture mode, each track's
* dimensions are overriden by special dimensions for that mode. The
* original track dimensions are preserved and can be restored by
* setting the movie into classic aperture mode. Aperture modes are
* not saved in movies.
* You can set the aperture mode property on a decompression session
* options object to indicate whether pixel buffers should be tagged
* to enable aspect ratio and clean aperture correction
* (kQTPropertyClass_ICMDecompressionSessionOptions /
* kICMDecompressionSessionOptionsPropertyID_ApertureMode).
*/
enum {
/*
* An aperture mode which gives compatibility with behavior in
* QuickTime 7.0.x and earlier.
* A movie in classic aperture mode uses track dimensions as set in
* NewMovieTrack and SetTrackDimensions.
* A decompression session in classic aperture mode does not set the
* clean aperture or pixel aspect ratio attachments on emitted pixel
* buffers.
* Movies default to classic aperture mode. If you call
* SetTrackDimensions on a track, the movie is automatically switched
* into classic aperture mode.
*/
kQTApertureMode_Classic = FOUR_CHAR_CODE('clas'),
/*
* An aperture mode for general display.
* Where possible, video will be displayed at the correct pixel
* aspect ratio, trimmed to the clean aperture. A movie in clean
* aperture mode sets each track's dimensions to match its
* kQTVisualPropertyID_CleanApertureDimensions.
* A decompression session in clean aperture mode sets the clean
* aperture and pixel aspect ratio attachments on emitted pixel
* buffers based on the image description.
*/
kQTApertureMode_CleanAperture = FOUR_CHAR_CODE('clea'),
/*
* An aperture mode for modal use in authoring applications.
* Where possible, video will be displayed at the correct pixel
* aspect ratio, but without trimming to the clean aperture so that
* the edge processing region can be viewed. A movie in production
* aperture mode sets each track's dimensions to match its
* kQTVisualPropertyID_ProductionApertureDimensions.
* A decompression session in production aperture mode sets the pixel
* aspect ratio attachments on emitted pixel buffers based on the
* image description.
*/
kQTApertureMode_ProductionAperture = FOUR_CHAR_CODE('prod'),
/*
* An aperture mode for technical use.
* Displays all encoded pixels with no aspect ratio or clean aperture
* compensation. A movie in encoded pixels aperture mode sets each
* track's dimensions to match its
* kQTVisualPropertyID_EncodedPixelsDimensions.
* A decompression session in encoded pixels aperture mode does not
* set the clean aperture or pixel aspect ratio attachments on
* emitted pixel buffers.
*/
kQTApertureMode_EncodedPixels = FOUR_CHAR_CODE('enco')
};
/* Property interface for Image Descriptions */
/*
* Summary:
* Properties of image descriptions.
*/
enum {
/*
* Class identifier for image description properties.
*/
kQTPropertyClass_ImageDescription = FOUR_CHAR_CODE('idsc'),
/*
* The width of the encoded image. Usually, but not always, this is
* the ImageDescription's width field.
*/
kICMImageDescriptionPropertyID_EncodedWidth = FOUR_CHAR_CODE('encw'), /* SInt32, Read/Write */
/*
* The height of the encoded image. Usually, but not always, this is
* the ImageDescription's height field.
*/
kICMImageDescriptionPropertyID_EncodedHeight = FOUR_CHAR_CODE('ench'), /* SInt32, Read/Write */
/*
* Describes the clean aperture of the buffer. If not specified
* explicitly in the image description, the default clean aperture
* (full encoded width and height) will be returned.
*/
kICMImageDescriptionPropertyID_CleanAperture = FOUR_CHAR_CODE('clap'), /* Native-endian CleanApertureImageDescriptionExtension, Read/Write */
/*
* Describes the pixel aspect ratio. If not specified explicitly in
* the image description, a square (1:1) pixel aspect ratio will be
* returned.
*/
kICMImageDescriptionPropertyID_PixelAspectRatio = FOUR_CHAR_CODE('pasp'), /* Native-endian PixelAspectRatioImageDescriptionExtension, Read/Write */
/*
* Dimensions at which the image could be displayed on a square-pixel
* display, generally calculated using the clean aperture and pixel
* aspect ratio.
* Note that this value is returned as a FixedPoint; the width and
* height can also be read separately as rounded SInt32s via
* kICMImageDescriptionPropertyID_CleanApertureDisplayWidth and
* kICMImageDescriptionPropertyID_CleanApertureDisplayHeight.
*/
kICMImageDescriptionPropertyID_CleanApertureDisplayDimensions = FOUR_CHAR_CODE('cadi'), /* FixedPoint, Read */
/*
* Dimensions at which the image could be displayed on a square-pixel
* display, disregarding any clean aperture but honoring the pixel
* aspect ratio. This may be useful for authoring applications that
* want to expose the edge processing region. For general viewing,
* use kICMImageDescriptionPropertyID_CleanApertureDimensions
* instead.
* Note that this value is returned as a FixedPoint; the width and
* height can also be read separately as rounded SInt32s via
* kICMImageDescriptionPropertyID_ProductionApertureDisplayWidth and
* kICMImageDescriptionPropertyID_ProductionApertureDisplayHeight.
*/
kICMImageDescriptionPropertyID_ProductionApertureDisplayDimensions = FOUR_CHAR_CODE('prdi'), /* FixedPoint, Read */
/*
* Dimensions of the encoded image.
* Note that this value is returned as a FixedPoint for convenience;
* the width and height can also be read separately as SInt32s via
* kICMImageDescriptionPropertyID_EncodedWidth and
* kICMImageDescriptionPropertyID_EncodedHeight.
*/
kICMImageDescriptionPropertyID_EncodedPixelsDimensions = FOUR_CHAR_CODE('endi'), /* FixedPoint, Read */
/*
* A width at which the image could be displayed on a square-pixel
* display, possibly calculated using the clean aperture and pixel
* aspect ratio.
*/
kICMImageDescriptionPropertyID_CleanApertureDisplayWidth = FOUR_CHAR_CODE('disw'), /* SInt32, Read */
/*
* A height at which the image could be displayed on a square-pixel
* display, possibly calculated using the clean aperture and pixel
* aspect ratio.
*/
kICMImageDescriptionPropertyID_CleanApertureDisplayHeight = FOUR_CHAR_CODE('dish'), /* SInt32, Read */
/*
* A width at which the image could be displayed on a square-pixel
* display, disregarding any clean aperture but honoring the pixel
* aspect ratio. This may be useful for authoring applications that
* want to expose the edge processing region. For general viewing,
* use kICMImageDescriptionPropertyID_CleanApertureDisplayWidth
* instead.
*/
kICMImageDescriptionPropertyID_ProductionApertureDisplayWidth = FOUR_CHAR_CODE('pdsw'), /* SInt32, Read */
/*
* A height at which the image could be displayed on a square-pixel
* display, disregarding any clean aperture but honoring the pixel
* aspect ratio. This may be useful for authoring applications that
* want to expose the edge processing region. For general viewing,
* use kICMImageDescriptionPropertyID_CleanApertureDisplayHeight
* instead.
*/
kICMImageDescriptionPropertyID_ProductionApertureDisplayHeight = FOUR_CHAR_CODE('pdsh'), /* SInt32, Read */
/*
* Synonym for
* kICMImageDescriptionPropertyID_CleanApertureDisplayWidth.
*/
kICMImageDescriptionPropertyID_DisplayWidth = FOUR_CHAR_CODE('disw'), /* SInt32, Read */
/*
* Synonym for
* kICMImageDescriptionPropertyID_CleanApertureDisplayHeight.
*/
kICMImageDescriptionPropertyID_DisplayHeight = FOUR_CHAR_CODE('dish'), /* SInt32, Read */
/*
* Synonym for
* kICMImageDescriptionPropertyID_ProductionApertureDisplayWidth.
*/
kICMImageDescriptionPropertyID_ProductionDisplayWidth = FOUR_CHAR_CODE('pdsw'), /* SInt32, Read */
/*
* Synonym for
* kICMImageDescriptionPropertyID_ProductionApertureDisplayHeight.
*/
kICMImageDescriptionPropertyID_ProductionDisplayHeight = FOUR_CHAR_CODE('pdsh'), /* SInt32, Read */
/*
* Color information, if available in the
* NCLCColorInfoImageDescriptionExtension format.
*/
kICMImageDescriptionPropertyID_NCLCColorInfo = FOUR_CHAR_CODE('nclc'), /* Native-endian NCLCColorInfoImageDescriptionExtension, Read/Write */
/*
* A CGColorSpaceRef for the colorspace described by the image
* description, constructed from video color info or ICC Profile.
* IMPORTANT NOTE: The YCbCr matrix from the video color info is not
* represented in the CGColorSpaceRef. The caller of GetProperty is
* responsible for releasing this, eg, by calling
* CGColorSpaceRelease. Only supported on Mac OS X.
*/
kICMImageDescriptionPropertyID_CGColorSpace = FOUR_CHAR_CODE('cgcs'), /* CGColorSpaceRef, Read -- caller of GetProperty must call CGColorSpaceRelease */
/*
* A CFDataRef containing the serialized ICC profile described by the
* image description. The caller of GetProperty is responsible for
* releasing this, eg, by calling CFRelease.
*/
kICMImageDescriptionPropertyID_ICCProfile = FOUR_CHAR_CODE('iccp'), /* CFDataRef, Read/Write -- caller of GetProperty must call CFRelease */
/*
* The gamma level described by the image description.
*/
kICMImageDescriptionPropertyID_GammaLevel = FOUR_CHAR_CODE('gama'), /* Fixed, Read/Write */
/*
* Information about the number and order of fields, if available.
*/
kICMImageDescriptionPropertyID_FieldInfo = FOUR_CHAR_CODE('fiel'), /* FieldInfoImageDescriptionExtension2, Read/Write */
/*
* The offset in bytes from the start of one row to the next. Only
* valid if the codec type is a chunky pixel format.
*/
kICMImageDescriptionPropertyID_RowBytes = FOUR_CHAR_CODE('rowb'), /* SInt32, Read/Write */
/*
* A track width suitable for passing to NewMovieTrack when creating
* a new track to hold this image data.
*/
kICMImageDescriptionPropertyID_ClassicTrackWidth = FOUR_CHAR_CODE('claw'), /* Fixed, Read */
/*
* A track height suitable for passing to NewMovieTrack when creating
* a new track to hold this image data.
*/
kICMImageDescriptionPropertyID_ClassicTrackHeight = FOUR_CHAR_CODE('clah'), /* Fixed, Read */
/*
* Defines a duration for quantizing time. This is applicable for
* cases where a single media sample generates visual output that
* varies continuously through its duration. By interpreting this
* property, such a sample may be considered to have internal "step
* points" at multiples of the stepping duration. This can be used to
* throttle frame generation during playback, and when stepping using
* InterestingTime APIs. Setting a step duration with value zero
* removes any current step duration.
*/
kICMImageDescriptionPropertyID_StepDuration = FOUR_CHAR_CODE('step'), /* TimeRecord (base ignored), Read/Write */
/*
* The clean aperture as a FixedRect in source coordinates, within
* the rectangle defined by the image description width and height,
* suitable for use as a source rectangle in a decompression
* sequence.
* For historical reasons, the DVCPROHD codecs store the production
* aperture display dimensions in the image description width and
* height; the actual encoded dimensions are smaller. For DVCPROHD,
* the clip rect will be relative to the image description width and
* height, not the encoded dimensions.
*/
kICMImageDescriptionPropertyID_CleanApertureClipRect = FOUR_CHAR_CODE('cacr'), /* FixedRect, Read */
/*
* A matrix transforming the clean aperture clip rect to the origin,
* scaled to the clean aperture display dimensions.
* For historical reasons, the DVCPROHD codecs store the production
* aperture display dimensions in the image description width and
* height; the actual encoded dimensions are smaller. For DVCPROHD,
* the matrix will be relative to the image description width and
* height, not the encoded dimensions.
*/
kICMImageDescriptionPropertyID_CleanApertureMatrix = FOUR_CHAR_CODE('camx'), /* MatrixRecord, Read */
/*
* A matrix transforming the image to the origin, scaled to the
* production aperture display dimensions.
* For historical reasons, the DVCPROHD codecs store the production
* aperture display dimensions in the image description width and
* height; the actual encoded dimensions are smaller. For DVCPROHD,
* the matrix will be relative to the image description width and
* height, not the encoded dimensions.
*/
kICMImageDescriptionPropertyID_ProductionApertureMatrix = FOUR_CHAR_CODE('pamx'), /* MatrixRecord, Read */
/*
* A localized, human readable string summarizing the image as a
* CFString, ie: "Apple DV, 720 x 480 (640 x 480), Millions".
* The elements are: the codec name, the encoded pixels dimensions,
* then parenthetically the clean aperture mode dimensions, but only
* if they are different from the encoded pixels dimensions; then the
* depth.
* The codec name shall be from the localized decompressor component
* name string if exactly one decompressor with the correct cType is
* available; otherwise the string in the image description shall be
* used. The caller of GetProperty is responsible for releasing this
* CFString, eg, by calling CFRelease.
*/
kICMImageDescriptionPropertyID_SummaryString = FOUR_CHAR_CODE('isum') /* CFStringRef, Read - caller of GetProperty must call CFRelease*/
};
/*
* ICMImageDescriptionGetPropertyInfo()
*
* Summary:
* Gets info about a particular property of a ImageDescription.
*
* Parameters:
*
* inDesc:
* ImageDescriptionHandle being interrogated
*
* inPropClass:
* The class of property being requested
*
* inPropID:
* The ID of the property being requested
*
* outPropType:
* The type of property is returned here (can be NULL)
*
* outPropValueSize:
* The size of property is returned here (can be NULL)
*
* outPropertyFlags:
* The property flags are returned here (can be NULL)
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMImageDescriptionGetPropertyInfo(
ImageDescriptionHandle inDesc,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
ComponentValueType * outPropType, /* can be NULL */
ByteCount * outPropValueSize, /* can be NULL */
UInt32 * outPropertyFlags); /* can be NULL */
/*
* ICMImageDescriptionGetProperty()
*
* Summary:
* Gets a particular property of a ImageDescriptionHandle.
*
* Parameters:
*
* inDesc:
* ImageDescriptionHandle being interrogated
*
* inPropClass:
* The class of property being requested
*
* inPropID:
* The ID of the property being requested
*
* inPropValueSize:
* The size of the property value buffer
*
* outPropValueAddress:
* Points to the buffer to receive the property value
*
* outPropValueSizeUsed:
* Points to a variable to receive the actual size of returned
* property value (can be NULL)
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMImageDescriptionGetProperty(
ImageDescriptionHandle inDesc,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
ByteCount inPropValueSize,
ComponentValuePtr outPropValueAddress,
ByteCount * outPropValueSizeUsed); /* can be NULL */
/*
* ICMImageDescriptionSetProperty()
*
* Summary:
* Sets a particular property of a ImageDescriptionHandle.
*
* Parameters:
*
* inDesc:
* ImageDescriptionHandle being modified
*
* inPropClass:
* The class of property being set
*
* inPropID:
* The ID of the property being set
*
* inPropValueSize:
* The size of property value
*
* inPropValueAddress:
* Points to the property value buffer
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMImageDescriptionSetProperty(
ImageDescriptionHandle inDesc,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
ByteCount inPropValueSize,
ConstComponentValuePtr inPropValueAddress);
/*
* ICMValidTimeFlags
*
* Summary:
* Flags to describe which time values are valid.
*/
typedef UInt32 ICMValidTimeFlags;
enum {
/*
* Indicates that a display time stamp is valid.
*/
kICMValidTime_DisplayTimeStampIsValid = 1L << 0,
/*
* Indicates that a display duration is valid.
*/
kICMValidTime_DisplayDurationIsValid = 1L << 1,
/*
* Indicates that a decode time stamp is valid.
*/
kICMValidTime_DecodeTimeStampIsValid = 1L << 2,
/*
* Indicates that a decode duration is valid.
*/
kICMValidTime_DecodeDurationIsValid = 1L << 3,
/*
* Indicates that a display offset (the offset from a decode time
* stamp to a display time stamp) is valid.
*/
kICMValidTime_DisplayOffsetIsValid = 1L << 4
};
/*
* ICMDecompressionSessionRef
*
* Summary:
* Represents a decompression session that emits CVPixelBufferRefs
* containing frames, tagged with display times.
*
* Discussion:
* ICMDecompressionSession does not support source extraction,
* matrix transformations, graphics transfer modes, region-based
* clipping or data-loading procedures. Note that the pixel buffers
* may be output out of display order, provided that the client opts
* in.
*/
typedef struct OpaqueICMDecompressionSession* ICMDecompressionSessionRef;
/*
* QTVisualContextRef
*
* Summary:
* Represents a destination visual rendering environment.
*
* Discussion:
* The QTVisualContextRef type encapsulates a connection to a
* generic visual destination. A single visual context object may
* not be associated with more than one movie at a time.
*/
typedef struct OpaqueQTVisualContext* QTVisualContextRef;
/*
* ICMDecompressionSessionOptionsRef
*
* Summary:
* Holds options for a decompression session.
*/
typedef struct OpaqueICMDecompressionSessionOptions* ICMDecompressionSessionOptionsRef;
/*
* ICMDecompressionFrameOptionsRef
*
* Summary:
* Holds options for decompressing an individual frame.
*/
typedef struct OpaqueICMDecompressionFrameOptions* ICMDecompressionFrameOptionsRef;
/*
* ICMDecompressionTrackingFlags
*
* Summary:
* Describes changes in state of a frame queued with an ICM
* decompression session.
*/
typedef UInt32 ICMDecompressionTrackingFlags;
enum {
/*
* Indicates that this is the last call for this sourceFrameRefCon.
*/
kICMDecompressionTracking_LastCall = 1L << 0,
/*
* Indicates that the session no longer needs the source data pointer.
*/
kICMDecompressionTracking_ReleaseSourceData = 1L << 1,
/*
* Indicates that a frame is being emitted. The pixelBuffer parameter
* contains the decompressed frame. If the decompression session is
* targetting a visual context, the frame has not yet been sent to
* the visual context but will be after the callback returns.
*/
kICMDecompressionTracking_EmittingFrame = 1L << 2,
/*
* Indicates that this frame was decoded.
*/
kICMDecompressionTracking_FrameDecoded = 1L << 3,
/*
* Indicates that the codec decided to drop this frame.
*/
kICMDecompressionTracking_FrameDropped = 1L << 4,
/*
* Indicates that this frame will not be able to be displayed unless
* it is queued for redecode (also known as FrameNotDisplayable).
*/
kICMDecompressionTracking_FrameNeedsRequeueing = 1L << 5
};
/*
* ICMDecompressionTrackingCallback
*
* Summary:
* The callback through which a client of an ICM decompression
* session receives decoded frames and information about decoding.
*
* Discussion:
* The client may retain the emitted pixel buffers as long as it
* needs; they will not be reused before the client releases them.
*
* Parameters:
*
* decompressionTrackingRefCon:
* The callback's reference value, copied from the
* decompressionTrackingRefCon field of the
* ICMDecompressionTrackingCallbackRecord structure.
*
* result:
* Indicates whether there was an error in decompression.
*
* decompressionTrackingFlags:
* One or more flags describing the a frame's state transitions.
*
* pixelBuffer:
* When the kICMDecompressionTracking_EmittingFrame flag is set in
* decompressionTrackingFlags, a pixel buffer containing the
* decompressed frame. Otherwise, NULL.
*
* displayTime:
* If kICMValidTime_DisplayTimeStampIsValid is set in
* validTimeFlags, the display time of the frame.
*
* displayDuration:
* If kICMValidTime_DisplayDurationIsValid is set in
* validTimeFlags, the display duration of the frame.
*
* validTimeFlags:
* Indicates which of displayTime and displayDuration is valid.
*
* reserved:
* Reserved for future use. Ignore the value of this parameter.
*
* sourceFrameRefCon:
* The frame's reference value, copied from the sourceFrameRefCon
* parameter to ICMDecompressionSessionDecodeFrame.
*/
typedef CALLBACK_API_C( void , ICMDecompressionTrackingCallback )(void *decompressionTrackingRefCon, OSStatus result, ICMDecompressionTrackingFlags decompressionTrackingFlags, CVPixelBufferRef pixelBuffer, TimeValue64 displayTime, TimeValue64 displayDuration, ICMValidTimeFlags validTimeFlags, void *reserved, void *sourceFrameRefCon);
/*
* ICMDecompressionTrackingCallbackRecord
*
* Summary:
* A tracking callback for an ICM decompression session.
*/
struct ICMDecompressionTrackingCallbackRecord {
/*
* The callback function pointer.
*/
ICMDecompressionTrackingCallback decompressionTrackingCallback;
/*
* The callback's reference value.
*/
void * decompressionTrackingRefCon;
};
typedef struct ICMDecompressionTrackingCallbackRecord ICMDecompressionTrackingCallbackRecord;
/*
* ICMDecompressionSessionCreate()
*
* Summary:
* Creates a session for decompressing video frames.
*
* Discussion:
* Frames will be output through calls to trackingCallback.
*
* Parameters:
*
* allocator:
* An allocator for the session. Pass NULL to use the default
* allocator.
*
* desc:
* An image description for the source frames.
*
* decompressionOptions:
* Options for the session. The session will retain this options
* object. You may change some options during the session by
* modifying the object.
*
* destinationPixelBufferAttributes:
* Describes requirements for emitted pixel buffers.
*
* trackingCallback:
* The callback to be called with information about queued frames,
* and pixel buffers containing the decompressed frames.
*
* decompressionSessionOut:
* Points to a variable to receive the new decompression session.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMDecompressionSessionCreate(
CFAllocatorRef allocator, /* can be NULL */
ImageDescriptionHandle desc,
ICMDecompressionSessionOptionsRef decompressionOptions, /* can be NULL */
CFDictionaryRef destinationPixelBufferAttributes, /* can be NULL */
ICMDecompressionTrackingCallbackRecord * trackingCallback,
ICMDecompressionSessionRef * decompressionSessionOut);
/*
* ICMDecompressionSessionCreateForVisualContext()
*
* Summary:
* Creates a session for decompressing video frames.
*
* Discussion:
* Frames will be output to a visual context. If desired, the
* trackingCallback may attach additional data to pixel buffers
* before they are sent to the visual context.
*
* Parameters:
*
* allocator:
* An allocator for the session. Pass NULL to use the default
* allocator.
*
* desc:
* An image description for the source frames.
*
* decompressionOptions:
* Options for the session. The session will retain this options
* object. You may change some options during the session by
* modifying the object.
*
* visualContext:
* The target visual context.
*
* trackingCallback:
* The callback to be called with information about queued frames,
* and pixel buffers containing the decompressed frames.
*
* decompressionSessionOut:
* Points to a variable to receive the new decompression session.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMDecompressionSessionCreateForVisualContext(
CFAllocatorRef allocator, /* can be NULL */
ImageDescriptionHandle desc,
ICMDecompressionSessionOptionsRef decompressionOptions, /* can be NULL */
QTVisualContextRef visualContext,
ICMDecompressionTrackingCallbackRecord * trackingCallback,
ICMDecompressionSessionRef * decompressionSessionOut);
/*
* ICMDecompressionSessionRetain()
*
* Summary:
* Increments the retain count of a decompression session.
*
* Discussion:
* If you pass NULL to this function, nothing happens.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( ICMDecompressionSessionRef )
ICMDecompressionSessionRetain(ICMDecompressionSessionRef session);
/*
* ICMDecompressionSessionRelease()
*
* Summary:
* Decrements the retain count of a decompression session. If it
* drops to zero, the session is disposed.
*
* Discussion:
* If you pass NULL to this function, nothing happens.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( void )
ICMDecompressionSessionRelease(ICMDecompressionSessionRef session);
/*
* ICMDecompressionSessionGetTypeID()
*
* Summary:
* Returns the CFTypeID for decompression sessions.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( CFTypeID )
ICMDecompressionSessionGetTypeID(void);
/*
* ICMDecompressionSessionDecodeFrame()
*
* Summary:
* Queues a frame for decompression.
*
* Parameters:
*
* session:
* The decompression session.
*
* data:
* Points to the compressed data for this frame. The data must
* remain in this location until the tracking callback is called
* with the kICMDecompressionTracking_ReleaseSourceData flag set
* in decompressionTrackingFlags.
*
* dataSize:
* The number of bytes of compressed data. You may not pass zero
* in this parameter.
*
* frameOptions:
* Options for this frame.
*
* frameTime:
* Points to a structure describing the frame's timing information.
*
* sourceFrameRefCon:
* Your reference value for the frame.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMDecompressionSessionDecodeFrame(
ICMDecompressionSessionRef session,
const UInt8 * data,
ByteCount dataSize,
ICMDecompressionFrameOptionsRef frameOptions, /* can be NULL */
const ICMFrameTimeRecord * frameTime,
void * sourceFrameRefCon);
/*
* ICMDecompressionSessionGetPropertyInfo()
*
* Summary:
* Retrieves information about properties of a decompression session.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMDecompressionSessionGetPropertyInfo(
ICMDecompressionSessionRef session,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
ComponentValueType * outPropType, /* can be NULL */
ByteCount * outPropValueSize, /* can be NULL */
UInt32 * outPropertyFlags); /* can be NULL */
/*
* ICMDecompressionSessionGetProperty()
*
* Summary:
* Retrieves the value of a specific property of a decompression
* session.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMDecompressionSessionGetProperty(
ICMDecompressionSessionRef session,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
ByteCount inPropValueSize,
ComponentValuePtr outPropValueAddress,
ByteCount * outPropValueSizeUsed); /* can be NULL */
/*
* ICMDecompressionSessionSetProperty()
*
* Summary:
* Sets the value of a specific property of a decompression session.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMDecompressionSessionSetProperty(
ICMDecompressionSessionRef session,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
ByteCount inPropValueSize,
ConstComponentValuePtr inPropValueAddress);
/*
* ICMNonScheduledDisplayTime
*
* Discussion:
* The display time for a decompression session.
*/
struct ICMNonScheduledDisplayTime {
/*
* A display time. Usually this is the display time of a
* non-scheduled queued frame.
*/
TimeValue64 displayTime;
/*
* The timescale according to which displayTime should be interpreted.
*/
TimeScale displayTimeScale;
/*
* Reserved, set to zero.
*/
UInt32 flags;
};
typedef struct ICMNonScheduledDisplayTime ICMNonScheduledDisplayTime;
/*
* Summary:
* Properties of decompression sessions.
*/
enum {
/*
* Class identifier for decompression session properties.
*/
kQTPropertyClass_ICMDecompressionSession = FOUR_CHAR_CODE('icds'),
/*
* The non-scheduled display time for a decompression session.
* Setting this requests display of the non-scheduled queued frame at
* that display time, if there is one.
* See ICMDecompressionSessionSetNonScheduledDisplayTime.
*/
kICMDecompressionSessionPropertyID_NonScheduledDisplayTime = FOUR_CHAR_CODE('nsti'), /* ICMNonScheduledDisplayTime, Read/Write */
/*
* The direction for non-scheduled display time.
* See ICMDecompressionSessionSetNonScheduledDisplayDirection.
*/
kICMDecompressionSessionPropertyID_NonScheduledDisplayDirection = FOUR_CHAR_CODE('nsdu'), /* Fixed, Read/Write */
/*
* The pixel buffer pool from which emitted pixel buffers are
* allocated. Getting this does not change the retain count of the
* pool.
*/
kICMDecompressionSessionPropertyID_PixelBufferPool = FOUR_CHAR_CODE('pool'), /* CVPixelBufferPoolRef, Read */
/*
* Indicates whether the a common pixel buffer pool is shared between
* the decompressor and the session client. This is false if separate
* pools are used because the decompressor's and the client's pixel
* buffer attributes were incompatible.
*/
kICMDecompressionSessionPropertyID_PixelBufferPoolIsShared = FOUR_CHAR_CODE('plsh') /* Boolean, Read */
};
/*
* ICMDecompressionSessionSetNonScheduledDisplayTime()
*
* Summary:
* Sets the display time for a decompression session, and requests
* display of the non-scheduled queued frame at that display time,
* if there is one.
*
* Discussion:
* Call ICMDecompressionSessionSetNonScheduledDisplayTime after
* queueing non-scheduled frames with
* ICMDecompressionSessionDecodeFrame with the
* icmFrameTimeIsNonScheduledDisplayTime flag set to request display
* of the frame at a particular display time.
* If there is no queued non-scheduled frame with this display time,
* the frame with the next earlier display time is displayed. (Which
* of two display times is earlier is determined using the
* non-scheduled display time direction, which you can set with
* ICMDecompressionSessionSetNonScheduledDisplayDirection.) If there
* is no such frame, nothing happens.
* This has no effect if frames are scheduled against a timebase.
*
* Parameters:
*
* session:
* The decompression session.
*
* displayTime:
* A display time. Usually this is the display time of a
* non-scheduled queued frame.
*
* displayTimeScale:
* The timescale according to which displayTime should be
* interpreted.
*
* flags:
* Reserved, set to zero.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMDecompressionSessionSetNonScheduledDisplayTime(
ICMDecompressionSessionRef session,
TimeValue64 displayTime,
TimeScale displayTimeScale,
UInt32 flags);
/*
* ICMDecompressionSessionSetNonScheduledDisplayDirection()
*
* Summary:
* Sets the direction for non-scheduled display time.
*
* Discussion:
* If rate is zero or positive, direction is forwards. If negative,
* direction is backwards.
* Any frames queued under the opposite direction will be flushed.
*
* The non-scheduled display direction defaults to forwards (rate
* 1.0).
*
* Parameters:
*
* session:
* The decompression session.
*
* rate:
* Indicates the direction.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMDecompressionSessionSetNonScheduledDisplayDirection(
ICMDecompressionSessionRef session,
Fixed rate);
/*
* ICMDecompressionSessionFlush()
*
* Summary:
* Flushes frames queued with a decompression session.
*
* Discussion:
* The tracking callback will be called for each frame with the
* result -1.
*
* Parameters:
*
* session:
* The decompression session.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMDecompressionSessionFlush(ICMDecompressionSessionRef session);
/*
* ICMDecompressionSessionOptionsCreate()
*
* Summary:
* Creates a decompression session options object.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMDecompressionSessionOptionsCreate(
CFAllocatorRef allocator, /* can be NULL */
ICMDecompressionSessionOptionsRef * options);
/*
* ICMDecompressionSessionOptionsCreateCopy()
*
* Summary:
* Copies a decompression session options object.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMDecompressionSessionOptionsCreateCopy(
CFAllocatorRef allocator, /* can be NULL */
ICMDecompressionSessionOptionsRef originalOptions,
ICMDecompressionSessionOptionsRef * copiedOptions);
/*
* ICMDecompressionSessionOptionsRetain()
*
* Summary:
* Increments the retain count of a decompression session options
* object.
*
* Discussion:
* If you pass NULL to this function, nothing happens.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( ICMDecompressionSessionOptionsRef )
ICMDecompressionSessionOptionsRetain(ICMDecompressionSessionOptionsRef options);
/*
* ICMDecompressionSessionOptionsRelease()
*
* Summary:
* Decrements the retain count of a decompression session options
* object. If it drops to zero, the object is disposed.
*
* Discussion:
* If you pass NULL to this function, nothing happens.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( void )
ICMDecompressionSessionOptionsRelease(ICMDecompressionSessionOptionsRef options);
/*
* ICMDecompressionSessionOptionsGetTypeID()
*
* Summary:
* Returns the CFTypeID for decompression session options objects.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( CFTypeID )
ICMDecompressionSessionOptionsGetTypeID(void);
/*
* ICMDecompressionSessionOptionsGetPropertyInfo()
*
* Summary:
* Retrieves information about properties of a decompression session
* options object.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMDecompressionSessionOptionsGetPropertyInfo(
ICMDecompressionSessionOptionsRef options,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
ComponentValueType * outPropType, /* can be NULL */
ByteCount * outPropValueSize, /* can be NULL */
UInt32 * outPropertyFlags); /* can be NULL */
/*
* ICMDecompressionSessionOptionsGetProperty()
*
* Summary:
* Retrieves the value of a specific property of a decompression
* session options object.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMDecompressionSessionOptionsGetProperty(
ICMDecompressionSessionOptionsRef options,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
ByteCount inPropValueSize,
ComponentValuePtr outPropValueAddress,
ByteCount * outPropValueSizeUsed); /* can be NULL */
/*
* ICMDecompressionSessionOptionsSetProperty()
*
* Summary:
* Sets the value of a specific property of a decompression session
* options object.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMDecompressionSessionOptionsSetProperty(
ICMDecompressionSessionOptionsRef options,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
ByteCount inPropValueSize,
ConstComponentValuePtr inPropValueAddress);
/*
* Summary:
* Properties of decompression session options objects.
*/
enum {
/*
* Class identifier for decompression session options object
* properties.
*/
kQTPropertyClass_ICMDecompressionSessionOptions = FOUR_CHAR_CODE('idso'),
/*
* By default, this is true, meaning that frames must be output in
* display order. Set this to false to allow frames to be output in
* decode order rather than in display order.
*/
kICMDecompressionSessionOptionsPropertyID_DisplayOrderRequired = FOUR_CHAR_CODE('dorq'), /* Boolean, Read/Write */
/*
* A specific decompressor component or component instance to be
* used, or one of the wildcards anyCodec, bestSpeedCodec,
* bestFidelityCodec, or bestCompressionCodec.
* By default, this is anyCodec.
*/
kICMDecompressionSessionOptionsPropertyID_DecompressorComponent = FOUR_CHAR_CODE('imdc'), /* DecompressorComponent, Read/Write */
/*
* The decompression accuracy.
* The default accuracy is codecNormalQuality.
*/
kICMDecompressionSessionOptionsPropertyID_Accuracy = FOUR_CHAR_CODE('acur'), /* CodecQ, Read/Write */
/*
* Requests special handling of fields. Not all codecs will obey this
* request; some codecs will only handle it at certain accuracy
* levels. Ignored for non-interlaced content.
*/
kICMDecompressionSessionOptionsPropertyID_FieldMode = FOUR_CHAR_CODE('fiel'), /* ICMFieldMode, Read/Write */
/*
* The maximum number of buffers ahead of the current time that
* should be decompressed. Used in sessions that target visual
* contexts. By default, the number of buffers will be determined
* from the visual context.
*/
kICMDecompressionSessionOptionsPropertyID_MaxBufferCount = FOUR_CHAR_CODE('m#bf'), /* UInt32, Read/Write */
/*
* The minimum time ahead of the current time that frames should be
* decompressed. Used in sessions that target visual contexts. By
* default, the output-ahead time will be determined from the visual
* context.
*/
kICMDecompressionSessionOptionsPropertyID_OutputAheadTime = FOUR_CHAR_CODE('futu'), /* TimeRecord, Read/Write */
/*
* You can set the aperture mode property on a decompression session
* options object to indicate whether pixel buffers should be tagged
* to enable aspect ratio and clean aperture correction. The default
* aperture mode for a decompression session is clean aperture mode.
*/
kICMDecompressionSessionOptionsPropertyID_ApertureMode = FOUR_CHAR_CODE('apmd') /* OSType, Read/Write */
};
/*
* ICMFieldMode
*
* Summary:
* Describes special field handling.
*/
typedef UInt32 ICMFieldMode;
enum {
/*
* Both fields should be decompressed.
*/
kICMFieldMode_BothFields = 0,
/*
* Only the top field should be decompressed, producing a half-height
* image.
*/
kICMFieldMode_TopFieldOnly = 1,
/*
* Only the bottom field should be decompressed, producing a
* half-height image.
*/
kICMFieldMode_BottomFieldOnly = 2,
/*
* Both fields should be decompressed, and then filtered to reduce
* interlacing artifacts.
*/
kICMFieldMode_DeinterlaceFields = 3
};
/*
* ICMDecompressionFrameOptionsCreate()
*
* Summary:
* Creates a frame decompression options object.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMDecompressionFrameOptionsCreate(
CFAllocatorRef allocator, /* can be NULL */
ICMDecompressionFrameOptionsRef * options);
/*
* ICMDecompressionFrameOptionsCreateCopy()
*
* Summary:
* Copies a frame decompression options object.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMDecompressionFrameOptionsCreateCopy(
CFAllocatorRef allocator, /* can be NULL */
ICMDecompressionFrameOptionsRef originalOptions,
ICMDecompressionFrameOptionsRef * copiedOptions);
/*
* ICMDecompressionFrameOptionsRetain()
*
* Summary:
* Increments the retain count of a frame decompression options
* object.
*
* Discussion:
* If you pass NULL to this function, nothing happens.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( ICMDecompressionFrameOptionsRef )
ICMDecompressionFrameOptionsRetain(ICMDecompressionFrameOptionsRef options);
/*
* ICMDecompressionFrameOptionsRelease()
*
* Summary:
* Decrements the retain count of a frame decompression options
* object. If it drops to zero, the object is disposed.
*
* Discussion:
* If you pass NULL to this function, nothing happens.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( void )
ICMDecompressionFrameOptionsRelease(ICMDecompressionFrameOptionsRef options);
/*
* ICMDecompressionFrameOptionsGetTypeID()
*
* Summary:
* Returns the CFTypeID for frame decompression options objects.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( CFTypeID )
ICMDecompressionFrameOptionsGetTypeID(void);
/*
* ICMDecompressionFrameOptionsGetPropertyInfo()
*
* Summary:
* Retrieves information about properties of a decompression frame
* options object.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMDecompressionFrameOptionsGetPropertyInfo(
ICMDecompressionFrameOptionsRef options,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
ComponentValueType * outPropType, /* can be NULL */
ByteCount * outPropValueSize, /* can be NULL */
UInt32 * outPropertyFlags); /* can be NULL */
/*
* ICMDecompressionFrameOptionsGetProperty()
*
* Summary:
* Retrieves the value of a specific property of a decompression
* frame options object.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMDecompressionFrameOptionsGetProperty(
ICMDecompressionFrameOptionsRef options,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
ByteCount inPropValueSize,
ComponentValuePtr outPropValueAddress,
ByteCount * outPropValueSizeUsed); /* can be NULL */
/*
* ICMDecompressionFrameOptionsSetProperty()
*
* Summary:
* Sets the value of a specific property of a decompression frame
* options object.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMDecompressionFrameOptionsSetProperty(
ICMDecompressionFrameOptionsRef options,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
ByteCount inPropValueSize,
ConstComponentValuePtr inPropValueAddress);
/*
* Summary:
* Properties of decompression frame options objects.
*/
enum {
/*
* Class identifier for decompression frame options object properties.
*/
kQTPropertyClass_ICMDecompressionFrameOptions = FOUR_CHAR_CODE('idfo'),
/*
* A specific pixel buffer that the frame should be decompressed
* into. Setting this circumvents the pixel buffer pool mechanism. If
* this buffer is not compatible with the codec's pixel buffer
* requirements, decompression will fail.
*/
kICMDecompressionFrameOptionsPropertyID_DestinationPixelBuffer = FOUR_CHAR_CODE('cvpb') /* CVPixelBufferRef, Read/Write */
};
/*
* ICMCompressionSessionRef
*
* Summary:
* Represents a compression session for a sequence of images.
* B-frame capable.
*/
typedef struct OpaqueICMCompressionSession* ICMCompressionSessionRef;
/*
* ICMEncodedFrameRef
*
* Summary:
* Represents a frame encoded by a compressor component and emitted
* by a compression session.
*
* Discussion:
* Compressor components have access to the mutable flavor of
* encoded frame object (ICMMutableEncodedFrameRef); compression
* session clients receive the read-only flavor
* (ICMMutableEncodedFrameRef).
*/
typedef const struct OpaqueICMEncodedFrame* ICMEncodedFrameRef;
typedef struct OpaqueICMEncodedFrame* ICMMutableEncodedFrameRef;
/*
* ICMCompressionSessionOptionsRef
*
* Summary:
* An opaque struct which holds options to configure a compression
* session.
*/
typedef struct OpaqueICMCompressionSessionOptions* ICMCompressionSessionOptionsRef;
/*
* ICMCompressionFrameOptionsRef
*
* Summary:
* A token which holds options to configure an individual frame
* during a compression session.
*/
typedef struct OpaqueICMCompressionFrameOptions* ICMCompressionFrameOptionsRef;
/*
* ICMMultiPassStorageRef
*
* Summary:
* A mechanism for storing information for each frame of a multipass
* compression session.
*
* Discussion:
* The ICM provides default storage mechanisms using temporary
* files, but clients may override this with custom mechanisms.
*/
typedef struct OpaqueICMMultiPassStorage* ICMMultiPassStorageRef;
/*
* ICMEncodedFrameOutputCallback
*
* Summary:
* The callback through which a client of an ICM compression session
* receives encoded frames.
*
* Discussion:
* During the encoded frame output callback, the ICM has a reference
* to the passed ICMEncodedFrame, but the ICM will release that
* reference afterwards; the callback should retain the encoded
* frame if the client wants to keep it after the callback returns.
*
* Parameters:
*
* encodedFrameOutputRefCon:
* The callback's reference value, copied from the
* encodedFrameOutputRefCon field of the
* ICMEncodedFrameOutputRecord.
*
* session:
* The compression session.
*
* error:
* Indicates whether there was an error.
*
* frame:
* The encoded frame.
*
* reserved:
* Reserved for future use. Ignore the value of this parameter.
*
* Result:
* If the callback returns an error, the compressor and ICM will
* stop emitting frames so that the error can be propogated back to
* the caller of ICMCompressionSessionEncodeFrame or
* ICMCompressionSessionCompleteFrames.
*/
typedef CALLBACK_API_C( OSStatus , ICMEncodedFrameOutputCallback )(void *encodedFrameOutputRefCon, ICMCompressionSessionRef session, OSStatus error, ICMEncodedFrameRef frame, void *reserved);
/*
* ICMEncodedFrameOutputRecord
*
* Summary:
* Holds an encoded frame callback and reference value.
*/
struct ICMEncodedFrameOutputRecord {
/*
* An encoded frame callback.
*/
ICMEncodedFrameOutputCallback encodedFrameOutputCallback;
/*
* The reference value for the encoded frame callback.
*/
void * encodedFrameOutputRefCon;
/*
* The allocator for encoded frame data. Pass NULL if you do not need
* a specific allocator.
*/
CFAllocatorRef frameDataAllocator;
};
typedef struct ICMEncodedFrameOutputRecord ICMEncodedFrameOutputRecord;
/*
* ICMSourceTrackingFlags
*
*/
typedef UInt32 ICMSourceTrackingFlags;
enum {
/*
* Indicates that this is the last call for this sourceFrameRefCon.
*/
kICMSourceTracking_LastCall = 1L << 0,
/*
* Indicates that the session is done with the source pixel buffer
* and has released any reference to it that it had.
*/
kICMSourceTracking_ReleasedPixelBuffer = 1L << 1,
/*
* Indicates that this frame was encoded.
*/
kICMSourceTracking_FrameWasEncoded = 1L << 2,
/*
* Indicates that this frame was dropped.
*/
kICMSourceTracking_FrameWasDropped = 1L << 3,
/*
* Indicates that this frame was merged into other frames.
*/
kICMSourceTracking_FrameWasMerged = 1L << 4,
/*
* Indicates that the time stamp of this frame was modified.
*/
kICMSourceTracking_FrameTimeWasChanged = 1L << 5,
/*
* Indicates that the ICM has copied the image from the source pixel
* buffer into another pixel buffer because the source pixel buffer
* was not compatible with the compressor's required pixel buffer
* attributes.
*/
kICMSourceTracking_CopiedPixelBuffer = 1L << 6
};
/*
* ICMSourceTrackingCallback
*
* Summary:
* A callback which the ICM calls to provide information about the
* status of a frame that was passed to
* ICMCompressionSessionEncodeFrame.
*
* Discussion:
* Note that this callback may be called several times.
*
* Parameters:
*
* sourceTrackingRefCon:
* The callback's reference value, copied from the
* sourceTrackingRefCon field of ICMSourceTrackingCallbackRecord.
*
* sourceTrackingFlags:
* Flags describing what has happened to the frame.
*
* sourceFrameRefCon:
* The frame's reference value, copied from the sourceFrameRefCon
* parameter to ICMCompressionSessionEncodeFrame.
*
* reserved:
* Reserved for future use. Ignore the value of this parameter.
*/
typedef CALLBACK_API_C( void , ICMSourceTrackingCallback )(void *sourceTrackingRefCon, ICMSourceTrackingFlags sourceTrackingFlags, void *sourceFrameRefCon, void *reserved);
/*
* ICMSourceTrackingCallbackRecord
*
* Summary:
* A tracking callback for an ICM compression session.
*/
struct ICMSourceTrackingCallbackRecord {
/*
* The callback function pointer.
*/
ICMSourceTrackingCallback sourceTrackingCallback;
/*
* The callback's reference value.
*/
void * sourceTrackingRefCon;
};
typedef struct ICMSourceTrackingCallbackRecord ICMSourceTrackingCallbackRecord;
/*
* ICMFrameType
*
* Summary:
* Informally identifies a type of frame.
*
* Discussion:
* Do not assume that there are no other frame types beyond I, P and
* B.
*/
typedef UInt16 ICMFrameType;
enum {
kICMFrameType_I = 'I',
kICMFrameType_P = 'P',
kICMFrameType_B = 'B',
kICMFrameType_Unknown = 0
};
/* ICMCompressionSessionRef routines */
/*
* ICMCompressionSessionCreate()
*
* Summary:
* Creates a compression session for the given codec type.
*
* Discussion:
* Some compressors do not support arbitrary source dimensions, and
* may override the suggested width and height.
*
* Parameters:
*
* allocator:
* An allocator for the session. Pass NULL to use the default
* allocator.
*
* width:
* The width of frames.
*
* height:
* The height of frames.
*
* cType:
* The codec type.
*
* timescale:
* The timescale to be used for all timestamps and durations used
* in the session.
*
* compressionOptions:
* Settings configuring the session.
*
* sourcePixelBufferAttributes:
* Required attributes for source pixel buffers, used when
* creating a pixel buffer pool for source frames. If you do not
* want the ICM to create one for you, pass NULL. (Using pixel
* buffers not allocated by the ICM may increase the chance that
* it will be necessary to copy image data.)
*
* encodedFrameOutputRecord:
* The callback that will receive encoded frames.
*
* compressionSessionOut:
* Points to a variable to receive the created session object.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressionSessionCreate(
CFAllocatorRef allocator, /* can be NULL */
int width,
int height,
CodecType cType,
TimeScale timescale,
ICMCompressionSessionOptionsRef compressionOptions, /* can be NULL */
CFDictionaryRef sourcePixelBufferAttributes, /* can be NULL */
ICMEncodedFrameOutputRecord * encodedFrameOutputRecord,
ICMCompressionSessionRef * compressionSessionOut);
/*
* ICMCompressionSessionRetain()
*
* Summary:
* Increments the retain count of a compression session.
*
* Discussion:
* If you pass NULL to this function, nothing happens.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( ICMCompressionSessionRef )
ICMCompressionSessionRetain(ICMCompressionSessionRef session);
/*
* ICMCompressionSessionRelease()
*
* Summary:
* Decrements the retain count of a compression session. If it
* drops to zero, the session is disposed.
*
* Discussion:
* If you pass NULL to this function, nothing happens. Remember to
* call ICMCompressionSessionCompleteFrames first if you want to
* ensure any pending frames are emitted. If you do not, they will
* be discarded.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( void )
ICMCompressionSessionRelease(ICMCompressionSessionRef session);
/*
* ICMCompressionSessionGetTypeID()
*
* Summary:
* Returns the CFTypeID for compression sessions.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( CFTypeID )
ICMCompressionSessionGetTypeID(void);
/*
* ICMCompressionSessionGetPropertyInfo()
*
* Summary:
* Retrieves information about properties of a compression session.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressionSessionGetPropertyInfo(
ICMCompressionSessionRef session,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
ComponentValueType * outPropType, /* can be NULL */
ByteCount * outPropValueSize, /* can be NULL */
UInt32 * outPropertyFlags); /* can be NULL */
/*
* ICMCompressionSessionGetProperty()
*
* Summary:
* Retrieves the value of a specific property of a compression
* session.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressionSessionGetProperty(
ICMCompressionSessionRef session,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
ByteCount inPropValueSize,
ComponentValuePtr outPropValueAddress,
ByteCount * outPropValueSizeUsed); /* can be NULL */
/*
* ICMCompressionSessionSetProperty()
*
* Summary:
* Sets the value of a specific property of a compression session.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressionSessionSetProperty(
ICMCompressionSessionRef session,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
ByteCount inPropValueSize,
ConstComponentValuePtr inPropValueAddress);
/*
* Summary:
* Properties of compression sessions.
*/
enum {
/*
* Class identifier for compression session properties.
*/
kQTPropertyClass_ICMCompressionSession = FOUR_CHAR_CODE('icse'),
/*
* The time scale for the compression session.
*/
kICMCompressionSessionPropertyID_TimeScale = FOUR_CHAR_CODE('tscl'), /* TimeScale, Read */
/*
* The compressor's pixel buffer attributes for the compression
* session. You can use these to create a pixel buffer pool for
* source pixel buffers. Note that this is not the same as the
* sourcePixelBufferAttributes passed in to
* ICMCompressionSessionCreate. Getting this property does not change
* its retain count.
*/
kICMCompressionSessionPropertyID_CompressorPixelBufferAttributes = FOUR_CHAR_CODE('batt'), /* CFDictionaryRef, Read */
/*
* A pool that can provide ideal source pixel buffers for a
* compression session. The compression session creates this pixel
* buffer pool based on the compressor's pixel buffer attributes and
* any pixel buffer attributes passed in to
* ICMCompressionSessionCreate. If the source pixel buffer attributes
* and the compressor pixel buffer attributes can not be reconciled,
* the pool is based on the source pixel buffer attributes and the
* ICM converts each CVPixelBuffer internally.
*/
kICMCompressionSessionPropertyID_PixelBufferPool = FOUR_CHAR_CODE('pool'), /* CVPixelBufferPoolRef, Read */
/*
* The image description for the compression session. For some
* codecs, the image description may not be available before the
* first frame is compressed. Multiple calls to retrieve this
* property will return the same handle. The ICM will dispose this
* handle when the compression session is disposed.
* IMPORTANT: The caller must NOT dispose this handle.
*/
kICMCompressionSessionPropertyID_ImageDescription = FOUR_CHAR_CODE('idsc') /* ImageDescriptionHandle, Read */
};
/*
* ICMCompressionSessionGetTimeScale()
*
* Summary:
* Retrieves the time scale for the compression session.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( TimeScale )
ICMCompressionSessionGetTimeScale(ICMCompressionSessionRef session);
/*
* ICMCompressionSessionGetPixelBufferPool()
*
* Summary:
* Returns a pool that can provide ideal source pixel buffers for a
* compression session.
*
* Discussion:
* The compression session creates this pixel buffer pool based on
* the compressor's pixel buffer attributes and any pixel buffer
* attributes passed in to ICMCompressionSessionCreate. If the
* source pixel buffer attributes and the compressor pixel buffer
* attributes can not be reconciled, the pool is based on the source
* pixel buffer attributes and the ICM converts each CVPixelBuffer
* internally.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( CVPixelBufferPoolRef )
ICMCompressionSessionGetPixelBufferPool(ICMCompressionSessionRef session);
/*
* ICMCompressionSessionGetImageDescription()
*
* Summary:
* Retrieves the image description for the compression session.
*
* Discussion:
* For some codecs, this may fail if called before the first frame
* is compressed. Multiple calls to
* ICMCompressionSessionGetImageDescription will return the same
* handle. The ICM will dispose this handle when the compression
* session is disposed.
* IMPORTANT: The caller must NOT dispose this handle.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressionSessionGetImageDescription(
ICMCompressionSessionRef session,
ImageDescriptionHandle * imageDescOut);
/* ICMCompressionSessionRef encoding routines */
/*
* ICMCompressionSessionEncodeFrame()
*
* Summary:
* Call this function to present frames to the compression session.
* Encoded frames may or may not be output before the function
* returns.
*
* Discussion:
* The session will retain the pixel buffer as long as necessary;
* the client should not modify the pixel data until the session
* releases it. (The most practical way to deal with this is by
* allocating pixel buffers from a pool.)
* The client may fill in both, either or neither of
* displayTimeStamp and displayDuration, but should set the
* appropriate flags to indicate which is valid. If the client needs
* to track the progress of a source frame, it should provide a
* sourceTrackingCallback.
* Note: If multipass compression is enabled, calls to
* ICMCompressionSessionEncodeFrame must be bracketed by
* ICMCompressionSessionBeginPass ... ICMCompressionSessionEndPass.
*
* Parameters:
*
* session:
* Identifies the compression session.
*
* pixelBuffer:
* Contains the source image to be compressed. PixelBuffer must
* have a nonzero reference count. The session will retain it as
* long as necessary. The client should not modify pixel buffer's
* pixels until the pixel buffer release callback is called. In a
* multipass encoding session pass where the compressor suggested
* the flag kICMCompressionPassMode_NoSourceFrames, you may pass
* NULL for pixelBuffer.
*
* displayTimeStamp:
* The display timestamp of the frame, using the timescale passed
* to ICMCompressionSessionCreate. If you pass a valid value, set
* the kICMValidTime_DisplayTimeStampIsValid flag in
* validTimeFlags.
*
* displayDuration:
* The display duration of the frame, using the timescale passed
* to ICMCompressionSessionCreate. If you pass a valid value, set
* the kICMValidTime_DisplayDurationIsValid flag in validTimeFlags.
*
* validTimeFlags:
* Flags to indicate which of displayTimeStamp and displayDuration
* are valid.
*
* frameOptions:
* Options for this frame.
*
* sourceTrackingCallback:
* A callback to be notified about the status of this source
* frame. Pass NULL if you do not require notification.
*
* sourceFrameRefCon:
* Your reference to the source frame.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressionSessionEncodeFrame(
ICMCompressionSessionRef session,
CVPixelBufferRef pixelBuffer,
TimeValue64 displayTimeStamp,
TimeValue64 displayDuration,
ICMValidTimeFlags validTimeFlags,
ICMCompressionFrameOptionsRef frameOptions, /* can be NULL */
ICMSourceTrackingCallbackRecord * sourceTrackingCallback, /* can be NULL */
void * sourceFrameRefCon);
/*
* ICMCompressionSessionCompleteFrames()
*
* Discussion:
* Call this function to force the compression session to complete
* encoding frames. Set completeAllFrames to direct the session to
* complete all pending frames.
* If completeAllFrames is false, only frames with display time
* stamps up to and including completeUntilDisplayTimeStamp.
* If ICMCompressionSessionOptionsSetDurationsNeeded is true and you
* are passing valid display timestamps but not display durations to
* ICMCompressionSessionEncodeFrame, pass the display timestamp of
* the next frame that would be passed to EncodeFrame in
* nextDisplayTimeStamp.
* Note: This function might return before frames are completed if
* the encoded frame callback returns an error.
*
* Parameters:
*
* session:
* Identifies the compression session.
*
* completeAllFrames:
* Set to direct the session to complete all pending frames.
*
* completeUntilDisplayTimeStamp:
* If completeAllFrames is false, the display timestamp to
* complete frames up to. Ignored if completeAllFrames is true.
*
* nextDisplayTimeStamp:
* See above. Ignored unless
* ICMCompressionSessionOptionsSetDurationsNeeded set true and
* kICMValidTime_DisplayDurationIsValid was clear in
* validTimeFlags in last call to ICMCompressionSessionEncodeFrame.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressionSessionCompleteFrames(
ICMCompressionSessionRef session,
Boolean completeAllFrames,
TimeValue64 completeUntilDisplayTimeStamp,
TimeValue64 nextDisplayTimeStamp);
/* ICMCompressionSessionRef multipass support routines */
/*
* ICMCompressionPassModeFlags
*
* Summary:
* Flags describing how a compressor should behave in a given pass
* of multipass encoding.
*/
typedef UInt32 ICMCompressionPassModeFlags;
enum {
/*
* In this pass the compressor shall output encoded frames.
*/
kICMCompressionPassMode_OutputEncodedFrames = 1L << 0,
/*
* In this pass the client need not provide source frame buffers.
*/
kICMCompressionPassMode_NoSourceFrames = 1L << 1,
/*
* In this pass the compressor may write private data to multipass
* storage.
*/
kICMCompressionPassMode_WriteToMultiPassStorage = 1L << 2,
/*
* In this pass the compressor may read private data from multipass
* storage.
*/
kICMCompressionPassMode_ReadFromMultiPassStorage = 1L << 3,
/*
* The compressor will set this flag to indicate that it will not be
* able to output encoded frames in the coming pass. If this flag is
* not set, then the client is allowed to set the
* kICMCompressionPassMode_OutputEncodedFrames flag when calling
* ICMCompressionSessionBeginPass.
*/
kICMCompressionPassMode_NotReadyToOutputEncodedFrames = 1L << 4
};
/*
* ICMCompressionSessionSupportsMultiPassEncoding()
*
* Summary:
* Queries whether a compression session supports multipass encoding.
*
* Discussion:
* Even if this function returns false, if you set the
* kICMCompressionSessionOptionsPropertyID_MultiPassStorage property
* on the CompressionSessionOptions, you must call
* ICMCompressionSessionBeginPass and ICMCompressionSessionEndPass.
*
* Parameters:
*
* session:
* The compression session.
*
* multiPassStyleFlags:
* Reserved. Set to zero.
*
* firstPassModeFlagsOut:
* Points to a variable to receive the session's requested mode
* flags for the first pass. The client may modify these flags,
* but should not set kICMCompressionPassMode_NoSourceFrames. Pass
* NULL if you do not want this information.
*
* Result:
* true if the session supports multipass encoding, false otherwise.
* If the session does not support multipass encoding,
* *firstPassModeFlagsOut will be set to
* kICMCompressionPassMode_OutputEncodedFrames.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( Boolean )
ICMCompressionSessionSupportsMultiPassEncoding(
ICMCompressionSessionRef session,
UInt32 multiPassStyleFlags,
ICMCompressionPassModeFlags * firstPassModeFlagsOut); /* can be NULL */
/*
* ICMCompressionSessionBeginPass()
*
* Summary:
* Call to announce the start of a specific compression pass.
*
* Discussion:
* The source frames and frame options for each display timestamp
* should be the same across passes.
* During multipass compression, valid displayTimeStamps must be
* passed to ICMCompressionSessionEncodeFrame since they are used to
* index the compressor's stored state.
* During an analysis pass
* (kICMCompressionPassMode_WriteToMultiPassStorage), the compressor
* does not output encoded frames, but records compressor-private
* information for each frame.
* During repeated analysis passes and the encoding pass
* (kICMCompressionPassMode_ReadFromMultiPassStorage), the
* compressor may refer to this information for other frames and use
* it to improve encoding.
* During an encoding pass
* (kICMCompressionPassMode_OutputEncodedFrames), the compressor
* must output encoded frames.
* If the compressor set the kICMCompressionPassMode_NoSourceFrames
* flag for the pass, the client may pass NULL pixel buffers to
* ICMCompressionSessionEncodeFrame.
* By default, the ICM provides local storage that lasts only until
* the compression session is disposed. If the client provides
* custom multipass storage, pass may be performed at different
* times or on different machines; segments of each pass may even be
* distributed.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressionSessionBeginPass(
ICMCompressionSessionRef session,
ICMCompressionPassModeFlags passModeFlags,
UInt32 flags);
/*
* ICMCompressionSessionEndPass()
*
* Summary:
* Call to announce the end of a pass.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressionSessionEndPass(ICMCompressionSessionRef session);
/*
* ICMCompressionSessionProcessBetweenPasses()
*
* Summary:
* Lets the compressor perform processing between passes.
*
* Discussion:
* Call this function repeatedly, until the compressor sets
* *interpassProcessingDoneOut to true to indicate that it is done
* with this round of interpass processing.
* When done, the compressor will indicate its preferred mode for
* the next pass.
* The client may choose to begin an encoding pass (by ORing in the
* kICMCompressionPassMode_OutputEncodedFrames flag) regardless of
* the compressor's request.
*
* Parameters:
*
* session:
* The compression session.
*
* flags:
* Reserved. Set to zero.
*
* interpassProcessingDoneOut:
* Points to a Boolean that will be set to false if
* ICMCompressionSessionProcessBetweenPasses should be called
* again, true if not
*
* requestedNextPassModeFlagsOut:
* Points to ICMCompressionPassModeFlags that will be set to the
* codec's recommended mode flags for the next pass.
* kICMCompressionPassMode_OutputEncodedFrames will only be set if
* it recommends that the next pass be the final one.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressionSessionProcessBetweenPasses(
ICMCompressionSessionRef session,
UInt32 flags,
Boolean * interpassProcessingDoneOut,
ICMCompressionPassModeFlags * requestedNextPassModeFlagsOut);
/* ICMCompressionSessionOptionsRef routines */
/*
* ICMCompressionSessionOptionsCreate()
*
* Summary:
* Creates a compression session options object.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressionSessionOptionsCreate(
CFAllocatorRef allocator, /* can be NULL */
ICMCompressionSessionOptionsRef * options);
/*
* ICMCompressionSessionOptionsCreateCopy()
*
* Summary:
* Copies a compression session options object.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressionSessionOptionsCreateCopy(
CFAllocatorRef allocator, /* can be NULL */
ICMCompressionSessionOptionsRef originalOptions,
ICMCompressionSessionOptionsRef * copiedOptions);
/*
* ICMCompressionSessionOptionsRetain()
*
* Summary:
* Increments the retain count of a compression session options
* object.
*
* Discussion:
* If you pass NULL to this function, nothing happens.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( ICMCompressionSessionOptionsRef )
ICMCompressionSessionOptionsRetain(ICMCompressionSessionOptionsRef options);
/*
* ICMCompressionSessionOptionsRelease()
*
* Summary:
* Decrements the retain count of a compression session options
* object. If it drops to zero, the object is disposed.
*
* Discussion:
* If you pass NULL to this function, nothing happens.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( void )
ICMCompressionSessionOptionsRelease(ICMCompressionSessionOptionsRef options);
/*
* ICMCompressionSessionOptionsGetTypeID()
*
* Summary:
* Returns the CFTypeID for compression session options objects.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( CFTypeID )
ICMCompressionSessionOptionsGetTypeID(void);
/*
* ICMCompressionSessionOptionsGetPropertyInfo()
*
* Summary:
* Retrieves information about properties of a compression session
* options object.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressionSessionOptionsGetPropertyInfo(
ICMCompressionSessionOptionsRef options,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
ComponentValueType * outPropType, /* can be NULL */
ByteCount * outPropValueSize, /* can be NULL */
UInt32 * outPropertyFlags); /* can be NULL */
/*
* ICMCompressionSessionOptionsGetProperty()
*
* Summary:
* Retrieves the value of a specific property of a compression
* session options object.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressionSessionOptionsGetProperty(
ICMCompressionSessionOptionsRef options,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
ByteCount inPropValueSize,
ComponentValuePtr outPropValueAddress,
ByteCount * outPropValueSizeUsed); /* can be NULL */
/*
* ICMCompressionSessionOptionsSetProperty()
*
* Summary:
* Sets the value of a specific property of a compression session
* options object.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressionSessionOptionsSetProperty(
ICMCompressionSessionOptionsRef options,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
ByteCount inPropValueSize,
ConstComponentValuePtr inPropValueAddress);
/*
*/
enum {
/*
* Indicates no limit on the number of frames in the compression
* window.
*/
kICMUnlimitedFrameDelayCount = -1L,
/*
* Indicates no time limit on the number of frames in the compression
* window.
*/
kICMUnlimitedFrameDelayTime = -1L,
/*
* Indicates no CPU time limit on compression.
*/
kICMUnlimitedCPUTimeBudget = -1L
};
/*
* ICMDataRateLimit
*
* Summary:
* A hard limit on the data rate.
*
* Discussion:
* A hard limit is described by a data size in bytes and a duration
* in seconds, and requires that the total size of compressed data
* for any continuous segment of that duration (in decode time) must
* not exceed the provided data size.
*/
struct ICMDataRateLimit {
/*
* The number of bytes.
*/
SInt32 dataSize;
/*
* The number of seconds.
*/
Float32 dataDuration;
};
typedef struct ICMDataRateLimit ICMDataRateLimit;
/*
* Summary:
* Scaling modes
*
* Discussion:
* These constants indicate how source frames to a compression
* session should be scaled if the dimensions and/or display aspect
* ratio do not match.
*/
enum {
/*
* The full width and height of source frames shall be scaled to the
* full width and height of the destination. This is the default if
* no other scaling mode is specified.
*/
kICMScalingMode_StretchProductionAperture = FOUR_CHAR_CODE('sp2p'),
/*
* The clean aperture of the source frames shall be scaled to the
* clean aperture of the destination.
*/
kICMScalingMode_StretchCleanAperture = FOUR_CHAR_CODE('sc2c'),
/*
* The clean aperture of the source frames shall be scaled to fit
* inside the clean aperture of the destination, preserving the
* original display aspect ratio. If the display aspect ratios are
* different, the source frames will be centered with black bars
* above and below, or to the left and right.
*/
kICMScalingMode_Letterbox = FOUR_CHAR_CODE('lett'),
/*
* The clean aperture of the source frames shall be scaled to cover
* the clean aperture of the destination, preserving the original
* display aspect ratio. If the display aspect ratios are different,
* the source frames will be centered and cropped.
*/
kICMScalingMode_Trim = FOUR_CHAR_CODE('trim')
};
/*
* ICMSimpleBoundaryConditions
*
* Summary:
* Indicates whether and how a compression session's frames will be
* concatenated with other compressed frames to form a longer series.
*
* Discussion:
* Some clients divide a long series of frames into several shorter
* segments, each of which is then compressed by an independent
* compression session. Boundary conditions tell the compressor
* about how each session fits into the greater series: does this
* session stand alone, or will it be used to encode the first
* segment, a middle segment, or the last segment in a longer
* continuum?
* This information enables compressors to ensure that compressed
* segments can be concatenated smoothly -- for example, avoiding
* data rate spikes where segments are joined.
* By default, a session is assumed to stand alone.
*/
struct ICMSimpleBoundaryConditions {
/*
* True if frames compressed in a separate session will be
* concatenated before the beginning of this one. False if this is a
* stand-alone session, or if this session will encode the first
* segment of a multi-segment compression. By default, false.
*/
Boolean moreFramesBeforeStart;
/*
* True if frames compressed in a separate session will be
* concatenated following the end of this one. False if this is a
* stand-alone session, or if this session will encode the last
* segment of a multi-segment compression. By default, false.
*/
Boolean moreFramesAfterEnd;
};
typedef struct ICMSimpleBoundaryConditions ICMSimpleBoundaryConditions;
/*
* Summary:
* Properties of compression sessions options objects.
*/
enum {
/*
* Class identifier for compression session options object properties.
*/
kQTPropertyClass_ICMCompressionSessionOptions = FOUR_CHAR_CODE('icso'),
/*
* Enables temporal compression. By default, temporal compression is
* disabled.
* IMPORTANT: If you want temporal compression (P frames and/or B
* frames) you must set this to true.
*/
kICMCompressionSessionOptionsPropertyID_AllowTemporalCompression = FOUR_CHAR_CODE('p ok'), /* Boolean, Read/Write */
/*
* Enables frame reordering.
* In order to encode B frames, a compressor must reorder frames,
* which means that the order in which they will be emitted and
* stored (the decode order) is different from the order in which
* they were presented to the compressor (the display order).
* By default, frame reordering is disabled.
* IMPORTANT: In order to encode using B frames, you must enable
* frame reordering.
*/
kICMCompressionSessionOptionsPropertyID_AllowFrameReordering = FOUR_CHAR_CODE('b ok'), /* Boolean, Read/Write */
/*
* Indicates that durations of emitted frames are needed.
* If this flag is set and source frames are provided with times but
* not durations, then frames will be delayed so that durations can
* be calculated as the difference between one frame's time stamp and
* the next frame's time stamp.
* By default, this flag is clear, so frames will not be delayed in
* order to calculate durations.
* IMPORTANT: If you will be passing encoded frames to
* AddMediaSampleFromEncodedFrame, you must set this flag to true.
*/
kICMCompressionSessionOptionsPropertyID_DurationsNeeded = FOUR_CHAR_CODE('need'), /* Boolean, Read/Write */
/*
* The maximum interval between key frames, also known as the key
* frame rate.
* Key frames, also known as sync frames, reset inter-frame
* dependencies; decoding a key frame is sufficient to prepare a
* decompressor for correctly decoding the difference frames that
* follow.
* Compressors are allowed to generate key frames more frequently if
* this would result in more efficient compression.
* The default key frame interval is 0, which indicates that the
* compressor should choose where to place all key frames. A key
* frame interval of 1 indicates that every frame must be a key
* frame, 2 indicates that at least every other frame must be a key
* frame, etc.
*/
kICMCompressionSessionOptionsPropertyID_MaxKeyFrameInterval = FOUR_CHAR_CODE('kyfr'), /* SInt32, Read/Write */
/*
* The requested maximum interval between partial sync frames. If the
* interval is n, any sequence of n successive frames must include at
* least one key or partial sync frame.
* Where supported, partial sync frames perform a partial reset of
* inter-frame dependencies; decoding two partial sync frames and the
* non-droppable difference frames between them is sufficient to
* prepare a decompressor for correctly decoding the difference
* frames that follow.
* Compressors are allowed to generate partial sync frames more
* frequently if this would result in more efficient compression.
*
* The default partial sync frame interval is 0, which indicates that
* the compressor should choose where to place partial sync frames. A
* partial sync frame interval of 1 means there can be no difference
* frames, so it is equivalent to a key frame interval of 1. A
* partial sync frame interval of 2 means that every other frame must
* be a key frame or a partial sync frame.
* Compressors that do not support partial sync frames will ignore
* this setting.
*/
kICMCompressionSessionOptionsPropertyID_MaxPartialSyncFrameInterval = FOUR_CHAR_CODE('psfr'), /* SInt32, Read/Write */
/*
* Enables the compressor to modify frame times.
* Some compressors are able to identify and coalesce runs of
* identical frames and output single frames with longer duration, or
* output frames at a different frame rate from the original. This
* feature is controlled by the "allow frame time changes" flag. By
* default, this flag is set to false, which forces compressors to
* emit one encoded frame for every source frame, and to preserve
* frame display times.
* (Note: this feature replaces the practice of having compressors
* return special high similarity values to indicate that frames
* could be dropped.)
* If you want to allow the compressor to modify frame times in order
* to improve compression performance, enable frame time changes.
*/
kICMCompressionSessionOptionsPropertyID_AllowFrameTimeChanges = FOUR_CHAR_CODE('+ ok'), /* Boolean, Read/Write */
/*
* Enables the compressor to call the encoded-frame callback from a
* different thread.
* By default, the flag is false, which means that the compressor
* must call the encoded-frame callback from the same thread that
* ICMCompressionSessionEncodeFrame and
* ICMCompressionSessionCompleteFrames were called on.
*/
kICMCompressionSessionOptionsPropertyID_AllowAsyncCompletion = FOUR_CHAR_CODE('asok'), /* Boolean, Read/Write */
/*
* The maximum frame delay count is the maximum number of frames that
* a compressor is allowed to hold before it must output a compressed
* frame. It limits the number of frames that may be held in the
* "compression window". If the maximum frame delay count is M, then
* before the call to encode frame N returns, frame N-M must have
* been emitted.
* The default is kICMUnlimitedFrameDelayCount, which sets no limit
* on the compression window.
*/
kICMCompressionSessionOptionsPropertyID_MaxFrameDelayCount = FOUR_CHAR_CODE('cwin'), /* SInt32, Read/Write */
/*
* The maximum frame delay time is the maximum difference between a
* source frame's display time and the corresponding encoded frame's
* decode time. It limits the span of display time that may be held
* in the "compression window". If the maximum frame delay time is
* TM, then before the call to encode a frame with display time TN
* returns, all frames with display times up to and including TN-TM
* must have been emitted.
* The default is kICMUnlimitedFrameDelayTime, which sets no time
* limit on the compression window.
*/
kICMCompressionSessionOptionsPropertyID_MaxFrameDelayTime = FOUR_CHAR_CODE('cwit'), /* TimeValue64, Read/Write */
/*
* Sets a specific compressor component or component instance to be
* used, or one of the wildcards anyCodec, bestSpeedCodec,
* bestFidelityCodec, or bestCompressionCodec.
* Use this API to force the Image Compression Manager to use a
* specific compressor component or compressor component instance.
* (If you pass in a component instance that you opened, the ICM will
* not close that instance; you must do so after the compression
* session is released.) To allow the Image Compression Manager to
* choose the compressor component, set the compressorComponent to
* anyCodec (the default), bestSpeedCodec, bestFidelityCodec or
* bestCompressionCodec.
*/
kICMCompressionSessionOptionsPropertyID_CompressorComponent = FOUR_CHAR_CODE('imco'), /* CompressorComponent, Read/Write */
/*
* A handle containing compressor settings. The compressor will be
* configured with these settings (by a call to
* ImageCodecSetSettings) during ICMCompressionSessionCreate.
*/
kICMCompressionSessionOptionsPropertyID_CompressorSettings = FOUR_CHAR_CODE('cost'), /* Handle, Read/Write */
/*
* The depth for compression.
* If a compressor does not support a specific depth, the closest
* supported depth will be used (preferring deeper depths to
* shallower depths). The default depth is k24RGBPixelFormat.
*/
kICMCompressionSessionOptionsPropertyID_Depth = FOUR_CHAR_CODE('deep'), /* UInt32, Read/Write */
/*
* The color table for compression. Used with indexed-color depths.
*
* Clients who get this property are responsible for disposing the
* returned CTabHandle.
*/
kICMCompressionSessionOptionsPropertyID_ColorTable = FOUR_CHAR_CODE('clut'), /* CTabHandle, Read/Write*/
/*
* The compression quality.
* This value is always used to set the spatialQuality; if temporal
* compression is enabled, it is also used to set temporalQuality.
* <BR> The default quality is codecNormalQuality.
*/
kICMCompressionSessionOptionsPropertyID_Quality = FOUR_CHAR_CODE('qual'), /* CodecQ, Read/Write */
/*
* The long-term desired average data rate in bytes per second.
* This is not a hard limit.
* The default data rate is zero, which indicates that the quality
* setting should determine the size of compressed data.
* Note that data rate settings only have an effect when timing
* information is provided for source frames, and that some codecs do
* not support limiting to specified data rates.
*/
kICMCompressionSessionOptionsPropertyID_AverageDataRate = FOUR_CHAR_CODE('aver'), /* SInt32, Read/Write */
/*
* Zero, one or two hard limits on data rate.
* Each hard limit is described by a data size in bytes and a
* duration in seconds, and requires that the total size of
* compressed data for any contiguous segment of that duration (in
* decode time) must not exceed the data size.
* By default, no data rate limits are set.
* When setting this property, the inPropValueSize parameter should
* be the number of data rate limits multiplied by
* sizeof(ICMDataRateLimit).
* Note that data rate settings only have an effect when timing
* information is provided for source frames, and that some codecs do
* not support limiting to specified data rates.
*/
kICMCompressionSessionOptionsPropertyID_DataRateLimits = FOUR_CHAR_CODE('hard'), /* C array of ICMDataRateLimit struct, Read/Write */
/*
* The current number of data rate limits.
*/
kICMCompressionSessionOptionsPropertyID_DataRateLimitCount = FOUR_CHAR_CODE('har#'), /* UInt32, Read */
/*
* The maximum allowed number of data rate limits. (Currently 2.)
*/
kICMCompressionSessionOptionsPropertyID_MaxDataRateLimits = FOUR_CHAR_CODE('mhar'), /* UInt32, Read */
/*
* Indicates that the source was previously compressed.
* This property is purely an optional, informational hint to the
* compressor; by default it is false.
*/
kICMCompressionSessionOptionsPropertyID_WasCompressed = FOUR_CHAR_CODE('wasc'), /* Boolean, Read/Write */
/*
* Recommends a CPU time budget for the compressor in microseconds
* per frame.
* Zero means to go as fast as possible.
* By default, this is set to kICMUnlimitedCPUTimeBudget, which sets
* no limit.
* This is an advisory hint to the compressor, and some compressors
* may ignore it. Multithreaded compressors may use this amount of
* CPU time on each processor.
* Compressors should not feel compelled to use the full time budget
* if they complete ahead of time!
*/
kICMCompressionSessionOptionsPropertyID_CPUTimeBudget = FOUR_CHAR_CODE('cput'), /* UInt32, Read/Write */
/*
* Storage for multi-pass compression.
* To enable multipass compression, the client must provide a storage
* location for multipass data. Use
* ICMMultiPassStorageCreateWithTemporaryFile to have the ICM store
* it in a temporary file. Use
* ICMMultiPassStorageCreateWithCallbacks to manage the storage
* yourself.
* Note that the amount of multipass data to be stored can be
* substantial; it could be greater than the size of the output movie
* file.
* If this property is not NULL, the client must call
* ICMCompressionSessionBeginPass and ICMCompressionSessionEndPass
* around groups of calls to ICMCompressionSessionEncodeFrame.
* By default, this property is NULL and multipass compression is
* not enabled. The compression session options object retains the
* multipass storage object, when one is set.
*/
kICMCompressionSessionOptionsPropertyID_MultiPassStorage = FOUR_CHAR_CODE('imps'), /* ICMMultiPassStorageRef, Read/Write */
/*
* Indicates the number of source frames, if known. If nonzero, this
* should be the exact number of times that the client calls
* ICMCompressionSessionEncodeFrame in each pass.
* The default is 0, which indicates that the number of source frames
* is not known.
*/
kICMCompressionSessionOptionsPropertyID_SourceFrameCount = FOUR_CHAR_CODE('frco'), /* UInt64, Read/Write */
/*
* Indicates the expected frame rate, if known. The frame rate is
* measured in frames per second. This is not used to control the
* frame rate; it is provided as a hint to the compressor so that it
* can set up internal configuration before compression begins. The
* actual frame rate will depend on frame durations and may vary. By
* default, this is zero, indicating "unknown".
*/
kICMCompressionSessionOptionsPropertyID_ExpectedFrameRate = FOUR_CHAR_CODE('fran'), /* Fixed, Read/Write */
/*
* Indicates how source frames to a compression session should be
* scaled if the dimensions and/or display aspect ratio do not match.
*/
kICMCompressionSessionOptionsPropertyID_ScalingMode = FOUR_CHAR_CODE('scam'), /* OSType, Read/Write */
/*
* Describes the clean aperture for compressed frames. Note that if
* the compressor enforces a clean aperture, it will override this
* setting. The clean aperture will be set on the output image
* description and may affect scaling in some scaling modes. By
* default, this is all zeros, meaning unset.
*/
kICMCompressionSessionOptionsPropertyID_CleanAperture = FOUR_CHAR_CODE('clap'), /* Native-endian CleanApertureImageDescriptionExtension, Read/Write */
/*
* Describes the pixel aspect ratio for compressed frames. Note that
* if the compressor enforces a pixel aspect ratio, it will override
* this setting. The pixel aspect ratio will be set on the output
* image description and may affect scaling in some scaling modes. By
* default, this is all zeros, meaning unset.
*/
kICMCompressionSessionOptionsPropertyID_PixelAspectRatio = FOUR_CHAR_CODE('pasp'), /* Native-endian PixelAspectRatioImageDescriptionExtension, Read/Write */
/*
* Describes the number and order of fields for compressed frames.
* Note that if the compressor enforces field info, it will override
* this setting. The field info will be set on the output image
* description and may affect scaling in some scaling modes. By
* default, this is all zeros, meaning unset.
*/
kICMCompressionSessionOptionsPropertyID_FieldInfo = FOUR_CHAR_CODE('fiel'), /* FieldInfoImageDescriptionExtension2, Read/Write */
/*
* Indicates whether and how a compression session's frames will be
* concatenated with other compressed frames to form a longer series.
*/
kICMCompressionSessionOptionsPropertyID_SimpleBoundaryConditions = FOUR_CHAR_CODE('ends'), /* ICMSimpleBoundaryConditions struct, Read/Write */
/*
* Requests additional distortion to be applied to the aspect ratio
* in the kICMScalingMode_Letterbox and kICMScalingMode_Trim scaling
* modes. Values greater than fixed1 mean wider, values less than
* fixed1 mean narrower. For example, a value of X2Fix(2.0) would
* make the picture aspect ratio twice as wide.
*/
kICMCompressionSessionOptionsPropertyID_ExtraAspectRatioStretchFactor = FOUR_CHAR_CODE('exsf') /* Fixed, Default fixed1, Read/Write */
};
/*
* ICMCompressionSessionOptionsSetAllowTemporalCompression()
*
* Summary:
* Enables temporal compression.
*
* Discussion:
* By default, temporal compression is disabled.
* IMPORTANT: If you want temporal compression (P frames and/or B
* frames) you must set this to true.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressionSessionOptionsSetAllowTemporalCompression(
ICMCompressionSessionOptionsRef options,
Boolean allowTemporalCompression);
/*
* ICMCompressionSessionOptionsGetAllowTemporalCompression()
*
* Summary:
* Retrieves the allow temporal compression flag.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( Boolean )
ICMCompressionSessionOptionsGetAllowTemporalCompression(ICMCompressionSessionOptionsRef options);
/*
* ICMCompressionSessionOptionsSetAllowFrameReordering()
*
* Summary:
* Enables frame reordering.
*
* Discussion:
* In order to encode B frames, a compressor must reorder frames,
* which means that the order in which they will be emitted and
* stored (the decode order) is different from the order in which
* they were presented to the compressor (the display order).
* By default, frame reordering is disabled.
* IMPORTANT: In order to encode using B frames, you must enable
* frame reordering.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressionSessionOptionsSetAllowFrameReordering(
ICMCompressionSessionOptionsRef options,
Boolean allowFrameReordering);
/*
* ICMCompressionSessionOptionsGetAllowFrameReordering()
*
* Summary:
* Retrieves the allow frame reordering flag.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( Boolean )
ICMCompressionSessionOptionsGetAllowFrameReordering(ICMCompressionSessionOptionsRef options);
/*
* ICMCompressionSessionOptionsSetDurationsNeeded()
*
* Summary:
* Indicates that durations of emitted frames are needed.
*
* Discussion:
* If this flag is set and source frames are provided with times but
* not durations, then frames will be delayed so that durations can
* be calculated as the difference between one frame's time stamp
* and the next frame's time stamp.
* By default, this flag is clear, so frames will not be delayed in
* order to calculate durations.
* IMPORTANT: If you will be passing encoded frames to
* AddMediaSampleFromEncodedFrame, you must set this flag to true.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressionSessionOptionsSetDurationsNeeded(
ICMCompressionSessionOptionsRef options,
Boolean decodeDurationsNeeded);
/*
* ICMCompressionSessionOptionsGetDurationsNeeded()
*
* Summary:
* Retrieves the "durations needed" flag.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( Boolean )
ICMCompressionSessionOptionsGetDurationsNeeded(ICMCompressionSessionOptionsRef options);
/*
* ICMCompressionSessionOptionsSetMaxKeyFrameInterval()
*
* Summary:
* Sets the maximum interval between key frames (also known as the
* key frame rate).
*
* Discussion:
* Compressors are allowed to generate key frames more frequently if
* this would result in more efficient compression.
* The default key frame interval is 0, which indicates that the
* compressor should choose where to place all key frames.
* (Note: this is a break with previous practice, which used a key
* frame rate of zero to disable temporal compression.)
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressionSessionOptionsSetMaxKeyFrameInterval(
ICMCompressionSessionOptionsRef options,
SInt32 maxKeyFrameInterval);
/*
* ICMCompressionSessionOptionsGetMaxKeyFrameInterval()
*
* Summary:
* Retrieves the maximum key frame interval.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( SInt32 )
ICMCompressionSessionOptionsGetMaxKeyFrameInterval(ICMCompressionSessionOptionsRef options);
/*
* ICMCompressionSessionOptionsSetAllowFrameTimeChanges()
*
* Summary:
* Enables the compressor to modify frame times.
*
* Discussion:
* Some compressors are able to identify and coalesce runs of
* identical frames and output single frames with longer duration,
* or output frames at a different frame rate from the original.
* This feature is controlled by the "allow frame time changes"
* flag. By default, this flag is set to false, which forces
* compressors to emit one encoded frame for every source frame, and
* to preserve frame display times.
* (Note: this feature replaces the practice of having compressors
* return special high similarity values to indicate that frames
* could be dropped.)
* If you want to allow the compressor to modify frame times in
* order to improve compression performance, enable frame time
* changes.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressionSessionOptionsSetAllowFrameTimeChanges(
ICMCompressionSessionOptionsRef options,
Boolean allowFrameTimeChanges);
/*
* ICMCompressionSessionOptionsGetAllowFrameTimeChanges()
*
* Summary:
* Retrieves the allow frame time changes flag.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( Boolean )
ICMCompressionSessionOptionsGetAllowFrameTimeChanges(ICMCompressionSessionOptionsRef options);
/* ICMMultiPassStorageRef routines */
/*
* ICMMultiPassStorageCreationFlags
*
*/
typedef UInt32 ICMMultiPassStorageCreationFlags;
enum {
/*
* Indicates that the temporary file should not be deleted when the
* multipass storage is released.
*/
kICMMultiPassStorage_DoNotDeleteWhenDone = 1L << 0
};
/*
* ICMMultiPassStorageCreateWithTemporaryFile()
*
* Summary:
* Creates a multipass storage using a temporary file.
*
* Discussion:
* If you pass NULL for directoryRef, the ICM will use the user's
* temporary items folder.
* If you pass NULL for fileName, the ICM will pick a unique name.
*
* The file will be deleted when the multipass storage is released,
* unless you set the kICMMultiPassStorage_DoNotDeleteWhenDone flag.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMMultiPassStorageCreateWithTemporaryFile(
CFAllocatorRef allocator, /* can be NULL */
FSRef * directoryRef, /* can be NULL */
CFStringRef fileName, /* can be NULL */
ICMMultiPassStorageCreationFlags flags,
ICMMultiPassStorageRef * multiPassStorageOut);
/*
* ICMMultiPassStorageStep
*
* Summary:
* Indicates a jump in time stamps used to index multipass storage.
*/
typedef UInt32 ICMMultiPassStorageStep;
enum {
/*
* Requests the first time stamp at which a value is stored.
*/
kICMMultiPassStorage_GetFirstTimeStamp = 1,
/*
* Requests the previous time stamp before the given time stamp at
* which a value is stored.
*/
kICMMultiPassStorage_GetPreviousTimeStamp = 2,
/*
* Requests the next time stamp after the given time stamp at which a
* value is stored.
*/
kICMMultiPassStorage_GetNextTimeStamp = 3,
/*
* Requests the last time stamp at which a value is stored.
*/
kICMMultiPassStorage_GetLastTimeStamp = 4
};
/*
* ICMMultiPassSetDataAtTimeStampCallback
*
* Summary:
* Stores a value at a given time stamp.
*
* Discussion:
* The new data should replace any previous data held at that
* timestamp with that index.
*
* Parameters:
*
* storageRefCon:
* The callbacks' reference value.
*
* timeStamp:
* The time stamp at which the value should be stored.
*
* index:
* An index by which multiple values may be stored at a time
* stamp. The meaning of individual indexes is private to the
* compressor.
*
* data:
* The data to be stored, or NULL to delete the value. The
* contents are private to the compressor component.
*/
typedef CALLBACK_API_C( OSStatus , ICMMultiPassSetDataAtTimeStampCallback )(void *storageRefCon, TimeValue64 timeStamp, long index, CFDataRef data);
/*
* ICMMultiPassGetTimeStampCallback
*
* Summary:
* Retrieves a time stamp for which a value is stored.
*
* Parameters:
*
* storageRefCon:
* The callbacks' reference value.
*
* fromTimeStamp:
* The initial time stamp. Ignored for some values of step.
*
* step:
* Indicates the kind of time stamp search to perform.
*
* timeStampOut:
* Points to a TimeValue64 to receive the found time stamp. Set to
* -1 if no time stamp is found.
*/
typedef CALLBACK_API_C( OSStatus , ICMMultiPassGetTimeStampCallback )(void *storageRefCon, TimeValue64 fromTimeStamp, ICMMultiPassStorageStep step, TimeValue64 *timeStampOut);
/*
* ICMMultiPassCopyDataAtTimeStampCallback
*
* Summary:
* Retrieves a value at a given time stamp and index.
*
* Parameters:
*
* storageRefCon:
* The callbacks' reference value.
*
* timeStamp:
* The time stamp at which the value should be retrieved.
*
* index:
* An index by which multiple values may be stored at a time
* stamp. The meaning of individual indexes is private to the
* compressor.
*
* dataOut:
* Points to a variable to receive the value. Set to a
* newly-created CFMutableData containing the value for the given
* time stamp and index, or set to NULL if no value is at that
* time stamp and index. It will be the callers responsibility to
* release the CFMutableData.
*/
typedef CALLBACK_API_C( OSStatus , ICMMultiPassCopyDataAtTimeStampCallback )(void *storageRefCon, TimeValue64 timeStamp, long index, CFMutableDataRef *dataOut);
/*
* ICMMultiPassReleaseCallback
*
* Summary:
* Called when the multipass storage's retain count drops to zero.
*
* Parameters:
*
* storageRefCon:
* The callbacks' reference value.
*/
typedef CALLBACK_API_C( OSStatus , ICMMultiPassReleaseCallback )(void * storageRefCon);
/*
* ICMMultiPassStorageCallbacks
*
* Summary:
* A collection of callbacks for creating a custom multipass storage
* object.
*/
struct ICMMultiPassStorageCallbacks {
/*
* The version of the struct. Set to
* kICMMultiPassStorageCallbacksVersionOne.
*/
UInt32 version;
/*
* The callbacks' reference value.
*/
void * storageRefCon;
/*
* The callback for storing values.
*/
ICMMultiPassSetDataAtTimeStampCallback setDataAtTimeStampCallback;
/*
* The callback for finding time stamps.
*/
ICMMultiPassGetTimeStampCallback getTimeStampCallback;
/*
* The callback for retrieving values.
*/
ICMMultiPassCopyDataAtTimeStampCallback copyDataAtTimeStampCallback;
/*
* The callback for disposing the callback's state when done.
*/
ICMMultiPassReleaseCallback releaseCallback;
};
typedef struct ICMMultiPassStorageCallbacks ICMMultiPassStorageCallbacks;
enum {
kICMMultiPassStorageCallbacksVersionOne = 1
};
/*
* ICMMultiPassStorageCreateWithCallbacks()
*
* Summary:
* Assembles a multipass storage mechanism from callbacks.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMMultiPassStorageCreateWithCallbacks(
CFAllocatorRef allocator, /* can be NULL */
ICMMultiPassStorageCallbacks * callbacks,
ICMMultiPassStorageRef * multiPassStorageOut);
/*
* ICMMultiPassStorageRetain()
*
* Summary:
* Increments the retain count of a multipass storage object.
*
* Discussion:
* If you pass NULL to this function, nothing happens.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( ICMMultiPassStorageRef )
ICMMultiPassStorageRetain(ICMMultiPassStorageRef multiPassStorage);
/*
* ICMMultiPassStorageRelease()
*
* Summary:
* Decrements the retain count of a multipass storage object. If it
* drops to zero, the object is disposed.
*
* Discussion:
* If you pass NULL to this function, nothing happens.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( void )
ICMMultiPassStorageRelease(ICMMultiPassStorageRef multiPassStorage);
/*
* ICMMultiPassStorageGetTypeID()
*
* Summary:
* Returns the CFTypeID for multipass storage objects.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( CFTypeID )
ICMMultiPassStorageGetTypeID(void);
/* ICMCompressionFrameOptionsRef routines */
/*
* ICMCompressionFrameOptionsCreate()
*
* Summary:
* Creates a frame compression options object.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressionFrameOptionsCreate(
CFAllocatorRef allocator, /* can be NULL */
ICMCompressionSessionRef session,
ICMCompressionFrameOptionsRef * options);
/*
* ICMCompressionFrameOptionsCreateCopy()
*
* Summary:
* Copies a frame compression options object.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressionFrameOptionsCreateCopy(
CFAllocatorRef allocator, /* can be NULL */
ICMCompressionFrameOptionsRef originalOptions,
ICMCompressionFrameOptionsRef * copiedOptions);
/*
* ICMCompressionFrameOptionsRetain()
*
* Summary:
* Increments the retain count of a frame compression options object.
*
* Discussion:
* If you pass NULL to this function, nothing happens.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( ICMCompressionFrameOptionsRef )
ICMCompressionFrameOptionsRetain(ICMCompressionFrameOptionsRef options);
/*
* ICMCompressionFrameOptionsRelease()
*
* Summary:
* Decrements the retain count of a frame compression options
* object. If it drops to zero, the object is disposed.
*
* Discussion:
* If you pass NULL to this function, nothing happens.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( void )
ICMCompressionFrameOptionsRelease(ICMCompressionFrameOptionsRef options);
/*
* ICMCompressionFrameOptionsGetTypeID()
*
* Summary:
* Returns the CFTypeID for frame compression options objects.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( CFTypeID )
ICMCompressionFrameOptionsGetTypeID(void);
/*
* ICMCompressionFrameOptionsGetPropertyInfo()
*
* Summary:
* Retrieves information about properties of a compression frame
* options object.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressionFrameOptionsGetPropertyInfo(
ICMCompressionFrameOptionsRef options,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
ComponentValueType * outPropType, /* can be NULL */
ByteCount * outPropValueSize, /* can be NULL */
UInt32 * outPropertyFlags); /* can be NULL */
/*
* ICMCompressionFrameOptionsGetProperty()
*
* Summary:
* Retrieves the value of a specific property of a compression frame
* options object.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressionFrameOptionsGetProperty(
ICMCompressionFrameOptionsRef options,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
ByteCount inPropValueSize,
ComponentValuePtr outPropValueAddress,
ByteCount * outPropValueSizeUsed); /* can be NULL */
/*
* ICMCompressionFrameOptionsSetProperty()
*
* Summary:
* Sets the value of a specific property of a compression frame
* options object.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressionFrameOptionsSetProperty(
ICMCompressionFrameOptionsRef options,
ComponentPropertyClass inPropClass,
ComponentPropertyID inPropID,
ByteCount inPropValueSize,
ConstComponentValuePtr inPropValueAddress);
/*
* Summary:
* Properties of compression frame options objects.
*/
enum {
/*
* Class identifier for compression frame options object properties.
*/
kQTPropertyClass_ICMCompressionFrameOptions = FOUR_CHAR_CODE('icfo'),
/*
* Forces frames to be compressed as key frames.
* The compressor must obey the "force key frame" flag if set. By
* default this property is false.
*/
kICMCompressionFrameOptionsPropertyID_ForceKeyFrame = FOUR_CHAR_CODE('keyf'), /* Boolean, Read/Write */
/*
* Requests a frame be compressed as a particular frame type.
* The frame type setting may be ignored by the compressor if not
* appropriate.
* By default this is set to kICMFrameType_Unknown.
* Do not assume that kICMFrameType_I means a key frame; if you need
* a key frame, set the "force key frame" property.
*/
kICMCompressionFrameOptionsPropertyID_FrameType = FOUR_CHAR_CODE('frty') /* ICMFrameType, Read/Write */
};
/*
* ICMCompressionFrameOptionsSetForceKeyFrame()
*
* Summary:
* Forces frames to be compressed as key frames.
*
* Discussion:
* The compressor must obey the "force key frame" flag if set. By
* default this is set false.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressionFrameOptionsSetForceKeyFrame(
ICMCompressionFrameOptionsRef options,
Boolean forceKeyFrame);
/*
* ICMCompressionFrameOptionsGetForceKeyFrame()
*
* Summary:
* Retrieves the "force key frame" flag.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( Boolean )
ICMCompressionFrameOptionsGetForceKeyFrame(ICMCompressionFrameOptionsRef options);
/*
* ICMCompressionFrameOptionsSetFrameType()
*
* Summary:
* Requests a frame be compressed as a particular frame type.
*
* Discussion:
* The frame type setting may be ignored by the compressor if not
* appropriate.
* By default this is set to kICMFrameType_Unknown.
* Do not assume that kICMFrameType_I means a key frame; if you need
* a key frame, set forceKeyFrame.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressionFrameOptionsSetFrameType(
ICMCompressionFrameOptionsRef options,
ICMFrameType frameType);
/*
* ICMCompressionFrameOptionsGetFrameType()
*
* Summary:
* Retrieves the frame type setting.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( ICMFrameType )
ICMCompressionFrameOptionsGetFrameType(ICMCompressionFrameOptionsRef options);
/* ICMEncodedFrameRef routines */
/*
* ICMEncodedFrameRetain()
*
* Summary:
* Increments the retain count of an encoded frame object.
*
* Discussion:
* If you pass NULL to this function, nothing happens.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( ICMEncodedFrameRef )
ICMEncodedFrameRetain(ICMEncodedFrameRef frame);
/*
* ICMEncodedFrameRelease()
*
* Summary:
* Decrements the retain count of an encoded frame object. If it
* drops to zero, the object is disposed.
*
* Discussion:
* If you pass NULL to this function, nothing happens.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( void )
ICMEncodedFrameRelease(ICMEncodedFrameRef frame);
/*
* ICMEncodedFrameGetTypeID()
*
* Summary:
* Returns the CFTypeID for encoded frame objects.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( CFTypeID )
ICMEncodedFrameGetTypeID(void);
/*
* ICMEncodedFrameGetDataPtr()
*
* Summary:
* Gets the data buffer.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( UInt8 * )
ICMEncodedFrameGetDataPtr(ICMEncodedFrameRef frame);
/*
* ICMEncodedFrameGetBufferSize()
*
* Summary:
* Gets the size of the data buffer.
*
* Discussion:
* This is the physical size of the buffer.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( ByteCount )
ICMEncodedFrameGetBufferSize(ICMEncodedFrameRef frame);
/*
* ICMEncodedFrameGetDataSize()
*
* Summary:
* Gets the data size of the compressed frame in the buffer.
*
* Discussion:
* This is the logical size of the frame data. It may be less than
* the physical size of the buffer.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( ByteCount )
ICMEncodedFrameGetDataSize(ICMEncodedFrameRef frame);
/*
* ICMEncodedFrameSetDataSize()
*
* Summary:
* Sets the data size of the compressed frame in the buffer.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMEncodedFrameSetDataSize(
ICMMutableEncodedFrameRef frame,
ByteCount dataSize);
/*
* ICMEncodedFrameGetDecodeNumber()
*
* Summary:
* Retrieves the decode number.
*
* Discussion:
* The ICM automatically stamps ascending decode numbers on frames
* after the compressor emits them. The first decode number in a
* session is 1.
* Note: Compressors should not call this function.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( UInt32 )
ICMEncodedFrameGetDecodeNumber(ICMEncodedFrameRef frame);
/*
* ICMEncodedFrameGetTimeScale()
*
* Summary:
* Retrieves the timescale.
*
* Discussion:
* This is always the same as the timescale of the compression
* session.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( TimeScale )
ICMEncodedFrameGetTimeScale(ICMEncodedFrameRef frame);
/*
* ICMEncodedFrameGetImageDescription()
*
* Summary:
* Retrieves the image description.
*
* Discussion:
* Returns the same image description handle as
* ICMCompressionSessionGetImageDescription.
* IMPORTANT: The caller should NOT dispose this handle.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMEncodedFrameGetImageDescription(
ICMEncodedFrameRef frame,
ImageDescriptionHandle * imageDescOut);
/*
* ICMEncodedFrameGetValidTimeFlags()
*
* Summary:
* Retrieves flags indicating which of the time stamps and durations
* are valid.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( ICMValidTimeFlags )
ICMEncodedFrameGetValidTimeFlags(ICMEncodedFrameRef frame);
/*
* ICMEncodedFrameGetDecodeTimeStamp()
*
* Summary:
* Retrieves the frame's decode time stamp.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( TimeValue64 )
ICMEncodedFrameGetDecodeTimeStamp(ICMEncodedFrameRef frame);
/*
* ICMEncodedFrameGetDisplayTimeStamp()
*
* Summary:
* Retrieves the frame's display time stamp.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( TimeValue64 )
ICMEncodedFrameGetDisplayTimeStamp(ICMEncodedFrameRef frame);
/*
* ICMEncodedFrameGetDisplayOffset()
*
* Summary:
* Retrieves the frame's display offset, which is the offset from
* decode time stamp to display time stamp.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( TimeValue64 )
ICMEncodedFrameGetDisplayOffset(ICMEncodedFrameRef frame);
/*
* ICMEncodedFrameGetDecodeDuration()
*
* Summary:
* Retrieves the frame's decode duration.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( TimeValue64 )
ICMEncodedFrameGetDecodeDuration(ICMEncodedFrameRef frame);
/*
* ICMEncodedFrameGetDisplayDuration()
*
* Summary:
* Retrieves the frame's display duration.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( TimeValue64 )
ICMEncodedFrameGetDisplayDuration(ICMEncodedFrameRef frame);
/*
* ICMEncodedFrameSetValidTimeFlags()
*
* Summary:
* Sets flags that indicate which of the time stamps and durations
* are valid.
*
* Discussion:
* Note that setting the (decode/display) (timestamp/duration)
* automatically sets the corresponding valid time flags. For
* example, calling ICMEncodedFrameSetDecodeTimeStamp sets
* kICMValidTime_DisplayTimeStampIsValid. If both decode timestamp
* and display timestamp are valid,
* kICMValidTime_DisplayOffsetIsValid is automatically set.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMEncodedFrameSetValidTimeFlags(
ICMMutableEncodedFrameRef frame,
ICMValidTimeFlags validTimeFlags);
/*
* ICMEncodedFrameSetDecodeTimeStamp()
*
* Summary:
* Sets the decode time stamp.
*
* Discussion:
* This automatically sets the kICMValidTime_DecodeTimeStampIsValid
* flag. If the display timestamp is valid, it also sets the
* kICMValidTime_DisplayOffsetIsValid flag.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMEncodedFrameSetDecodeTimeStamp(
ICMMutableEncodedFrameRef frame,
TimeValue64 decodeTimeStamp);
/*
* ICMEncodedFrameSetDisplayTimeStamp()
*
* Summary:
* Sets the display time stamp.
*
* Discussion:
* This automatically sets the kICMValidTime_DisplayTimeStampIsValid
* flag. If the decode timestamp is valid, it also sets the
* kICMValidTime_DisplayOffsetIsValid flag.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMEncodedFrameSetDisplayTimeStamp(
ICMMutableEncodedFrameRef frame,
TimeValue64 displayTimeStamp);
/*
* ICMEncodedFrameSetDecodeDuration()
*
* Summary:
* Sets the decode duration.
*
* Discussion:
* This automatically sets the kICMValidTime_DecodeDurationIsValid
* flag.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMEncodedFrameSetDecodeDuration(
ICMMutableEncodedFrameRef frame,
TimeValue64 decodeDuration);
/*
* ICMEncodedFrameSetDisplayDuration()
*
* Summary:
* Sets the display duration.
*
* Discussion:
* This automatically sets the kICMValidTime_DisplayDurationIsValid
* flag.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMEncodedFrameSetDisplayDuration(
ICMMutableEncodedFrameRef frame,
TimeValue64 displayDuration);
/*
* ICMEncodedFrameGetMediaSampleFlags()
*
* Summary:
* Retrieves the media sample flags for an encoded frame.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( MediaSampleFlags )
ICMEncodedFrameGetMediaSampleFlags(ICMEncodedFrameRef frame);
/*
* ICMEncodedFrameSetMediaSampleFlags()
*
* Summary:
* Sets the media sample flags for an encoded frame.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMEncodedFrameSetMediaSampleFlags(
ICMMutableEncodedFrameRef frame,
MediaSampleFlags mediaSampleFlags);
/*
* ICMEncodedFrameGetFrameType()
*
* Summary:
* Retrieves the frame type for an encoded frame.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( ICMFrameType )
ICMEncodedFrameGetFrameType(ICMEncodedFrameRef frame);
/*
* ICMEncodedFrameSetFrameType()
*
* Summary:
* Sets the frame type for an encoded frame.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMEncodedFrameSetFrameType(
ICMMutableEncodedFrameRef frame,
ICMFrameType frameType);
/*
* ICMEncodedFrameGetSimilarity()
*
* Summary:
* Retrieves the similarity for an encoded frame.
*
* Discussion:
* 1.0 means identical. 0.0 means not at all alike. By default,
* this is set to -1.0, which means unknown.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( Float32 )
ICMEncodedFrameGetSimilarity(ICMEncodedFrameRef frame);
/*
* ICMEncodedFrameSetSimilarity()
*
* Summary:
* Sets the similarity for an encoded frame.
*
* Discussion:
* 1.0 means identical. 0.0 means not at all alike.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMEncodedFrameSetSimilarity(
ICMMutableEncodedFrameRef frame,
Float32 similarity);
/*
* ICMEncodedFrameGetSourceFrameRefCon()
*
* Summary:
* Retrieves the source frame reference value.
*
* Discussion:
* This is copied from the sourceFrameRefCon parameter to
* ICMCompressionSessionEncodeFrame.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( void * )
ICMEncodedFrameGetSourceFrameRefCon(ICMEncodedFrameRef frame);
/* ICMCompressorSession interface for compressor components */
/*
* ICMCompressorSessionRef
*
* Summary:
* Represents the session between the ICM and an image compressor
* component.
*
* Discussion:
* (Do not confuse this with ICMCompressionSessionRef, which is the
* session between the client and the ICM.) Note: compressors do not
* need to make any retain or release calls on this token.
*/
typedef struct OpaqueICMCompressorSession* ICMCompressorSessionRef;
/*
* ICMCompressorSourceFrameRef
*
* Summary:
* An opaque token that represents a frame that has been passed to
* ICMCompressionSessionEncodeFrame.
*
* Discussion:
* Such tokens are passed to the compressor component, which may
* retain a window of them in order to perform out-of-order encoding.
*/
typedef struct OpaqueICMCompressorSourceFrame* ICMCompressorSourceFrameRef;
/*
* ICMCompressorSourceFrameRetain()
*
* Summary:
* Increments the retain count of a source frame object.
*
* Discussion:
* If you pass NULL to this function, nothing happens.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( ICMCompressorSourceFrameRef )
ICMCompressorSourceFrameRetain(ICMCompressorSourceFrameRef sourceFrame);
/*
* ICMCompressorSourceFrameRelease()
*
* Summary:
* Decrements the retain count of a source frame object. If it
* drops to zero, the object is disposed.
*
* Discussion:
* If you pass NULL to this function, nothing happens.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( void )
ICMCompressorSourceFrameRelease(ICMCompressorSourceFrameRef sourceFrame);
/*
* ICMCompressorSourceFrameGetTypeID()
*
* Summary:
* Returns the CFTypeID for source frame objects.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( CFTypeID )
ICMCompressorSourceFrameGetTypeID(void);
/*
* ICMCompressorSourceFrameGetPixelBuffer()
*
* Summary:
* Retrieves a source frame's pixel buffer.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( CVPixelBufferRef )
ICMCompressorSourceFrameGetPixelBuffer(ICMCompressorSourceFrameRef sourceFrame);
/*
* ICMCompressorSourceFrameGetDisplayNumber()
*
* Summary:
* Retrieves a source frame's display number.
*
* Discussion:
* The ICM tags source frames with display numbers in the order they
* are passed to ICMCompressionSessionEncodeFrame; the first display
* number is 1. Compressors may compare these numbers to work out
* whether prediction is forward or backward even when display times
* are not provided.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( long )
ICMCompressorSourceFrameGetDisplayNumber(ICMCompressorSourceFrameRef sourceFrame);
/*
* ICMCompressorSourceFrameGetDisplayTimeStampAndDuration()
*
* Summary:
* Retrieves the display time stamp and duration of a source frame.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressorSourceFrameGetDisplayTimeStampAndDuration(
ICMCompressorSourceFrameRef sourceFrame,
TimeValue64 * displayTimeStampOut, /* can be NULL */
TimeValue64 * displayDurationOut, /* can be NULL */
TimeScale * timeScaleOut, /* can be NULL */
ICMValidTimeFlags * validTimeFlagsOut); /* can be NULL */
/*
* ICMCompressorSourceFrameGetFrameOptions()
*
* Summary:
* Retrieves the frame compression options for a source frame.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( ICMCompressionFrameOptionsRef )
ICMCompressorSourceFrameGetFrameOptions(ICMCompressorSourceFrameRef sourceFrame);
/*
* ICMCompressorSourceFrameDetachPixelBuffer()
*
* Summary:
* Disconnects the pixel buffer from the source frame and allows it
* to be released.
*
* Discussion:
* Compressor components often need to hold onto
* ICMCompressorSourceFrameRefs for some time after they are done
* with the pixel buffers. In order to allow pixel buffer memory to
* be released earlier, they may call
* ICMCompressorSourceFrameDetachPixelBuffer to declare that they
* have no further need for the source frame's pixel buffer. After
* calling this, ICMCompressorSourceFrameGetPixelBuffer will return
* NULL.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressorSourceFrameDetachPixelBuffer(ICMCompressorSourceFrameRef sourceFrame);
/*
* ICMCompressorSessionDropFrame()
*
* Summary:
* Called by a compressor to indicate that sourceFrame has been
* dropped and will not contribute to any encoded frames.
*
* Discussion:
* Calling this function does not automatically release the source
* frame; if the compressor called ICMCompressorSourceFrameRetain it
* should still call ICMCompressorSourceFrameRelease.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressorSessionDropFrame(
ICMCompressorSessionRef session,
ICMCompressorSourceFrameRef sourceFrame);
/*
* ICMCompressorSessionEmitEncodedFrame()
*
* Summary:
* Called by a compressor to output an encoded frame corresponding
* to one (or more) source frames.
*
* Discussion:
* (Encoded frames may only correspond to more than one source frame
* if allowFrameTimeChanges is set in the
* compressionSessionOptions.)
* After calling this, the compressor should release the encoded
* frame by calling ICMEncodedFrameRelease.
* Calling this function does not automatically release the source
* frames; if the compressor called ICMCompressorSourceFrameRetain
* it should still call ICMCompressorSourceFrameRelease.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMCompressorSessionEmitEncodedFrame(
ICMCompressorSessionRef session,
ICMMutableEncodedFrameRef encodedFrame,
long numberOfSourceFrames,
ICMCompressorSourceFrameRef sourceFrames[]);
/*
* ICMEncodedFrameCreateMutable()
*
* Summary:
* Called by a compressor to create an encoded-frame token
* corresponding to a given source frame.
*
* Discussion:
* The encoded frame will initially have zero mediaSampleFlags; if
* the frame is not a key frame, the compressor must call
* ICMEncodedFrameSetMediaSampleFlags to set mediaSampleNotSync. If
* the frame is droppable, the compressor should set
* mediaSampleDroppable. If the frame is a partial key frame, the
* compressor should set mediaSamplePartialSync.
* The encoded frame will initially have undefined decodeTimeStamp
* and decodeDuration. The compressor may set these directly by
* calling ICMEncodedFrameSetDecodeTimeStamp and/or
* ICMEncodedFrameSetDecodeDuration. If these are not set by the
* compressor, the ICM will attempt to derive them.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMEncodedFrameCreateMutable(
ICMCompressorSessionRef session,
ICMCompressorSourceFrameRef sourceFrame,
ByteCount bufferSize,
ICMMutableEncodedFrameRef * frameOut);
/* Multi-pass storage access routines for compressor components */
/*
* ICMMultiPassStorageSetDataAtTimeStamp()
*
* Summary:
* Called by a multipass-capable compressor to store data at a given
* timestamp.
*
* Discussion:
* The new data replaces any previous data held at that timestamp.
* If data is NULL, the data for that timestamp is deleted. The
* format of the data is private to the compressor.
*
* Parameters:
*
* multiPassStorage:
* The multipass storage object.
*
* timeStamp:
* The time stamp at which the value should be stored.
*
* index:
* An index by which multiple values may be stored at a time
* stamp. The meaning of individual indexes is private to the
* compressor.
*
* data:
* The data to be stored, or NULL to delete the value.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMMultiPassStorageSetDataAtTimeStamp(
ICMMultiPassStorageRef multiPassStorage,
TimeValue64 timeStamp,
long index,
CFDataRef data);
/*
* ICMMultiPassStorageGetTimeStamp()
*
* Summary:
* Called by a multipass-capable compressor to retrieve a time stamp
* for which a value is stored.
*
* Parameters:
*
* multiPassStorage:
* The multipass storage object.
*
* fromTimeStamp:
* The initial time stamp. Ignored for some values of step.
*
* step:
* Indicates the kind of time stamp search to perform.
*
* timeStampOut:
* Points to a TimeValue64 to receive the found time stamp. It
* will be set to -1 if no time stamp is found.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMMultiPassStorageGetTimeStamp(
ICMMultiPassStorageRef multiPassStorage,
TimeValue64 fromTimeStamp,
ICMMultiPassStorageStep step,
TimeValue64 * timeStampOut);
/*
* ICMMultiPassStorageCopyDataAtTimeStamp()
*
* Summary:
* Called by a multipass-capable compressor to retrieve data at a
* given timestamp.
*
* Parameters:
*
* multiPassStorage:
* The multipass storage object.
*
* timeStamp:
* The time stamp at which the value should be retrieved.
*
* index:
* An index by which multiple values may be stored at a time
* stamp. The meaning of individual indexes is private to the
* compressor.
*
* dataOut:
* Points to a CFMutableDataRef to receive the value. It will be
* set to a newly-created CFMutableData containing the value for
* the given time stamp and index, or set to NULL if no value is
* at that time stamp and index. It is the caller's responsibility
* to release the CFMutableData.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
ICMMultiPassStorageCopyDataAtTimeStamp(
ICMMultiPassStorageRef multiPassStorage,
TimeValue64 timeStamp,
long index,
CFMutableDataRef * dataOut);
#if TARGET_OS_MAC
/*
* kQTVisualContextTypeKey
*
* Summary:
* Read-only CFStringRef: Type of the visual context.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
extern const CFStringRef kQTVisualContextTypeKey;
/*
* kQTVisualContextType_PixelBuffer
*
* Summary:
* Value for kQTVisualContextTypeKey for pixel buffer visual
* contexts.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
extern const CFStringRef kQTVisualContextType_PixelBuffer;
/*
* kQTVisualContextType_OpenGLTexture
*
* Summary:
* Value for kQTVisualContextTypeKey for OpenGL texture visual
* contexts.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
extern const CFStringRef kQTVisualContextType_OpenGLTexture;
/*
* kQTVisualContextWorkingColorSpaceKey
*
* Summary:
* CGColorSpaceRef: Color space in which QuickTime will perform
* image processing. If this attribute is not set, images will be
* processed in the output color space.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
extern const CFStringRef kQTVisualContextWorkingColorSpaceKey;
/*
* kQTVisualContextOutputColorSpaceKey
*
* Summary:
* CGColorSpaceRef: Color space of images produced by this visual
* context. If this attribute is not set, images may be in any color
* space.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
extern const CFStringRef kQTVisualContextOutputColorSpaceKey;
/*
* kQTVisualContextExpectedReadAheadKey
*
* Summary:
* CFNumberRef: Number of seconds ahead of real-time that the client
* expects to pull images out of the visual context. Applications
* using the CoreVideo display link should set this attribute
* according to value returned from
* CVDisplayLinkGetOutputVideoLatency().
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
extern const CFStringRef kQTVisualContextExpectedReadAheadKey;
/*
* kQTVisualContextPixelBufferAttributesKey
*
* Summary:
* CFDictionaryRef: Dictionary containing pixel buffer attributes as
* described for the CoreVideo pixel buffer pool.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
extern const CFStringRef kQTVisualContextPixelBufferAttributesKey;
/*
* kQTVisualContextTargetDimensionsKey
*
* Summary:
* CFDictionaryRef: Dictionary containing
* kQTVisualContextTargetDimensions_WidthKey and
* kQTVisualContextTargetDimensions_HeightKey. This is only a hint
* to optimize certain media types, such as text, that can render at
* any resolution. If this attribute is not set, the movie will
* render at its native resolution.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
extern const CFStringRef kQTVisualContextTargetDimensionsKey;
/*
* kQTVisualContextTargetDimensions_WidthKey
*
* Summary:
* CFNumberRef: Width, in pixels, of the rendering target.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
extern const CFStringRef kQTVisualContextTargetDimensions_WidthKey;
/*
* kQTVisualContextTargetDimensions_HeightKey
*
* Summary:
* CFNumberRef: Height, in pixels, of the rendering target.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
extern const CFStringRef kQTVisualContextTargetDimensions_HeightKey;
#else
#define kQTVisualContextTypeKey CFSTR("Type")
#define kQTVisualContextType_PixelBuffer CFSTR("PixelBuffer")
#define kQTVisualContextType_OpenGLTexture CFSTR("OpenGLTexture")
#define kQTVisualContextType_Direct3DTexture CFSTR("Direct3DTexture")
#define kQTVisualContextWorkingColorSpaceKey CFSTR("WorkingColorSpace")
#define kQTVisualContextOutputColorSpaceKey CFSTR("OutputColorSpace")
#define kQTVisualContextExpectedReadAheadKey CFSTR("ExpectedReadAhead")
#define kQTVisualContextPixelBufferAttributesKey CFSTR("PixelBufferAttributes")
#define kQTVisualContextTargetDimensionsKey CFSTR("TargetDimensions")
#define kQTVisualContextTargetDimensions_WidthKey CFSTR("Width")
#define kQTVisualContextTargetDimensions_HeightKey CFSTR("Height")
#endif /* TARGET_OS_MAC */
/*
* QTVisualContextRetain()
*
* Summary:
* Increments the visual context's reference count.
*
* Discussion:
* The same visual context is returned for convenience. If
* visualContext is NULL, nothing happens.
*
* Parameters:
*
* visualContext:
* [in] The visual context to retain.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( QTVisualContextRef )
QTVisualContextRetain(QTVisualContextRef visualContext);
/*
* QTVisualContextRelease()
*
* Summary:
* Decrements the visual context's reference count.
*
* Discussion:
* If the retain count decreases to zero, the visual context is
* disposed. If visualContext is NULL, nothing happens.
*
* Parameters:
*
* visualContext:
* [in] The visual context to release.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( void )
QTVisualContextRelease(QTVisualContextRef visualContext);
/*
* QTVisualContextGetTypeID()
*
* Summary:
* Returns the CFTypeID for QTVisualContextRef.
*
* Discussion:
* You could use this to test whether a CFTypeRef that extracted
* from a CF container such as a CFArray was a QTVisualContextRef.
* All visual contexts have the same CFTypeID. If you need to
* distinguish between different types of visual contexts (eg.
* PixelBuffer vs. OpenGLTexture), query for kQTVisualContextTypeKey
* with QTVisualContextGetAttribute().
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( CFTypeID )
QTVisualContextGetTypeID(void);
/*
* QTVisualContextSetAttribute()
*
* Summary:
* Sets a visual context attribute.
*
* Parameters:
*
* visualContext:
* [in] The visual context.
*
* attributeKey:
* [in] Identifier of attribute to set.
*
* attributeValue:
* [in] Value of attribute to set, or NULL to remove a value.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
QTVisualContextSetAttribute(
QTVisualContextRef visualContext,
CFStringRef attributeKey,
CFTypeRef attributeValue); /* can be NULL */
/*
* QTVisualContextGetAttribute()
*
* Summary:
* Gets a visual context attribute.
*
* Parameters:
*
* visualContext:
* [in] The visual context.
*
* attributeKey:
* [in] Identifier of attribute to get.
*
* attributeValueOut:
* [out] Pointer to variable that will receive the attribute
* value, or NULL if the attribute is not set.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
QTVisualContextGetAttribute(
QTVisualContextRef visualContext,
CFStringRef attributeKey,
CFTypeRef * attributeValueOut);
/*
* QTVisualContextImageAvailableCallback
*
* Summary:
* User-defined callback function to recieve notifications when a
* new image becomes available.
*
* Discussion:
* Due to unpredictible activity, such as user seeks or the arrival
* of streaming video packets from a network, new images may become
* available for times supposedly occupied by previous images.
* Applications using the CoreVideo display link to drive rendering
* probably do not need to install a callback of this type since
* they will already be checking for new images at a sufficient rate.
*
* Parameters:
*
* visualContext:
* [in] The visual context invoking the callback.
*
* timeStamp:
* [in] Time for which a new image has become available.
*
* refCon:
* [in] User-defined value passed to
* QTVisualContextSetImageAvailableCallback.
*/
typedef CALLBACK_API_C( void , QTVisualContextImageAvailableCallback )(QTVisualContextRef visualContext, const CVTimeStamp *timeStamp, void *refCon);
/*
* QTVisualContextSetImageAvailableCallback()
*
* Summary:
* Installs user-defined callback to be notified when new images
* become available.
*
* Discussion:
* This routine installs the user defined
* QTVisualContextImageAvailableCallback callback. There can only be
* one callback associated with a QTVisualContext at a given time.
*
* Parameters:
*
* visualContext:
* [in] The visual context.
*
* imageAvailableCallback:
* [in] User-defined callback function to recieve notifications.
* Pass NULL to remove any existing callback.
*
* refCon:
* [in] User-defined value to pass to
* QTVisualContextImageAvailableCallback.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
QTVisualContextSetImageAvailableCallback(
QTVisualContextRef visualContext,
QTVisualContextImageAvailableCallback imageAvailableCallback, /* can be NULL */
void * refCon); /* can be NULL */
/*
* QTVisualContextIsNewImageAvailable()
*
* Summary:
* Queries whether a new image is available for a given time.
*
* Discussion:
* This function returns true if there is a image available for the
* specified time that is different from the last image retrieved
* from QTVisualContextCopyImageForTime. See
* QTVisualContextCopyImageForTime for restrictions on time-stamps.
*
* Parameters:
*
* visualContext:
* [in] The visual context.
*
* timeStamp:
* [in] Time in question. Pass NULL to request the image at the
* current time.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( Boolean )
QTVisualContextIsNewImageAvailable(
QTVisualContextRef visualContext,
const CVTimeStamp * timeStamp); /* can be NULL */
/*
* QTVisualContextCopyImageForTime()
*
* Summary:
* Retrieves an image buffer from the visual context, indexed by the
* provided timestamp.
*
* Discussion:
* You should not request image buffers further ahead of the current
* time than the read-ahead time specified with the
* kQTVisualContextExpectedReadAheadKey attribute. You may skip
* images by passing later times, but you may not pass an earlier
* time than passed to a previous call to this function.
*
* Parameters:
*
* visualContext:
* [in] The visual context.
*
* allocator:
* [in] Allocator used to create new CVImageBufferRef.
*
* timeStamp:
* [in] Time in question. Pass NULL to request the image at the
* current time.
*
* newImage:
* [out] Points to variable to receive new image. If there is no
* video at the requested time, this variable will be set to NULL.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
QTVisualContextCopyImageForTime(
QTVisualContextRef visualContext,
CFAllocatorRef allocator, /* can be NULL */
const CVTimeStamp * timeStamp, /* can be NULL */
CVImageBufferRef * newImage);
/*
* QTVisualContextTask()
*
* Summary:
* Causes visual context to release internally held resources for
* later re-use.
*
* Discussion:
* For optimal resource management, this function should be called
* in every rendering pass, after old images have been released, new
* images have been used and all rendering has been flushed to the
* screen. This call is not mandatory.
*
* Parameters:
*
* visualContext:
* [in] The visual context.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( void )
QTVisualContextTask(QTVisualContextRef visualContext);
#if TARGET_OS_MAC
/*
* QTOpenGLTextureContextCreate()
*
* Summary:
* Creates a new OpenGL texture context for the given OpenGL context
* and pixel format.
*
* Discussion:
* This function will fail if the graphics hardware is insufficient.
*
* Parameters:
*
* allocator:
* [in] Allocator used to create the texture context.
*
* cglContext:
* [in] OpenGL context used to create textures.
*
* cglPixelFormat:
* [in] OpenGL pixel format used to create the OpenGL context.
*
* attributes:
* [in] Dictionary of attributes.
*
* newTextureContext:
* [out] Points to a variable to recieve the new OpenGL texture
* context.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
QTOpenGLTextureContextCreate(
CFAllocatorRef allocator, /* can be NULL */
CGLContextObj cglContext,
CGLPixelFormatObj cglPixelFormat,
CFDictionaryRef attributes, /* can be NULL */
QTVisualContextRef * newTextureContext);
/*
* QTPixelBufferContextCreate()
*
* Summary:
* Creates a new pixel buffer context with the given attributes.
*
* Discussion:
* This function will fail if the graphics hardware is insufficient.
*
* Parameters:
*
* allocator:
* [in] Allocator used to create the pixel buffer context.
*
* attributes:
* [in] Dictionary of attributes.
*
* newPixelBufferContext:
* [out] Points to a variable to recieve the new pixel buffer
* context.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: in version 10.4 (or QuickTime 7.0) and later
*/
EXTERN_API_C( OSStatus )
QTPixelBufferContextCreate(
CFAllocatorRef allocator, /* can be NULL */
CFDictionaryRef attributes, /* can be NULL */
QTVisualContextRef * newPixelBufferContext);
#endif /* TARGET_OS_MAC */
#if TARGET_OS_WIN32
#if CALL_NOT_IN_CARBON
/*
* QTDirect3DTextureContextCreate()
*
* Summary:
* Creates a new Direct3D texture context for the given Direct3D
* device and pixel format.
*
* Discussion:
* This function will fail if the graphics hardware is insufficient.
*
* Parameters:
*
* allocator:
* [in] Allocator used to create the texture context.
*
* d3dDevice:
* [in] Direct3D device used to create textures.
*
* d3dPixelFormat:
* [in] Direct3D pixel format used to create the Direct3D device.
*
* attributes:
* [in] Dictionary of attributes.
*
* newTextureContext:
* [out] Points to a variable to recieve the new Direct3D texture
* context.
*
* Availability:
* Non-Carbon CFM: not available
* CarbonLib: not available
* Mac OS X: not available
* Windows: in qtmlClient.lib 6.6 and later
*/
EXTERN_API_C( OSStatus )
QTDirect3DTextureContextCreate(
CFAllocatorRef allocator, /* can be NULL */
void * d3dDevice,
UInt32 d3dPixelFormat,
CFDictionaryRef attributes, /* can be NULL */
QTVisualContextRef * newTextureContext);
#endif /* CALL_NOT_IN_CARBON */
#endif /* TARGET_OS_WIN32 */
#endif // !__LP64__
#if PRAGMA_STRUCT_ALIGN
#pragma options align=reset
#elif PRAGMA_STRUCT_PACKPUSH
#pragma pack(pop)
#elif PRAGMA_STRUCT_PACK
#pragma pack()
#endif
#ifdef PRAGMA_IMPORT_OFF
#pragma import off
#elif PRAGMA_IMPORT
#pragma import reset
#endif
#ifdef __cplusplus
}
#endif
#endif /* __IMAGECOMPRESSION__ */