{ File: HIToolbox/HIDisclosureViews.h Contains: API and type definitions related to disclosure views. Version: HIToolbox-437~1 Copyright: © 1999-2008 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 } { Initial Pascal Translation: Jonas Maebe, , October 2009 } { Modified for use with Free Pascal Version 308 Please report any bugs to } {$ifc not defined MACOSALLINCLUDE or not MACOSALLINCLUDE} {$mode macpas} {$packenum 1} {$macro on} {$inline on} {$calling mwpascal} unit HIDisclosureViews; interface {$setc UNIVERSAL_INTERFACES_VERSION := $0400} {$setc GAP_INTERFACES_VERSION := $0308} {$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 CPUPOWERPC32} {$setc __ppc__ := 1} {$elsec} {$setc __ppc__ := 0} {$endc} {$ifc not defined __ppc64__ and defined CPUPOWERPC64} {$setc __ppc64__ := 1} {$elsec} {$setc __ppc64__ := 0} {$endc} {$ifc not defined __i386__ and defined CPUI386} {$setc __i386__ := 1} {$elsec} {$setc __i386__ := 0} {$endc} {$ifc not defined __x86_64__ and defined CPUX86_64} {$setc __x86_64__ := 1} {$elsec} {$setc __x86_64__ := 0} {$endc} {$ifc not defined __arm__ and defined CPUARM} {$setc __arm__ := 1} {$elsec} {$setc __arm__ := 0} {$endc} {$ifc defined cpu64} {$setc __LP64__ := 1} {$elsec} {$setc __LP64__ := 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_PPC64 := FALSE} {$setc TARGET_CPU_X86 := FALSE} {$setc TARGET_CPU_X86_64 := FALSE} {$setc TARGET_CPU_ARM := FALSE} {$setc TARGET_OS_MAC := TRUE} {$setc TARGET_OS_IPHONE := FALSE} {$setc TARGET_IPHONE_SIMULATOR := FALSE} {$elifc defined __ppc64__ and __ppc64__} {$setc TARGET_CPU_PPC := FALSE} {$setc TARGET_CPU_PPC64 := TRUE} {$setc TARGET_CPU_X86 := FALSE} {$setc TARGET_CPU_X86_64 := FALSE} {$setc TARGET_CPU_ARM := FALSE} {$setc TARGET_OS_MAC := TRUE} {$setc TARGET_OS_IPHONE := FALSE} {$setc TARGET_IPHONE_SIMULATOR := FALSE} {$elifc defined __i386__ and __i386__} {$setc TARGET_CPU_PPC := FALSE} {$setc TARGET_CPU_PPC64 := FALSE} {$setc TARGET_CPU_X86 := TRUE} {$setc TARGET_CPU_X86_64 := FALSE} {$setc TARGET_CPU_ARM := FALSE} {$ifc defined(iphonesim)} {$setc TARGET_OS_MAC := FALSE} {$setc TARGET_OS_IPHONE := TRUE} {$setc TARGET_IPHONE_SIMULATOR := TRUE} {$elsec} {$setc TARGET_OS_MAC := TRUE} {$setc TARGET_OS_IPHONE := FALSE} {$setc TARGET_IPHONE_SIMULATOR := FALSE} {$endc} {$elifc defined __x86_64__ and __x86_64__} {$setc TARGET_CPU_PPC := FALSE} {$setc TARGET_CPU_PPC64 := FALSE} {$setc TARGET_CPU_X86 := FALSE} {$setc TARGET_CPU_X86_64 := TRUE} {$setc TARGET_CPU_ARM := FALSE} {$setc TARGET_OS_MAC := TRUE} {$setc TARGET_OS_IPHONE := FALSE} {$setc TARGET_IPHONE_SIMULATOR := FALSE} {$elifc defined __arm__ and __arm__} {$setc TARGET_CPU_PPC := FALSE} {$setc TARGET_CPU_PPC64 := FALSE} {$setc TARGET_CPU_X86 := FALSE} {$setc TARGET_CPU_X86_64 := FALSE} {$setc TARGET_CPU_ARM := TRUE} { will require compiler define when/if other Apple devices with ARM cpus ship } {$setc TARGET_OS_MAC := FALSE} {$setc TARGET_OS_IPHONE := TRUE} {$setc TARGET_IPHONE_SIMULATOR := FALSE} {$elsec} {$error __ppc__ nor __ppc64__ nor __i386__ nor __x86_64__ nor __arm__ is defined.} {$endc} {$ifc defined __LP64__ and __LP64__ } {$setc TARGET_CPU_64 := TRUE} {$elsec} {$setc TARGET_CPU_64 := FALSE} {$endc} {$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_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,Controls,HIView,MacWindows,QuickdrawTypes,CFBase,HIObject; {$endc} {not MACOSALLINCLUDE} {$ifc TARGET_OS_MAC} {$ALIGN POWER} {ΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡ} { ₯ DISCLOSURE BUTTON } { (CDEF 30) } {ΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡ} { The HIObject class ID for the HIDisclosureButton class. } {$ifc USE_CFSTR_CONSTANT_MACROS} {$definec kHIDisclosureButtonClassID CFSTRP('com.apple.HIDisclosureButton')} {$endc} {$ifc not TARGET_CPU_64} { * CreateDisclosureButtonControl() * * Summary: * Creates a new instance of the Disclosure Button Control. * * Discussion: * CreateDisclosureButtonControl is preferred over NewControl * because it allows you to specify the exact set of parameters * required to create the control without overloading parameter * semantics. The initial minimum of the Disclosure Button will be * kControlDisclosureButtonClosed, and the maximum will be * kControlDisclosureButtonDisclosed. * * Mac OS X threading: * Not thread safe * * Parameters: * * inWindow: * The WindowRef in which to create the control. * * inBoundsRect: * The bounding rectangle for the control. The height of the * control is fixed and the control will be centered vertically * within the rectangle you specify. * * inValue: * The initial value; either kControlDisclosureButtonClosed or * kControlDisclosureButtonDisclosed. * * inAutoToggles: * A boolean value indicating whether its value should change * automatically after tracking the mouse. * * outControl: * On successful exit, this will contain the new control. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework [32-bit only] * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.0 and later * Non-Carbon CFM: not available } function CreateDisclosureButtonControl( inWindow: WindowRef; const (*var*) inBoundsRect: Rect; inValue: SInt32; inAutoToggles: Boolean; var outControl: ControlRef ): OSStatus; external name '_CreateDisclosureButtonControl'; (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *) { Control Kind Tag } {$endc} {not TARGET_CPU_64} const kControlKindDisclosureButton = FourCharCode('disb'); { * Discussion: * Disclosure Button Values } const { * The control be drawn suggesting a closed state. } kControlDisclosureButtonClosed = 0; { * The control will be drawn suggesting an open state. } kControlDisclosureButtonDisclosed = 1; {ΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡ} { ₯ DISCLOSURE TRIANGLE (CDEF 4) } {ΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡΡ} { This control can be used as either left or right facing. It can also handle its own } { tracking if you wish. This means that when the 'autotoggle' variant is used, if the } { user clicks the control, its state will change automatically from open to closed } { and vice-versa depending on its initial state. After a successful call to Track- } { Control, you can just check the current value to see what state it was switched to. } { * Summary: * Triangle proc IDs * * Discussion: * This control can be used as either left or right facing. It can * also handle its own tracking if you wish. This means that when * the 'autotoggle' variant is used, if the user clicks the control, * its state will change automatically from open to closed and * vice-versa depending on its initial state. After a successful * call to TrackControl, you can just check the current value to see * what state it was switched to. } const kControlTriangleProc = 64; kControlTriangleLeftFacingProc = 65; kControlTriangleAutoToggleProc = 66; kControlTriangleLeftFacingAutoToggleProc = 67; { * ControlDisclosureTriangleOrientation * * Summary: * The orientations available to a disclosure triangle control. } type ControlDisclosureTriangleOrientation = UInt16; const { * Points right on a left-to-right script system (Mac OS X and later * or CarbonLib 1.5 and later only) } kControlDisclosureTrianglePointDefault = 0; kControlDisclosureTrianglePointRight = 1; kControlDisclosureTrianglePointLeft = 2; { Control Kind Tag } const kControlKindDisclosureTriangle = FourCharCode('dist'); { The HIObject class ID for the HIDisclosureTriangle class. } {$ifc USE_CFSTR_CONSTANT_MACROS} {$definec kHIDisclosureTriangleClassID CFSTRP('com.apple.HIDisclosureTriangle')} {$endc} {$ifc not TARGET_CPU_64} { * CreateDisclosureTriangleControl() * * Summary: * Creates a Disclosure Triangle control at a specific position in * the specified window. * * Discussion: * Disclosure Triangles are small controls that give the user a way * to toggle the visibility of information or other user interface. * When information is in a hidden state, a Disclosure Triangle is * considered "closed" and should point to the right (or sometimes * to the left). When the user clicks on it, the Disclosure Triangle * rotates downwards into the "open" state. The application should * repond by revealing the appropriate information or interface. On * Mac OS X, a root control will be created for the window if one * does not already exist. If a root control exists for the window, * the Disclosure Triangle control will be embedded into it. * * Mac OS X threading: * Not thread safe * * Parameters: * * inWindow: * The WindowRef into which the Disclosure Triangle will be * created. * * inBoundsRect: * The desired position (in coordinates local to the window's * port) for the Disclosure Triangle. * * inOrientation: * The direction the Disclosure Triangle should point when it is * "closed". Passing kControlDisclosureTrianglePointDefault is * only legal as of Mac OS X and CarbonLib 1.5. * * inTitle: * The title for the Disclosure Triangle. The title will only be * displayed if the inDrawTitle parameter is true. Title display * only works on Mac OS X. * * inInitialValue: * The starting value determines whether the Disclosure Triangle * is initially in its "open" or "closed" state. The value 0 * represents the "closed" state and 1 represents the "open" state. * * inDrawTitle: * A Boolean indicating whether the Disclosure Triangle should * draw its title next to the widget. Title display only works on * Mac OS X. * * inAutoToggles: * A Boolean indicating whether the Disclosure Triangle should * change its own value (from "open" to "closed" and vice-versa) * automatically when it is clicked on. * * outControl: * On successful output, outControl will contain a reference to * the Disclosure Triangle control. * * Result: * An OSStatus code indicating success or failure. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework [32-bit only] * CarbonLib: in CarbonLib 1.1 and later * Non-Carbon CFM: not available } function CreateDisclosureTriangleControl( inWindow: WindowRef; const (*var*) inBoundsRect: Rect; inOrientation: ControlDisclosureTriangleOrientation; inTitle: CFStringRef; inInitialValue: SInt32; inDrawTitle: Boolean; inAutoToggles: Boolean; var outControl: ControlRef ): OSStatus; external name '_CreateDisclosureTriangleControl'; (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *) {$endc} {not TARGET_CPU_64} { * Summary: * Tagged data supported by disclosure triangles } const { * An SInt16 for the last value that the control had. } kControlTriangleLastValueTag = FourCharCode('last'); {$ifc not TARGET_CPU_64} { * SetDisclosureTriangleLastValue() * * Summary: * Set the last value that the control had. * * Mac OS X threading: * Not thread safe * * Parameters: * * inDisclosureTriangle: * The disclosure triangle to affect. * * inValue: * The last value. * * Result: * An OSErr code indicating success or failure. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework [32-bit only] * CarbonLib: in CarbonLib 1.0 and later * Non-Carbon CFM: in AppearanceLib 1.0 and later } function SetDisclosureTriangleLastValue( inDisclosureTriangle: HIViewRef; inValue: SInt16 ): OSErr; external name '_SetDisclosureTriangleLastValue'; (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *) { * HIDisclosureTriangleSetDisplaysTitle() * * Summary: * Sets whether a disclosure triangle displays its title. * * Mac OS X threading: * Not thread safe * * Parameters: * * inDisclosureTriangle: * The disclosure triangle to affect. * * inDisplaysTitle: * A Boolean where true means "display the title" and false means * "don't display the title". * * Result: * An OSStatus code indicating success or failure. * * Availability: * Mac OS X: in version 10.5 and later in Carbon.framework [32-bit only] * CarbonLib: not available * Non-Carbon CFM: not available } function HIDisclosureTriangleSetDisplaysTitle( inDisclosureTriangle: HIViewRef; inDisplaysTitle: Boolean ): OSStatus; external name '_HIDisclosureTriangleSetDisplaysTitle'; (* AVAILABLE_MAC_OS_X_VERSION_10_5_AND_LATER *) { * HIDisclosureTriangleGetDisplaysTitle() * * Summary: * Determines whether a disclosure triangle displays its title. * * Mac OS X threading: * Not thread safe * * Parameters: * * inDisclosureTriangle: * The disclosure triangle to test. * * Result: * A Boolean indicating if the view will display the title. The * incoming disclosure triangle reference must be valid or the * return value is undefined. * * Availability: * Mac OS X: in version 10.5 and later in Carbon.framework [32-bit only] * CarbonLib: not available * Non-Carbon CFM: not available } function HIDisclosureTriangleGetDisplaysTitle( inDisclosureTriangle: HIViewRef ): Boolean; external name '_HIDisclosureTriangleGetDisplaysTitle'; (* AVAILABLE_MAC_OS_X_VERSION_10_5_AND_LATER *) {$endc} {$endc} {TARGET_OS_MAC} {$ifc not defined MACOSALLINCLUDE or not MACOSALLINCLUDE} end. {$endc} {not MACOSALLINCLUDE}