123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812 |
- {
- File: HIToolbox/HIShape.h
-
- Contains: Generic Abstract Shape API
-
- Version: HIToolbox-219.4.81~2
-
- Copyright: © 2001-2005 by Apple Computer, Inc., all rights reserved.
-
- Bugs?: For bug reports, consult the following page on
- the World Wide Web:
-
- http://www.freepascal.org/bugs.html
-
- }
- { File: HIShape.p(.pas) }
- { }
- { Contains: CodeWarrior Pascal(GPC) translation of Apple's Mac OS X 10.2 introduced HIShape.h. }
- { Translation compatible with make-gpc-interfaces.pl generated MWPInterfaces }
- { (GPCPInterfaces) and Mac OS X 10.2.x or higher. The CodeWarrior Pascal translation }
- { is linkable with Mac OS X 10.2.x or higher CFM CarbonLib. The GPC translation is }
- { linkable with Mac OS X 10.2.x or higher Mach-O Carbon.framework. }
- { }
- { Version: 1.0 }
- { }
- { Pascal Translation: Gale Paeper, <[email protected]>, 2004 }
- { }
- { Copyright: Subject to the constraints of Apple's original rights, you're free to use this }
- { translation as you deem fit. }
- { }
- { Bugs?: This is an AS IS translation with no express guarentees of any kind. }
- { If you do find a bug, please help out the Macintosh Pascal programming community by }
- { reporting your bug finding and possible fix to either personal e-mail to Gale Paeper }
- { or a posting to the MacPascal mailing list. }
- { }
- { Translation assisted by: }
- {This file was processed by Dan's Source Converter}
- {version 1.3 (this version modified by Ingemar Ragnemalm)}
- { Pascal Translation Updated: Peter N Lewis, <[email protected]>, August 2005 }
- {
- Modified for use with Free Pascal
- Version 200
- Please report any bugs to <[email protected]>
- }
- {$mode macpas}
- {$packenum 1}
- {$macro on}
- {$inline on}
- {$CALLING MWPASCAL}
- unit HIShape;
- interface
- {$setc UNIVERSAL_INTERFACES_VERSION := $0342}
- {$setc GAP_INTERFACES_VERSION := $0200}
- {$ifc not defined USE_CFSTR_CONSTANT_MACROS}
- {$setc USE_CFSTR_CONSTANT_MACROS := TRUE}
- {$endc}
- {$ifc defined CPUPOWERPC and defined CPUI386}
- {$error Conflicting initial definitions for CPUPOWERPC and CPUI386}
- {$endc}
- {$ifc defined FPC_BIG_ENDIAN and defined FPC_LITTLE_ENDIAN}
- {$error Conflicting initial definitions for FPC_BIG_ENDIAN and FPC_LITTLE_ENDIAN}
- {$endc}
- {$ifc not defined __ppc__ and defined CPUPOWERPC}
- {$setc __ppc__ := 1}
- {$elsec}
- {$setc __ppc__ := 0}
- {$endc}
- {$ifc not defined __i386__ and defined CPUI386}
- {$setc __i386__ := 1}
- {$elsec}
- {$setc __i386__ := 0}
- {$endc}
- {$ifc defined __ppc__ and __ppc__ and defined __i386__ and __i386__}
- {$error Conflicting definitions for __ppc__ and __i386__}
- {$endc}
- {$ifc defined __ppc__ and __ppc__}
- {$setc TARGET_CPU_PPC := TRUE}
- {$setc TARGET_CPU_X86 := FALSE}
- {$elifc defined __i386__ and __i386__}
- {$setc TARGET_CPU_PPC := FALSE}
- {$setc TARGET_CPU_X86 := TRUE}
- {$elsec}
- {$error Neither __ppc__ nor __i386__ is defined.}
- {$endc}
- {$setc TARGET_CPU_PPC_64 := FALSE}
- {$ifc defined FPC_BIG_ENDIAN}
- {$setc TARGET_RT_BIG_ENDIAN := TRUE}
- {$setc TARGET_RT_LITTLE_ENDIAN := FALSE}
- {$elifc defined FPC_LITTLE_ENDIAN}
- {$setc TARGET_RT_BIG_ENDIAN := FALSE}
- {$setc TARGET_RT_LITTLE_ENDIAN := TRUE}
- {$elsec}
- {$error Neither FPC_BIG_ENDIAN nor FPC_LITTLE_ENDIAN are defined.}
- {$endc}
- {$setc ACCESSOR_CALLS_ARE_FUNCTIONS := TRUE}
- {$setc CALL_NOT_IN_CARBON := FALSE}
- {$setc OLDROUTINENAMES := FALSE}
- {$setc OPAQUE_TOOLBOX_STRUCTS := TRUE}
- {$setc OPAQUE_UPP_TYPES := TRUE}
- {$setc OTCARBONAPPLICATION := TRUE}
- {$setc OTKERNEL := FALSE}
- {$setc PM_USE_SESSION_APIS := TRUE}
- {$setc TARGET_API_MAC_CARBON := TRUE}
- {$setc TARGET_API_MAC_OS8 := FALSE}
- {$setc TARGET_API_MAC_OSX := TRUE}
- {$setc TARGET_CARBON := TRUE}
- {$setc TARGET_CPU_68K := FALSE}
- {$setc TARGET_CPU_MIPS := FALSE}
- {$setc TARGET_CPU_SPARC := FALSE}
- {$setc TARGET_OS_MAC := TRUE}
- {$setc TARGET_OS_UNIX := FALSE}
- {$setc TARGET_OS_WIN32 := FALSE}
- {$setc TARGET_RT_MAC_68881 := FALSE}
- {$setc TARGET_RT_MAC_CFM := FALSE}
- {$setc TARGET_RT_MAC_MACHO := TRUE}
- {$setc TYPED_FUNCTION_POINTERS := TRUE}
- {$setc TYPE_BOOL := FALSE}
- {$setc TYPE_EXTENDED := FALSE}
- {$setc TYPE_LONGLONG := TRUE}
- uses MacTypes,CFBase,CGContext,Drag,Quickdraw,CarbonEvents,HIGeometry;
- {$ALIGN POWER}
- {
- * HIShape
- *
- * Discussion:
- * HIShape is an abstract shape object for use with some of the
- * HIToolbox APIs. It is designed as a replacement for RgnHandles
- * (though it is currently implemented in terms of them at the time
- * of this writing). This abstraction will allow us to avoid using
- * QD types in our APIs, particularly in HIView.
- *
- * One of the biggest benefits of HIShape is that we have mutable
- * and immutable variants. This means that immutable shapes can be
- * created and passed around and 'copied' very quickly, since they
- * are actually refcounted when copied. This avoids needing to do
- * the handle-to-handle copies that occur right now with
- * RgnHandle-based APIs.
- }
- type
- HIShapeRef = ^SInt32; { an opaque 32-bit type }
- type
- HIMutableShapeRef = ^SInt32; { an opaque 32-bit type }
- {
- * HIShapeGetTypeID()
- *
- * Discussion:
- * Returns the CF type ID for the HIShape class.
- *
- * Mac OS X threading:
- * Not thread safe
- *
- * Result:
- * A CF type ID.
- *
- * Availability:
- * Mac OS X: in version 10.2 and later in Carbon.framework
- * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later
- * Non-Carbon CFM: not available
- }
- function HIShapeGetTypeID: CFTypeID; external name '_HIShapeGetTypeID';
- (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER *)
- {======================================================================================}
- { IMMUTABLE FUNCTIONS }
- {======================================================================================}
- {
- * HIShapeCreateEmpty()
- *
- * Discussion:
- * Creates an immutable empty shape. Useful at times.
- *
- * Mac OS X threading:
- * Not thread safe
- *
- * Result:
- * An immutable, empty HIShape reference.
- *
- * Availability:
- * Mac OS X: in version 10.4 and later in Carbon.framework
- * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.4 and later
- * Non-Carbon CFM: not available
- }
- function HIShapeCreateEmpty: HIShapeRef; external name '_HIShapeCreateEmpty';
- (* AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER *)
- {
- * HIShapeCreateWithQDRgn()
- *
- * Discussion:
- * Creates an immutable shape based on an existing Quickdraw region
- * handle.
- *
- * Mac OS X threading:
- * Not thread safe
- *
- * Parameters:
- *
- * inRgn:
- * The Quickdraw region from which to create the HIShape.
- *
- * Result:
- * An immutable HIShape reference.
- *
- * Availability:
- * Mac OS X: in version 10.2 and later in Carbon.framework
- * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later
- * Non-Carbon CFM: not available
- }
- function HIShapeCreateWithQDRgn( inRgn: RgnHandle ): HIShapeRef; external name '_HIShapeCreateWithQDRgn';
- (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER *)
- {
- * HIShapeCreateWithRect()
- *
- * Discussion:
- * Creates an immutable, rectangular shape based on a given
- * rectangle.
- *
- * Mac OS X threading:
- * Not thread safe
- *
- * Parameters:
- *
- * inRect:
- * The HIRect from which to create the resulting shape.
- *
- * Result:
- * An immutable HIShape reference.
- *
- * Availability:
- * Mac OS X: in version 10.2 and later in Carbon.framework
- * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later
- * Non-Carbon CFM: not available
- }
- function HIShapeCreateWithRect( const (*var*) inRect: HIRect ): HIShapeRef; external name '_HIShapeCreateWithRect';
- (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER *)
- {
- * HIShapeCreateCopy()
- *
- * Discussion:
- * Creates an immutable copy of a mutable or immutable HIShape.
- *
- * Mac OS X threading:
- * Not thread safe
- *
- * Parameters:
- *
- * inShape:
- * The existing HIShapeRef you wish to copy.
- *
- * Result:
- * An immutable HIShape reference.
- *
- * Availability:
- * Mac OS X: in version 10.2 and later in Carbon.framework
- * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later
- * Non-Carbon CFM: not available
- }
- function HIShapeCreateCopy( inShape: HIShapeRef ): HIShapeRef; external name '_HIShapeCreateCopy';
- (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER *)
- {
- * HIShapeCreateIntersection()
- *
- * Discussion:
- * Creates a new immutable shape which is the intersection of two
- * others.
- *
- * Mac OS X threading:
- * Not thread safe
- *
- * Parameters:
- *
- * inShape1:
- * An existing HIShapeRef.
- *
- * inShape2:
- * An existing HIShapeRef.
- *
- * Result:
- * A new immutable HIShapeRef.
- *
- * Availability:
- * Mac OS X: in version 10.2 and later in Carbon.framework
- * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later
- * Non-Carbon CFM: not available
- }
- function HIShapeCreateIntersection( inShape1: HIShapeRef; inShape2: HIShapeRef ): HIShapeRef; external name '_HIShapeCreateIntersection';
- (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER *)
- {
- * HIShapeCreateDifference()
- *
- * Discussion:
- * Creates a new immutable shape which is the difference of two
- * others. The second shape is subtracted from the first.
- *
- * Mac OS X threading:
- * Not thread safe
- *
- * Parameters:
- *
- * inShape1:
- * An existing HIShapeRef.
- *
- * inShape2:
- * An existing HIShapeRef.
- *
- * Result:
- * A new immutable HIShapeRef.
- *
- * Availability:
- * Mac OS X: in version 10.2 and later in Carbon.framework
- * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later
- * Non-Carbon CFM: not available
- }
- function HIShapeCreateDifference( inShape1: HIShapeRef; inShape2: HIShapeRef ): HIShapeRef; external name '_HIShapeCreateDifference';
- (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER *)
- {
- * HIShapeCreateUnion()
- *
- * Discussion:
- * Creates a new immutable shape which is the union of two others.
- *
- * Mac OS X threading:
- * Not thread safe
- *
- * Parameters:
- *
- * inShape1:
- * An existing HIShapeRef.
- *
- * inShape2:
- * An existing HIShapeRef.
- *
- * Result:
- * A new immutable HIShapeRef.
- *
- * Availability:
- * Mac OS X: in version 10.2 and later in Carbon.framework
- * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later
- * Non-Carbon CFM: not available
- }
- function HIShapeCreateUnion( inShape1: HIShapeRef; inShape2: HIShapeRef ): HIShapeRef; external name '_HIShapeCreateUnion';
- (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER *)
- {
- * HIShapeIsEmpty()
- *
- * Discussion:
- * Returns true if the given HIShapeRef is empty, i.e. its area is
- * empty.
- *
- * Mac OS X threading:
- * Not thread safe
- *
- * Parameters:
- *
- * inShape:
- * The existing HIShapeRef you wish to test.
- *
- * Result:
- * A boolean result.
- *
- * Availability:
- * Mac OS X: in version 10.2 and later in Carbon.framework
- * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later
- * Non-Carbon CFM: not available
- }
- function HIShapeIsEmpty( inShape: HIShapeRef ): Boolean; external name '_HIShapeIsEmpty';
- (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER *)
- {
- * HIShapeIsRectangular()
- *
- * Discussion:
- * Returns true if the given HIShapeRef is rectangular.
- *
- * Mac OS X threading:
- * Not thread safe
- *
- * Parameters:
- *
- * inShape:
- * The existing HIShapeRef you wish to test.
- *
- * Result:
- * A boolean result.
- *
- * Availability:
- * Mac OS X: in version 10.2 and later in Carbon.framework
- * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later
- * Non-Carbon CFM: not available
- }
- function HIShapeIsRectangular( inShape: HIShapeRef ): Boolean; external name '_HIShapeIsRectangular';
- (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER *)
- {
- * HIShapeContainsPoint()
- *
- * Discussion:
- * Returns true if the given HIShapeRef contains the point passed in.
- *
- * Mac OS X threading:
- * Not thread safe
- *
- * Parameters:
- *
- * inShape:
- * An existing HIShapeRef.
- *
- * inPoint:
- * The point to check.
- *
- * Result:
- * A boolean result.
- *
- * Availability:
- * Mac OS X: in version 10.2 and later in Carbon.framework
- * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later
- * Non-Carbon CFM: not available
- }
- function HIShapeContainsPoint( inShape: HIShapeRef; const (*var*) inPoint: HIPoint ): Boolean; external name '_HIShapeContainsPoint';
- (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER *)
- {
- * HIShapeIntersectsRect()
- *
- * Discussion:
- * Returns true if the given HIShapeRef intersects the rect passed
- * in.
- *
- * Mac OS X threading:
- * Not thread safe
- *
- * Parameters:
- *
- * inShape:
- * An existing HIShapeRef.
- *
- * inRect:
- * The rectangle to check.
- *
- * Result:
- * A boolean result.
- *
- * Availability:
- * Mac OS X: in version 10.4 and later in Carbon.framework
- * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.4 and later
- * Non-Carbon CFM: not available
- }
- function HIShapeIntersectsRect( inShape: HIShapeRef; const (*var*) inRect: HIRect ): Boolean; external name '_HIShapeIntersectsRect';
- (* AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER *)
- {
- * HIShapeGetBounds()
- *
- * Discussion:
- * Returns the bounding rectangle of a given HIShapeRef.
- *
- * Mac OS X threading:
- * Not thread safe
- *
- * Parameters:
- *
- * inShape:
- * An existing HIShapeRef.
- *
- * outRect:
- * Receives the bounding rectangle.
- *
- * Result:
- * A pointer to the rectangle you passed in, for convenience.
- *
- * Availability:
- * Mac OS X: in version 10.2 and later in Carbon.framework
- * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later
- * Non-Carbon CFM: not available
- }
- function HIShapeGetBounds( inShape: HIShapeRef; var outRect: HIRect ): HIRectPtr; external name '_HIShapeGetBounds';
- (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER *)
- {
- * HIShapeGetAsQDRgn()
- *
- * Discussion:
- * Changes a given Quickdraw region handle to have the same shape as
- * a given HIShapeRef. Essentially you are converting an HIShapeRef
- * into a RgnHandle. This conversion may lose fidelity depending on
- * how the shape was created originally.
- *
- * Mac OS X threading:
- * Not thread safe
- *
- * Parameters:
- *
- * inShape:
- * An existing HIShapeRef.
- *
- * outRgn:
- * An existing region to change.
- *
- * Result:
- * An operating system status code.
- *
- * Availability:
- * Mac OS X: in version 10.2 and later in Carbon.framework
- * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later
- * Non-Carbon CFM: not available
- }
- function HIShapeGetAsQDRgn( inShape: HIShapeRef; outRgn: RgnHandle ): OSStatus; external name '_HIShapeGetAsQDRgn';
- (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER *)
- {
- * HIShapeReplacePathInCGContext()
- *
- * Discussion:
- * Given an HIShapeRef and a CGContextRef, make the current path in
- * the context represent the shape. You might use this to clip to a
- * shape, for example. You could call this function and then
- * immediately call CGContextClip.
- *
- * Mac OS X threading:
- * Not thread safe
- *
- * Parameters:
- *
- * inShape:
- * An existing HIShapeRef.
- *
- * inContext:
- * The context to apply the shape to.
- *
- * Result:
- * An operating system status code.
- *
- * Availability:
- * Mac OS X: in version 10.2 and later in Carbon.framework
- * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later
- * Non-Carbon CFM: not available
- }
- function HIShapeReplacePathInCGContext( inShape: HIShapeRef; inContext: CGContextRef ): OSStatus; external name '_HIShapeReplacePathInCGContext';
- (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER *)
- {
- * HIShapeSetQDClip()
- *
- * Discussion:
- * Given an HIShapeRef and a Quickdraw port, set the current clip in
- * the port to the shape.
- *
- * Mac OS X threading:
- * Not thread safe
- *
- * Parameters:
- *
- * inShape:
- * An existing HIShapeRef.
- *
- * inPort:
- * The port to set the clip for.
- *
- * Result:
- * An operating system status code.
- *
- * Availability:
- * Mac OS X: in version 10.2 and later in Carbon.framework
- * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later
- * Non-Carbon CFM: not available
- }
- function HIShapeSetQDClip( inShape: HIShapeRef; inPort: CGrafPtr ): OSStatus; external name '_HIShapeSetQDClip';
- (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER *)
- {======================================================================================}
- { MUTABLE FUNCTIONS }
- {======================================================================================}
- {
- * HIShapeCreateMutable()
- *
- * Discussion:
- * Creates a new, mutable, empty shape.
- *
- * Mac OS X threading:
- * Not thread safe
- *
- * Result:
- * A mutable shape reference.
- *
- * Availability:
- * Mac OS X: in version 10.2 and later in Carbon.framework
- * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later
- * Non-Carbon CFM: not available
- }
- function HIShapeCreateMutable: HIMutableShapeRef; external name '_HIShapeCreateMutable';
- (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER *)
- {
- * HIShapeCreateMutableCopy()
- *
- * Discussion:
- * Given an existing HIShapeRef, creates a new mutable copy.
- *
- * Mac OS X threading:
- * Not thread safe
- *
- * Parameters:
- *
- * inOrig:
- * The shape to copy.
- *
- * Result:
- * A mutable shape reference.
- *
- * Availability:
- * Mac OS X: in version 10.2 and later in Carbon.framework
- * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later
- * Non-Carbon CFM: not available
- }
- function HIShapeCreateMutableCopy( inOrig: HIShapeRef ): HIMutableShapeRef; external name '_HIShapeCreateMutableCopy';
- (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER *)
- {
- * HIShapeSetEmpty()
- *
- * Discussion:
- * Sets a mutable shape to be an empty shape.
- *
- * Mac OS X threading:
- * Not thread safe
- *
- * Parameters:
- *
- * inShape:
- * The shape to empty.
- *
- * Result:
- * An operating system status code.
- *
- * Availability:
- * Mac OS X: in version 10.2 and later in Carbon.framework
- * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later
- * Non-Carbon CFM: not available
- }
- function HIShapeSetEmpty( inShape: HIMutableShapeRef ): OSStatus; external name '_HIShapeSetEmpty';
- (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER *)
- {
- * HIShapeIntersect()
- *
- * Discussion:
- * Takes two shapes and sets a third to be their intersection.
- *
- * Mac OS X threading:
- * Not thread safe
- *
- * Parameters:
- *
- * inShape1:
- * The first shape.
- *
- * inShape2:
- * The second shape.
- *
- * outResult:
- * The shape to receive the result of the intersection. This can
- * be one of the source shapes.
- *
- * Result:
- * An operating system status code.
- *
- * Availability:
- * Mac OS X: in version 10.2 and later in Carbon.framework
- * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later
- * Non-Carbon CFM: not available
- }
- function HIShapeIntersect( inShape1: HIShapeRef; inShape2: HIShapeRef; outResult: HIMutableShapeRef ): OSStatus; external name '_HIShapeIntersect';
- (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER *)
- {
- * HIShapeDifference()
- *
- * Discussion:
- * Takes two shapes and sets a third to be their difference. The
- * second shape is subtracted from the first.
- *
- * Mac OS X threading:
- * Not thread safe
- *
- * Parameters:
- *
- * inShape1:
- * The first shape.
- *
- * inShape2:
- * The second shape.
- *
- * outResult:
- * The shape to receive the result of the intersection. This can
- * be one of the source shapes.
- *
- * Result:
- * An operating system status code.
- *
- * Availability:
- * Mac OS X: in version 10.2 and later in Carbon.framework
- * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later
- * Non-Carbon CFM: not available
- }
- function HIShapeDifference( inShape1: HIShapeRef; inShape2: HIShapeRef; outResult: HIMutableShapeRef ): OSStatus; external name '_HIShapeDifference';
- (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER *)
- {
- * HIShapeUnion()
- *
- * Discussion:
- * Takes two shapes and sets a third to be their union.
- *
- * Mac OS X threading:
- * Not thread safe
- *
- * Parameters:
- *
- * inShape1:
- * The first shape.
- *
- * inShape2:
- * The second shape.
- *
- * outResult:
- * The shape to receive the result of the union. This can be one
- * of the source shapes.
- *
- * Result:
- * An operating system status code.
- *
- * Availability:
- * Mac OS X: in version 10.2 and later in Carbon.framework
- * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later
- * Non-Carbon CFM: not available
- }
- function HIShapeUnion( inShape1: HIShapeRef; inShape2: HIShapeRef; outResult: HIMutableShapeRef ): OSStatus; external name '_HIShapeUnion';
- (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER *)
- {
- * HIShapeOffset()
- *
- * Discussion:
- * Offsets a shape by some delta.
- *
- * Mac OS X threading:
- * Not thread safe
- *
- * Parameters:
- *
- * inShape:
- * The shape to offset.
- *
- * inDX:
- * The delta to move the shape on the X axis.
- *
- * inDY:
- * The delta to move the shape on the Y axis.
- *
- * Result:
- * An operating system status code.
- *
- * Availability:
- * Mac OS X: in version 10.2 and later in Carbon.framework
- * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later
- * Non-Carbon CFM: not available
- }
- function HIShapeOffset( inShape: HIMutableShapeRef; inDX: Float32; inDY: Float32 ): OSStatus; external name '_HIShapeOffset';
- (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER *)
- end.
|