{ File: HIToolbox/CarbonEvents.h Contains: Carbon Event Manager Version: HIToolbox-624~3 Copyright: © 1999-2008 by Apple Inc., all rights reserved. Bugs?: For bug reports, consult the following page on the World Wide Web: http://bugs.freepascal.org } { Pascal Translation Updated: Peter N Lewis, , August 2005 } { Pascal Translation Updated: Jonas Maebe, , October 2009 } { Pascal Translation Updated: Jonas Maebe, , October 2012 } { Modified for use with Free Pascal Version 308 Please report any bugs to } {$ifc not defined MACOSALLINCLUDE or not MACOSALLINCLUDE} {$mode macpas} {$modeswitch cblocks} {$packenum 1} {$macro on} {$inline on} {$calling mwpascal} unit CarbonEvents; 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 not defined __arm64__ and defined CPUAARCH64} {$setc __arm64__ := 1} {$elsec} {$setc __arm64__ := 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_CPU_ARM64 := FALSE} {$setc TARGET_OS_MAC := TRUE} {$setc TARGET_OS_IPHONE := FALSE} {$setc TARGET_IPHONE_SIMULATOR := FALSE} {$setc TARGET_OS_EMBEDDED := 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_CPU_ARM64 := FALSE} {$setc TARGET_OS_MAC := TRUE} {$setc TARGET_OS_IPHONE := FALSE} {$setc TARGET_IPHONE_SIMULATOR := FALSE} {$setc TARGET_OS_EMBEDDED := 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} {$setc TARGET_CPU_ARM64 := 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} {$setc TARGET_OS_EMBEDDED := FALSE} {$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_CPU_ARM64 := 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} {$setc TARGET_OS_EMBEDDED := 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} {$setc TARGET_CPU_ARM64 := FALSE} {$setc TARGET_OS_MAC := FALSE} {$setc TARGET_OS_IPHONE := TRUE} {$setc TARGET_IPHONE_SIMULATOR := FALSE} {$setc TARGET_OS_EMBEDDED := TRUE} {$elifc defined __arm64__ and __arm64__} {$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 := FALSE} {$setc TARGET_CPU_ARM64 := TRUE} {$ifc defined ios} {$setc TARGET_OS_MAC := FALSE} {$setc TARGET_OS_IPHONE := TRUE} {$setc TARGET_OS_EMBEDDED := TRUE} {$elsec} {$setc TARGET_OS_MAC := TRUE} {$setc TARGET_OS_IPHONE := FALSE} {$setc TARGET_OS_EMBEDDED := FALSE} {$endc} {$setc TARGET_IPHONE_SIMULATOR := FALSE} {$elsec} {$error __ppc__ nor __ppc64__ nor __i386__ nor __x86_64__ nor __arm__ nor __arm64__ 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,CFBase,QuickdrawTypes,CFArray,HIObject,Events,Menus,AERegistry,CarbonEventsCore,HIGeometry; {$endc} {not MACOSALLINCLUDE} {$ifc TARGET_OS_MAC} {$ALIGN MAC68K} {--------------------------------------------------------------------------------------} { Parameter names and types } {--------------------------------------------------------------------------------------} const { * This event parameter may be added to any event that is posted to * the main event queue. When the event is removed from the queue and * sent to the event dispatcher, the dispatcher will retrieve the * EventTargetRef contained in this parameter and send the event * directly to that event target. * * Note that it is your application's responsibility to ensure that * the EventTargetRef contained in this parameter is still valid when * the event is dispatched. If the target's object is destroyed * before the event is dispatched, you must remove the event from the * event queue yourself. The behavior when attempting to dispatch an * event to invalid target is undefined and may crash. * * If this parameter is not available in the event, the dispatcher * will send the event to a suitable target, or to the application * target if no more specific target is appropriate. Available in * CarbonLib 1.3.1 and later, and Mac OS X. } kEventParamPostTarget = FourCharCode('ptrg'); { typeEventTargetRef} { * Indicates an event parameter of type EventTargetRef. } typeEventTargetRef = FourCharCode('etrg'); { EventTargetRef} { * This event parameter may be added to any event that is posted to * the main event queue. When the event is removed from the queue and * sent to the event dispatcher, the dispatcher will retrieve the * target options contained in this parameter and will pass those * options to SendEventToEventTargetWithOptions. Currently, the * available options are kEventTargetDontPropagate and * kEventTargetSendToAllHandlers. * * If this parameter is not available in the event, the dispatcher * will pass no option bits when sending the event. Available in * CarbonLib 1.3.1 and later, and Mac OS X. } kEventParamPostOptions = FourCharCode('popt'); { typeEventTargetOptions} typeEventTargetOptions = FourCharCode('etop'); { OptionBits} { Generic toolbox parameters and types} { *** NOTE ON AUTOMATIC TYPE CONVERSIONS Please keep in mind that some of these types can be automatically converted to other types just by asking for them as different types. The following type conversions are automatic: Mac OS X 10.1 and later: typeQDPoint <--> typeHIPoint Mac OS X 10.2 and later: typeQDRectangle <--> typeHIRect typeCFTypeRef(CFNumber) --> typeSInt16, typeSInt32, typeUInt32, typeSInt64 typeCFTypeRef(CFNumber) --> typeIEEE32BitFloatingPoint, typeIEEE64BitFloatingPoint typeCFTypeRef(CFBoolean) --> typeBoolean typeCFTypeRef(CFNumber) --> typeBoolean typeCFTypeRef(AXUIElementRef) --> typeHIAccessibleObjectRef any CF type other than typeCFTypeRef --> typeCFTypeRef Mac OS X 10.4 and later: type[Mutable]CFStringRef --> typeUnicodeText Mac OS X 10.5 and later: typeVoidPtr <--> typeSInt32 (32-bit only) <--> typeUInt32 (32-bit only) typeByteCount <--> typeSInt32 (32-bit only) typeByteOffset <--> typeSInt32 (32-bit only) typeGDHandle <--> typeCGDisplayID (32-bit only) typeCGFloat <--> typeFloat/typeIEEE64BitFloatingPoint (32-bit only) The following event parameter types allow clients to explicitly state the coordinate space of the point, size, rectangle or scalar. Automatic translations are provided between all of the various coordinate spaces. The 72DPIGlobal coordinate space is assumed for the pre-existing point, size, rectangle and scalar types. For more information on coordinate spaces see HIGeometry.h. typeHIPoint <--> typeHIPoint72DPIGlobal, typeHIPointScreenPixel typeHISize <--> typeHISize72DPIGlobal, typeHISizeScreenPixel typeHIRect <--> typeHIRect72DPIGlobal, typeHIRectScreenPixel typeCGFloat <--> typeCGFloat72DPIGlobal, typeCGFloatScreenPixel Also, any registered AppleEvent coercion handlers will be called to coerce data types that are otherwise not convertable. } const kEventParamWindowRef = FourCharCode('wind'); { typeWindowRef} kEventParamGrafPort = FourCharCode('graf'); { typeGrafPtr} kEventParamMenuRef = FourCharCode('menu'); { typeMenuRef} kEventParamEventRef = FourCharCode('evnt'); { typeEventRef} kEventParamControlRef = FourCharCode('ctrl'); { typeControlRef} kEventParamRgnHandle = FourCharCode('rgnh'); { typeQDRgnHandle} kEventParamEnabled = FourCharCode('enab'); { typeBoolean} kEventParamDimensions = FourCharCode('dims'); { typeQDPoint} kEventParamBounds = FourCharCode('boun'); { typeQDRectangle} kEventParamAvailableBounds = FourCharCode('avlb'); { typeQDRectangle} kEventParamAEEventID = keyAEEventID; { typeType} kEventParamAEEventClass = keyAEEventClass; { typeType} kEventParamCGContextRef = FourCharCode('cntx'); { typeCGContextRef} kEventParamCGImageRef = FourCharCode('cgim'); { typeCGImageRef} kEventParamDeviceDepth = FourCharCode('devd'); { typeSInt16} kEventParamDeviceColor = FourCharCode('devc'); { typeBoolean} kEventParamMutableArray = FourCharCode('marr'); { typeCFMutableArrayRef} kEventParamResult = FourCharCode('ansr'); { any type - depends on event like direct object} kEventParamMinimumSize = FourCharCode('mnsz'); { typeHISize} kEventParamMaximumSize = FourCharCode('mxsz'); { typeHISize} kEventParamAttributes = FourCharCode('attr'); { typeUInt32} kEventParamReason = FourCharCode('why?'); { typeUInt32} kEventParamTransactionID = FourCharCode('trns'); { typeUInt32} kEventParamDisplayDevice = FourCharCode('gdev'); { typeCGDisplayID or typeGDHandle} kEventParamGDevice = kEventParamDisplayDevice; kEventParamIndex = FourCharCode('indx'); { typeCFIndex} kEventParamUserData = FourCharCode('usrd'); { typeVoidPtr} kEventParamShape = FourCharCode('shap'); { typeHIShapeRef} typeWindowRef = FourCharCode('wind'); { WindowRef} typeGrafPtr = FourCharCode('graf'); { CGrafPtr} typeGWorldPtr = FourCharCode('gwld'); { GWorldPtr} typeMenuRef = FourCharCode('menu'); { MenuRef} typeControlRef = FourCharCode('ctrl'); { ControlRef} typeCollection = FourCharCode('cltn'); { Collection} typeQDRgnHandle = FourCharCode('rgnh'); { RgnHandle} typeOSStatus = FourCharCode('osst'); { OSStatus} typeCFIndex = FourCharCode('cfix'); { CFIndex} typeCGContextRef = FourCharCode('cntx'); { CGContextRef} typeCGImageRef = FourCharCode('cgim'); { CGImageRef} typeHIPoint = FourCharCode('hipt'); { HIPoint} typeHISize = FourCharCode('hisz'); { HISize} typeHIRect = FourCharCode('hirc'); { HIRect} typeHIShapeRef = FourCharCode('shap'); { HIShapeRef} typeVoidPtr = FourCharCode('void'); { void *} typeGDHandle = FourCharCode('gdev'); { GDHandle} typeCGDisplayID = FourCharCode('cgid'); { CGDirectDisplayID} typeCGFloat = FourCharCode('cgfl'); { CGFloat} typeHIPoint72DPIGlobal = FourCharCode('hipg'); { HIPoint} typeHIPointScreenPixel = FourCharCode('hips'); { HIPoint} typeHISize72DPIGlobal = FourCharCode('hisg'); { HISize} typeHISizeScreenPixel = FourCharCode('hiss'); { HISize} typeHIRect72DPIGlobal = FourCharCode('hirg'); { HIRect} typeHIRectScreenPixel = FourCharCode('hirs'); { HIRect} typeCGFloat72DPIGlobal = FourCharCode('hifg'); { CGFloat} typeCGFloatScreenPixel = FourCharCode('hifs'); { CGFloat} kEventParamDisplayChangeFlags = FourCharCode('cgdp'); { typeCGDisplayChangeFlags} typeCGDisplayChangeFlags = FourCharCode('cgdf'); { CGDisplayChangeSummaryFlags } { Event parameter changes for 64-bit applications With the introduction of 64-bit support in the Carbon Event Manager, four kinds of event parameters require changes to their underlying data types. The parameters that have changed are used to pass refcon data, byte counts, byte offsets, and graphics devices. In the case of refcon data, byte counts, and byte offsets, these parameters used typeSInt32 or typeUInt32 as the event parameter type prior to Mac OS X 10.5. Unfortunately, typeSInt32 and typeUInt32 specify a 32-bit value, and on Mac OS X 10.5, these parameters must be 64 bits wide when compiling for the 64-bit API so that 64-bit pointers, byte counts, and byte offsets may be passed without truncation. We have defined three new event parameter types to provide source compatibility between 32-bit and 64-bit applications: typeRefCon, typeByteCount, and typeByteOffset. Use of these types by 32-bit applications is optional; the toolbox provides automatic coercion between the old types and the new types where needed (typeRefCon), so existing apps will continue to run, and you may recompile an existing 32-bit app on Mac OS X 10.5 without modification to use these types. However, you must use these new types in order to work properly with the 64-bit API. The actual value of these constants is dependent on whether you are compiling for a 32-bit or 64-bit target, and in the case of typeRefCon, on the value of the preprocessor macro MAC_OS_X_VERSION_MIN_REQUIRED, which specifies the minimum Mac OS X system version on which your application will run. typeRefCon is always equal to typeVoidPtr for 64-bit targets. It is also equal to typeVoidPtr when compiling 32-bit targets for Mac OS X 10.5 and later, but is equal to typeSInt32 when compiling for earlier versions of Mac OS X. The Carbon Event Manager in Mac OS X 10.5 and later will automatically convert between typeVoidPtr and typeSInt32 for 32-bit apps (but not for 64-bit apps). typeByteCount and typeByteOffset use typeUInt64 for 64-bit targets, and typeUInt32 for 32-bit targets. The parameters that have changed to use these types formerly used typeSInt32 (typeLongInteger), not typeUInt32, but in practice they always refer to positive values which the toolbox will convert automatically to/from typeUInt32, so no binary compatibility problem is introduced by using the new types in an application compiled on Mac OS X 10.5 and run on prior systems. When compiling your code using the Mac OS X 10.5 header files, if you don't care about 64-bit compilation, you may continue to use typeSInt32 or typeLongInteger to extract refcon, byte count, and byte offset parameters; the coercion handlers provided by the toolbox will convert event parameter data using typeVoidPtr, typeByteCount, or typeByteOffset to your requested data type. If you want code that will run cleanly on both 32-bit and 64-bit targets, you should modify your calls to GetEventParameter to use typeRefCon, typeByteCount, or typeByteOffset instead of typeSInt32 or typeLongInteger. Using these preferred types will allow your 32-bit application to run on both pre-10.5 and 10.5 systems, and will allow your 64-bit application to run on 10.5 and later. Note that when extracting data from an event parameter of typeRefCon, the data type of the variable to which the parameter data is written should always be pointer-sized; i.e., use void* or SRefCon/URefCon/ PRefCon, not SInt32. Using a 32-bit variable will fail on 64-bit targets. Similarly, when extracting data from an event parameter of typeByteCount or typeByteOffset, always use the corresponding basic data type (ByteCount or ByteOffset), and use sizeof(ByteCount) or sizeof(ByteOffset), not sizeof(SInt32) or sizeof(UInt32), to specify the amount of data that you need. typeRefCon is currently used by the following events: kEventTSMDocumentAccessGetLength kEventTSMDocumentAccessGetSelectedRange kEventTSMDocumentAccessGetCharactersPtr kEventTSMDocumentAccessGetCharactersPtrForLargestBuffer kEventTSMDocumentAccessGetCharacters kEventTSMDocumentAccessGetFont kEventTSMDocumentAccessGetGlyphInfo kEventTSMDocumentAccessGetFirstRectForRange kEventTSMDocumentAccessLockDocument kEventTSMDocumentAccessUnlockDocument kEventTextInputUpdateActiveInputArea kEventTextInputUnicodeForKeyEvent kEventTextInputOffsetToPos kEventTextInputPosToOffset kEventTextInputShowHideBottomWindow kEventTextInputGetSelectedText kEventTextInputFilterText kEventAppLaunchNotification kEventControlArbitraryMessage typeByteCount is currently used by the following events: kEventControlSetData kEventControlGetData typeByteOffset is currently used by the following events: kEventTextInputPosToOffset In the case of graphics devices, some event parameters used typeGDHandle prior to Mac OS X 10.5. However, the GDHandle type is not available in 64-bit mode, and on Mac OS X 10.5, these parameters contain CGDirectDisplayIDs instead. We have defined a new event parameter type, typeCGDisplayID, to indicate that the data type of a graphics device event parameter is a CGDirectDisplayID instead of a GDHandle. We are not providing a generic type that changes its value based on the ABI or minimum required system version, because you will need to explicitly choose in your code which type of graphics device identifier you need. Use of typeCGDisplayID by 32-bit applications is optional; the toolbox provides automatic coercion between typeCGDisplayID and typeGDHandle, so existing apps will continue to run, and you may recompile an existing 32-bit app on Mac OS X 10.5 without modification to typeCGDisplayID. However, you must use typeCGDisplayID in order to work properly with the 64-bit API. typeCGDisplayID is currently used by the following events: kEventAppAvailableWindowBoundsChanged kEventWindowConstrain kEventMenuGetFrameBounds } type typeRefCon = UnivPtr; // PRefCon {$ifc TARGET_CPU_64} type typeByteCount = UInt64; // ByteCount typeByteOffset = UInt64; // ByteOffset typeSignedByteCount = SInt64; // Size typeSignedByteOffset = SInt64; // Size {$elsec} {TARGET_CPU_64} type typeByteCount = UInt32; // ByteCount typeByteOffset = UInt32; // ByteOffset typeSignedByteCount = SInt32; // Size typeSignedByteOffset = SInt32; // Size {$endc} {TARGET_CPU_64} { Mouse event parameters and types} const kEventParamMouseLocation = FourCharCode('mloc'); { typeHIPoint} kEventParamWindowMouseLocation = FourCharCode('wmou'); { typeHIPoint (Mac OS X 10.1 or later)} kEventParamMouseButton = FourCharCode('mbtn'); { typeMouseButton} kEventParamClickCount = FourCharCode('ccnt'); { typeUInt32} kEventParamMouseWheelAxis = FourCharCode('mwax'); { typeMouseWheelAxis} kEventParamMouseWheelDelta = FourCharCode('mwdl'); { typeSInt32} kEventParamMouseWheelSmoothVerticalDelta = FourCharCode('saxy'); { typeSInt32} kEventParamMouseWheelSmoothHorizontalDelta = FourCharCode('saxx'); { typeSInt32} kEventParamMouseDelta = FourCharCode('mdta'); { typeHIPoint (10.2 or later) or typeQDPoint} kEventParamMouseChord = FourCharCode('chor'); { typeUInt32} kEventParamTabletEventType = FourCharCode('tblt'); { typeUInt32} kEventParamMouseTrackingRef = FourCharCode('mtrf'); { typeMouseTrackingRef} typeMouseButton = FourCharCode('mbtn'); { EventMouseButton} typeMouseWheelAxis = FourCharCode('mwax'); { EventMouseWheelAxis} typeMouseTrackingRef = FourCharCode('mtrf'); { MouseTrackingRef} { Gesture event parameters} const kEventParamMagnificationAmount = FourCharCode('magn'); { typeCGFloat} kEventParamRotationAmount = FourCharCode('rota'); { typeCGFloat} kEventParamSwipeDirection = FourCharCode('swip'); { typeHIPoint} { Keyboard event parameter and types} const kEventParamKeyCode = FourCharCode('kcod'); { typeUInt32} kEventParamKeyMacCharCodes = FourCharCode('kchr'); { typeChar (DEPRECATED for 64bit on Mac OS X 10.6 and later.)} kEventParamKeyModifiers = FourCharCode('kmod'); { typeUInt32} kEventParamKeyUnicodes = FourCharCode('kuni'); { typeUnicodeText} kEventParamKeyboardType = FourCharCode('kbdt'); { typeUInt32} typeEventHotKeyID = FourCharCode('hkid'); { EventHotKeyID} { General TSM event parameters} const kEventParamTSMSendRefCon = FourCharCode('tsrc'); { typeRefCon} kEventParamTSMSendComponentInstance = FourCharCode('tsci'); { typeComponentInstance} { TextInput event parameters} const kEventParamTextInputSendRefCon = kEventParamTSMSendRefCon; { typeRefCon} kEventParamTextInputSendComponentInstance = kEventParamTSMSendComponentInstance; { typeComponentInstance} kEventParamTextInputSendSLRec = FourCharCode('tssl'); { typeIntlWritingCode} kEventParamTextInputReplySLRec = FourCharCode('trsl'); { typeIntlWritingCode} kEventParamTextInputSendText = FourCharCode('tstx'); { typeUnicodeText (if TSMDocument is Unicode), otherwise typeChar} kEventParamTextInputReplyText = FourCharCode('trtx'); { typeUnicodeText (if TSMDocument is Unicode), otherwise typeChar} kEventParamTextInputSendAttributedString = FourCharCode('tsas'); { typeCFAttributedStringRef} kEventParamTextInputReplyAttributedString = FourCharCode('tras'); { typeCFAttributedStringRef} kEventParamTextInputSendUpdateRng = FourCharCode('tsup'); { typeTextRangeArray} kEventParamTextInputSendHiliteRng = FourCharCode('tshi'); { typeTextRangeArray} kEventParamTextInputSendClauseRng = FourCharCode('tscl'); { typeOffsetArray} kEventParamTextInputSendPinRng = FourCharCode('tspn'); { typeTextRange} kEventParamTextInputSendFixLen = FourCharCode('tsfx'); { typeSignedByteCount} kEventParamTextInputSendLeadingEdge = FourCharCode('tsle'); { typeBoolean} kEventParamTextInputReplyLeadingEdge = FourCharCode('trle'); { typeBoolean} kEventParamTextInputSendTextOffset = FourCharCode('tsto'); { typeSignedByteOffset} kEventParamTextInputReplyTextOffset = FourCharCode('trto'); { typeByteOffset} kEventParamTextInputReplyRegionClass = FourCharCode('trrg'); { typeSInt32} kEventParamTextInputSendCurrentPoint = FourCharCode('tscp'); { typeHIPoint} kEventParamTextInputSendDraggingMode = FourCharCode('tsdm'); { typeBoolean} kEventParamTextInputReplyPoint = FourCharCode('trpt'); { typeHIPoint} kEventParamTextInputReplyFont = FourCharCode('trft'); { typeSInt32} kEventParamTextInputReplyFMFont = FourCharCode('trfm'); { typeUInt32} kEventParamTextInputReplyPointSize = FourCharCode('trpz'); { typeCGFloat (originally typeFixed)} kEventParamTextInputReplyLineHeight = FourCharCode('trlh'); { typeCGFloat (originally typeSInt16)} kEventParamTextInputReplyLineAscent = FourCharCode('trla'); { typeCGFloat (originally typeSInt16)} kEventParamTextInputReplyCTFontRef = FourCharCode('trcf'); { typeCTFontRef} kEventParamTextInputReplyATSFont = FourCharCode('traf'); { typeATSFontRef} kEventParamTextInputReplyTextAngle = FourCharCode('trta'); { typeFixed} kEventParamTextInputSendShowHide = FourCharCode('tssh'); { typeBoolean} kEventParamTextInputReplyShowHide = FourCharCode('trsh'); { typeBoolean} kEventParamTextInputSendKeyboardEvent = FourCharCode('tske'); { typeEventRef} kEventParamTextInputSendTextServiceEncoding = FourCharCode('tsse'); { typeUInt32} kEventParamTextInputSendTextServiceMacEncoding = FourCharCode('tssm'); { typeUInt32} kEventParamTextInputReplyMacEncoding = FourCharCode('trme'); { typeUInt32} kEventParamTextInputGlyphInfoArray = FourCharCode('glph'); { typeGlyphInfoArray} kEventParamTextInputSendGlyphInfoArray = kEventParamTextInputGlyphInfoArray; kEventParamTextInputReplyGlyphInfoArray = FourCharCode('rgph'); { typeGlyphInfoArray} kEventParamTextInputSendReplaceRange = FourCharCode('tsrp'); { typeCFRange} kEventParamTextInputSendMouseEvent = FourCharCode('tsme'); { typeEventRef} { TSMDocumentAccess event parameters and types} const kEventParamTSMDocAccessSendRefCon = kEventParamTSMSendRefCon; { typeRefCon} kEventParamTSMDocAccessSendComponentInstance = kEventParamTSMSendComponentInstance; { typeComponentInstance} kEventParamTSMDocAccessCharacterCount = FourCharCode('tdct'); { typeCFIndex} kEventParamTSMDocAccessReplyCharacterRange = FourCharCode('tdrr'); { typeCFRange} kEventParamTSMDocAccessReplyCharactersPtr = FourCharCode('tdrp'); { typePtr} kEventParamTSMDocAccessSendCharacterIndex = FourCharCode('tdsi'); { typeCFIndex} kEventParamTSMDocAccessSendCharacterRange = FourCharCode('tdsr'); { typeCFRange} kEventParamTSMDocAccessSendCharactersPtr = FourCharCode('tdsp'); { typePtr} kEventParamTSMDocAccessRequestedCharacterAttributes = FourCharCode('tdca'); { typeUInt32} kEventParamTSMDocAccessReplyCTFontRef = FourCharCode('tdcf'); { typeCTFontRef} kEventParamTSMDocAccessReplyATSFont = FourCharCode('tdaf'); { typeATSFontRef} kEventParamTSMDocAccessReplyFontSize = FourCharCode('tdrs'); { typeCGFloat (originally typeFloat)} kEventParamTSMDocAccessEffectiveRange = FourCharCode('tder'); { typeRange} kEventParamTSMDocAccessReplyCTGlyphInfoRef = FourCharCode('tdri'); { typeCTGlyphInfoRef} kEventParamTSMDocAccessReplyATSUGlyphSelector = FourCharCode('tdrg'); { typeGlyphSelector} kEventParamTSMDocAccessLockCount = FourCharCode('tdlc'); { typeCFIndex} kEventParamTSMDocAccessLineBounds = FourCharCode('tdlb'); { typeHIRect} kEventParamTSMDocAccessBaselineDelta = FourCharCode('tdbd'); { typeCGFloat} typeATSFontRef = FourCharCode('atsf'); { ATSFontRef} typeGlyphSelector = FourCharCode('glfs'); { ATSUGlyphSelector} { Command event parameters and types} const kEventParamHICommand = FourCharCode('hcmd'); { typeHICommand} typeHICommand = FourCharCode('hcmd'); { HICommand} { Window event parameters and types} const kEventParamWindowFeatures = FourCharCode('wftr'); { typeUInt32} kEventParamWindowDefPart = FourCharCode('wdpc'); { typeWindowDefPartCode} kEventParamWindowPartCode = FourCharCode('wpar'); { typeWindowPartCode} kEventParamCurrentBounds = FourCharCode('crct'); { typeQDRectangle} kEventParamOriginalBounds = FourCharCode('orct'); { typeQDRectangle} kEventParamPreviousBounds = FourCharCode('prct'); { typeQDRectangle} kEventParamClickActivation = FourCharCode('clac'); { typeClickActivationResult} kEventParamWindowRegionCode = FourCharCode('wshp'); { typeWindowRegionCode} kEventParamWindowContentBounds = FourCharCode('wcbn'); { typeQDRectangle} kEventParamWindowDragHiliteFlag = FourCharCode('wdhf'); { typeBoolean} kEventParamWindowModifiedFlag = FourCharCode('wmff'); { typeBoolean} kEventParamWindowProxyGWorldPtr = FourCharCode('wpgw'); { typeGWorldPtr} kEventParamWindowProxyImageRgn = FourCharCode('wpir'); { typeQDRgnHandle} kEventParamWindowProxyOutlineRgn = FourCharCode('wpor'); { typeQDRgnHandle} kEventParamWindowStateChangedFlags = FourCharCode('wscf'); { typeUInt32 } kEventParamWindowTitleFullWidth = FourCharCode('wtfw'); { typeSInt16} kEventParamWindowTitleTextWidth = FourCharCode('wttw'); { typeSInt16} kEventParamWindowGrowRect = FourCharCode('grct'); { typeQDRectangle} kEventParamPreviousDockRect = FourCharCode('pdrc'); { typeHIRect} kEventParamPreviousDockDevice = FourCharCode('pdgd'); { typeGDHandle (10.3 and later), typeCGDisplayID (10.5 and later)} kEventParamCurrentDockRect = FourCharCode('cdrc'); { typeHIRect} kEventParamCurrentDockDevice = FourCharCode('cdgd'); { typeGDHandle (10.3 and later), typeCGDisplayID (10.5 and later)} kEventParamWindowTransitionAction = FourCharCode('wtac'); { typeWindowTransitionAction} kEventParamWindowTransitionEffect = FourCharCode('wtef'); { typeWindowTransitionEffect} typeWindowRegionCode = FourCharCode('wshp'); { WindowRegionCode} typeWindowDefPartCode = FourCharCode('wdpt'); { WindowDefPartCode} typeWindowPartCode = FourCharCode('wpar'); { WindowPartCode} typeClickActivationResult = FourCharCode('clac'); { ClickActivationResult} typeWindowTransitionAction = FourCharCode('wtac'); { WindowTransitionAction} typeWindowTransitionEffect = FourCharCode('wtef'); { WindowTransitionEffect} { Control event parameters and types} const kEventParamControlPart = FourCharCode('cprt'); { typeControlPartCode} kEventParamInitCollection = FourCharCode('icol'); { typeCollection} kEventParamControlMessage = FourCharCode('cmsg'); { typeSInt16} kEventParamControlParam = FourCharCode('cprm'); { typeRefCon} kEventParamControlResult = FourCharCode('crsl'); { typeSInt32} kEventParamControlRegion = FourCharCode('crgn'); { typeQDRgnHandle} kEventParamControlAction = FourCharCode('caup'); { typeControlActionUPP} kEventParamControlIndicatorDragConstraint = FourCharCode('cidc'); { typeIndicatorDragConstraint} kEventParamControlIndicatorRegion = FourCharCode('cirn'); { typeQDRgnHandle} kEventParamControlIsGhosting = FourCharCode('cgst'); { typeBoolean} kEventParamControlIndicatorOffset = FourCharCode('ciof'); { typeQDPoint} kEventParamControlClickActivationResult = FourCharCode('ccar'); { typeClickActivationResult} kEventParamControlSubControl = FourCharCode('csub'); { typeControlRef} kEventParamControlOptimalBounds = FourCharCode('cobn'); { typeQDRectangle} kEventParamControlOptimalBaselineOffset = FourCharCode('cobo'); { typeSInt16} kEventParamControlDataTag = FourCharCode('cdtg'); { typeEnumeration} kEventParamControlDataBuffer = FourCharCode('cdbf'); { typePtr} kEventParamControlDataBufferSize = FourCharCode('cdbs'); { typeByteCount} kEventParamControlDrawDepth = FourCharCode('cddp'); { typeSInt16} kEventParamControlDrawInColor = FourCharCode('cdic'); { typeBoolean} kEventParamControlDrawEngraved = FourCharCode('cden'); { typeBoolean} kEventParamControlFeatures = FourCharCode('cftr'); { typeUInt32} kEventParamControlPartBounds = FourCharCode('cpbd'); { typeQDRectangle} kEventParamControlOriginalOwningWindow = FourCharCode('coow'); { typeWindowRef} kEventParamControlCurrentOwningWindow = FourCharCode('ccow'); { typeWindowRef} kEventParamControlFocusEverything = FourCharCode('cfev'); { typeBoolean} kEventParamNextControl = FourCharCode('cnxc'); { typeControlRef} kEventParamStartControl = FourCharCode('cstc'); { typeControlRef} kEventParamControlSubview = FourCharCode('csvw'); { typeControlRef} kEventParamControlPreviousPart = FourCharCode('copc'); { typeControlPartCode} kEventParamControlCurrentPart = FourCharCode('cnpc'); { typeControlPartCode} kEventParamControlInvalRgn = FourCharCode('civr'); { typeQDRgnHandle} kEventParamControlValue = FourCharCode('cval'); { typeSInt32} kEventParamControlHit = FourCharCode('chit'); { typeBoolean} kEventParamControlPartAutoRepeats = FourCharCode('caur'); { typeBoolean} kEventParamControlFrameMetrics = FourCharCode('cfmt'); { typeControlFrameMetrics} kEventParamControlWouldAcceptDrop = FourCharCode('cldg'); { typeBoolean} kEventParamControlPrefersShape = FourCharCode('cpsh'); { typeBoolean} typeControlActionUPP = FourCharCode('caup'); { ControlActionUPP} typeIndicatorDragConstraint = FourCharCode('cidc'); { IndicatorDragConstraint} typeControlPartCode = FourCharCode('cprt'); { ControlPartCode} typeControlFrameMetrics = FourCharCode('cins'); { HIViewFrameMetrics} { Menu event parameters and types} const kEventParamCurrentMenuTrackingMode = FourCharCode('cmtm'); { typeMenuTrackingMode} kEventParamNewMenuTrackingMode = FourCharCode('nmtm'); { typeMenuTrackingMode} kEventParamMenuFirstOpen = FourCharCode('1sto'); { typeBoolean} kEventParamMenuItemIndex = FourCharCode('item'); { typeMenuItemIndex} kEventParamMenuCommand = FourCharCode('mcmd'); { typeMenuCommand} kEventParamEnableMenuForKeyEvent = FourCharCode('fork'); { typeBoolean} kEventParamMenuEventOptions = FourCharCode('meop'); { typeMenuEventOptions} kEventParamMenuContext = FourCharCode('mctx'); { typeUInt32} kEventParamMenuDismissed = FourCharCode('mdis'); { typeUInt32} kEventParamMenuItemBounds = FourCharCode('mitb'); { typeQDRectangle} kEventParamMenuMarkBounds = FourCharCode('mmkb'); { typeQDRectangle} kEventParamMenuIconBounds = FourCharCode('micb'); { typeQDRectangle} kEventParamMenuTextBounds = FourCharCode('mtxb'); { typeQDRectangle} kEventParamMenuTextBaseline = FourCharCode('mtbl'); { typeSInt16} kEventParamMenuCommandKeyBounds = FourCharCode('mcmb'); { typeQDRectangle} kEventParamMenuVirtualTop = FourCharCode('mvrt'); { typeSInt32} kEventParamMenuVirtualBottom = FourCharCode('mvrb'); { typeSInt32} kEventParamMenuDrawState = FourCharCode('mdrs'); { typeThemeMenuState} kEventParamMenuItemType = FourCharCode('mitp'); { typeThemeMenuItemType} kEventParamMenuItemWidth = FourCharCode('mitw'); { typeSInt16} kEventParamMenuItemHeight = FourCharCode('mith'); { typeSInt16} kEventParamMenuFrameView = FourCharCode('mfrv'); { typeControlRef} kEventParamMenuType = FourCharCode('mtyp'); { typeThemeMenuType} kEventParamMenuIsPopup = FourCharCode('mpop'); { typeBoolean} kEventParamMenuDirection = FourCharCode('mdir'); { typeMenuDirection} kEventParamParentMenu = FourCharCode('mprm'); { typeMenuRef} kEventParamParentMenuItem = FourCharCode('mpri'); { typeMenuItemIndex} kEventParamMenuPopupItem = FourCharCode('mpit'); { typeMenuItemIndex} kEventParamMenuContextHeight = FourCharCode('mcht'); { typeCGFloat} typeMenuItemIndex = FourCharCode('midx'); { MenuItemIndex} typeMenuCommand = FourCharCode('mcmd'); { MenuCommand} typeMenuTrackingMode = FourCharCode('mtmd'); { MenuTrackingMode} typeMenuEventOptions = FourCharCode('meop'); { MenuEventOptions} typeThemeMenuState = FourCharCode('tmns'); { ThemeMenuState} typeThemeMenuItemType = FourCharCode('tmit'); { ThemeMenuItemType} typeMenuDirection = FourCharCode('mdir'); { UInt32} typeThemeMenuType = FourCharCode('tmty'); { ThemeMenuType} { Application event parameters} const kEventParamProcessID = FourCharCode('psn '); { typeProcessSerialNumber} kEventParamLaunchRefCon = FourCharCode('lref'); { typeRefCon} kEventParamLaunchErr = FourCharCode('err '); { typeOSStatus} kEventParamSystemUIMode = FourCharCode('uimd'); { typeUInt32} kEventParamSystemUIOptions = FourCharCode('uiop'); { typeUInt32} kEventParamIsInInstantMouser = FourCharCode('imou'); { typeBoolean} kEventParamPreviousWindow = FourCharCode('prvw'); { typeWindowRef} kEventParamCurrentWindow = FourCharCode('curw'); { typeWindowRef} { Tablet event parameters and types} const kEventParamTabletPointRec = FourCharCode('tbrc'); { typeTabletPointRec} kEventParamTabletProximityRec = FourCharCode('tbpx'); { typeTabletProximityRec} typeTabletPointRec = FourCharCode('tbrc'); { kEventParamTabletPointRec} typeTabletProximityRec = FourCharCode('tbpx'); { kEventParamTabletProximityRec} { Appearance event parameters} const kEventParamNewScrollBarVariant = FourCharCode('nsbv'); { typeSInt16} { Service event parameters} const kEventParamPasteboardRef = FourCharCode('pbrd'); { typePasteboardRef} kEventParamScrapRef = FourCharCode('scrp'); { typeScrapRef} kEventParamServiceCopyTypes = FourCharCode('svsd'); { typeCFMutableArrayRef} kEventParamServicePasteTypes = FourCharCode('svpt'); { typeCFMutableArrayRef} kEventParamServiceMessageName = FourCharCode('svmg'); { typeCFStringRef} kEventParamServiceUserData = FourCharCode('svud'); { typeCFStringRef} typePasteboardRef = FourCharCode('pbrd'); { PasteboardRef} typeScrapRef = FourCharCode('scrp'); { ScrapRef} { Accessibility event parameters} const kEventParamAccessibleObject = FourCharCode('aobj'); { typeCFTypeRef with an AXUIElementRef} kEventParamAccessibleChild = FourCharCode('achl'); { typeCFTypeRef with an AXUIElementRef} kEventParamAccessibleAttributeName = FourCharCode('atnm'); { typeCFStringRef} kEventParamAccessibleAttributeNames = FourCharCode('atns'); { typeCFMutableArrayRef of CFStringRefs} kEventParamAccessibleAttributeValue = FourCharCode('atvl'); { variable} kEventParamAccessibleAttributeSettable = FourCharCode('atst'); { typeBoolean} kEventParamAccessibleAttributeParameter = FourCharCode('atpa'); { typeCFTypeRef} kEventParamAccessibleActionName = FourCharCode('acnm'); { typeCFStringRef} kEventParamAccessibleActionNames = FourCharCode('acns'); { typeCFMutableArrayRef of CFStringRefs} kEventParamAccessibleActionDescription = FourCharCode('acds'); { typeCFMutableStringRef} kEventParamAccessibilityEventQueued = FourCharCode('aequ'); { typeBoolean} { Text field event type} const typeCFRange = FourCharCode('cfrn'); { CFRange} { AppleEvent event parameters} const kEventParamAppleEvent = FourCharCode('aevt'); { typeAppleEvent} kEventParamAppleEventReply = FourCharCode('aerp'); { typeAppleEvent} {--------------------------------------------------------------------------------------} { ¥ Helpful utilities } {--------------------------------------------------------------------------------------} { * MouseTrackingResult * * Discussion: * These constants are returned from calls to TrackMouseLocation, * TrackMouseLocationWithOptions, TrackMouseRegion, * HIViewTrackMouseLocation, and HIViewTrackMouseShape. Those * routines are designed as replacements to calls such as StillDown * and WaitMouseUp. The advantage over those routines is that the * tracking APIs will block if the user is not moving the mouse, * whereas mouse tracking loops based on StillDown and WaitMouseUp * will spin, chewing up valuable CPU time that could be better * spent elsewhere. It is highly recommended that any tracking loops * in your application stop using StillDown and WaitMouseUp and * start using a tracking API. See the notes on those routines for * more information. } type MouseTrackingResult = UInt16; const { * kMouseTrackingMouseDown is returned when the user presses any * mouse button. } kMouseTrackingMouseDown = 1; { * kMouseTrackingMouseUp is returned when the user releases a mouse * button. Typically you would look for this result in a mouse * tracking loop to know when to exit the loop. } kMouseTrackingMouseUp = 2; { * kMouseTrackingMouseExited is returned when the user moves the * mouse out of the specified region. This value is only returned * from TrackMouseRegion and HIViewTrackMouseShape. } kMouseTrackingMouseExited = 3; { * kMouseTrackingMouseEntered is returned when the user moves the * mouse into the specified region. This value is only returned from * TrackMouseRegion and HIViewTrackMouseShape. } kMouseTrackingMouseEntered = 4; { * kMouseTrackingMouseDragged is returned when the user moves the * mouse while holding down a mouse button. This value is not * returned by TrackMouseRegion or HIViewTrackMouseShape; instead, * when the mouse moves, those APIs check if the mouse has moved into * or out of the specified region, and return * kMouseTrackingMouseEntered/Exited. } kMouseTrackingMouseDragged = 5; { * kMouseTrackingKeyModifiersChanged is returned when the user * changes the keyboard modifiers. This value is not returned by * TrackMouseRegion. It is returned by all other tracking APIs. } kMouseTrackingKeyModifiersChanged = 6; { * kMouseTrackingUserCancelled is returned if the user presses the * escape or cmd-period keys during mouse tracking. This value is * returned by TrackMouseRegion in Mac OS X 10.2 and CarbonLib 1.6 * and later, and by all versions of all other tracking APIs. } kMouseTrackingUserCancelled = 7; { * kMouseTrackingTimedOut is returned if the timeout expires. This * value is only returned by APIs that take a timeout parameter. } kMouseTrackingTimedOut = 8; { * kMouseTrackingMouseMoved is returned when the user moves the mouse * while no mouse button is pressed. It is not returned by * TrackMouseRegion or HIViewTrackMouseShape; instead, when the mouse * moves, those APIs check if the mouse has moved into or out of the * specified region, and return kMouseTrackingMouseEntered/Exited. * Available in Mac OS X 10.2 and CarbonLib 1.6 and later. } kMouseTrackingMouseMoved = 9; { * kMouseTrackingClientEvent is returned when a caller-specified * event was received during mouse tracking. This value is only * returned by APIs that take a client- specified list of event * parameters. Available in Mac OS X 10.5 and later. } kMouseTrackingClientEvent = 10; { * kMouseTrackingScrollWheel is returned when the user scrolls a * mouse wheel. This value is only returned when the * kTrackMouseLocationOptionIncludeScrollWheel option bit is * specified in a call to TrackMouseLocationWithOptions, * HIViewTrackMouseLocation, or HIViewTrackMouseShape. Available in * Mac OS X 10.5 and later. } kMouseTrackingScrollWheel = 11; { * Summary: * Constants for use with the OptionBits parameter to * TrackMouseLocationWithOptions, HIViewTrackMouseLocation, and * HIViewTrackMouseShape. } const { * Indicates that mouse-up events should be left in the queue. } kTrackMouseLocationOptionDontConsumeMouseUp = 1 shl 0; { * Indicates that kEventMouseWheelMoved and kEventMouseScroll events * should cause the tracking API to stop tracking and return * kMouseTrackingScrollWheel. } kTrackMouseLocationOptionIncludeScrollWheel = 1 shl 3; { * CheckEventQueueForUserCancel() * * Summary: * Determines if there is a cancel event in the main thread's event * queue. * * Discussion: * This API supports two cancel events: Escape and Cmd-Period. The * cancel event itself, as well as mouse or keyboard events in front * of the cancel event in the event queue, will be removed from the * queue. * * Mac OS X threading: * Not thread safe * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.0.2 and later * Non-Carbon CFM: not available } function CheckEventQueueForUserCancel: Boolean; external name '_CheckEventQueueForUserCancel'; (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *) { * IsUserCancelEventRef() * * Discussion: * Tests the event given to see whether the event represents a 'user * cancel' event. Currently this is defined to be either the escape * key being pressed, or command-period being pressed. * * Mac OS X threading: * Not thread safe * * Result: * A boolean value indicating whether the event is a user cancel * event. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later * Non-Carbon CFM: not available } function IsUserCancelEventRef( event: EventRef ): Boolean; external name '_IsUserCancelEventRef'; (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *) {$ifc not TARGET_CPU_64} { * TrackMouseLocation() * * Discussion: * Once entered, this routine waits for certain mouse events (move, * mouse down, mouse up). When one of these events occurs, the * function returns and tells the caller what happened and where the * mouse is currently located. While there is no activity, the * current event loop is run, effectively blocking the current * thread (save for any timers that fire). This helps to minimize * CPU usage when there is nothing going on. * * On Mac OS X 10.1 and earlier, and CarbonLib 1.5 and earlier, * TrackMouseLocation, TrackMouseLocationWithOptions, and * TrackMouseRegion only support mouse-tracking when a mouse button * is pressed. They cannot be used for mouse-tracking when no mouse * button is pressed; if called when no button is pressed, they will * simply block until a button is pressed and will not return when * the mouse is moved. On Mac OS X 10.2 and CarbonLib 1.6 and later, * TrackMouseLocation, TrackMouseLocationWithOptions, and * TrackMouseRegion support mouse-tracking without a pressed mouse * button; TrackMouseLocation and TrackMouseLocationWithOptions * return kMouseTrackingMouseMoved if the mouse is moved while no * button is pressed, and TrackMouseRegion returns * kMouseTrackingMouseEntered/Exited if the mouse moves into or out * of the specified region while no button is pressed. * * For mouse tracking within an HIView, also see * HIViewTrackMouseLocation. * * Mac OS X threading: * Not thread safe * * Parameters: * * inPort: * The grafport to consider for mouse coordinates. You can pass * NULL for this parameter to indicate the current port. The mouse * location is returned in terms of local coordinates of this * port. You can pass -1 for this parameter to indicate that the * mouse location should be returned in global coordinates instead * of local coordinates. * * outPt: * On exit, this parameter receives the mouse location from the * last mouse event that caused this function to exit. * * outResult: * On exit, this parameter receives a value representing what kind * of event was received that cause the function to exit, such as * kMouseTrackingMouseUp. * * Result: * An operating system result code. * * 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 TrackMouseLocation( inPort: GrafPtr { can be NULL }; var outPt: Point; var outResult: MouseTrackingResult ): OSStatus; external name '_TrackMouseLocation'; (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *) { * TrackMouseLocationWithOptions() * * Discussion: * This routine is largely identical to TrackMouseLocation. Please * read the notes on that function as well. * TrackMouseLocationWithOptions supports additional parameters for * leaving mouse-up events in the event queue, specifying a timeout, * and retrieving the current mouse position and keyboard modifiers. * * * For mouse tracking within an HIView, also see * HIViewTrackMouseLocation. * * Mac OS X threading: * Not thread safe * * Parameters: * * inPort: * The grafport to consider for mouse coordinates. You can pass * NULL for this parameter to indicate the current port. The mouse * location is returned in terms of local coordinates of this * port. You can pass -1 for this parameter to indicate that the * mouse location should be returned in global coordinates instead * of local coordinates. * * inOptions: * The only option supported by this routine at present is * kTrackMouseLocationOptionDontConsumeMouseUp, which indicates * that the toolbox should leave mouse-up events in the queue. You * may also pass zero for this parameter to get the default * behavior, which is to remove mouse-up events from the queue * before returning. * * inTimeout: * The amount of time to wait for an event. If no events arrive * within this time, kMouseTrackingTimedOut is returned in * outResult. Pass kEventDurationForever to wait indefinitely for * the next event. * * outPt: * On exit, this parameter receives the mouse location from the * last mouse event that caused this function to exit. If a * timeout or key modifiers changed event caused this function to * exit, the current mouse position at the time is returned. * * outModifiers: * On exit, this parameter receives the most recent state of the * keyboard modifiers. If a timeout caused this function to exit, * the current keyboard modifiers at the time are returned. * * outResult: * On exit, this parameter receives a value representing what kind * of event was received that cause the function to exit, such as * kMouseTrackingMouseUp. * * Result: * An operating system result code. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework [32-bit only] * CarbonLib: in CarbonLib 1.3 and later * Non-Carbon CFM: not available } function TrackMouseLocationWithOptions( inPort: GrafPtr { can be NULL }; inOptions: OptionBits; inTimeout: EventTimeout; var outPt: Point; outModifiers: UInt32Ptr { can be NULL }; var outResult: MouseTrackingResult ): OSStatus; external name '_TrackMouseLocationWithOptions'; (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *) { * TrackMouseRegion() * * Discussion: * This routine is largely identical to TrackMouseLocation. Please * read the notes on that function as well. TrackMouseRegion differs * from TrackMouseLocation by only returning when the mouse enters * or exits a specified region that you pass in to the function, as * opposed to whenever the mouse moves (it also returns for mouse * up/down events). This is useful if you don't need to know * intermediate mouse events, but rather just if the mouse enters or * leaves an area. * * For mouse tracking within an HIView, also see * HIViewTrackMouseShape. * * Mac OS X threading: * Not thread safe * * Parameters: * * inPort: * The grafport to consider for mouse coordinates. You can pass * NULL for this parameter to indicate the current port. You can * pass -1 for this parameter to indicate that the mouse region * should be interpreted in global coordinates instead of local * coordinates. * * inRegion: * The region to consider. This should be in the coordinates of * the port you passed to inPort, or global coordinates if you * passed -1 for the inPort parameter. * * ioWasInRgn: * On entry, this parameter should be set to true if the mouse is * currently inside the region passed in inRegion, or false if the * mouse is currently outside the region. On exit, this parameter * is updated to reflect the current reality; e.g., if the * outResult parameter returns kMouseTrackingMouseExited, * ioWasInRgn will be set to false when this function exits. * Because it is updated from within, you should only need to set * this yourself before the first call to this function in your * tracking loop. Typically, you should set this value to false * initially, and TrackMouseRegion will return immediately with * kMouseTrackingMouseEntered if your guess was wrong. * * outResult: * On exit, this parameter receives a value representing what kind * of event was received that cause the function to exit, such as * kMouseTrackingMouseEntered. * * Result: * An operating system result code. * * 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 TrackMouseRegion( inPort: GrafPtr { can be NULL }; inRegion: RgnHandle; var ioWasInRgn: Boolean; var outResult: MouseTrackingResult ): OSStatus; external name '_TrackMouseRegion'; (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *) {$endc} {not TARGET_CPU_64} { * Summary: * Mouse tracking info selectors for HIMouseTrackingGetParameters. } const { * Requests the time and distance for determining ÒstickyÓ mouse * tracking. When the mouse is clicked on a menu title, the toolbox * will enter a sticky mouse-tracking mode depending on the time and * distance between the mouse-down event and the mouse-up event. In * this mode, the menu is tracked even though the mouse has already * been released. } kMouseParamsSticky = FourCharCode('stic'); { * Requests the time and distance for initiating the drag of a * window's proxy icon. After a mouse-down on a proxy icon, if the * user begins to drag the mouse prior to the specified amount of * time elapsing, the Window Manager drags the window, but if this * amount of time elapses before the mouse moves, the Window Manager * drags the proxy icon. The Window Manager also checks that the * mouse is within the specified distance from the original * mouse-down location before beginning the proxy icon drag. This * selector is available in Mac OS X 10.5 and later. } kMouseParamsProxyIcon = FourCharCode('prox'); { * Requests the time for determining when the user intends that a * mouse-down should invoke some further action. For example, this * selector is used when the user clicks on a bevel button with an * attached menu. The bevel button will display the menu after the * user has held down the mouse for this amount of time. For this * selector, the distance output parameter is not applicable and is * set to (0,0), if not NULL. This selector is available in Mac OS X * 10.5 and later. } kMouseParamsClickAndHold = FourCharCode('clho'); { * Requests the distance for determining when the user intends to * begin a drag of the clicked object. This distance is used by the * WaitMouseMoved API to determine when the user has moved the mouse * outside of the drag threshold. For this selector, the time output * parameter is not applicable and is set to 0, if not NULL. This * selector is available in Mac OS X 10.5 and later. } kMouseParamsDragInitiation = FourCharCode('drag'); { * HIMouseTrackingGetParameters() * * Summary: * Returns information about how mouse tracking loops should behave. * * Discussion: * Mouse tracking loops may use different timeouts and wander * distances to determine their behavior. This API provides a * generic service for requesting this information. * * Mac OS X threading: * Not thread safe * * Parameters: * * inSelector: * Indicates which type of information should be returned. * * outTime: * If selector is kMouseParamsSticky, returns the maximum time * between mouse-down and mouse-up. If the time between events is * longer than this value, sticky mode should not be invoked. May * be NULL if this information is not required. * * outDistance: * If selector is kMouseParamsSticky, returns the maximum distance * between mouse-down and mouse-up. If the distance between events * is longer than this value, sticky mode should not be invoked. * May be NULL if this information is not required. * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available in CarbonLib 1.x * Non-Carbon CFM: not available } function HIMouseTrackingGetParameters( inSelector: OSType; outTime: EventTimePtr { can be NULL }; outDistance: HISizePtr { can be NULL } ): OSStatus; external name '_HIMouseTrackingGetParameters'; (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *) {$ifc not TARGET_CPU_64} { * ConvertEventRefToEventRecord() * * Discussion: * This is a convenience routine to help you if there are places in * your application where you need an EventRecord and all you have * is an EventRef. If the event can be converted, outEvent is filled * in and the function returns true. If not, false is returned and * outEvent will contain a nullEvent. * * Currently, the following events can be converted: * * kEventClassMouse: kEventMouseDown, kEventMouseUp, * kEventMouseMoved, kEventMouseDragged. * * kEventClassKeyboard: kEventRawKeyDown, kEventRawKeyUp, * kEventRawKeyRepeat. * * kEventClassControl: kEventControlTrack (in Mac OS X 10.4 and * later; converts to a mouseDown event). * * kEventClassWindow: kEventWindowUpdate, kEventWindowActivate, * kEventWindowDeactivate, kEventWindowCursorChange. * * kEventClassApplication: kEventAppActivated, kEventAppDeactivated. *

kEventClassAppleEvent: kEventAppleEvent. * * Mac OS X threading: * Not thread safe * * Parameters: * * inEvent: * The EventRef to convert into an EventRecord. * * outEvent: * The EventRecord to fill out. * * Result: * A boolean indicating if the conversion was successful (true) or * not (false). * * 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 ConvertEventRefToEventRecord( inEvent: EventRef; var outEvent: EventRecord ): Boolean; external name '_ConvertEventRefToEventRecord'; (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *) { * IsEventInMask() * * Discussion: * This is a companion function for ConvertEventRefToEventRecord, * and is provided as a convenience routine to help you if there are * places in your application where you want to check an EventRef to * see if it matches a classic EventMask bitfield. If the event * matches, the function returns true. * * Mac OS X threading: * Not thread safe * * Parameters: * * inEvent: * The EventRef to convert into an EventRecord. * * inMask: * The mask to consider. * * Result: * A boolean indicating if the event was considered to be in the * mask provided. * * 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 IsEventInMask( inEvent: EventRef; inMask: EventMask ): Boolean; external name '_IsEventInMask'; (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *) { * GetLastUserEventTime() * * Mac OS X threading: * Not thread safe * * 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 GetLastUserEventTime: EventTime; external name '_GetLastUserEventTime'; (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *) {--------------------------------------------------------------------------------------} { ¥ Mouse Coalescing } {--------------------------------------------------------------------------------------} { * IsMouseCoalescingEnabled() * * Discussion: * Returns true if mouse coalescing is current enabled. When * enabled, we coalesce mouse moved and mouse dragged events. By * default, coalescing is on, but you can use * SetMouseCoalescingEnabled to disable it if you want finer-grained * mouse movement events, which is useful for drawing with tablets. * * Mac OS X threading: * Not thread safe * * Result: * A boolean indicating if coalescing is enabled. * * Availability: * Mac OS X: in version 10.1 and later in Carbon.framework [32-bit only] * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.1 and later * Non-Carbon CFM: not available } function IsMouseCoalescingEnabled: Boolean; external name '_IsMouseCoalescingEnabled'; (* AVAILABLE_MAC_OS_X_VERSION_10_1_AND_LATER *) { * SetMouseCoalescingEnabled() * * Discussion: * Allows you to set mouse move/drag event coalescing on or off. By * default, coalescing is on, but you can use this function to * disable it if you want finer-grained mouse movement events, which * is useful for drawing with tablets. * * Mac OS X threading: * Not thread safe * * Parameters: * * inNewState: * A boolean indicating if coalescing should be enabled (true) or * disabled (false). * * outOldState: * A boolean which receives the prior state of mouse coalescing * for restoration later. You can pass NULL for this parameter if * you don't care. * * Result: * An operating system result code. * * Availability: * Mac OS X: in version 10.1 and later in Carbon.framework [32-bit only] * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.1 and later * Non-Carbon CFM: not available } function SetMouseCoalescingEnabled( inNewState: Boolean; outOldState: BooleanPtr { can be NULL } ): OSStatus; external name '_SetMouseCoalescingEnabled'; (* AVAILABLE_MAC_OS_X_VERSION_10_1_AND_LATER *) {======================================================================================} { EVENT CLASSES } {======================================================================================} {$endc} {not TARGET_CPU_64} { * Summary: * Event classes } const { * Events related to the mouse (mouse down/up/moved). } kEventClassMouse = FourCharCode('mous'); { * Events related to the keyboard. } kEventClassKeyboard = FourCharCode('keyb'); { * Events related to text input (by keyboard, or by input method). } kEventClassTextInput = FourCharCode('text'); { * Application-level events (launch, quit, etc.). } kEventClassApplication = FourCharCode('appl'); { * Apple Events. } kEventClassAppleEvent = FourCharCode('eppc'); { * Events related to menus. } kEventClassMenu = FourCharCode('menu'); { * Events related to windows. } kEventClassWindow = FourCharCode('wind'); { * Events related to controls. } kEventClassControl = FourCharCode('cntl'); { * Events related to commands generated by menu items or controls. * These events contain HICommand structures. } kEventClassCommand = FourCharCode('cmds'); { * Events related to tablets. } kEventClassTablet = FourCharCode('tblt'); { * Events related to File Manager volumes. } kEventClassVolume = FourCharCode('vol '); { * Events related to the Appearance Manager. } kEventClassAppearance = FourCharCode('appm'); { * Events related to the Services Manager. } kEventClassService = FourCharCode('serv'); { * Events related to toolbars. } kEventClassToolbar = FourCharCode('tbar'); { * Events related to toolbar items. } kEventClassToolbarItem = FourCharCode('tbit'); { * Events related to toolbar item views. } kEventClassToolbarItemView = FourCharCode('tbiv'); { * Events related to application accessibility. } kEventClassAccessibility = FourCharCode('acce'); { * Events related to the system. } kEventClassSystem = FourCharCode('macs'); { * Events related to Ink. } kEventClassInk = FourCharCode('ink '); kEventClassTSMDocumentAccess = FourCharCode('tdac'); { * Events related to gestures: magnify, swipe, rotate. } kEventClassGesture = FourCharCode('gest'); {--------------------------------------------------------------------------------------} { Mouse Events } {--------------------------------------------------------------------------------------} { kEventClassMouse quick reference: kEventMouseDown = 1, kEventMouseUp = 2, kEventMouseMoved = 5, kEventMouseDragged = 6, kEventMouseEntered = 8, kEventMouseExited = 9, kEventMouseWheelMoved = 10, kEventMouseScroll = 11 NOTE: As of Mac OS X 10.1, mouse events carry more information which allow you to do less work and gain accuracy of hit testing. First, there is the kEventParamWindowRef parameter. This parameter tells you over which window the mouse click/move/etc occurred. In mouse dragged events, this is the window the mouse went down in, NOT the window the mouse is currently over. Next, there is the kEventParamWindowMouseLocation parameter. This is the window-relative position of the mouse in the window given in the kEventParamWindowRef parameter. 0,0 is at the top left of the structure of the window. } { * EventMouseButton * } type EventMouseButton = UInt16; const { * Only button for a one-button mouse (usually left button for * multi-button mouse) } kEventMouseButtonPrimary = 1; { * Usually right button for a multi-button mouse } kEventMouseButtonSecondary = 2; { * Usually middle button for a three-button mouse } kEventMouseButtonTertiary = 3; { * EventMouseWheelAxis * } type EventMouseWheelAxis = UInt16; const { * The X axis (left or right) } kEventMouseWheelAxisX = 0; { * The Y axis (up or down) } kEventMouseWheelAxisY = 1; { * kEventClassMouse / kEventMouseDown * * Summary: * A mouse button was pressed. * * Discussion: * All windows have a default handler installed on the window target * that handles this event by calling SetFrontProcess on the current * process if the current process is not already the front process. * It is very important that an event handler for this event always * return eventNotHandledErr, so that the default handler can run * and can activate the current process. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamMouseLocation (in, typeHIPoint) * The mouse location, in global coordinates. * * --> kEventParamWindowRef (in, typeWindowRef) * The window under the mouse. Available in Mac OS X 10.1 and * later. * * --> kEventParamWindowMouseLocation (in, typeHIPoint) * The window-relative position of the mouse in the window * given in the kEventParamWindowRef parameter. 0,0 is at the * top left of the structure of the window. Available in Mac * OS X 10.1 and later. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The part code that the mouse location hit in the window. * This parameter only exists if the WindowRef parameter * exists. This saves you the trouble of calling FindWindow, * which is expensive on Mac OS X as it needs to call the * Window Server. Available in Mac OS X 10.3 and later. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the event was * generated. * * --> kEventParamMouseButton (in, typeMouseButton) * Which mouse button was pressed. * * --> kEventParamClickCount (in, typeUInt32) * Whether this is a single click, double click, etc. * * --> kEventParamMouseChord (in, typeUInt32) * Which other mouse buttons were pressed when the event was * generated. Available on Mac OS X only. * * --> kEventParamTabletEventType (in, typeUInt32) * The type of tablet event which generated this mouse event; * contains either kEventTabletPoint or kEventTabletProximity. * Only present if the event was generated from a tablet. * Available in Mac OS X 10.1 and CarbonLib 1.5, and later. * * --> kEventParamTabletPointRec (in, typeTabletPointRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletPoint. Available on Mac OS X 10.1 and CarbonLib * 1.5, and later. * * --> kEventParamTabletProximityRec (in, typeTabletProximityRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletProximity. Available on Mac OS X 10.1 and * CarbonLib 1.5, and later. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventMouseDown = 1; { * kEventClassMouse / kEventMouseUp * * Summary: * A mouse button was released. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamMouseLocation (in, typeHIPoint) * The mouse location, in global coordinates. * * --> kEventParamWindowRef (in, typeWindowRef) * The window in which the mouse was original pressed. * Available in Mac OS X 10.1 and later. * * --> kEventParamWindowMouseLocation (in, typeHIPoint) * The window-relative position of the mouse in the window * given in the kEventParamWindowRef parameter. 0,0 is at the * top left of the structure of the window. Available in Mac * OS X 10.1 and later. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The part code that the mouse location hit in the window. * This parameter only exists if the WindowRef parameter * exists. This saves you the trouble of calling FindWindow, * which is expensive on Mac OS X as it needs to call the * Window Server. Available in Mac OS X 10.3 and later. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the event was * generated. * * --> kEventParamMouseButton (in, typeMouseButton) * Which mouse button was released. * * --> kEventParamClickCount (in, typeUInt32) * Whether this is a single click, double click, etc. * * --> kEventParamMouseChord (in, typeUInt32) * Which other mouse buttons were pressed when the event was * generated. Available on Mac OS X only. * * --> kEventParamTabletEventType (in, typeUInt32) * The type of tablet event which generated this mouse event; * contains either kEventTabletPoint or kEventTabletProximity. * Only present if the event was generated from a tablet. * Available in Mac OS X 10.1 and CarbonLib 1.5, and later. * * --> kEventParamTabletPointRec (in, typeTabletPointRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletPoint. Available on Mac OS X 10.1 and CarbonLib * 1.5, and later. * * --> kEventParamTabletProximityRec (in, typeTabletProximityRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletProximity. Available on Mac OS X 10.1 and * CarbonLib 1.5, and later. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventMouseUp = 2; { * kEventClassMouse / kEventMouseMoved * * Summary: * The mouse was moved. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamMouseLocation (in, typeHIPoint) * The mouse location, in global coordinates. * * --> kEventParamWindowRef (in, typeWindowRef) * The window under the mouse. Available in Mac OS X 10.3 and * later. * * --> kEventParamWindowMouseLocation (in, typeHIPoint) * The window-relative position of the mouse in the window * given in the kEventParamWindowRef parameter. 0,0 is at the * top left of the structure of the window. Available in Mac * OS X 10.3 and later. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The part code that the mouse location hit in the window. * This parameter only exists if the WindowRef parameter * exists. This saves you the trouble of calling FindWindow, * which is expensive on Mac OS X as it needs to call the * Window Server. Available in Mac OS X 10.3 and later. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the event was * generated. * * --> kEventParamMouseDelta (in, typeHIPoint) * The change in mouse position, in absolute units, ignoring * scaling. Available in Mac OS X only. * * --> kEventParamTabletEventType (in, typeUInt32) * The type of tablet event which generated this mouse event; * contains either kEventTabletPoint or kEventTabletProximity. * Only present if the event was generated from a tablet. * Available in Mac OS X 10.1 and CarbonLib 1.5, and later. * * --> kEventParamTabletPointRec (in, typeTabletPointRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletPoint. Available on Mac OS X 10.1 and CarbonLib * 1.5, and later. * * --> kEventParamTabletProximityRec (in, typeTabletProximityRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletProximity. Available on Mac OS X 10.1 and * CarbonLib 1.5, and later. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventMouseMoved = 5; { * kEventClassMouse / kEventMouseDragged * * Summary: * The mouse was moved, and a button was down. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamMouseLocation (in, typeHIPoint) * The mouse location, in global coordinates. * * --> kEventParamWindowRef (in, typeWindowRef) * The window in which the mouse was original pressed. * Available in Mac OS X 10.1 and later. * * --> kEventParamWindowMouseLocation (in, typeHIPoint) * The window-relative position of the mouse in the window * given in the kEventParamWindowRef parameter. 0,0 is at the * top left of the structure of the window. Available in Mac * OS X 10.1 and later. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The part code that the mouse location hit in the window. * This parameter only exists if the WindowRef parameter * exists. This saves you the trouble of calling FindWindow, * which is expensive on Mac OS X as it needs to call the * Window Server. Available in Mac OS X 10.3 and later. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the event was * generated. * * --> kEventParamMouseDelta (in, typeHIPoint) * The change in mouse position, in absolute units, ignoring * scaling. Available in Mac OS X only. * * --> kEventParamTabletEventType (in, typeUInt32) * The type of tablet event which generated this mouse event; * contains either kEventTabletPoint or kEventTabletProximity. * Only present if the event was generated from a tablet. * Available in Mac OS X 10.1 and CarbonLib 1.5, and later. * * --> kEventParamTabletPointRec (in, typeTabletPointRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletPoint. Available on Mac OS X 10.1 and CarbonLib * 1.5, and later. * * --> kEventParamTabletProximityRec (in, typeTabletProximityRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletProximity. Available on Mac OS X 10.1 and * CarbonLib 1.5, and later. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventMouseDragged = 6; { * kEventClassMouse / kEventMouseEntered * * Summary: * The mouse entered a tracking area. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamMouseTrackingRef (in, typeMouseTrackingRef) * The MouseTrackingRef whose region the mouse has just * entered. * * --> kEventParamMouseLocation (in, typeHIPoint) * The mouse location, in global coordinates. * * --> kEventParamWindowRef (in, typeWindowRef) * The window under the mouse. * * --> kEventParamWindowMouseLocation (in, typeHIPoint) * The window-relative position of the mouse in the window * given in the kEventParamWindowRef parameter. 0,0 is at the * top left of the structure of the window. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the event was * generated. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework [32-bit only] * CarbonLib: not available } const kEventMouseEntered = 8; { * kEventClassMouse / kEventMouseExited * * Summary: * The mouse exited a tracking area. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamMouseTrackingRef (in, typeMouseTrackingRef) * The MouseTrackingRef whose region the mouse has just exited. * * --> kEventParamMouseLocation (in, typeHIPoint) * The mouse location, in global coordinates. * * --> kEventParamWindowRef (in, typeWindowRef) * The window under the mouse. * * --> kEventParamWindowMouseLocation (in, typeHIPoint) * The window-relative position of the mouse in the window * given in the kEventParamWindowRef parameter. 0,0 is at the * top left of the structure of the window. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the event was * generated. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework [32-bit only] * CarbonLib: not available } const kEventMouseExited = 9; { * kEventClassMouse / kEventMouseWheelMoved * * Summary: * The mouse wheel was moved. * * Discussion: * This event is sent to the window or view underneath the mouse. * The window or view does not need to be active to receive this * event, but it must be in the active application; this event is * not sent to windows or views in inactive applications. The event * is sent first to the window, and if the window does not handle * the view, the standard window event handler will send the event * to the view under the mouse. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamMouseLocation (in, typeHIPoint) * The mouse location, in global coordinates. * * --> kEventParamWindowRef (in, typeWindowRef) * The window under the mouse. Available in Mac OS X 10.1 and * later. * * --> kEventParamWindowMouseLocation (in, typeHIPoint) * The window-relative position of the mouse in the window * given in the kEventParamWindowRef parameter. 0,0 is at the * top left of the structure of the window. Available in Mac * OS X 10.1 and later. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The part code that the mouse location hit in the window. * This parameter only exists if the WindowRef parameter * exists. This saves you the trouble of calling FindWindow, * which is expensive on Mac OS X as it needs to call the * Window Server. Available in Mac OS X 10.3 and later. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the event was * generated. * * --> kEventParamMouseWheelAxis (in, typeMouseWheelAxis) * The wheel axis which moved. Contains either * kEventMouseWheelAxisX or kEventMouseWheelAxisY. * * --> kEventParamMouseWheelDelta (in, typeSInt32) * The amount of change in the wheel position. Generally, a * positive change should be interpreted as an upward scroll * (equivalent to a click in the up arrow of a scrollbar); a * negative change should be interpreted as a downward scroll * (equivalent to a click in the down arrow of a scrollbar). * Applications should not scale the delta value provided in * the event; the Mac OS X input device system provides * pre-scaling according to the userÕs desired mouse wheel * speed. * * --> kEventParamDirectionInverted (in, typeBoolean) * Indicates that the scroll direction is inverted from the * usage on Mac OS X 10.6 and earlier. In other words, if this * parameter is true, the scroll direction indicates the * direction that the content should move, rather than the * scrollbar thumb. Available on Mac OS X 10.7 and later. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventMouseWheelMoved = 10; { * kEventClassMouse / kEventMouseScroll * * Summary: * The user wants to scroll the object underneath the given mouse * location by the specified number of pixels. * * Discussion: * This event is sent to the window or view underneath the mouse. * The window or view does not need to be active to receive this * event, but it must be in the active application; this event is * not sent to windows or views in inactive applications. The event * is sent first to the window, and if the window does not handle * the view, the standard window event handler will send the event * to the view under the mouse. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamMouseLocation (in, typeHIPoint) * The mouse location, in global coordinates. * * --> kEventParamWindowRef (in, typeWindowRef) * The window under the mouse. * * --> kEventParamWindowMouseLocation (in, typeHIPoint) * The window-relative position of the mouse in the window * given in the kEventParamWindowRef parameter. 0,0 is at the * top left of the structure of the window. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The part code that the mouse location hit in the window. * This parameter only exists if the WindowRef parameter * exists. This saves you the trouble of calling FindWindow, * which is expensive on Mac OS X as it needs to call the * Window Server. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the event was * generated. * * --> kEventParamMouseWheelSmoothVerticalDelta (in, typeSInt32) * A typeSInt32 indicating how many pixels to scroll * vertically. Do not multiply this by your line height the * same way you would for the kEventParamMouseWheelDelta * parameter of a kEventMouseWheelMoved event. Both this and * the equivalent Horizontal parameter may be present in an * event, but are not guaranteed to be present. If both are * present, you should scroll both horizontally and vertically * if you can. You should be prepared for this parameter to be * missing, however. * * --> kEventParamMouseWheelSmoothHorizontalDelta (in, typeSInt32) * A typeSInt32 indicating how many pixels to scroll * horizontally. Do not multiply this by your line height the * same way you would for the kEventParamMouseWheelDelta * parameter of a kEventMouseWheelMoved event. Both this and * the equivalent Vertical parameter may be present in an * event, but are not guaranteed to be present. If both are * present, you should scroll both horizontally and vertically * if you can. You should be prepared for this parameter to be * missing, however. * * --> kEventParamEventRef (in, typeEventRef) * A typeEventRef of a compatibility kEventMouseWheelMoved * event that corresponds to this event. This parameter may * not always be present. This parameter is used by the event * dispatching mechanism to make sure that objects which don't * register for kEventMouseScroll events can see * kEventMouseWheelMoved events instead. You may extract this * event and examine its contents if your code requires a * kEventMouseWheelMoved event. * * --> kEventParamDirectionInverted (in, typeBoolean) * Indicates that the scroll direction is inverted from the * usage on Mac OS X 10.6 and earlier. In other words, if this * parameter is true, the scroll direction indicates the * direction that the content should move, rather than the * scrollbar thumb. Available on Mac OS X 10.7 and later. * * Availability: * Mac OS X: in version 10.4 and later in Carbon.framework * CarbonLib: not available } const kEventMouseScroll = 11; {--------------------------------------------------------------------------------------} { Gesture Events } {--------------------------------------------------------------------------------------} { kEventClassGesture quick reference: kEventGestureStarted = 1, kEventGestureEnded = 2, kEventGestureMagnify = 4, kEventGestureSwipe = 5, kEventGestureRotate = 6, } { * kEventClassGesture / kEventGestureStarted * * Discussion: * Sent when a gesture has started. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamMouseLocation (in, typeHIPoint) * The mouse location, in global coordinates. * * --> kEventParamWindowRef (in, typeWindowRef) * The window under the mouse. * * --> kEventParamWindowMouseLocation (in, typeHIPoint) * The window-relative position of the mouse in the window * given in the kEventParamWindowRef parameter. 0,0 is at the * top left of the structure of the window. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The part code that the mouse location hit in the window. * This parameter only exists if the WindowRef parameter * exists. This saves you the trouble of calling FindWindow, * which is expensive on Mac OS X as it needs to call the * Window Server. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the event was * generated. * * Availability: * Mac OS X: in version 10.6 and later in Carbon.framework * CarbonLib: not available } const kEventGestureStarted = 1; { * kEventClassGesture / kEventGestureEnded * * Discussion: * Sent when a gesture has ended. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamMouseLocation (in, typeHIPoint) * The mouse location, in global coordinates. * * --> kEventParamWindowRef (in, typeWindowRef) * The window under the mouse. * * --> kEventParamWindowMouseLocation (in, typeHIPoint) * The window-relative position of the mouse in the window * given in the kEventParamWindowRef parameter. 0,0 is at the * top left of the structure of the window. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The part code that the mouse location hit in the window. * This parameter only exists if the WindowRef parameter * exists. This saves you the trouble of calling FindWindow, * which is expensive on Mac OS X as it needs to call the * Window Server. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the event was * generated. * * Availability: * Mac OS X: in version 10.6 and later in Carbon.framework * CarbonLib: not available } const kEventGestureEnded = 2; { * kEventClassGesture / kEventGestureMagnify * * Discussion: * Sent when the user performs a magnify gesture, otherwise known as * a zoom gesture, or a pinch. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamMouseLocation (in, typeHIPoint) * The mouse location, in global coordinates. * * --> kEventParamWindowRef (in, typeWindowRef) * The window under the mouse. * * --> kEventParamWindowMouseLocation (in, typeHIPoint) * The window-relative position of the mouse in the window * given in the kEventParamWindowRef parameter. 0,0 is at the * top left of the structure of the window. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The part code that the mouse location hit in the window. * This parameter only exists if the WindowRef parameter * exists. This saves you the trouble of calling FindWindow, * which is expensive on Mac OS X as it needs to call the * Window Server. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the event was * generated. * * --> kEventParamMagnificationAmount (in, typeCGFloat) * The desired magnification percentage based on the user's * gesture. * * Availability: * Mac OS X: in version 10.6 and later in Carbon.framework * CarbonLib: not available } const kEventGestureMagnify = 4; { * kEventClassGesture / kEventGestureSwipe * * Discussion: * Sent when the user performs a swipe gesture. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamMouseLocation (in, typeHIPoint) * The mouse location, in global coordinates. * * --> kEventParamWindowRef (in, typeWindowRef) * The window under the mouse. * * --> kEventParamWindowMouseLocation (in, typeHIPoint) * The window-relative position of the mouse in the window * given in the kEventParamWindowRef parameter. 0,0 is at the * top left of the structure of the window. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The part code that the mouse location hit in the window. * This parameter only exists if the WindowRef parameter * exists. This saves you the trouble of calling FindWindow, * which is expensive on Mac OS X as it needs to call the * Window Server. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the event was * generated. * * --> kEventParamSwipeDirection (in, typeHIPoint) * A point describing the direction to move the content in * respond to the user's gesture. If the y coordinate is -1, * move the content up. If the y coordinate is 1, move the * content down. If the x coordinate is -1, move the content * to the left. If the x coordinate is 1, move the content to * the right. * * Availability: * Mac OS X: in version 10.6 and later in Carbon.framework * CarbonLib: not available } const kEventGestureSwipe = 5; { * kEventClassGesture / kEventGestureRotate * * Discussion: * Sent when the user performs a rotate gesture. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamMouseLocation (in, typeHIPoint) * The mouse location, in global coordinates. * * --> kEventParamWindowRef (in, typeWindowRef) * The window under the mouse. * * --> kEventParamWindowMouseLocation (in, typeHIPoint) * The window-relative position of the mouse in the window * given in the kEventParamWindowRef parameter. 0,0 is at the * top left of the structure of the window. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The part code that the mouse location hit in the window. * This parameter only exists if the WindowRef parameter * exists. This saves you the trouble of calling FindWindow, * which is expensive on Mac OS X as it needs to call the * Window Server. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the event was * generated. * * --> kEventParamRotationAmount (in, typeCGFloat) * The desired rotation amount, in degrees in polar * coordinates. * * Availability: * Mac OS X: in version 10.6 and later in Carbon.framework * CarbonLib: not available } const kEventGestureRotate = 6; {--------------------------------------------------------------------------------------} { TSM Document Access Events } {--------------------------------------------------------------------------------------} { kEventClassTSMDocumentAccess quick reference: ** Text Access ** kEventTSMDocumentAccessGetLength = 1, kEventTSMDocumentAccessGetSelectedRange = 2, kEventTSMDocumentAccessGetCharactersPtr = 3, kEventTSMDocumentAccessGetCharactersPtrForLargestBuffer = 4, kEventTSMDocumentAccessGetCharacters = 5, ** Text Attribute Access ** kEventTSMDocumentAccessGetFont = 6, kEventTSMDocumentAccessGetGlyphInfo = 7, kEventTSMDocumentAccessGetFirstRectForRange = 11, ** Transaction control ** kEventTSMDocumentAccessLockDocument = 8, kEventTSMDocumentAccessUnlockDocument = 9 These events allow access to a document's content. They are grouped in the following categories: text access, text attribute, and transaction related events. NOTE: TSM dispatches events of the TSMDocumentAccess class only as Carbon events. These are not converted for TSM clients that still install AppleEvent handlers for TSM events. NOTE: Text Services dispatch these Carbon events through TSM's SendTextInputEvent API. Normally only used for TextInput class TSM events, but this SendTextInputEvent is a bit of a misnomer. You should use it for TSMDocumentAccess class events as well. } { ** Document Access Text events ** The following Text Access events are very similar in design to the CFString API. The entire document can be conceived as a flattened Unicode string, and the events in this interface can access any portion of it. The GetSelectedRange() method allow a text service to obtain text near the insertion point (or selection), but access is by no means restricted to this vicinity. Use the GetLength() method to obtain the size of the document. Supporting these events effectively provide hooks into the text engine, but it is understood that access to a document in this way is to be strictly Read-Only. Where direct access to a document's content cannot be provided through a pointer, the requested text can be copied instead. Situations where a pointer may not be available from the text engine include the following: -A pointer would require conversion of text in Mac encodings to Unicode -A pointer would require sparse Unicode text blocks to be flattened into a single buffer. The idea is to minimize copying and converting text encodings where possible. The text service will typically begin by asking for a document pointer via kEventTSMDocumentAccessGetCharactersPtr. If this fails, it will typically fallback to kEventTSMDocumentAccessGetCharactersPtrForLargestBuffer, specifying a location of interest. If this fails, it will fallback to kEventTSMDocumentAccessGetCharacters, specifying a range of interest. Of course, when requesting small amounts of data such a few characters on either side of the insertion point, there is no obligation to optimize in this way. It's valid to simply use kEventTSMDocumentAccessGetCharacters. The text engine is entirely free to deny a request for a text pointer for these or any other implementation specific reason. } { * kEventClassTSMDocumentAccess / kEventTSMDocumentAccessGetLength * * Summary: * Returns the number of 16-bit Unicode characters in the document. * * Discussion: * This event is equivalent to calling CFStringGetLength() on the * app's document. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamTSMDocAccessSendComponentInstance (in, typeComponentInstance) * This event parameter is DEPRECATED on Mac OS X 10.5 and * later. * * This parameter is provided by the input method originating * the event. (Required parameter) * * --> kEventParamTSMDocAccessSendRefCon (in, typeRefCon) * TSM's SendTextInputEvent, called by an input method, * inserts this parameter before dispatching the event to the * user focus. (Required Parameter) * * On Mac OS X 10.4 and earlier, this parameter uses * typeSInt32, and you must retrieve it using that constant. * On Mac OS X 10.5 and later, to support 64-bit refcon * values, this parameter uses typeRefCon. For 64-bit * compatibility, you must use typeRefCon when retrieving this * parameter; for 32-bit targets, however, you may continue to * use typeSInt32 if you wish, or switch to typeRefCon. * * <-- kEventParamTSMDocAccessCharacterCount (out, typeCFIndex) * The size of the document in UniChar. Required reply * parameter. * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available } const kEventTSMDocumentAccessGetLength = 1; { * kEventClassTSMDocumentAccess / kEventTSMDocumentAccessGetSelectedRange * * Summary: * Returns the selection range in the document. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamTSMDocAccessSendComponentInstance (in, typeComponentInstance) * This event parameter is DEPRECATED on Mac OS X 10.5 and * later. * * This parameter is provided by the input method originating * the event. (Required parameter) * * --> kEventParamTSMDocAccessSendRefCon (in, typeRefCon) * TSM's SendTextInputEvent, called by an input method, * inserts this parameter before dispatching the event to the * user focus. (Required Parameter) * * On Mac OS X 10.4 and earlier, this parameter uses * typeSInt32, and you must retrieve it using that constant. * On Mac OS X 10.5 and later, to support 64-bit refcon * values, this parameter uses typeRefCon. For 64-bit * compatibility, you must use typeRefCon when retrieving this * parameter; for 32-bit targets, however, you may continue to * use typeSInt32 if you wish, or switch to typeRefCon. * * <-- kEventParamTSMDocAccessReplyCharacterRange (out, typeCFRange) * The selection range as a CFRange in UniChar. If the * selection is empty, the range identifies the insertion * point and the range will specify a length of 0. Required * reply parameter. * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available } const kEventTSMDocumentAccessGetSelectedRange = 2; { * kEventClassTSMDocumentAccess / kEventTSMDocumentAccessGetCharactersPtr * * Summary: * Returns a Unicode pointer to the entire document content. * * Discussion: * This event is equivalent to calling CFStringGetCharactersPtr() on * the app's document treated as a CFString. Some text engines may * not support this event for reasons that are implementation * dependent. For example, a text engine's backing store may consist * of legacy encoding runs. It may also consist of unflattened * Unicode, stored as a B-tree of text blocks. For such reasons, a * text engine may reject a request for a pointer to a flattened * Unicode buffer. It is also understood that text access through * this pointer is to be strictly READ-ONLY. Any changes to the * document should be made through TSM TextInput events, such as * kEventTextInputUpdateActiveInputArea or * kEventTextInputUnicodeText. NOTE: This pointer is valid only * during a transaction surrounded by document lock/unlock events, * or until an event causes the document to change, such as * dispatching kEventTextInputUpdateActiveInputArea or * kEventTextInputUnicodeText events, whichever occurs first. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamTSMDocAccessSendComponentInstance (in, typeComponentInstance) * This event parameter is DEPRECATED on Mac OS X 10.5 and * later. * * This parameter is provided by the input method originating * the event. (Required parameter) * * --> kEventParamTSMDocAccessSendRefCon (in, typeRefCon) * TSM's SendTextInputEvent, called by an input method, * inserts this parameter before dispatching the event to the * user focus. (Required Parameter) * * On Mac OS X 10.4 and earlier, this parameter uses * typeSInt32, and you must retrieve it using that constant. * On Mac OS X 10.5 and later, to support 64-bit refcon * values, this parameter uses typeRefCon. For 64-bit * compatibility, you must use typeRefCon when retrieving this * parameter; for 32-bit targets, however, you may continue to * use typeSInt32 if you wish, or switch to typeRefCon. * * <-- kEventParamTSMDocAccessReplyCharactersPtr (out, typePtr) * The UniChar pointer to the document. Required reply * parameter, if the event is supported. * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available } const kEventTSMDocumentAccessGetCharactersPtr = 3; { * kEventClassTSMDocumentAccess / kEventTSMDocumentAccessGetCharactersPtrForLargestBuffer * * Summary: * Returns a Unicode pointer to a portion of the document. * * Discussion: * This event is similar to calling CFStringGetCharactersPtr() on a * portion of the app's document treated as a CFString, except that * the substring is determined by the text engine. Some text engines * may keep text in unflattened Unicode, stored as a B-tree of text * blocks, for example. In some cases, especially near locations * such as the insertion point, the text engine may have cached a * good chunk of text to which it can readily provide a pointer. A * text engine may reject a request for such a pointer. It is also * understood that text access through this pointer is to be * strictly READ-ONLY. Any changes to the document should be made * through TSM TextInput events, such as * kEventTextInputUpdateActiveInputArea or * kEventTextInputUnicodeText. NOTE: This pointer is valid only * during a transaction surrounded by document lock/unlock, or until * an event causes the document to change, such as dispatching * kEventTextInputUpdateActiveInputArea or * kEventTextInputUnicodeText events. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamTSMDocAccessSendComponentInstance (in, typeComponentInstance) * This event parameter is DEPRECATED on Mac OS X 10.5 and * later. * * This parameter is provided by the input method originating * the event. (Required parameter) * * --> kEventParamTSMDocAccessSendRefCon (in, typeRefCon) * TSM's SendTextInputEvent, called by an input method, * inserts this parameter before dispatching the event to the * user focus. (Required Parameter) * * On Mac OS X 10.4 and earlier, this parameter uses * typeSInt32, and you must retrieve it using that constant. * On Mac OS X 10.5 and later, to support 64-bit refcon * values, this parameter uses typeRefCon. For 64-bit * compatibility, you must use typeRefCon when retrieving this * parameter; for 32-bit targets, however, you may continue to * use typeSInt32 if you wish, or switch to typeRefCon. * * --> kEventParamTSMDocAccessSendCharacterIndex (in, typeCFIndex) * The location in the document for which the caller would * like a pointer to a buffer of text that includes that * location. This buffer could be available from a cache * due to recent interaction near that location, such as the * insertion point. Required parameter. * * <-- kEventParamTSMDocAccessReplyCharactersPtr (out, typePtr) * The UniChar pointer to a portion of the document text. * Required reply parameter, if the event is handled. * * <-- kEventParamTSMDocAccessReplyCharacterRange (out, typeCFRange) * The document-relative range of text represented by the * returned text pointer. Required reply parameter, if the * event is handled. * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available } const kEventTSMDocumentAccessGetCharactersPtrForLargestBuffer = 4; { * kEventClassTSMDocumentAccess / kEventTSMDocumentAccessGetCharacters * * Summary: * Fills caller provided buffer with Unicode characters in the * specified range. * * Discussion: * This event is equivalent to calling CFStringGetCharacters() on * the app's document treated as a CFString. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamTSMDocAccessSendComponentInstance (in, typeComponentInstance) * This event parameter is DEPRECATED on Mac OS X 10.5 and * later. * * This parameter is provided by the input method originating * the event. (Required parameter) * * --> kEventParamTSMDocAccessSendRefCon (in, typeRefCon) * TSM's SendTextInputEvent, called by an input method, * inserts this parameter before dispatching the event to the * user focus. (Required Parameter) * * On Mac OS X 10.4 and earlier, this parameter uses * typeSInt32, and you must retrieve it using that constant. * On Mac OS X 10.5 and later, to support 64-bit refcon * values, this parameter uses typeRefCon. For 64-bit * compatibility, you must use typeRefCon when retrieving this * parameter; for 32-bit targets, however, you may continue to * use typeSInt32 if you wish, or switch to typeRefCon. * * --> kEventParamTSMDocAccessSendCharacterRange (in, typeCFRange) * The range of text that should be copied into the buffer * provided by the caller. Required parameter. * * --> kEventParamTSMDocAccessSendCharactersPtr (in, typePtr) * A buffer provided by the caller to contain the specified * range of UniChars. This buffer is identical in usage to * that of CFStringGetCharacters(). Required parameter. * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available } const kEventTSMDocumentAccessGetCharacters = 5; { ** Document Access Attribute events ** The following Text Attribute events define how a text service can obtain certain attributes at text locations throughout an application's document. Currently, the only attributes supported by these events are font (and font size) via kEventTSMDocumentAccessGetFont and glyphID/CID info via kEventTSMDocumentAccessGetGlyphInfo. Where these attributes span multiple characters, effective ranges (over which the attribute is constant) are returned by the text engine. } { * Summary: * Values used TSMDocAccessAttributes bit field * * Discussion: * The following bit assignments are used for TSMDocAccessAttributes * parameters. This parameter is used to specify desired (optional) * attributes in the kEventTSMDocumentAccessGetFont and * kEventTSMDocumentAccessGetGlyphInfo events. They are specified in * the kEventParamTSMDocAccessRequestedCharacterAttributes parameter. } const { * Font size information is desired. * On Mac OS 10.5 and later, this attribute is DEPRECATED in favor of * CTFontRef information contained in the * kEventParamTSMDocAccessReplyCTFontRef parameter. Font size is * accessed through the CTFontRef itself. * Note: Text Services Manager will always set this attribute when * dispatching the kEventTSMDocumentAccessGetFont event to the * application. This allows a more meaningful CTFontRef to be * constructed for the benefit of requesting input methods should the * application return only compatibility data in the form of * ATSFontRef and font size. } kTSMDocAccessFontSizeAttributeBit = 0; { * Effective Range information is desired. Used in * kEventTSMDocumentAccessGetFont and * kEventTSMDocumentAccessGetGlyphInfo events. } kTSMDocAccessEffectiveRangeAttributeBit = 1; type TSMDocAccessAttributes = UInt32; const kTSMDocAccessFontSizeAttribute = 1 shl kTSMDocAccessFontSizeAttributeBit; kTSMDocAccessEffectiveRangeAttribute = 1 shl kTSMDocAccessEffectiveRangeAttributeBit; { More attributes may be added in the future} { * kEventClassTSMDocumentAccess / kEventTSMDocumentAccessGetFont * * Summary: * Returns font, font size, and the range over which these * attributes are constant. * * Discussion: * Where the font/font size attributes span multiple characters, an * effective range (over which requested attributes are constant) is * returned by the text engine. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamTSMDocAccessSendComponentInstance (in, typeComponentInstance) * This event parameter is DEPRECATED on Mac OS X 10.5 and * later. * * This parameter is provided by the input method originating * the event. (Required parameter) * * --> kEventParamTSMDocAccessSendRefCon (in, typeRefCon) * TSM's SendTextInputEvent, called by an input method, * inserts this parameter before dispatching the event to the * user focus. (Required Parameter) * * On Mac OS X 10.4 and earlier, this parameter uses * typeSInt32, and you must retrieve it using that constant. * On Mac OS X 10.5 and later, to support 64-bit refcon * values, this parameter uses typeRefCon. For 64-bit * compatibility, you must use typeRefCon when retrieving this * parameter; for 32-bit targets, however, you may continue to * use typeSInt32 if you wish, or switch to typeRefCon. * * --> kEventParamTSMDocAccessSendCharacterIndex (in, typeCFIndex) * The location in the document for which the caller would * like font information.
Required parameter. * * --> kEventParamTSMDocAccessRequestedCharacterAttributes (in, typeUInt32) * A TSMDocAccessAttributes bit field filled out with the * attributes desired. * Applicable values for this event are: * * kTSMDocAccessFontSizeAttribute * This attribute requests font size information through the * kEventParamTSMDocAccessReplyFontSize parameter (only if an * ATSFontRef is being returned via * kEventParamTSMDocAccessReplyATSFont). * * Note: On Mac OS X 10.5 and later, Text Services Manager * will always set this attribute when dispatching the * kEventTSMDocumentAccessGetFont event to the application. * This allows a more meaningful CTFontRef to be constructed * for the benefit of requesting input methods should the * application return only compatibility data in the form of * ATSFontRef and font size. * * kTSMDocAccessEffectiveRangeAttribute * This attribute requests the text range over which font or * font/size is constant.

Required parameter. * * <-- kEventParamTSMDocAccessReplyCTFontRef (out, typeCTFontRef) * The CTFontRef for the location specified by the caller. * This is the PREFERRED method of accessing font info on Mac * OS X 10.5 and later. * * Note: For compatibility with applications that have not * yet adopted the CTFont API, the toolbox will automatically * coerce this parameter, if not present, from * kEventParamTSMDocAccessReplyATSFont and the font size * parameter kEventParamTSMDocAccessReplyFontSize. * * Note2: This parameter is particularly important for input * methods to adopt, because it will allow them to reproduce * application text with much higher fidelity in its own UI * when the application also adopts CTFont. * * Optional reply parameter if * kEventParamTSMDocAccessReplyATSFont and * kEventParamTSMDocAccessReplyFontSize are provided. * * <-- kEventParamTSMDocAccessReplyATSFont (out, typeATSFontRef) * The ATSFontRef for the location specified by the * caller. * * On Mac OS X 10.5 and later, this parameter is part of the * compatibility parameter set, and will be deprecated in the * future. For compatibility with existing input methods, if * the application returns a CTFontRef (via * kEventParamTSMDocAccessReplyCTFontRef), TSM will coerce the * CTFontRef to this ATSFontRef parameter and the font size * kEventParamTSMDocAccessReplyFontSize parameter. * Please use kEventParamTSMDocAccessReplyCTFontRef if at all * possible. * * Optional reply parameter if * kEventParamTSMDocAccessReplyCTFontRef is provided. * * <-- kEventParamTSMDocAccessReplyFontSize (out, typeCGFloat) * The font size for the requested location if an ATSFontRef * is being returned via kEventParamTSMDocAccessReplyATSFont * and kTSMDocAccessFontSizeAttribute is specified in the bit * field passed as the * kEventParamTSMDocAccessRequestedCharacterAttributes * parameter. * Note: This parameter is not normally used if a CTFontRef * is being returned via kEventParamTSMDocAccessReplyCTFontRef * (Mac OS X 10.5 and later), but could be helpful if the * application is using an affine transform in conjunction * with the ATSFontRef and the ideal font size differs enough * from the font size that would be derived from the * CTFontRef. However, see comment under * kEventParamTSMDocAccessReplyCTFontRef pertaining to the * importance of input method adoption of CTFont API. * Note2: This event parameter was originally typed as * typeFloat which is also typeIEEE64BitFloatingPoint. * However, a 'float' (see MacTypes.h) is really a 32 bit IEEE * float. Clients of this parameter have made the assumption * that these types correspond with oneanother, and as long as * the same assumption was made everywhere, this caused no * problem. * In Mac OS X 10.5 and later, this parameter has been * re-typed as typeCGFloat, which references a Float32 on * 32-bit, and a double on 64-bit. For compatibility, TSM * will assume that when data of typeFloat is used in * conjunction with this parameter, the data actually contains * a 32-bit IEEE float, and will coerce this data accordingly * when converting to/from typeCGFloat. * NOTE2: The above special-case coercion to/from typeFloat * exists only on 32-bit. Always use typeCGFloat on * 64-bit. * * Optional reply parameter if * kEventParamTSMDocAccessReplyCTFontRef is provided. * * --> kEventParamTSMDocAccessSendCharacterRange (in, typeCFRange) * The maximum range of text the caller cares about. This is * used to "clip" the area of interest to the caller so the * text engine doesn't need to process a style run all the way * back to, say, the beginning of a line or a document, in * order to return an effective range.
Required parameter. * * <-- kEventParamTSMDocAccessEffectiveRange (out, typeCFRange) * Optional reply parameter. * The range of text over which both font and size are * constant, within the bounds of the * kEventParamTSMDocAccessSendCharacterRange parameter. * Return this information if * kTSMDocAccessEffectiveRangeAttribute is specified in the * bit field passed as the * kEventParamTSMDocAccessRequestedCharacterAttributes * parameter. * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available } const kEventTSMDocumentAccessGetFont = 6; { * kEventClassTSMDocumentAccess / kEventTSMDocumentAccessGetGlyphInfo * * Summary: * Returns glyph info and the range covered by that glyph. * * Discussion: * Where a glyph spans multiple characters, the effective range, * represented by the glyph, is returned by the app. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamTSMDocAccessSendComponentInstance (in, typeComponentInstance) * This event parameter is DEPRECATED on Mac OS X 10.5 and * later. * * This parameter is provided by the input method originating * the event.
Required parameter. * * --> kEventParamTSMDocAccessSendRefCon (in, typeRefCon) * TSM's SendTextInputEvent, called by an input method, * inserts this parameter before dispatching the event to the * user focus. * Required Parameter. * * On Mac OS X 10.4 and earlier, this parameter uses * typeSInt32, and you must retrieve it using that constant. * On Mac OS X 10.5 and later, to support 64-bit refcon * values, this parameter uses typeRefCon. For 64-bit * compatibility, you must use typeRefCon when retrieving this * parameter; for 32-bit targets, however, you may continue to * use typeSInt32 if you wish, or switch to typeRefCon. * * --> kEventParamTSMDocAccessSendCharacterIndex (in, typeCFIndex) * The location in the document for which the caller would * like glyph information.
Required parameter. * * --> kEventParamTSMDocAccessRequestedCharacterAttributes (in, typeUInt32) * A TSMDocAccessAttributes bit field filled out with the * information desired. * Applicable values for this event are : * kTSMDocAccessEffectiveRangeAttribute which requests the * text range represented by a glyph.
Required parameter. * * <-- kEventParamTSMDocAccessReplyCTGlyphInfoRef (out, typeCTGlyphInfoRef) * The CTGlyphInfoRef for the glyph used to display the range * of text returned in the * kEventParamTSMDocAccessEffectiveRange parameter. If the * glyph used is the one that would normally be derived, this * parameter can be omitted. * This is the PREFERRED method of accessing glyph info on Mac * OS X 10.5 and later. * * For compatibility purposes, this parameter may be requested * by an input method even when the application returns glyph * information as a ATSUGlyphSelector via the * kEventParamTSMDocAccessReplyATSUGlyphSelector event * parameter. The toolbox provides automatic coercion between * these two parameters.

Optional reply parameter. * * <-- kEventParamTSMDocAccessReplyATSUGlyphSelector (out, typeGlyphSelector) * The ATSUGlyphSelector for the glyph used to display the * range of text returned in the * kEventParamTSMDocAccessEffectiveRange parameter. If the * glyph used is the one that ATSUI would normally derive, * this parameter can be omitted. This is the NON PREFERRED * way of accessing glyph info on Mac OS X 10.5 and later, and * this parameter will be deprecated in the future. Use * kEventParamTSMDocAccessReplyCTGlyphInfoRef instead. * * For compatibility purposes, this parameter may still be * requested even when the application returns glyph * information via the CTGlyphInfoRef parameter * kEventParamTSMDocAccessReplyCTGlyphInfoRef. The toolbox * provides automatic coercion between these two * parameters.

Optional reply parameter. * * <-- kEventParamTSMDocAccessEffectiveRange (out, typeCFRange) * The range of text displayed as a glyph ID or CID. * Optional reply parameter. * Return this information if * kTSMDocAccessEffectiveRangeAttribute is specified in the * bit field passed as the * kEventParamTSMDocAccessRequestedCharacterAttributes * parameter. * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available } const kEventTSMDocumentAccessGetGlyphInfo = 7; { * kEventClassTSMDocumentAccess / kEventTSMDocumentAccessGetFirstRectForRange * * Summary: * Returns a bounding rectangle on the screen for a specified * character range. * Where the character range would best be described by multiple * logical rectangles, this event should return the first such * rectangle and the corresponding character subrange * * Discussion: * Input methods have a need to locate the on-screen position of a * character range in a document.Ê The goal may be toÊcall attention * to the user about a range of text by using its bounding rectangle * or byÊoverlaying some text with different font/attributes. * The handler of this event should return aÊrectangle for the * largest character subrange of text, starting from the range * beginning, that is drawn on a single line usingÊsimilar font, * size, and style. * If text overlay is desired, the CTFontRef(s) used over the * character range can be obtained via * theÊkEventTSMDocumentAccessGetFont event.Ê The baseline to be * used for drawing is determined by applying the returned * BaselineDelta parameter to the bounding rectangle's origin. * When the bounding rectangle returned corresponds to only a * proper subset of the requested character range, the subrange is * specified in the EffectiveRange parameter, allowing the client to * iterate over the character range of interest. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamTSMDocAccessSendRefCon (in, typeRefCon) * TSM's SendTextInputEvent, called by an input method, * inserts this parameter before dispatching the event to the * user focus. (Required Parameter) * * --> kEventParamTSMDocAccessSendCharacterRange (in, typeCFRange) * The range of text for which a bounding rectangle is * requested. (Required Parameter) * * <-- kEventParamTSMDocAccessEffectiveRange (out, typeCFRange) * Required reply parameter. * The subrange of text, within the bounds of the * kEventParamTSMDocAccessSendCharacterRange parameter, over * which font/size/style of text are similar and displayed on * a single line. * * <-- kEventParamTSMDocAccessLineBounds (out, typeHIRect) * Required reply parameter. * This parameter contains an HIRect of the visible line area * for the text subrange returned in the EffectiveRange * parameter. * ThisÊHIRect can be accessed using the default typeHIRect to * obtain values in global coordinates, or 72dpi virtual * coordinate space, or can be accessedÊwith other parameter * types that specify the coordinate space of interest, such * as typeHIRectScreenPixel. * * <-- kEventParamTSMDocAccessBaselineDelta (out, typeCGFloat) * Required reply parameter. * This parameter specifies the delta between the bounding * rectangle's origin and the text baseline at the first * character in the returned EffectiveRange parameter. * * Availability: * Mac OS X: in version 10.5 and later in Carbon.framework * CarbonLib: not available } const kEventTSMDocumentAccessGetFirstRectForRange = 11; { ** Document Access Lock/Unlock events ** } { * kEventClassTSMDocumentAccess / kEventTSMDocumentAccessLockDocument * * Summary: * Notifies the app that it should not change its document's text * content (on its own) while a text service is involved in a * transaction. The app should not allow changes, for example, by * its secondary threads. * * Discussion: * These events define how a text service can obtain access to a * document in a way that ensures data integrity during its * transaction. The primary motivation of these events is to * prevent the application from letting its secondary threads modify * the document while a text service is busy servicing an event, * such as a key event, or some user interaction with text service * provided UI such as a menu selection. Also, while the document is * locked, a text service is free to request pointer access to the * document's text content (if this is supported by the app's text * engine.) These lock-related events should be implemented using a * ref counting scheme. Most apps will not support this kind of * threading, so implementation of these events in the text engine * will be optional. In most text engines, the implementation of * these events should be trivial, i.e. just maintain a simple * semaphore. TSM itself will implicitly lock/unlock around normal * entry points into a text service, such as when it delivers key * events to an input method, but there may be times when document * changes can be driven by an input method without TSM involvement, * such as the Carbon events involved when the user interacts with * some UI. In this case, the input method must manage locking, if * the app supports it. However, the logic in an input method * should not have to care whether TSM is in the call chain or * not... and TSM should not have to care whether an input method * will do the right thing. This is why the lock mechanism needs to * be some kind of refcounting scheme instead of a simple on/off * mechanism. This document lock support is completely optional on * the part of the text engine (if it is not threaded). TSM will * implicitly lock/unlock the document around delivery of events to * input methods, if the app supports it. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamTSMDocAccessSendComponentInstance (in, typeComponentInstance) * This event parameter is DEPRECATED on Mac OS X 10.5 and * later. * * This parameter is provided by the input method originating * the event. (Required parameter) * * --> kEventParamTSMDocAccessSendRefCon (in, typeRefCon) * TSM's SendTextInputEvent, called by an input method, * inserts this parameter before dispatching the event to the * user focus. (Required Parameter) * * On Mac OS X 10.4 and earlier, this parameter uses * typeSInt32, and you must retrieve it using that constant. * On Mac OS X 10.5 and later, to support 64-bit refcon * values, this parameter uses typeRefCon. For 64-bit * compatibility, you must use typeRefCon when retrieving this * parameter; for 32-bit targets, however, you may continue to * use typeSInt32 if you wish, or switch to typeRefCon. * * <-- kEventParamTSMDocAccessLockCount (out, typeCFIndex) * The resulting refCount of locks on the document. Required * reply parameter, if the event is handled. * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available } const kEventTSMDocumentAccessLockDocument = 8; { * kEventClassTSMDocumentAccess / kEventTSMDocumentAccessUnlockDocument * * Summary: * Unlock the document so the app's text engine is free to initiate * changes again. * * Discussion: * (see kEventTSMDocumentAccessLockDocument) * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamTSMDocAccessSendComponentInstance (in, typeComponentInstance) * This event parameter is DEPRECATED on Mac OS X 10.5 and * later. * * This parameter is provided by the input method originating * the event. (Required parameter) * * --> kEventParamTSMDocAccessSendRefCon (in, typeRefCon) * TSM's SendTextInputEvent, called by an input method, * inserts this parameter before dispatching the event to the * user focus. (Required Parameter) * * On Mac OS X 10.4 and earlier, this parameter uses * typeSInt32, and you must retrieve it using that constant. * On Mac OS X 10.5 and later, to support 64-bit refcon * values, this parameter uses typeRefCon. For 64-bit * compatibility, you must use typeRefCon when retrieving this * parameter; for 32-bit targets, however, you may continue to * use typeSInt32 if you wish, or switch to typeRefCon. * * <-- kEventParamTSMDocAccessLockCount (out, typeCFIndex) * The resulting refCount of locks on the document. Required * reply parameter, if the event is handled. * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available } const kEventTSMDocumentAccessUnlockDocument = 9; {--------------------------------------------------------------------------------------} { Text Input Events } {--------------------------------------------------------------------------------------} { kEventClassTextInput quick reference: kEventTextInputUpdateActiveInputArea = 1, kEventTextInputUnicodeForKeyEvent = 2, kEventTextInputOffsetToPos = 3, kEventTextInputPosToOffset = 4, kEventTextInputShowHideBottomWindow = 5, kEventTextInputGetSelectedText = 6, kEventTextInputUnicodeText = 7, kEventTextInputFilterText = 14, kEventTextInputIsMouseEventInInlineInputArea = 16 The following TextInput events (UpdateActiveInputArea thru GetSelectedText) reimplement the AppleEvents defined in Inside Mac Text: Text Services Manager, and provide the benefits of Carbon Event targeting, dispatching, and propagation to applications that have formerly handled the TSM suite of AppleEvents. TextInput handlers may be installed on controls, windows, or the application event target (equivalent to AppleEvent-based handling). In all cases, if a given TextInput handler is not installed, TSM will convert that TextInput to an AppleEvent and redispatch via AESend to the current process, making adoption as gradual as is desired. } { * kEventClassTextInput / kEventTextInputUpdateActiveInputArea * * Summary: * Tells the application/text engine to initiate/terminate or manage * the content of an inline input session. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamTextInputSendComponentInstance (in, typeComponentInstance) * This event parameter is DEPRECATED on Mac OS X 10.5 and * later. * * This parameter is provided by the input method originating * the event. If an invalid value is specified, tsmUnknownErr * will be returned. (Required parameter) * * --> kEventParamTextInputSendRefCon (in, typeRefCon) * TSM's SendTextInputEvent, called by an input method, * inserts this parameter before dispatching the event to the * user focus. (Required Parameter) * * On Mac OS X 10.4 and earlier, this parameter uses * typeSInt32, and you must retrieve it using that constant. * On Mac OS X 10.5 and later, to support 64-bit refcon * values, this parameter uses typeRefCon. For 64-bit * compatibility, you must use typeRefCon when retrieving this * parameter; for 32-bit targets, however, you may continue to * use typeSInt32 if you wish, or switch to typeRefCon. * * --> kEventParamTextInputSendSLRec (in, typeIntlWritingCode) * This event parameter is DEPRECATED on Mac OS X 10.5 and * later. * * The ScriptLanguageRecord associated with the contents of an * inline input session. This parameter is normally provided * by the input method originating the event. TSM's * SendTextInputEvent will construct this parameter, when * missing, based on the input method component description. * (Required Parameter) * * --> kEventParamTextInputSendFixLen (in, typeSignedByteCount) * This parameter specifies a (signed) byte count of how much * text, if any, of the inline input session is being * confirmed (or commited) to the application. A value of -1 * indicates the entire inline session is being confirmed. A * value of 0 indicates that none of the text is being * confirmed (yet), although there may still be some change to * the contents of the inline input session. This parameter * is provided by the input method originating the event. * (Required Parameter) * * On Mac OS X 10.5 and later, this parameter is typed as * typeSignedByteCount. For all 32bit targets, whether for * Mac OS X 10.5 or earlier, you can freely use this new * type. * For 64bit on Mac OS X 10.5 and later, in order to support * 64-bit text lengths, you must use typeSignedByteCount. * * --> kEventParamTextInputSendAttributedString (in, typeCFAttributedStringRef) * The attributed string to be added to the inline input * session. This is the preferred event parameter on Mac OS X * 10.5 and later. The attributes are those defined in * CTStringAttributes.h. * On Mac OS X 10.5, TSM supports the font attribute and the * glyph info attribute. TSM does not (yet) define or support * attributes for UpdateRng, HiliteRng, ClauseRng, and PinRng, * although this is the intended direction in the future. * NOTE: When a glyph info attribute is set for a particular * text range, it is expected that a font attribute covers at * least that same text range. This is also important to * allow TSM to coerce attributes to compatibility data * structures, such as the * kEventParamTextInputSendGlyphInfoArray event parameter. * NOTE2: If this event parameter is missing and requested, * it is coerced from the compatibility parameters provided in * this event, in particular, kEventParamTextInputSendText and * kEventParamTextInputSendGlyphInfoArray. * NOTE3: Even when this parameter is provided by an input * method, the kEventParamTextInputSendTextServiceMacEncoding * is still needed if the current TSMDocument (as returned by * TSMGetActiveDocument) is not of type * kUnicodeDocumentInterfaceType and the encoding needed for * conversion is a Mac encoding variant. * * Required Parameter if kEventParamTextInputSendText is not * provided. * * --> kEventParamTextInputSendText (in, typeUnicodeText) * The text to be added to the inline input session. The data * type of this parameter actually depends on the TSMDocument * type created via NewTSMDocument: it will be typeChar for * kTextService documents, or typeUnicodeText for * kUnicodeDocument documents. * Required Parameter if * kEventParamTextInputSendAttributedString is not provided. * * --> kEventParamTextInputSendUpdateRng (in, typeTextRangeArray) * An array of text-range records (see TextRangeArray) that * indicates how to update (a subrange of) the active input * area (aka. inline input session). The TextRange structures * occur in pairs, the first of which identifies a subrange of * the existing active input area (in the app's backing store, * resulting from a previous UpdateActiveInputArea event) to * be replaced by a new subrange of text, identified by the * second TextRange in the pair. The new text subrange is * obtained from the contents of the * kEventParamTextInputSendText parameter. In general, the * Nth array element, where N is even, specifies the range of * old text to be updated and array element N+1 specifies the * range of new text to replace the corresponding old text. * The fHiliteStyle field of the TextRange records is ignored * in this parameter. NOTE: There are some "loose ends" in * the TSM event protocol that were never clearly defined, but * which have been introduced over the years by input methods * themselves, probably through some trial and error. The * conventions regarding this optional parameter seem to be as * follows: If the UpdateRng parameter is missing from the * event, the input method is requesting that the entire * contents of the existing inline input session (if there is * one) is to be replaced "wholesale" by the new text * contained in the kEventParamTextInputSendText parameter. If * the UpdateRng parameter exists, but contains no ranges * (i.e. fNumOfRanges == 0), this seems to be hint from the * input method that no text in the active input area is * changing. It may be that the existing active input area is * being confirmed "as is", or that the input method is * modifying its highlite attributes in some way, due to some * user action, such as changing the selected clause or * highlited subrange of text in the active input area, or * that the input method is changing the caret position in the * active input area (if it uses the kTSMHiliteCaretPosition * hilite style). Depending on how your text engine draws * hilite styles supported in the * kEventParamTextInputSendHiliteRng parameter, you may or may * not need to redraw the text itself, simply change the * hilite. This parameter is optional and may not be present * in all instances of this event. * * --> kEventParamTextInputSendHiliteRng (in, typeTextRangeArray) * An array of text-range records (see TextRangeArray) that * specifies how various subranges of the active input area * are to be highlited, and possibly specifies caret position * within the active input area. NOTE: The text offsets used * in the HiliteRng parameter are relative to the beginning of * the active input area AFTER all text has been updated (per * the SendUpdateRng parameter) and any (subrange of) text has * been confirmed. Specifically, if the entire text is being * confirmed, it is clear that any contents of this parameter * should be ignored, especially non-zero values * kTSMHiliteCaretPosition. This parameter is optional and may * not be present in all instances of this event. * * --> kEventParamTextInputSendClauseRng (in, typeOffsetArray) * An array of offsets (see OffsetArray) used by an input * method to specify word or clause boundaries in the * resulting active input area. Offsets are relative to the * start of the resulting active input area. This parameter is * optional and may not be present in all instances of this * event. * * --> kEventParamTextInputSendPinRng (in, typeTextRange) * A TextRange record that specifies a start offset and an end * offset that should be scrolled into view if the text * specified by these offsets is not already in view. The * fHiliteStyle field of the TextRange records is ignored in * this parameter. This parameter is optional and may not be * present in all instances of this event. * * --> kEventParamTextInputSendTextServiceEncoding (in, typeUInt32) * The encoding associated with the text sent by an input * method. On MacOS X, this parameter is not commonly used * because all TSM input methods produce Unicode, but TSM will * respect a Unicode encoding variant here, if specified. In * CarbonLib, this parameter identifies the Mac encoding * (usually an encoding variant) of the text produced by the * input method on MacOS, where it is not a requirement that * input methods be Unicode-savvy. On this platform, TSM * needs the information to convert text to Unicode from a Mac * encoding variant which cannot be derived from the * ScriptLanguage record associated with the input method * component. This parameter is optional and may not be * present in all instances of this event. * * --> kEventParamTextInputSendTextServiceMacEncoding (in, typeUInt32) * The Mac encoding (variant) associated with the text sent by * an input method. On Mac OS X, this parameter is needed by * TSM to convert input method produced Unicodes to a Mac * encoding when the application that has focus is not * Unicode-savvy in the TSM sense... i.e. the current * TSMDocument (as returned by TSMGetActiveDocument) is not of * type kUnicodeDocument. This parameter can also be useful * if a Unicode-savvy handler should need to convert from * Unicode. * This parameter is optional and may not be present in all * instances of this event. * * --> kEventParamTextInputSendGlyphInfoArray (in, typeGlyphInfoArray) * A TSMGlyphInfoArray structure in which an input method can * associate unencoded glyphs IDs and/or fonts with * (sub)ranges of text it produces. The array elements * identify non-overlapping ranges of text and the glyph ID * (character collection is 0) such as in an OpenType font, or * the CID (collection is non-zero) such as in TrueType fonts. * If the glyphID itself is 0, only the font specified is to * be applied to the text range. This is useful for * characters in Unicode private use area, such as Windings, * but note that this capability should be used with care * because changing the font of an input text stream can lead * to a confusing user interface. An input method will only * include this parameter if the text engine has indicated it * supports this feature via the * kTSMDocumentSupportGlyphInfoPropertyTag TSMDocumentProperty * tag. For more information, see the Glyph Access protocol * described in Technote TN2079. This parameter is optional * and may not be present in all instances of this event. * * --> kEventParamTextInputSendReplaceRange (in, typeCFRange) * The CFRange in the application's document that should be * replaced by the contents of the inline input session * defined by other parameters in this event. The text * service will have obtained and calculated this range by * accessing the document's text via events of the * TSMDocumentAccess class. This CFRange parameter refers to * text in flat Unicode space (UniChar) offsets, and its * location is document relative, not relative to the * insertion point or any inline session. A text service may * include this parameter only if the text engine has * indicated it supports this feature via the * kTSMDocumentSupportDocumentAccessPropertyTag * TSMDocumentProperty tag. This parameter is optional and may * not be present in all instances of this event. NOTE: This * parameter is supported by the TSM Carbon event only, not by * TSM's kUpdateActiveInputArea AppleEvent. If a text engine * developer wishes to support this parameter, it must * implement a Carbon event handler for this event and set the * kTSMDocumentSupportDocumentAccessPropertyTag property tag. * NOTE: Care must be exercised by the app when there is an * active inline input session. A text service that sends an a * UpdateActiveInputArea event specifying this parameter * should not be the same text service that owns the inline * input session, since the text engine would need to call * FixTSMDocument(). This, in turn, would cause recursion * through that same text service via FixTextService(). * However, the app should be prepared for recursion * regardless of which text service owns the inline input * session because it will call FixTSMDocument() to confirm * the inline input session, and "somebody" will likely send * an UpdateActiveInputArea event as a result. Therefore, * document state obtained before the call to FixTSMDocument() * may not be valid after this call completes. * * Result: * TSM will return tsmUnknownErr if the input method has specified * an invalid component instance for this event's * kEventParamTextInputSendComponentInstance parameter. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventTextInputUpdateActiveInputArea = 1; { * kEventClassTextInput / kEventTextInputUnicodeForKeyEvent * * Summary: * Provides Unicode text input resulting from either a key event * (TSM originates the event in this case) or from a * kEventTextInputUnicodeText event produced by an input method, * such as a Character Palette class input method, or a HandWriting * input method. * * Discussion: * This is the primary event by which applications should receive * text input on Mac OS X. Apple recommends that applications use * this event rather than the kEventRawKeyDown event to handle text * input. * * A client need not be fully TSM-aware to process or receive this * event. You can also get Mac encoding characters from the raw * keyboard event contained in this event. If no UnicodeForKeyEvent * handler is installed, and no kUnicodeNotFromInputMethod * AppleEvent handler is installed (or the application has not * created a Unicode TSMDocument), the Mac encoding charCodes (if * these can be converted from the Unicodes) are provided to * WaitNextEvent. * * This event is generated automatically by TSM when a * kEventRawKeyDown event is sent to the application event target. * The typical keyboard event flow begins with a kEventRawKeyDown * event posted to the event queue. This event is dequeued during * WaitNextEvent or RunApplicationEventLoop, and sent to the event * dispatcher target. If the keydown event reaches the application * target, it is handled by TSM, which generates a * kEventTextInputUnicodeForKeyEvent and sends it to the event * dispatcher target. The event dispatcher will resend the event to * the user focus target, which sends it to the focused control in * the focused window. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamTextInputSendComponentInstance (in, typeComponentInstance) * This event parameter is DEPRECATED on Mac OS X 10.5 and * later. * * This parameter is provided by the input method originating * the event. (Required parameter) * * --> kEventParamTextInputSendRefCon (in, typeRefCon) * TSM's SendTextInputEvent, called by an input method, * inserts this parameter before dispatching the event to the * user focus. (Required Parameter) * * On Mac OS X 10.4 and earlier, this parameter uses * typeSInt32, and you must retrieve it using that constant. * On Mac OS X 10.5 and later, to support 64-bit refcon * values, this parameter uses typeRefCon. For 64-bit * compatibility, you must use typeRefCon when retrieving this * parameter; for 32-bit targets, however, you may continue to * use typeSInt32 if you wish, or switch to typeRefCon. * * --> kEventParamTextInputSendSLRec (in, typeIntlWritingCode) * This event parameter is DEPRECATED on Mac OS X 10.5 and * later. * * The ScriptLanguageRecord associated with the text contained * in the event. This parameter is normally provided by the * input method originating the event. TSM's * SendTextInputEvent will construct this parameter from * current script information as a result of a key event, or * using input method provided information when TSM receives a * kEventTextInputUnicodeText event. (Required Parameter) * * --> kEventParamTextInputSendAttributedString (in, typeCFAttributedStringRef) * The attributed string entered by the user. This is the * preferred event parameter on Mac OS X 10.5 and later. The * attributes are those defined in CTStringAttributes.h. * On Mac OS X 10.5, TSM supports the font attribute and the * glyph info attribute. * NOTE: When a glyph info attribute is set for a particular * text range, it is expected that a font attribute covers at * least that same text range. This is also important to * allow TSM to coerce attributes to compatibility data * structures, such as the * kEventParamTextInputSendGlyphInfoArray event parameter. * NOTE2: If this event parameter is missing and requested, * it is coerced from the compatibility parameters provided in * this event, in particular, kEventParamTextInputSendText and * kEventParamTextInputSendGlyphInfoArray. * * Required Parameter if kEventParamTextInputSendText is not * provided. * * --> kEventParamTextInputSendText (in, typeUnicodeText) * The Unicode characters that entered by the user. * Required Parameter if * kEventParamTextInputSendAttributedString is not provided. * * --> kEventParamTextInputSendKeyboardEvent (in, typeEventRef) * This parameter is the original raw keyboard event that * produced the text. It enables access to * kEventParamKeyModifiers and kEventParamKeyCode parameters. * Note that when contents of TSMÕs bottom-line input window * are confirmed (i.e., during typing of Chinese, Korean, or * Japanese), the raw keyboard eventÕs keyCode and modifiers * are set to default values. * * You can also extract from the RawKeyDown event either * Unicodes or Mac encoding characters as follows: * * kEventParamKeyUnicodes typeUnicodeText * kEventParamKeyMacCharCodes typeChar (if available) * (DEPRECATED for 64bit on Mac OS X 10.6 and later.) * * The kEventParamKeyUnicodes parameter of the raw keyboard * event is identical to the TextInput eventÕs * kEventParamTextInputSendText parameter. * * --> kEventParamTextInputSendGlyphInfoArray (in, typeGlyphInfoArray) * A TSMGlyphInfoArray structure in which an input method can * associate unencoded glyphs IDs and/or fonts with * (sub)ranges of text it produces. The array elements * identify non-overlapping ranges of text and the glyph ID * (character collection is 0) such as in an OpenType font, or * the CID (collection is non-zero) such as in TrueType fonts. * If the glyphID itself is 0, only the font specified is to * be applied to the text range. This is useful for * characters in Unicode private use area, such as Windings, * but note that this capability should be used with care * because changing the font of an input text stream can lead * to a confusing user interface. For more information, see * the Glyph Access protocol described in Technote TN2079. * This parameter is optional and may not be present in all * instances of this event. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventTextInputUnicodeForKeyEvent = 2; { * kEventClassTextInput / kEventTextInputOffsetToPos * * Summary: * Requests conversion from inline session text offset to global * coordinate. * * Discussion: * This event is typically produced by an input method so that it * can best position a palette near the text being edited by the * user. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamTextInputSendComponentInstance (in, typeComponentInstance) * This event parameter is DEPRECATED on Mac OS X 10.5 and * later. * * This parameter is provided by the input method originating * the event. (Required parameter) * * --> kEventParamTextInputSendRefCon (in, typeRefCon) * TSM's SendTextInputEvent, called by an input method, * inserts this parameter before dispatching the event to the * user focus. (Required Parameter) * * On Mac OS X 10.4 and earlier, this parameter uses * typeSInt32, and you must retrieve it using that constant. * On Mac OS X 10.5 and later, to support 64-bit refcon * values, this parameter uses typeRefCon. For 64-bit * compatibility, you must use typeRefCon when retrieving this * parameter; for 32-bit targets, however, you may continue to * use typeSInt32 if you wish, or switch to typeRefCon. * * --> kEventParamTextInputSendTextOffset (in, typeSignedByteOffset) * Specifies a (signed) byte offset in an active input area * for which the global position is desired. Because an * inline input session always begins at the insertion point, * the offset is always considered relative to the insertion * point, even when there is no active input area. (Required * Parameter) * * On Mac OS X 10.5 and later, this parameter is typed as * typeSignedByteOffset. For all 32bit targets, whether for * Mac OS X 10.5 or earlier, you can freely use this new * type. * For 64bit on Mac OS X 10.5 and later, in order to support * 64-bit text lengths, you must use typeSignedByteOffset. * * If an offset is outside the bounds of the document text, * errOffsetInvalid should be returned. Negative offsets are * not valid when an inline input session exists, but are * valid when none exists, to allow query of offsets before * the insertion point. * * NOTE: Non-zero offsets in the absence of an active input * area can only be specified when the originator of the event * is certain that the character encoding used by the target * (the current TSMDocument) is the same as its own encoding. * When there is no active input area, TSM is unable to * convert offsets between different encodings that might be * used by the app and an input method (as it normally does) * since TSM does not have access to the document text. * Practically, this means that both the originator and event * target must be Unicode-savvy, i.e. the current TSMDocument * was created with kUnicodeDocumentInterfaceType. * * NOTE: Insertion point relative offsets when there is no * active input area is contrary to the original definition of * this parameter in IM-Text 7-74 which states that the offset * is "relative to the start of the current text body" in this * case. However, most applications and text engines have * already implemented the case offset = 0 as being the * insertion point. This allows an input method to display * some UI near the the insertion point even before typing * takes place. * * --> kEventParamTextInputSendLeadingEdge (in, typeBoolean) * Specifies which glyph on either side of the supplied text * offset that should be used to compute the on-screen * position returned. This value is similar to the * leadingEdge parameter of the QuickDraw PixelToChar * function. If this parameter is true, the location of the * character (or characters if the glyph is represented by * multiple characters) at the specified text offset is * returned. If this parameter is false, the on-screen * position returned should be the trailing edge of the glyph * represented by the character (or characters) immediately * preceding (in memory order) the supplied text offset. * Note also that while the on-screen position for a given * offset and leading/trailing edge value is affected by this * parameter, it also affects what should be returned for the * other optional parameters at style run boundaries, such as * script and font information. * This parameter is optional and may not be present in all * instances of this event. * The default value for this parameter is 'true'. * * <-- kEventParamTextInputReplyPoint (out, typeHIPoint) * The position on screen of the requested text offset and * leading/trailing edge value. * By default, this HIPoint is accessed in global coordinates, * or 72dpi virtual coordinate Space, but can be accessed as * any other type that specifies the desired coordinate * space. * This parameter was originally typed as typeQDPoint, but on * Mac OS X 10.5 and later, it should be accessed as * typeHIPoint. The toolbox provides automatic type coercion * between these two types.
Required parameter. * * <-- kEventParamTextInputReplySLRec (out, typeIntlWritingCode) * This event parameter is DEPRECATED on Mac OS X 10.5 and * later. * * The ScriptLanguageRecord associated with the text at the * offset specified in the event, either the * ScriptLanguageRecord of the active input area if one * exists, or of the text at the specified offset and * specified leading/ trailing edge value. At a script run * boundary, such as where a Japanese text run ends, and a * Roman begins, a leading edge value of 'true' should return * the Roman script/language while a leading edge value of * 'false' should return the Japanese script/language. * This parameter is optional and may not be returned to the * caller. * * <-- kEventParamTextInputReplyCTFontRef (out, typeCTFontRef) * The CTFontRef associated with the text at the offset * specified in the event. This is the PREFERRED method of * accessing font info on Mac OS X 10.5 and later. Use * typeCTFontRef as the data type to retrieve this event * parameter. * * This is either the font of the active input area if one * exists, or of the text at the specified offset and * specified leading/trailing edge value. At a font run * boundary, such as where a Japanese text run ends, and a * Roman begins, a leading edge value of 'true' should return * the font of the Roman text run while a leading edge value * of 'false' should return the Japanese font. * * Note: For compatibility with applications that have not * yet adopted the CTFont API, the toolbox will automatically * coerce this parameter, if not present, from * kEventParamTextInputReplyATSFont (or on 32-bit: * kEventParamTextInputReplyFMFont or * kEventParamTextInputReplyFont) and the font size parameter * kEventParamTextInputReplyPointSize. * * Note2: This parameter is particularly important for input * methods to adopt, because it will allow them to reproduce * application text with much higher fidelity in its own UI * when the application also adopts CTFont. If the ATSFont and * FontSize info do not allow enough fidelity for your needs, * that's a sign that your input method should adopt CTFontRef * parameters in TSM events. * * If this CTFontRef parameter is provided, the following * event parameters are not needed (but see note under * kEventParamTextInputReplyPointSize): * * kEventParamTextInputReplyPointSize * kEventParamTextInputReplyLineHeight * kEventParamTextInputReplyLineAscent * * Optional reply parameter if * kEventParamTextInputReplyATSFont (or on 32-bit: * kEventParamTextInputReplyFMFont or * kEventParamTextInputReplyFont) and * kEventParamTextInputReplyPointSize are provided. * * <-- kEventParamTextInputReplyATSFont (out, typeATSFontRef) * The ATSFontRef associated with the text at the offset * specified in the event. This is either the font of the * active input area if one exists, or of the text at the * specified offset and specified leading/trailing edge value. * At a font run boundary, such as where a Japanese text run * ends, and a Roman begins, a leading edge value of 'true' * should return the font of the Roman text run while a * leading edge value of 'false' should return the Japanese * font. * * This is the recommended "compatibility" method of accessing * font info on Mac OS X 10.5 and later. The QD font and * FMFont parameters (see kEventParamTextInputReplyFMFont and * kEventParamTextInputReplyFont) are deprecated in all cases, * and not supported on 64-bit. * Note: For compatibility with applications that have not * yet adopted the CTFont API, the toolbox will automatically * coerce this parameter, if not present, from * kEventParamTextInputReplyCTFontRef (or on 32-bit, from * kEventParamTextInputReplyFMFont or * kEventParamTextInputReplyFont). * * If this ATSFontRef parameter is provided, the following * event parameters should be provided as typeCGFloat (see * note under kEventParamTextInputReplyPointSize): * * kEventParamTextInputReplyPointSize * kEventParamTextInputReplyLineHeight * kEventParamTextInputReplyLineAscent * * Optional reply parameter if * kEventParamTextInputReplyCTFontRef (or on 32-bit: * kEventParamTextInputReplyFMFont or * kEventParamTextInputReplyFont) and * kEventParamTextInputReplyPointSize are provided. * * <-- kEventParamTextInputReplyFMFont (out, typeUInt32) * This event parameter is DEPRECATED on Mac OS X 10.5 and * later. * * The FMFont associated with the text at the offset specified * in the event, either the FMFont of the active input area if * one exists, or of the text at the specified offset and * specified leading/ trailing edge value. At a font run * boundary, such as where a Japanese text run ends, and a * Roman begins, a leading edge value of 'true' should return * the font of the Roman text run while a leading edge value * of 'false' should return the Japanese font. * This parameter allows the handler to return an FMFont when * a FMFontFamily or FOND would be inconvenient to * compute. * This parameter is NOT SUPPORTED on 64-bit. * This parameter is optional and may not be returned to the * caller. * * <-- kEventParamTextInputReplyFont (out, typeSInt32) * This event parameter is DEPRECATED on Mac OS X 10.5 and * later. * * The QD Font associated with the text at the offset * specified in the event, either the QD Font of the active * input area if one exists, or of the text at the specified * offset and specified leading/ trailing edge value. At a * font run boundary, such as where a Japanese text run ends, * and a Roman begins, a leading edge value of 'true' should * return the font of the Roman text run while a leading edge * value of 'false' should return the Japanese font. * This parameter is NOT SUPPORTED on 64-bit. * This parameter is optional and may not be returned to the * caller. * * <-- kEventParamTextInputReplyPointSize (out, typeCGFloat) * If the kEventParamTextInputReplyCTFontRef parameter is * accessed using typeCTFontRef, this parameter is not used * (Mac OS X 10.5 and later). * * The point size associated with the text at the offset * specified in the event, either the point size of the active * input area if one exists, or of the text at the specified * offset. At a style run boundary where point size changes, * the leadingEdge parameter determines which point size * should be returned. * * Note: This parameter is not normally used if a CTFontRef * is being returned via kEventParamTextInputReplyCTFontRef * (Mac OS X 10.5 and later), but could be helpful if the * context in which the ATSFontRef is used (such as the use of * an affine transform) would produce a font size different * from the font size that would be derived from the * CTFontRef. However, see comment under * kEventParamTextInputReplyCTFontRef pertaining to the * importance of input method adoption of CTFont API. * * Note2: This parameter was originally typed as typeFixed * for QD font and FMFont, but should be inserted as * typeCGFloat when an ATSFontRef is returned via * kEventParamTextInputReplyATSFont. The toolbox provides * automatic type coercion between typeFixed and typeCGFloat * on 32-bit. Always use typeCGFloat on 64-bit. * This parameter is optional and may not be returned to the * caller. * * <-- kEventParamTextInputReplyLineHeight (out, typeCGFloat) * If the kEventParamTextInputReplyCTFontRef parameter is * accessed using typeCTFontRef, this parameter is not used * (Mac OS X 10.5 and later). * * The line height associated with the text at the offset * specified in the event, either the line height of the * active input area if one exists, or of the text at the * specified offset. At a style run boundary where point size * changes, the leadingEdge parameter determines which line * height should be returned. * By default, this value is accessed in global coordinate * space, or 72dpi virtual coordinate Space, but can be * accessed as any other type that specifies the desired * coordinate space, i.e. in Screen Pixel space. * * NOTE: This parameter was originally typed as typeSInt16 * for QD font and FMFont, but should be inserted as * typeCGFloat when an ATSFontRef is returned via * kEventParamTextInputReplyATSFont. The toolbox provides * automatic type coercion between typeSInt16 and typeCGFloat * on 32-bit. Always use typeCGFloat on 64-bit. * This parameter is optional and may not be returned to the * caller. * * <-- kEventParamTextInputReplyLineAscent (out, typeCGFloat) * If the kEventParamTextInputReplyCTFontRef parameter is * accessed using typeCTFontRef, this parameter is not used * (Mac OS X 10.5 and later). * * The line ascent associated with the text at the offset * specified in the event, either the line ascent of the * active input area if one exists, or of the text at the * specified offset. At a style run boundary where point size * changes, the leadingEdge parameter determines which line * ascent should be returned. * By default, this value is accessed in global coordinate * space, or 72dpi virtual coordinate Space, but can be * accessed as any other type that specifies the desired * coordinate space, i.e. in Screen Pixel space. * * NOTE: This parameter was originally typed as typeSInt16 * for QD font and FMFont, but should be inserted as * typeCGFloat when an ATSFontRef is returned via * kEventParamTextInputReplyATSFont. The toolbox provides * automatic type coercion between typeSInt16 and typeCGFloat * on 32-bit. Always use typeCGFloat on 64-bit. * This parameter is optional and may not be returned to the * caller. * * <-- kEventParamTextInputReplyTextAngle (out, typeFixed) * The orientation associated with the text at the offset * specified in the event, either the orientation of the * active input area if one exists, or of the text at the * specified offset. At a style run boundary where * orientation changes, the leadingEdge parameter determines * which orientation should be returned. The value 90 * specifies a horizontal line direction and 180 specifies a * vertical line direction. This parameter is optional and may * not be returned to the caller. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventTextInputOffsetToPos = 3; { * kEventClassTextInput / kEventTextInputPosToOffset * * Summary: * Requests conversion from global coordinate to a byte offset in * text. * * Discussion: * This event is used for mouse tracking. An input method typically * produces this event to perform proper cursor management as the * cursor moves over various subranges, or clauses of text (or the * boundaries between these) in an inline input session, or moves * between an inline input session to the main text body, or even * outside of the main text body. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamTextInputSendComponentInstance (in, typeComponentInstance) * This event parameter is DEPRECATED on Mac OS X 10.5 and * later. * * This parameter is provided by the input method originating * the event. (Required parameter) * * --> kEventParamTextInputSendRefCon (in, typeRefCon) * TSM's SendTextInputEvent, called by an input method, * inserts this parameter before dispatching the event to the * user focus. (Required Parameter) * * On Mac OS X 10.4 and earlier, this parameter uses * typeSInt32, and you must retrieve it using that constant. * On Mac OS X 10.5 and later, to support 64-bit refcon * values, this parameter uses typeRefCon. For 64-bit * compatibility, you must use typeRefCon when retrieving this * parameter; for 32-bit targets, however, you may continue to * use typeSInt32 if you wish, or switch to typeRefCon. * * --> kEventParamTextInputSendCurrentPoint (in, typeHIPoint) * The point whose text offset (and classification) the input * method is requesting. This point is usually the current * mouse position. * Text offset classifications are defined by * kEventParamTextInputReplyRegionClass. * By default, this point is accessed in global coordinate * space, or 72dpi virtual coordinate Space, but can be * accessed as any other type that specifies the desired * coordinate space. * This parameter was originally typed as typeQDPoint, but on * Mac OS X 10.5 and later, it should be accessed as * typeHIPoint. The toolbox provides automatic type coercion * between these two types.

Required parameter. * * --> kEventParamTextInputSendDraggingMode (in, typeBoolean) * A Boolean value that indicates whether the input method is * currently tracking the mouse -- that is, whether the user * is dragging the current selection. If it is TRUE, the * application should pin the cursor to the limits of the * active input area (to avoid highlighting beyond the limits * of the active input area). * This parameter is optional and may not be present in all * instances of this event. * * <-- kEventParamTextInputReplyTextOffset (out, typeByteOffset) * The text offset (ByteOffset) corresponding to the supplied * point. If the click is within the limits of the active * input area, the offset is relative to the start of the * active input area. Otherwise, the offset is relative to the * start of the application's text body. This offset is * always a positive value. (Required reply parameter) * * On Mac OS X 10.4 and earlier, this parameter uses * typeSInt32, and you must retrieve it using that constant. * On Mac OS X 10.5 and later, to support 64-bit offset * values, this parameter uses typeByteOffset. For 64-bit * compatibility, you must use typeByteOffset when retrieving * this parameter; for 32-bit targets, however, you may * continue to use typeSInt32 if you wish, or switch to * typeByteOffset which is really typeUInt32 to which the * toolbox will automatically convert because this parameter * always contains positive values. * * <-- kEventParamTextInputReplyRegionClass (out, typeSInt32) * The classification of the offset parameter. The values * kTSMOutsideOfBody and kTSMInsideOfBody means that the * position is outside or inside of the text body, * respectively. A value of kTSMInsideOfActiveInputArea means * that the position is inside of the active input area. * (Required reply parameter) * * <-- kEventParamTextInputReplyLeadingEdge (out, typeBoolean) * Specifies whether the point supplied corresponds to the * leading edge (true) or trailing edge (false) of a glyph. * This value is similar to the leadingEdge parameter of the * QuickDraw PixelToChar function. * If the supplied point is on the leading edge of a glyph, * this parameter contains the text offset of the character * whose glyph is at the pixel location. (If the glyph * represents multiple characters, it returns the text offset * of the first of these characters in memory.) If the * supplied point is on the trailing edge of a glyph, this * parameter returns the text offset of the first character in * memory following the character or characters represented by * the glyph. * This parameter is optional and may not be returned to the * caller. * * <-- kEventParamTextInputReplySLRec (out, typeIntlWritingCode) * This event parameter is DEPRECATED on Mac OS X 10.5 and * later. * * The ScriptLanguageRecord of the script run containing the * character at the returned text offset and leading/trailing * edge value. * This parameter is optional and may not be returned to the * caller. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventTextInputPosToOffset = 4; { * kEventClassTextInput / kEventTextInputShowHideBottomWindow * * Summary: * Show or hide the bottom-line input window. * * Discussion: * This event is produced by input methods to control the Text * Services Manager bottom-line input window, and is not normally * handled by an application. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamTextInputSendComponentInstance (in, typeComponentInstance) * This event parameter is DEPRECATED on Mac OS X 10.5 and * later. * * This parameter is provided by the input method originating * the event.
Required parameter. * * --> kEventParamTextInputSendRefCon (in, typeRefCon) * TSM's SendTextInputEvent, called by an input method, * inserts this parameter before dispatching the event to the * user focus. (Required Parameter) * * On Mac OS X 10.4 and earlier, this parameter uses * typeSInt32, and you must retrieve it using that constant. * On Mac OS X 10.5 and later, to support 64-bit refcon * values, this parameter uses typeRefCon. For 64-bit * compatibility, you must use typeRefCon when retrieving this * parameter; for 32-bit targets, however, you may continue to * use typeSInt32 if you wish, or switch to typeRefCon. * * --> kEventParamTextInputSendShowHide (in, typeBoolean) * If true, the bottomline input window should be shown; if * false, it should be hidden. This parameter is not needed if * the input method is simply inquiring about the state of the * input window. * This parameter is optional and may not be present in all * instances of this event. * * <-- kEventParamTextInputReplyShowHide (out, typeBoolean) * The current state of the input window: true if the window * is shown; false if it is hidden. If the optional parameter * kEventParamTextInputSendShowHide is included, this return * parameter should show the state of the window before it was * set to the state requested in the optional parameter. * This parameter is optional and may not be returned to the * caller. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventTextInputShowHideBottomWindow = 5; { * kEventClassTextInput / kEventTextInputGetSelectedText * * Summary: * Get the selected text (or the character before or after the * insertion point, based on the leadingEdge parameter) from the * applicationÕs text engine. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamTextInputSendComponentInstance (in, typeComponentInstance) * This event parameter is DEPRECATED on Mac OS X 10.5 and * later. * * This parameter is provided by the input method originating * the event. If an invalid value is specified, tsmUnknownErr * will be returned. (Required parameter) * * --> kEventParamTextInputSendRefCon (in, typeRefCon) * TSM's SendTextInputEvent, called by an input method, * inserts this parameter before dispatching the event to the * user focus. (Required Parameter) * * On Mac OS X 10.4 and earlier, this parameter uses * typeSInt32, and you must retrieve it using that constant. * On Mac OS X 10.5 and later, to support 64-bit refcon * values, this parameter uses typeRefCon. For 64-bit * compatibility, you must use typeRefCon when retrieving this * parameter; for 32-bit targets, however, you may continue to * use typeSInt32 if you wish, or switch to typeRefCon. * * --> kEventParamTextInputSendLeadingEdge (in, typeBoolean) * If there is a non-empty selection, this parameter should be * ignored. When the current selection is empty, i.e. an * insertion point, and this parameter is NOT supplied, no * text should be returned. If the current selection is empty * and this parameter is supplied, return the character (or * characters) representing the glyph on the side of the * insertion point indicated by this leadingEdge parameter. * This value is similar to the leadingEdge parameter of the * QuickDraw PixelToChar function. If this parameter is true, * the character (or characters) at the insertion point is * returned. If this parameter is false, the character (or * characters) immediately preceding (in memory order) the * insertion point should be returned. This parameter is * optional and may not be present in all instances of this * event. This parameter has no default value and no text * should be returned when this parameter is ommited and there * is no selected text. * * --> kEventParamTextInputSendTextServiceEncoding (in, typeUInt32) * The encoding associated with the text sent by an input * method. On MacOS X, this parameter is not commonly used * because all TSM input methods produce (and request) * Unicode, but if specified, this may be a Unicode variant * encoding. In CarbonLib on MacOS, this parameter identifies * the Mac encoding (usually an encoding variant) of the text * produced by the input method on MacOS, where it is not a * requirement that input methods be Unicode-savvy. On this * platform, TSM needs the information to convert text to * Unicode from a Mac encoding variant which cannot be derived * from the ScriptLanguage record associated with the input * method component. This parameter is optional and may not be * present in all instances of this event. * * --> kEventParamTextInputReplyAttributedString (in, typeCFAttributedStringRef) * The attributed string for the text selection. This is the * preferred event parameter on Mac OS X 10.5 and later. The * attributes are those defined in CTStringAttributes.h. * On Mac OS X 10.5, TSM supports the font attribute and the * glyph info attribute. * NOTE: When a glyph info attribute is set for a particular * text range, it is expected that a font attribute covers at * least that same text range. This is also important to * allow TSM to coerce attributes to compatibility data * structures, such as the kEventParamTextInputGlyphInfoArray * event parameter. * NOTE2: If this event parameter is missing and requested, * it is coerced from the compatibility parameters provided in * this event, in particular, kEventParamTextInputReplyText * and kEventParamTextInputGlyphInfoArray. * * This parameter is optional and may not be returned to the * caller. * * <-- kEventParamTextInputReplyText (out, typeUnicodeText) * The data type of this parameter actually depends on the * TSMDocument type created via NewTSMDocument: it should be * typeChar for kTextService documents, or typeUnicodeText for * kUnicodeDocument documents. * This parameter has been deprecated in favor of * kEventParamTextInputReplyAttributedString on Mac OS X 10.5 * and later. * This parameter is optional and may not be returned to the * caller. * * <-- kEventParamTextInputReplySLRec (out, typeIntlWritingCode) * This event parameter is DEPRECATED on Mac OS X 10.5 and * later. * * The ScriptLanguageRecord of the script run containing the * text being returned to an input method. This parameter is * optional and may not be returned to the caller. * * <-- kEventParamTextInputReplyMacEncoding (out, typeUInt32) * The Mac encoding (variant) associated with the text * returned to the input method. On Mac OS X, this parameter * may needed by TSM to convert application produced text from * a Mac encoding to Unicodes returned to the input method. * This parameter is optional and may not be returned to the * caller. * * <-- kEventParamTextInputGlyphInfoArray (out, typeGlyphInfoArray) * A TSMGlyphInfoArray structure in which the event handler * can associate unencoded glyphs IDs and/or fonts with * (sub)ranges of text it returns. The array elements * identify non-overlapping ranges of text and the glyph ID * (character collection is 0) such as in an OpenType font, or * the CID (collection is non-zero) such as in TrueType fonts. * If the glyphID itself is 0, only the font specified is to * be applied to the text range. This is useful for * characters in Unicode private use area. For more * information, see the Glyph Access protocol described in * Technote TN2079. This parameter is optional and may not be * returned to the caller. NOTE: This parameter should really * have been kEventParamTextInputReplyGlyphInfoArray, which * was introduced after glyphInfo support was added to this * event, but we can't change it now without breaking binary * compatibility. * * Result: * TSM will return tsmUnknownErr if the input method has specified * an invalid component instance for this event's * kEventParamTextInputSendComponentInstance parameter. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventTextInputGetSelectedText = 6; { * kEventClassTextInput / kEventTextInputUnicodeText * * Summary: * Used by input methods to provide original input text to the Text * Services Manager. * * Discussion: * This Unicode text event is produced only by input methods or * other text services, and is delivered to TSM via * SendTextInputEvent(). TSM never dispatches this event to the user * focus, so application handlers should NOT install handlers for * this event. Instead, TSM chains this event into any active * keyboard input method in order to prevent interference with * existing inline input sessions. The keyboard input method can * either insert the text into the inline session, or it may confirm * its session and return the UnicodeText event to TSM unhandled, in * which case TSM will convert the event into a UnicodeForKey event * (converting the Unicodes to Mac charCodes and synthesizing * information where needed) and finally dispatch the resulting * event to the user focus as usual. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamTextInputSendComponentInstance (in, typeComponentInstance) * This event parameter is DEPRECATED on Mac OS X 10.5 and * later. * * This parameter is provided by the input method originating * the event. (Required parameter) * * --> kEventParamTextInputSendSLRec (in, typeIntlWritingCode) * This event parameter is DEPRECATED on Mac OS X 10.5 and * later. * * The ScriptLanguageRecord associated with the text contained * in the event. This parameter is provided by the input * method originating the event. This parameter is optional * and may not be present in all instances of this event. * * --> kEventParamTextInputSendAttributedString (in, typeCFAttributedStringRef) * The attributed string produced by an input method. This is * the preferred event parameter on Mac OS X 10.5 and later. * The attributes are those defined in * CTStringAttributes.h. * On Mac OS X 10.5, TSM supports the font attribute and the * glyph info attribute. * NOTE: When a glyph info attribute is set for a particular * text range, it is expected that a font attribute covers at * least that same text range. This is also important to * allow TSM to coerce attributes to compatibility data * structures, such as the * kEventParamTextInputSendGlyphInfoArray event parameter. * NOTE2: If this event parameter is missing and requested, * it is coerced from the compatibility parameters provided in * this event, in particular, kEventParamTextInputSendText and * kEventParamTextInputSendGlyphInfoArray. * * Required Parameter if kEventParamTextInputSendText is not * provided. * * --> kEventParamTextInputSendText (in, typeUnicodeText) * The Unicode characters produced by an input method. * Required Parameter if * kEventParamTextInputSendAttributedString is not provided. * * --> kEventParamTextInputSendTextServiceEncoding (in, typeUInt32) * The encoding associated with the text sent by an input * method. On MacOS X, this parameter is not commonly used * because all TSM input methods produce (and request) * Unicode, but if specified, this may be a Unicode variant * encoding. This parameter is optional and may not be present * in all instances of this event. * * --> kEventParamTextInputSendTextServiceMacEncoding (in, typeUInt32) * The Mac encoding (variant) associated with the text sent by * an input method, should TSM or an event handler need to * convert the Unicodes. This parameter is optional and may * not be present in all instances of this event. * * --> kEventParamTextInputSendGlyphInfoArray (in, typeGlyphInfoArray) * A TSMGlyphInfoArray structure in which an input method can * associate unencoded glyphs IDs and/or fonts with * (sub)ranges of text it produces. The array elements * identify non-overlapping ranges of text and the glyph ID * (character collection is 0) such as in an OpenType font, or * the CID (collection is non-zero) such as in TrueType fonts. * If the glyphID itself is 0, only the font specified is to * be applied to the text range. This is useful for * characters in Unicode private use area, such as Windings, * but note that this capability should be used with care * because changing the font of an input text stream can lead * to a confusing user interface. For more information, see * the Glyph Access protocol described in Technote TN2079. * This parameter is optional and may not be present in all * instances of this event. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventTextInputUnicodeText = 7; { * kEventClassTextInput / kEventTextInputFilterText * * Summary: * Send text about to be inserted into the user focus to be filtered * first. * * Discussion: * Sent before any final-form text is sent to the user focus. Final * form text includes text produced by a keyboard layout, Ink input * method, Character palette or any other TSM text service, and any * text being "confirmed" (or commited) from an inline input * session. In the case of text confirmed from an inline input * session, TSM will take the resulting text buffer filtered by the * event handler and adjust all parameters in the * UpdateActiveInputArea event produced by the input method. The * text filtering action will thus be transparent to both the app's * UpdateActiveInputArea handler and the input method confirming the * text. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamTextInputSendRefCon (in, typeRefCon) * TSM's SendTextInputEvent, called by an input method, * inserts this parameter before dispatching the event to the * user focus. (Required Parameter) * * On Mac OS X 10.4 and earlier, this parameter uses * typeSInt32, and you must retrieve it using that constant. * On Mac OS X 10.5 and later, to support 64-bit refcon * values, this parameter uses typeRefCon. For 64-bit * compatibility, you must use typeRefCon when retrieving this * parameter; for 32-bit targets, however, you may continue to * use typeSInt32 if you wish, or switch to typeRefCon. * * --> kEventParamTextInputSendText (in, typeUnicodeText) * The Unicode characters that are about to be sent to the * user focus, and need to be filtered. (Required Parameter) * * <-- kEventParamTextInputReplyText (out, typeUnicodeText) * The filtered Unicode characters... may be a zero-size * parameter. (Required Parameter) * * Result: * Return noErr to indicate that the text needing filtering has been * changed, otherwise return eventNotHandledErr. * * Availability: * Mac OS X: in version 10.4 and later in Carbon.framework * CarbonLib: not available } const kEventTextInputFilterText = 14; { * kEventClassTextInput / kEventTextInputIsMouseEventInInlineInputArea * * Summary: * Test whether the mouse event's point intersects the on-screen * area used for the current inline input session. * * Discussion: * When there is a currently active TSMDocument (as returned by * TSMGetActiveDocument), and only when there is an active inline * input session, TSM will dispatch this event to the event * dispatcher target, which sends it to the user focus event target. * The intent of this event is to ask the owner of the TSMDocument * whether the mouse event specified should be considered to * intersect the area (bounds) occupied by the inline input * session. * * This event is dispatched for any kEventClassMouse event except * kEventMouseEntered and kEventMouseExited. The entire mouse event * is included instead of only the point, in order to allow the * event handler to be as light-weight as possible, i.e. leverage * the additional content of mouse events, such as * kEventParamWindowRef and kEventParamWindowMouseLocation, but it * is understood that the mouse event itself will in no way be * modified in the event handler. Because this event is dispatched * for kEventMouseMoved events, it should do as little work as * possible, such as a call to HIShapeContainsPoint(). * * If the owner of the current TSMDocument does not respond to this * event, TSM will hit-test the mouse event against the content * region of the key focus window (as returned by * GetUserFocusWindow). * * When the owner of the current TSMDocument indicates that the * mouse event does intersect the inline input session (or the event * is not handled and the mouse event intersects the key focus * window's content region), the mouse event is delivered to the * input method. * * Note: kEventMouseMoved events are promoted to * kEventWindowCursorChange events before being delivered to the * input method. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamTextInputSendRefCon (in, typeRefCon) * This RefCon property of the active TSMDocument. * * --> kEventParamTextInputSendMouseEvent (in, typeEventRef) * The mouse event being hit-tested against the inline input * session. * * <-- kEventParamResult (out, typeBoolean) * Whether the mouse event's point intersects the area * occupied by the inline input session. * * Availability: * Mac OS X: in version 10.5 and later in Carbon.framework * CarbonLib: not available } const kEventTextInputIsMouseEventInInlineInputArea = 16; {--------------------------------------------------------------------------------------} { Raw Keyboard Events } {--------------------------------------------------------------------------------------} { kEventClassKeyboard quick reference: kEventRawKeyDown = 1, kEventRawKeyRepeat = 2, kEventRawKeyUp = 3, kEventRawKeyModifiersChanged = 4, kEventHotKeyPressed = 5, kEventHotKeyReleased = 6 ); |*! @event kEventRawKeyDown @abstract A key was pressed. @discussion This is the lowest-level keyboard input event. When this event is sent, the keyboard input has not yet been processed by the Text Services Manager or passed to input methods. Usually, you should not handle this event, because doing so may interfere with input methods; instead, you should handle the kEventTextInputUnicodeForKeyEvent event, which is sent after input methods have handled the raw key event, and contains both Unicode and the original keyboard event. This event has a default handler on the application event target. The default handler calls the Text Services Manager to pass the event through to input methods. The default handler also implements certain standard keyboard equivalents, such as cmd-` for intra- process window rotation and the universal keyboard access equivalents for interprocess window rotation and document, floating, toolbar, and menubar keyboard focus. @param kEventParamKeyUnicodes The Unicode(s) generated by the key that was pressed.
This parameter is preferred for obtaining text for a key press and should be used instead of kEventParamKeyMacCharCodes, in particular in 64bit. @param kEventParamKeyMacCharCodes This event parameter is DEPRECATED for 64bit on Mac OS X 10.6 and later.

The character generated by the key that was pressed. The characterÕs encoding is determined by the current keyboard script. @param kEventParamKeyCode The virtual keycode of the key that was pressed. @param kEventParamKeyModifiers The keyboard modifiers that were down when the key was pressed. @param kEventParamKeyboardType The type of keyboard on which the key was pressed. } { * kEventClassKeyboard / kEventRawKeyDown * * Mac OS X threading: * Not thread safe * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventRawKeyDown = 1; { * kEventClassKeyboard / kEventRawKeyRepeat * * Summary: * Sent periodically as a key is held down by the user. * * Discussion: * Usually, you should not handle this event, because doing so may * interfere with input methods; instead, you should handle the * kEventTextInputUnicodeForKeyEvent event, which is sent after * input methods have handled the raw key event, and contains both * Unicode and the original keyboard event. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamKeyUnicodes (in, typeUnicodeText) * The Unicode(s) generated by the key that was pressed. * This parameter is preferred for obtaining text for a key * press and should be used instead of * kEventParamKeyMacCharCodes, in particular in 64bit. * * --> kEventParamKeyMacCharCodes (in, typeChar) * This event parameter is DEPRECATED for 64bit on Mac OS X * 10.6 and later. * * The character generated by the key that was pressed. The * characterÕs encoding is determined by the current keyboard * script. * * --> kEventParamKeyCode (in, typeUInt32) * The virtual keycode of the key that was pressed. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were down when the key was * pressed. * * --> kEventParamKeyboardType (in, typeUInt32) * The type of keyboard on which the key was pressed. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventRawKeyRepeat = 2; { * kEventClassKeyboard / kEventRawKeyUp * * Summary: * A key was released. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamKeyUnicodes (in, typeUnicodeText) * The Unicode(s) generated by the key that was released. * This parameter is preferred for obtaining text for a key * press and should be used instead of * kEventParamKeyMacCharCodes, in particular in 64bit. * * --> kEventParamKeyMacCharCodes (in, typeChar) * This event parameter is DEPRECATED for 64bit on Mac OS X * 10.6 and later. * * The character generated by the key that was released. The * characterÕs encoding is determined by the current keyboard * script. * * --> kEventParamKeyCode (in, typeUInt32) * The virtual keycode of the key that was released. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were down when the key was * released. * * --> kEventParamKeyboardType (in, typeUInt32) * The type of keyboard on which the key was released. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventRawKeyUp = 3; { * kEventClassKeyboard / kEventRawKeyModifiersChanged * * Summary: * The keyboard modifiers have changed. * * Discussion: * This event is sent to all handlers registered for it. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that are now pressed. This is the * current state of the modifiers, not a delta state; it * includes modifiers that were pressed before the latest * change to modifier state. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventRawKeyModifiersChanged = 4; { * kEventClassKeyboard / kEventHotKeyPressed * * Summary: * A registered hot key was pressed. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeEventHotKeyID) * The ID of the hot key that was pressed. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.3 and later } const kEventHotKeyPressed = 5; { * kEventClassKeyboard / kEventHotKeyReleased * * Summary: * A registered hot key was released. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeEventHotKeyID) * The ID of the hot key that was released. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.3 and later } const kEventHotKeyReleased = 6; { * Summary: * Key modifier change event bits and masks * * Discussion: * From bit 8, cmdKeyBit, to bit 15, rightControlKeyBit, are * compatible with Event Manager modifiers. } const { * Indicates that this keyboard event was generated either on the * numeric keypad, or in the numeric section of an iBook or PowerBook * keyboard with the NumLock key pressed. This state bit does not * provide an indication of the NumLock state on non-portable * keyboards. This bit is only set on Mac OS X. } kEventKeyModifierNumLockBit = 16; { * Indicates that the Fn key was pressed when this keyboard event was * generated. This bit is only set on Mac OS X. } kEventKeyModifierFnBit = 17; const kEventKeyModifierNumLockMask = 1 shl kEventKeyModifierNumLockBit; kEventKeyModifierFnMask = 1 shl kEventKeyModifierFnBit; {--------------------------------------------------------------------------------------} { Application Events } {--------------------------------------------------------------------------------------} { kEventClassApplication quick reference: kEventAppActivated = 1, kEventAppDeactivated = 2, kEventAppQuit = 3, kEventAppLaunchNotification = 4, kEventAppLaunched = 5, kEventAppTerminated = 6, kEventAppFrontSwitched = 7, kEventAppFocusMenuBar = 8, kEventAppFocusNextDocumentWindow = 9, kEventAppFocusNextFloatingWindow = 10, kEventAppFocusToolbar = 11, kEventAppFocusDrawer = 12, kEventAppGetDockTileMenu = 20, kEventAppUpdateDockTile = 21, kEventAppIsEventInInstantMouser = 104, kEventAppHidden = 107, kEventAppShown = 108, kEventAppSystemUIModeChanged = 109, kEventAppAvailableWindowBoundsChanged = 110, kEventAppActiveWindowChanged = 111 } { * kEventClassApplication / kEventAppActivated * * Summary: * This application has been activated. * * Discussion: * This event is sent to all handlers registered for it. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamWindowRef (in, typeWindowRef) * This parameter is present if a click on an application * window was the cause of the app activation; it contains the * window that was clicked. This parameter is not provided if * the application was activated for some other reason. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventAppActivated = 1; { * kEventClassApplication / kEventAppDeactivated * * Summary: * This application has been deactivated. * * Discussion: * This event is sent to all handlers registered for it. * * Mac OS X threading: * Not thread safe * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventAppDeactivated = 2; { * kEventClassApplication / kEventAppQuit * * Summary: * A request to quit. Sent by QuitApplicationEventLoop to the * application target. * * Discussion: * The RunApplicationEventLoop API installs a default handler on the * application target for this event while the event loop is * running. The handler is removed before RunApplicationEventLoop * returns. * * The event handler installed by RunApplicationEventLoop will cause * RunApplicationEventLoop to exit. Most applications will not need * to handle this event; instead, an application should install an * AppleEvent handler for the kAEQuitApplication event handler if it * needs to check for unsaved documents or do other cleanup before * quitting. * * Mac OS X threading: * Not thread safe * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventAppQuit = 3; { * kEventClassApplication / kEventAppLaunchNotification * * Summary: * Notification that an asynchronous process launch has completed. * * Discussion: * This event is received when you use LaunchServices to launch a * process asynchronously. Your application only receives this event * for processes that you launch; it is not sent for process * launches from other applications (such as the Finder). * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamProcessID (in, typeProcessSerialNumber) * The ProcessSerialNumber of the process that was launched. * * --> kEventParamLaunchRefCon (in, typeRefCon) * Contains the value in the asyncRefCon field of the LSLaunch * structure that was used to launch the process. * * On Mac OS X 10.4 and earlier, this parameter uses * typeUInt32, and you must retrieve it using that constant. * On Mac OS X 10.5 and later, to support 64-bit refcon * values, this parameter uses typeRefCon. For 64-bit * compatibility, you must use typeRefCon when retrieving this * parameter; for 32-bit targets, however, you may continue to * use typeUInt32 if you wish, or switch to typeRefCon. * * --> kEventParamLaunchErr (in, typeOSStatus) * A result code indicating success or failure of the launch. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventAppLaunchNotification = 4; { * kEventClassApplication / kEventAppLaunched * * Summary: * Another app was launched. * * Discussion: * This event is sent to all handlers registered for it. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamProcessID (in, typeProcessSerialNumber) * The ProcessSerialNumber of the process that was launched. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.3.1 and later } const kEventAppLaunched = 5; { * kEventClassApplication / kEventAppTerminated * * Summary: * Another app terminated. * * Discussion: * This event is sent to all handlers registered for it. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamProcessID (in, typeProcessSerialNumber) * The ProcessSerialNumber of the process that terminated. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.3.1 and later } const kEventAppTerminated = 6; { * kEventClassApplication / kEventAppFrontSwitched * * Summary: * The front (active) application has changed. * * Discussion: * This event is sent to all handlers registered for it. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamProcessID (in, typeProcessSerialNumber) * The ProcessSerialNumber of the process that became * frontmost. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.3.1 and later } const kEventAppFrontSwitched = 7; { * kEventClassApplication / kEventAppHidden * * Summary: * The current application has been hidden. * * Discussion: * This event is sent to all handlers registered for it. * * Mac OS X threading: * Not thread safe * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventAppHidden = 107; { * kEventClassApplication / kEventAppShown * * Summary: * The current application has been shown. * * Discussion: * This event is sent to all handlers registered for it. * * Mac OS X threading: * Not thread safe * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventAppShown = 108; { * kEventClassApplication / kEventAppSystemUIModeChanged * * Summary: * The system UI mode or options of the frontmost application have * changed. * * Discussion: * On Mac OS X 10.6 and later, this event is sent if the UI options * of the frontmost application change, even if the mode remains the * same. Prior to Mac OS X 10.6, this event is only sent if the UI * mode changes. This event is sent to all handlers registered for * it. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamSystemUIMode (in, typeUInt32) * The new system UI mode. Contains a kUIMode constant from * MacApplication.h. * * --> kEventParamSystemUIOptions (in, typeUInt32) * The new system UI options. Contains a bitmask of kUIOption * constants from MacApplication.h. This parameter is * available on Mac OS X 10.6 and later. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventAppSystemUIModeChanged = 109; const { * Indicates that a deviceÕs available window positioning bounds have * changed because of a change in Dock position or size. } kAvailBoundsChangedForDock = 1 shl 0; { * Indicates that a deviceÕs available window positioning bounds have * changed because of a change in display configuration. } kAvailBoundsChangedForDisplay = 1 shl 1; { * kEventClassApplication / kEventAppAvailableWindowBoundsChanged * * Summary: * The available window positioning bounds have changed. * * Discussion: * This event is sent to all handlers registered for it. * * This event is currently sent in two circumstances: when the Dock * has changed position or size, and when the display configuration * has changed. A separate copy of this event is sent to each * affected GDevice. * * All applications have a default handler installed on the * application target that responds to this event by sending * kEventWindowConstrain events to each window on the specified * device. It is not possible to prevent this handler from running, * since this event is sent to all registered handlers. However, * applications that would like to do their own window layout may * install a handler for this event, and also set the * kWindowNoConstrainAttribute on their windows, which will cause * the basic window handler to ignore kEventWindowConstrain. An * application may also install its own kEventWindowConstrain * handler and selectively return a value other than * eventNotHandledErr, which will prevent the event from being sent * to the basic window handler. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDisplayDevice (in, typeCGDisplayID) * The display device whose available positioning bounds have * changed. On Mac OS X 10.3 and later, this parameter is * available as a GDHandle using typeGDHandle; on Mac OS X * 10.5 and later, this parameter is also available as a * CGDirectDisplayID using typeCGDisplayID. * * --> kEventParamReason (in, typeUInt32) * The reasons why the available positioning bounds have * changed. This parameter contains one or more of the * kAvailBoundsChangedFor constants. * * --> kEventParamTransactionID (in, typeUInt32) * An integer which is the same for all instances of this * event that are produced by the same configuration change. * For example, if multiple displays are attached, then this * event is sent once for each display after a display * configuration change; however, the transaction ID parameter * will the same for each event, so a handler for this event * can choose to ignore all but the first event by correlating * the the transaction IDs. * * --> kEventParamPreviousDockRect (in, typeHIRect) * The DockÕs previous bounds, in global coordinates. This * parameter is optional and may not be present in all * instances of this event. It is present in events with a * kEventParamReason parameter containing * kAvailBoundsChangedForDock. * * --> kEventParamPreviousDockDevice (in, typeCGDisplayID) * The display device on which the Dock was previously * positioned. This parameter is optional and may not be * present in all instances of this event. It is present in * events with a kEventParamReason parameter containing * kAvailBoundsChangedForDock. On Mac OS X 10.3 and later, * this parameter is available as a GDHandle using * typeGDHandle; on Mac OS X 10.5 and later, this parameter is * also available as a CGDirectDisplayID using typeCGDisplayID. * * --> kEventParamCurrentDockRect (in, typeHIRect) * The DockÕs current bounds, in global coordinates. This * parameter is optional and may not be present in all * instances of this event. It is present in events with a * kEventParamReason parameter containing * kAvailBoundsChangedForDock. * * --> kEventParamCurrentDockDevice (in, typeCGDisplayID) * The display device on which the Dock is currently * positioned. This parameter is optional and may not be * present in all instances of this event. It is present in * events with a kEventParamReason parameter containing * kAvailBoundsChangedForDock. On Mac OS X 10.3 and later, * this parameter is available as a GDHandle using * typeGDHandle; on Mac OS X 10.5 and later, this parameter is * also available as a CGDirectDisplayID using typeCGDisplayID. * * --> kEventParamRgnHandle (in, typeQDRgnHandle) * The GrayRgn before the configuration change. This parameter * is optional and may not be present in all instances of this * event. It is present in events with a kEventParamReason * parameter containing kAvailBoundsChangedForDisplay. To get * the GrayRgn after the configuration change, just call the * GetGrayRgn API. * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available } const kEventAppAvailableWindowBoundsChanged = 110; { * kEventClassApplication / kEventAppActiveWindowChanged * * Summary: * Notification that the active window in the current process has * changed. * * Discussion: * The Window Manager internally tracks the active window, which is * the window that is returned by ActiveNonFloatingWindow. When * SelectWindow is called on a window, that window is made the new * active window. At that time, the Window Manager also posts a * kEventAppActiveWindowChanged event to the main event * queue. * * The ActivateWindow API also causes this event to be * posted. * * If more than one window is activated sequentially before the * event loop is run, only a single kEventAppActiveWindowChanged * event will be left in the event queue, its PreviousActiveWindow * parameter will be the window that was originally active, and its * CurrentActiveWindow parameter will be the window that was finally * active. * * This event only reports changes to the current process. It does * not report activation changes in other processes. *
This event is sent to all handlers registered for it. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamPreviousWindow (in, typeWindowRef) * The window that was previously active. * * --> kEventParamCurrentWindow (in, typeWindowRef) * The window that is now active. * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available } const kEventAppActiveWindowChanged = 111; { * kEventClassApplication / kEventAppGetDockTileMenu * * Summary: * A request for a menu to be displayed by the applicationÕs dock * tile. * * Discussion: * This event has a default handler on the application target. The * default handler will return the menu, if any, that was provided * by the SetApplicationDockTileMenu API. The sender of this event * will release the menu after the Dock has displayed it, so if you * return a permanently allocated MenuRef, you should call * RetainMenu on it before returning from your event handler. For * most applications, it will be easier to use the * SetApplicationDockTileMenu API directly rather than installing a * handler for this event. * * Mac OS X threading: * Not thread safe * * Parameters: * * <-- kEventParamMenuRef (out, typeMenuRef) * A MenuRef to be displayed in the Dock is returned by the * handler in this parameter. * * Availability: * Mac OS X: in version 10.1 and later in Carbon.framework * CarbonLib: not available } const kEventAppGetDockTileMenu = 20; { * kEventClassApplication / kEventAppUpdateDockTile * * Summary: * Indicates that your application should redraw its custom * application Dock tile, if appropriate. * * Discussion: * This event is sent when your application has customized either * its application Dock tile or a collapsed window Dock tile. If * your app customizes its application Dock tile appearance using * SetApplicationDockTileImage, OverlayApplicationDockTileImage, * BeginCGContextForApplicationDockTile, * BeginQDContextForApplicationDockTile, or * HIApplicationCreateDockTileContext, then your application should * redraw its Dock tile in response to this event. This event is not * sent if your application has not customized any of its Dock * tiles. * * This event is currently sent in two cases: when the Dock tile * changes size (typically in response to a change in the user * interface scale factor), or when the Dock process is restarted. * In either case, any customization that your application has * previously performed is lost. * * If your application only customizes its collapsed window Dock * tiles, but not its application Dock tile, then you can ignore * this event. * * This event is sent to all handlers registered for it on the * application event target. The default application event handler * for this event sends kEventWindowUpdateDockTile events to any * collapsed windows that have customized their Dock tiles. * * Mac OS X threading: * Not thread safe * * Availability: * Mac OS X: in version 10.5 and later in Carbon.framework * CarbonLib: not available } const kEventAppUpdateDockTile = 21; { * kEventClassApplication / kEventAppFocusMenuBar * * Summary: * The user has requested keyboard focus on the menubar. * * Discussion: * This event is handled automatically by the default application * event handler. A handler for this event should switch the * keyboard focus to the menubar. Applications may install handlers * for this event to track keyboard focus, but should not prevent * the event from being handled by the default application handler. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the user * requested a focus switch. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventAppFocusMenuBar = 8; { * kEventClassApplication / kEventAppFocusNextDocumentWindow * * Summary: * The user has requested keyboard focus on a document window. * * Discussion: * This event is handled automatically by the default application * event handler. A handler for this event should cycle to the next * (or previous, if the shift key is down) document window, or if * there are no more windows to activate in the applicationÕs window * list, to the next or previous document window in the next or * previous process. User focus (see SetUserFocusWindow) should be * applied to the new front document window. If something other than * a document window has the focus at the time you receive this * event, the frontmost document window should be given the user * focus instead, and no z-order change should be made. * Additionally, the keyboard focus should be moved to the main * control in the newly focused window if no keyboard focus exists * within the window. * * A handler for this event should never override it entirely; if * necessary, it should only check if the user focus is somewhere * other than a document window, and if so, set the focus on the * active document window. If the focus is already on a document * window, a handler for this event should always return * eventNotHandledErr so that the default handler can rotate to the * next window across all processes. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the user * requested a focus switch. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventAppFocusNextDocumentWindow = 9; { * kEventClassApplication / kEventAppFocusNextFloatingWindow * * Summary: * The user has requested keyboard focus on a floating window. * * Discussion: * This event is handled automatically by the default application * event handler. A handler for this event should cycle to the next * (or previous, if the shift key is down) floating window in the * application. User focus (see SetUserFocusWindow) should be * applied to the new front floating window. If something other than * a floating window has the focus at the time you receive this * event, the frontmost floating window should be given the user * focus instead, and no z-order change should be made. * Additionally, the keyboard focus should be moved to the main * control in the newly focused window if no keyboard focus exists * within the window. The default handler sends a * kEventCommandProcess event containing * kHICommandRotateFloatingWindowsForward/Backward when it detects * that floating windows should be cycled. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the user * requested a focus switch. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventAppFocusNextFloatingWindow = 10; { * kEventClassApplication / kEventAppFocusToolbar * * Summary: * The user has requested keyboard focus on the toolbar in the * focused window. * * Discussion: * For windows that use the standard HIToolbar control, this event * is handled automatically by the default application event * handler. A handler for this event should put focus on the first * control in the toolbar in the focused window, if a toolbar is * present. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the user * requested a focus switch. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventAppFocusToolbar = 11; { * kEventClassApplication / kEventAppFocusDrawer * * Summary: * The user has requested keyboard focus on the drawer in the * focused window. * * Discussion: * This event is handled automatically by the default application * event handler. A handler for this event should put focus on the * first control in the drawer in the focused window, if a drawer is * present. If multiple drawers are present, focus is moved in * clockwise order from one drawer to the next, starting with the * top drawer, if any. If the modifiers parameter contains the shift * key, then focus should be moved in reverse (counterclockwise) * order. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the user * requested a focus switch. * * Availability: * Mac OS X: in version 10.4 and later in Carbon.framework * CarbonLib: not available } const kEventAppFocusDrawer = 12; { * kEventClassApplication / kEventAppIsEventInInstantMouser * * Summary: * Sent when the system needs to determine if the given event's * global mouse location is over an "instant mousing" area. An * instant mousing area is an area where a mouse down should not * generate ink, but should only be interpreted as a click. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamEventRef (in, typeEventRef) * The Event to check. * * <-- kEventParamIsInInstantMouser (out, typeBoolean) * True if event was in an "instant mousing" area, false * otherwise. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventAppIsEventInInstantMouser = 104; {--------------------------------------------------------------------------------------} { Apple Events } {--------------------------------------------------------------------------------------} { kEventClassAppleEvent quick reference: kEventAppleEvent = 1 } { * kEventClassAppleEvent / kEventAppleEvent * * Summary: * Sent when a high-level event is received. * * Discussion: * The RunApplicationEventLoop API installs a default handler on the * application target for this event while the event loop is * running. The handler is removed before RunApplicationEventLoop * returns. * * The handler installed by RunApplicationEventLoop will call * AEProcessAppleEvent. * * It is not possible to get the AppleEvent itself from this Carbon * event; only its event class and kind are available. To inspect * the AppleEvent parameters, the event must actually be dispatched * using AEProcessAppleEvent. * * If you need to handle this Carbon event yourself, on Mac OS X * 10.5 and later you may simply call the AEProcessEvent API. On Mac * OS X 10.4 and earlier, the necessary steps are: (1) remove the * Carbon event from the queue. The AppleEvent requires some special * preparation before it can be processed, and this preparation only * occurs when the event is dequeued. You may choose to ignore the * return value from RemoveEventFromQueue, since in some cases the * event will have already been removed from the queue. In those * cases, calling RemoveEventFromQueue is unnecessary, and will * return an error, but is also harmless. (2) Use * ConvertEventRefToEventRecord to get an EventRecord from the * Carbon event. (3) Call AEProcessAppleEvent on the EventRecord. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamAEEventClass (in, typeType) * The event class of the Apple event. * * --> kEventParamAEEventID (in, typeType) * The event ID of the Apple event. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventAppleEvent = 1; {--------------------------------------------------------------------------------------} { Window Events } {--------------------------------------------------------------------------------------} { kEventClassWindow quick reference: -- window refresh events -- kEventWindowUpdate = 1, kEventWindowDrawContent = 2, -- window activation events -- kEventWindowActivated = 5, kEventWindowDeactivated = 6, kEventWindowHandleActivate = 91, kEventWindowHandleDeactivate = 92, kEventWindowGetClickActivation = 7, kEventWindowGetClickModality = 8, -- window state change events -- kEventWindowShowing = 22, kEventWindowHiding = 23, kEventWindowShown = 24, kEventWindowHidden = 25, kEventWindowCollapsing = 86, kEventWindowCollapsed = 67, kEventWindowExpanding = 87, kEventWindowExpanded = 70, kEventWindowZoomed = 76, kEventWindowBoundsChanging = 26, kEventWindowBoundsChanged = 27, kEventWindowResizeStarted = 28, kEventWindowResizeCompleted = 29, kEventWindowDragStarted = 30, kEventWindowDragCompleted = 31, kEventWindowClosed = 73, kEventWindowTransitionStarted = 88, kEventWindowTransitionCompleted = 89, -- window click events -- kEventWindowClickDragRgn = 32, kEventWindowClickResizeRgn = 33, kEventWindowClickCollapseRgn = 34, kEventWindowClickCloseRgn = 35, kEventWindowClickZoomRgn = 36, kEventWindowClickContentRgn = 37, kEventWindowClickProxyIconRgn = 38, kEventWindowClickToolbarButtonRgn = 41, kEventWindowClickStructureRgn = 42, -- window cursor change events -- kEventWindowCursorChange = 40, -- window action events -- kEventWindowCollapse = 66, (kEventWindowCollapsed = 67) kEventWindowCollapseAll = 68, kEventWindowExpand = 69, (kEventWindowExpanded = 70) kEventWindowExpandAll = 71, kEventWindowClose = 72, (kEventWindowClosed = 73) kEventWindowCloseAll = 74, kEventWindowZoom = 75, (kEventWindowZoomed = 76) kEventWindowZoomAll = 77, kEventWindowContextualMenuSelect = 78, kEventWindowPathSelect = 79, kEventWindowGetIdealSize = 80, kEventWindowGetMinimumSize = 81, kEventWindowGetMaximumSize = 82, kEventWindowConstrain = 83, kEventWindowRestoreFromDock = 84, kEventWindowHandleContentClick = 85, (kEventWindowCollapsing = 86) (kEventWindowExpanding = 87) (kEventWindowTransitionStarted = 88) (kEventWindowTransitionCompleted = 89) kEventWindowGetDockTileMenu = 90, (kEventWindowHandleActivate = 91) (kEventWindowHandleDeactivate = 92) kEventWindowGetIdealStandardState = 93, kEventWindowUpdateDockTile = 94, kEventWindowColorSpaceChanged = 95, kEventWindowRestoredAfterRelaunch = 96, kEventWindowProxyBeginDrag = 128, kEventWindowProxyEndDrag = 129, kEventWindowToolbarSwitchMode = 150, -- window focus events -- kEventWindowFocusAcquired = 200, kEventWindowFocusRelinquish = 201, kEventWindowFocusContent = 202, kEventWindowFocusToolbar = 203, kEventWindowFocusDrawer = 204, kEventWindowFocusLost = 205, kEventWindowFocusRestored = 206, -- sheet events -- kEventWindowSheetOpening, = 210, kEventWindowSheetOpened = 211, kEventWindowSheetClosing = 212, kEventWindowSheetClosed = 213, -- drawer events -- kEventWindowDrawerOpening = 220, kEventWindowDrawerOpened = 221, kEventWindowDrawerClosing = 222, kEventWindowDrawerClosed = 223, -- full screen events -- kEventWindowGetFullScreenContentSize = 240, kEventWindowFullScreenEnterStarted = 241, kEventWindowFullScreenEnterCompleted = 242, kEventWindowFullScreenExitStarted = 243, kEventWindowFullScreenExitCompleted = 244, -- window definition events -- kEventWindowDrawFrame = 1000, kEventWindowDrawPart = 1001, kEventWindowGetRegion = 1002, kEventWindowHitTest = 1003, kEventWindowInit = 1004, kEventWindowDispose = 1005, kEventWindowDragHilite = 1006, kEventWindowModified = 1007, kEventWindowSetupProxyDragImage = 1008, kEventWindowStateChanged = 1009, kEventWindowMeasureTitle = 1010, kEventWindowDrawGrowBox = 1011, kEventWindowGetGrowImageRegion = 1012, kEventWindowPaint = 1013, kEventWindowAttributesChanged = 1019, kEventWindowTitleChanged = 1020 On window handlers: All windows have a handler installed called the Òbasic window handler.Ó This handler provides certain basic services for all windows; for example, it handles clicks in the collapse and toolbar buttons, since these buttons were handled automatically for WaitNextEvent-based applications in the classic Mac OS toolbox, and so are still be handled automatically in Carbon by the basic window handler. The basic window handler also implements the HICommands that are sent by the standard window menu to minimize, maximize, or zoom a window (kHICommandMinimize/Maximize/ZoomWindow), and the window-class events that are generated by those commands (kEventWindowCollapse/Expand/Zoom). When the window is created with, or has added, the kWindowStandardHandlerAttribute, the window also has installed the Òstandard window handler.Ó The standard handler provides much more advanced behavior than the basic window handler; a window using the standard handler generally requires no other extra handlers to move, resize, redraw, or track user clicks in controls. Applications will generally add extra handlers to respond to command events generated by controls in the window. } {$ifc not TARGET_CPU_64} { * kEventClassWindow / kEventWindowUpdate * * Summary: * The lowest-level window update event. * * Discussion: * Posted to the event queue for any window that needs updating * regardless of whether the window has the standard handler * installed. The standard window handler responds to this event by * calling BeginUpdate and SetPort, sending a * kEventWindowDrawContent event, and calling EndUpdate. An * application handler for this event that does not call through to * the standard handler must itself call BeginUpdate and * EndUpdate. * * If all handlers for this event return eventNotHandledErr, and the * application is calling WaitNextEvent or GetNextEvent, then a * kEventWindowUpdate event will be returned as a classic updateEvt. * * * This event is only sent to non-compositing windows. To draw the * contents of a compositing window, use a kEventControlDraw handler * on an HIView in the window. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that requires updating. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework [32-bit only] * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowUpdate = 1; { * kEventClassWindow / kEventWindowDrawContent * * Summary: * A request to update a windowÕs content. * * Discussion: * This event is sent by the standard window handler when it * receives a kEventWindowUpdate event. BeginUpdate, SetPort, and * EndUpdate are called by the standard handler inside its * kEventWindowUpdate handler; your handler for the * kEventWindowDrawContent event only needs to draw into the current * port. * * The standard window handler responds to this event by calling * UpdateControls. * * Regardless of whether the window uses the standard window event * handler, you will also receive this event right before a window * is made visible, to allow you to draw the windowÕs initial * contents; you can implement this event to avoid flicker when the * window is first shown. * * This event is only sent to non-compositing windows. To draw the * contents of a compositing window, use a kEventControlDraw handler * on an HIView in the window. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that requires updating. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework [32-bit only] * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowDrawContent = 2; {$endc} {not TARGET_CPU_64} { * kEventClassWindow / kEventWindowActivated * * Summary: * Notification that a window has been activated. * * Discussion: * This event is sent to all handlers registered for it. It is sent * to any window that is activated, regardless of whether the window * has the standard handler installed. On Mac OS X 10.3 and later, * the standard window event handler responds to this event by * sending a kEventWindowHandleActivate event to the window; on * CarbonLib and earlier releases of Mac OS X, the standard window * handler calls ActivateControl on the windowÕs root * control. * * If all handlers for this event return eventNotHandledErr, then * the Window Manager posts the event to the event queue, where it * will later be returned from WaitNextEvent as a classic * activateEvt. If any handler returns an error code other than * eventNotHandledErr, then the event will not be posted to the * event queue. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that is now active. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowActivated = 5; { * kEventClassWindow / kEventWindowDeactivated * * Summary: * Notification that a window has been deactivated. * * Discussion: * This event is sent to all handlers registered for it. It is sent * to any window that is deactivated, regardless of whether the * window has the standard handler installed. On Mac OS X 10.3 and * later, the standard window event handler responds to this event * by sending a kEventWindowHandleDeactivate event to the window; on * CarbonLib and earlier releases of Mac OS X, the standard window * handler calls DeactivateControl on the windowÕs root * control. * * If all handlers for this event return eventNotHandledErr, then * the Window Manager posts the event to the event queue, where it * will later be returned from WaitNextEvent as a classic * activateEvt. If any handler returns an error code other than * eventNotHandledErr, then the event will not be posted to the * event queue. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that is now inactive. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowDeactivated = 6; { * kEventClassWindow / kEventWindowHandleActivate * * Summary: * The window has received a kEventWindowActivated event, and its * contents should become active. * * Discussion: * This event is generated by the standard window handler in * response to a kEventWindowActivated event. An application may * handle this event by activating its content appropriately. The * standard window handler responds to this event by calling * ActivateControl on the window's root control. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that was activated. * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available } const kEventWindowHandleActivate = 91; { * kEventClassWindow / kEventWindowHandleDeactivate * * Summary: * The window has received a kEventWindowDeactivated event, and its * contents should become inactive. * * Discussion: * This event is generated by the standard window handler in * response to a kEventWindowDeactivated event. An application may * handle this event by deactivating its content appropriately. The * standard window handler responds to this event by calling * DeactivateControl on the window's root control. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that was deactivated. * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available } const kEventWindowHandleDeactivate = 92; { * kEventClassWindow / kEventWindowGetClickActivation * * Summary: * Sent when a click occurs in a window. Allows the window to * determine whether the window should be activated and whether the * click should be handled. * * Discussion: * This event is sent when a click occurs in a window that is not * frontmost in its window group. * * For all windows, it is sent to a clicked window when the window's * process is inactive. For windows that use the standard window * event handler, this event is also sent to clicked windows when * the window's process is active. * * A handler for this event can determine whether the window is * activated and whether the click is handled or ignored by setting * the kEventParamClickActivation parameter to one of the * ClickActivationResult constants in Controls.h. * * The default behavior varies according to the window state and the * click location: * - if the click falls on the window widgets in the window * structure, then the default window event handler usually returns * kDoNotActivateAndHandleClick. * - otherwise, the standard window event handler returns * kActivateAndIgnoreClick. * You have the option of overriding the behavior to support * click-through or select-and-click. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that was clicked. * * --> kEventParamMouseLocation (in, typeQDPoint) * The location of the click, in global coordinates. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the mouse was * clicked. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The window part that was clicked. Available in Mac OS X * 10.3 and later. * * --> kEventParamWindowDefPart (in, typeWindowDefPartCode) * The window part that was clicked. This is really a window * part code, not a window def part code, despite the * parameter name; this parameter is available in all versions * of Mac OS X and CarbonLib 1.1 and later, but use * kEventParamWindowPartCode when available instead for * clarity. * * --> kEventParamControlRef (in, typeControlRef) * The control that was clicked. Only present if the click was * on a control. * * <-- kEventParamClickActivation (out, typeClickActivationResult) * On exit, indicates how the click should be handled. Should * be set a ClickActivationResult constant from Controls.h. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowGetClickActivation = 7; { * Summary: * Responses to the kEventWindowGetClickModality event. } const { * Indicates whether a modal window prevents the mouse event from * being passed to the clicked window. If this bit is set, the * kEventParamModalWindow and kEventParamWindowModality parameters * should be set before the event handler returns. If this bit is * clear, normal event handling will occur; the clicked window will * typically be z-ordered to the top of its window group, activated, * become the user focus window, and receive the mouse event for * further processing. } kHIModalClickIsModal = 1 shl 0; { * If kHIModalClickIsModal is set, this flag indicates whether the * click event should be allowed to pass to the clicked window. If * kHIModalClickIsModal is not set, this flag is ignored. } kHIModalClickAllowEvent = 1 shl 1; { * If kHIModalClickIsModal is set and kHIModalClickAllowEvent is not * set, this flag indicates whether the caller should announce that * the click has been blocked by a modal window using appropriate UI * (typically, by calling AudioServicesPlayAlertSound). If * kHIModalClickIsModal is not set, or if kHIModalClickAllowEvent is * set, this flag is ignored. } kHIModalClickAnnounce = 1 shl 2; { * If both kHIModalClickIsModal and kHIModalClickAllowEvent are set, * this flag indicates whether the clicked window should be z-ordered * to the top of its window group. The window will not, however, be * activated or become the user focus window. If either of * kHIModalClickIsModal or kHIModalClickAllowEvent is not set, this * flag is ignored. } kHIModalClickRaiseWindow = 1 shl 3; type HIModalClickResult = UInt32; const typeModalClickResult = FourCharCode('wmcr'); { HIModalClickResult} typeWindowModality = FourCharCode('wmod'); { WindowModality} kEventParamModalClickResult = typeModalClickResult; { typeModalClickResult} kEventParamModalWindow = FourCharCode('mwin'); { typeWindowRef} kEventParamWindowModality = typeWindowModality; { typeWindowModality} { * kEventClassWindow / kEventWindowGetClickModality * * Summary: * Determines whether a mouse-down or mouse-up event is blocked by a * modal window. * * Discussion: * This event is sent to a window by the event dispatcher target * prior to dispatching a mouse-down or mouse-up event to the * clicked window. A handler for this event may examine application * state to determine whether this click should be allowed. * * This event may also be sent in other circumstances besides a * mouse event. The toolbox currently sends this event in the * following other cases: * * - in SelectWindow * - when handling the cmd-~ key sequence * - when restoring a collapsed window from the Dock * - when handling the kHICommandSelectWindow command * - during application activation, when activating a clicked * window * * In each case, the result of this event is used to determine * whether z-ordering, activation, and hiliting of the window should * be allowed. * * This event contains an optional EventRef parameter that is the * original mouse event. This parameter is not always present; if * not present, the handler should generally assume that the click * was a single click. * * There is a default handler for this event installed on the * application target. The default behavior is to determine whether * this is a modal click by examining the modality of the visible, * uncollapsed windows in front of the clicked window, the location * of the click, and the keyboard modifiers. A custom handler may, * of course, entirely ignore window z-order or modality, and * determine modality in any way it deems necessary. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that was clicked. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The window part that was clicked. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the mouse * button was pressed. * * --> kEventParamEventRef (in, typeEventRef) * The original mouse event. This parameter is optional and * may not be present in all instances of this event. If this * parameter is not present, the handler should assume that * the click was a single click, with the window part and * keyboard modifiers specified by the other parameters in the * kEventWindowGetClickModality event. * * <-- kEventParamModalClickResult (out, typeModalClickResult) * On exit, this parameter should contain an * HIModalClickResult value indicating how the click should be * handled. * * <-- kEventParamModalWindow (out, typeWindowRef) * On exit, this parameter should contain the modal window * that caused the click to be blocked, if any. The sender of * this event uses this information to determine which window * should be activated if the application is inactive. * * * This parameter is only required if the * kEventParamModalClickResult parameter contains * kHIModalClickIsModal. If an event handler wants to report * that a click has been blocked by modality, but cannot * determine which window blocked the click, it is acceptable * to either not add this parameter to the event, or to set * the parameter to a NULL WindowRef. * * <-- kEventParamWindowModality (out, typeWindowModality) * On exit, this parameter should contain the modality of the * modal window that is in front of the clicked window, if * any. This parameter is only required if the * kEventParamModalClickResult parameter contains * kHIModalClickIsModal. The modality values you may add here * are from the WindowModality enumeration in MacWindows.h. * * Availability: * Mac OS X: in version 10.4 and later in Carbon.framework * CarbonLib: not available } const kEventWindowGetClickModality = 8; { * Summary: * Window bounds change event attributes * * Discussion: * When the toolbox sends out a kEventWindowBoundsChanging or * kEventWindowBoundsChanged event, it also sends along a parameter * containing attributes of the event. These attributes can be used * to determine what aspect of the window changed (origin, size, or * both), and whether or not some user action is driving the change * (drag or resize). } const { * The bounds is changing because the user is dragging the window * around. } kWindowBoundsChangeUserDrag = 1 shl 0; { * The bounds is changing because the user is resizing the window. } kWindowBoundsChangeUserResize = 1 shl 1; { * The dimensions (width and height) of the window content area are * changing. } kWindowBoundsChangeSizeChanged = 1 shl 2; { * The top left corner (origin) of the window content is changing. } kWindowBoundsChangeOriginChanged = 1 shl 3; { * The bounds is changing because ZoomWindow or ZoomWindowIdeal was * called. Note that this flag does not imply any user interaction; * if the application calls ZoomWindow itself without user request, * this flag will still be set. Available in Mac OS X 10.2 and * CarbonLib 1.6, and later. } kWindowBoundsChangeZoom = 1 shl 4; { * kEventClassWindow / kEventWindowShowing * * Summary: * Notification that a window is being shown. * * Discussion: * This event is sent to all handlers registered for it. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window being shown. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowShowing = 22; { * kEventClassWindow / kEventWindowHiding * * Summary: * Notification that a window is being hidden. * * Discussion: * This event is sent to all handlers registered for it. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window being hidden. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowHiding = 23; { * kEventClassWindow / kEventWindowShown * * Summary: * Notification that a window has been shown. * * Discussion: * This event is sent to all handlers registered for it. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that was shown. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowShown = 24; { * kEventClassWindow / kEventWindowHidden * * Summary: * Notification that a window has been hidden. * * Discussion: * This event is sent to all handlers registered for it. Prior to * Mac OS X 10.2 and CarbonLib 1.6, kEventWindowClosed and * kEventWindowHidden were sent in that order by the Window Manager * to a window being destroyed. This was problematic if you had a * Hidden handler which used data that was destroyed by the Closed * handler. The Window Manager in Mac OS X 10.2 and CarbonLib 1.6 * and later now sends these events in the reverse order: * kEventWindowHidden first, followed by kEventWindowClosed. The * last event sent to a window remains kEventWindowDispose. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that was hidden. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowHidden = 25; { * kEventClassWindow / kEventWindowCollapsing * * Summary: * Notification that a window is about to collapse. * * Discussion: * This event is sent to all handlers registered for it. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window being collapsed. * * Availability: * Mac OS X: in version 10.1 and later in Carbon.framework * CarbonLib: in CarbonLib 1.6 and later } const kEventWindowCollapsing = 86; { * kEventClassWindow / kEventWindowCollapsed * * Summary: * Notification that a window has successfully collapsed. * * Discussion: * This event is sent to all handlers registered for it. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that was collapsed. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowCollapsed = 67; { * kEventClassWindow / kEventWindowExpanding * * Summary: * Notification that a window is about to expand. * * Discussion: * This event is sent to all handlers registered for it. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window being expanded. * * Availability: * Mac OS X: in version 10.1 and later in Carbon.framework * CarbonLib: in CarbonLib 1.6 and later } const kEventWindowExpanding = 87; { * kEventClassWindow / kEventWindowExpanded * * Summary: * Notification that a window has successfully expanded. * * Discussion: * This event is sent to all handlers registered for it. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that was expanded. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowExpanded = 70; { * kEventClassWindow / kEventWindowZoomed * * Summary: * Notification that a window has been successfully zoomed. * * Discussion: * This event is sent to all handlers registered for it. In * CarbonLib 1.1 through CarbonLib 1.4, and Mac OS X 10.0 and 10.1, * this event is only sent by the standard window event handler * after handling kEventWindowZoom; starting with CarbonLib 1.5 and * Mac OS X 10.2, this event is sent by ZoomWindow and * ZoomWindowIdeal. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that was zoomed. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The part code (inZoomIn or inZoomOut) that was passed to * ZoomWindow or ZoomWindowIdeal. This parameter is available * in Mac OS X 10.4 and later. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowZoomed = 76; { * kEventClassWindow / kEventWindowBoundsChanging * * Summary: * Notification that a windowÕs bounds are about to be changed. * * Discussion: * Sent during DragWindow or ResizeWindow, before the window is * actually moved or resized, and also during programmatic * bounds-changing APIs such as SetWindowBounds and ZoomWindow. An * event handler may alter the kEventParamCurrentBounds parameter in * the event to change the eventual location of the window. You may * change the size, origin, or both of the windowÕs bounds. Do not, * however, call SizeWindow or SetWindowBounds yourself from inside * a handler for this event. * * In Mac OS X 10.1 and later, kEventWindowBoundsChanging is sent * before all changes to a windowÕs bounds, regardless of whether * the change is initiated by the user or by a direct call to a * Window Manager API. Applications may intercept the event and * modify the bounds. When the event is sent because of a direct * call to the Window Manager, the * kWindowBoundsChangeUserDrag/Resize attribute bits will not be set. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window being shown. * * --> kEventParamAttributes (in, typeUInt32) * The bounds-changing attributes indicating whether the * window is being resized, moved, or both. * * --> kEventParamOriginalBounds (in, typeQDRectangle) * The windowÕs original content bounds before the window * resize or drag began. * * --> kEventParamPreviousBounds (in, typeQDRectangle) * The windowÕs content bounds before the current bounds * change. * * <-> kEventParamCurrentBounds (in/out, typeQDRectangle) * On entry, the windowÕs proposed new content bounds; on * exit, the content bounds that are desired by the event * handler. * * Result: * Return noErr to indicate that the Window Manager should use the * kEventParamCurrentBounds parameter as the windowÕs new content * bounds. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowBoundsChanging = 26; { * kEventClassWindow / kEventWindowBoundsChanged * * Summary: * Notification that a windowÕs bounds have been changed. * * Discussion: * This event is sent to all handlers registered for it. Do not call * SizeWindow or SetWindowBounds from inside a handler for this * event; if you need to enforce a certain window bounds, install a * kEventWindowBoundsChanging handler instead. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window whose bounds were changed. * * --> kEventParamAttributes (in, typeUInt32) * The bounds-changing attributes indicating whether the * window was resized, moved, or both. * * --> kEventParamOriginalBounds (in, typeQDRectangle) * The windowÕs original content bounds before the window * resize or drag began. * * --> kEventParamPreviousBounds (in, typeQDRectangle) * The windowÕs content bounds before the current bounds * change. * * --> kEventParamCurrentBounds (in, typeQDRectangle) * The windowÕs new content bounds. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowBoundsChanged = 27; { * kEventClassWindow / kEventWindowResizeStarted * * Summary: * Notification that the user has just started to resize a window. * * Discussion: * This event is sent to all handlers registered for it. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window being resized. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowResizeStarted = 28; { * kEventClassWindow / kEventWindowResizeCompleted * * Summary: * Notification that the user has just finished resizing a window. * * Discussion: * This event is sent to all handlers registered for it. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that was resized. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowResizeCompleted = 29; { * kEventClassWindow / kEventWindowDragStarted * * Summary: * Notification that the user has just started to drag a window. * * Discussion: * This event is sent to all handlers registered for it. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window being dragged. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowDragStarted = 30; { * kEventClassWindow / kEventWindowDragCompleted * * Summary: * Notification that the user has just finished dragging a window. * * Discussion: * This event is sent to all handlers registered for it. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that was dragged. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowDragCompleted = 31; { * kEventClassWindow / kEventWindowClosed * * Summary: * Notification that a window is being destroyed. * * Discussion: * This event is sent to all handlers registered for it. Prior to * Mac OS X 10.2 and CarbonLib 1.6, kEventWindowClosed and * kEventWindowHidden were sent in that order by the Window Manager * to a window being destroyed. This was problematic if you had a * Hidden handler which used data that was destroyed by the Closed * handler. The Window Manager in Mac OS X 10.2 and CarbonLib 1.6 * and later now sends these events in the reverse order: * kEventWindowHidden first, followed by kEventWindowClosed. The * last event sent to a window remains kEventWindowDispose. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window being destroyed. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowClosed = 73; { * kEventClassWindow / kEventWindowTransitionStarted * * Summary: * Notification that a window transition has started. * * Discussion: * This event is sent to all handlers registered for it. It is sent * by the TransitionWindow, TransitionWindowAndParent, and * TransitionWindowWithOptions APIs just before the first frame of * the transition animation. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that will be transitioning. * * --> kEventParamUserData (in, typeVoidPtr) * The user data that was specified in the * TransitionWindowOptions.userData field. If no user data was * specified, this parameter will still be present, but its * value will be NULL. * * --> kEventParamWindowTransitionAction (in, typeWindowTransitionAction) * The transition action that is starting. * * --> kEventParamWindowTransitionEffect (in, typeWindowTransitionEffect) * The transition effect that is starting. * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available } const kEventWindowTransitionStarted = 88; { * kEventClassWindow / kEventWindowTransitionCompleted * * Summary: * Notification that a window transition has completed. * * Discussion: * This event is sent to all handlers registered for it. It is sent * by the TransitionWindow, TransitionWindowAndParent, and * TransitionWindowWithOptions APIs just after the last frame of the * transition animation. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that was transitioning. * * --> kEventParamUserData (in, typeVoidPtr) * The user data that was specified in the * TransitionWindowOptions.userData field. If no user data was * specified, this parameter will still be present, but its * value will be NULL. * * --> kEventParamWindowTransitionAction (in, typeWindowTransitionAction) * The transition action that has completed. * * --> kEventParamWindowTransitionEffect (in, typeWindowTransitionEffect) * The transition effect that has completed. * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available } const kEventWindowTransitionCompleted = 89; {$ifc not TARGET_CPU_64} { * kEventClassWindow / kEventWindowClickDragRgn * * Summary: * Sent when the mouse is clicked in the drag region. * * Discussion: * The standard window handler responds to this event by checking if * the click is a window path-select click; if so, it sends * kEventWindowPathSelect to allow customization of the path-select * menu, and then calls WindowPathSelect. If the click is not a * path-select click, the standard window handler calls DragWindow. * Note that this event is not sent for composited windows; the * window frame view handles the mouse-down event directly. To * intercept a drag region click in a composited window, install a * kEventControlClick handler on the windowÕs root view. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that was clicked. * * --> kEventParamMouseLocation (in, typeHIPoint) * The mouse location, in global coordinates. * * --> kEventParamWindowRef (in, typeWindowRef) * The window under the mouse. Available in Mac OS X 10.1 and * later. * * --> kEventParamWindowMouseLocation (in, typeHIPoint) * The window-relative position of the mouse in the window * given in the kEventParamWindowRef parameter. 0,0 is at the * top left of the structure of the window. Available in Mac * OS X 10.1 and later. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The part code that the mouse location hit in the window. * This parameter only exists if the WindowRef parameter * exists. This saves you the trouble of calling FindWindow, * which is expensive on Mac OS X as it needs to call the * Window Server. Available in Mac OS X 10.3 and later. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the event was * generated. * * --> kEventParamMouseButton (in, typeMouseButton) * Which mouse button was pressed. * * --> kEventParamClickCount (in, typeUInt32) * Whether this is a single click, double click, etc. * * --> kEventParamMouseChord (in, typeUInt32) * Which other mouse buttons were pressed when the event was * generated. Available on Mac OS X only. * * --> kEventParamTabletEventType (in, typeUInt32) * The type of tablet event which generated this mouse event; * contains either kEventTabletPoint or kEventTabletProximity. * Only present if the event was generated from a tablet. * Available in Mac OS X 10.1 and CarbonLib 1.5, and later. * * --> kEventParamTabletPointRec (in, typeTabletPointRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletPoint. Available on Mac OS X 10.1 and CarbonLib * 1.5, and later. * * --> kEventParamTabletProximityRec (in, typeTabletProximityRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletProximity. Available on Mac OS X 10.1 and * CarbonLib 1.5, and later. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework [32-bit only] * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowClickDragRgn = 32; { * kEventClassWindow / kEventWindowClickResizeRgn * * Summary: * Sent when the mouse is clicked in the resize area. * * Discussion: * The standard window handler responds to this event by calling * ResizeWindow. Note that this event is not sent for composited * windows; the window resize view handles the mouse-down event * directly. To intercept a resize region click in a composited * window, install a kEventControlClick handler on the windowÕs * resize view. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that was clicked. * * --> kEventParamMouseLocation (in, typeHIPoint) * The mouse location, in global coordinates. * * --> kEventParamWindowRef (in, typeWindowRef) * The window under the mouse. Available in Mac OS X 10.1 and * later. * * --> kEventParamWindowMouseLocation (in, typeHIPoint) * The window-relative position of the mouse in the window * given in the kEventParamWindowRef parameter. 0,0 is at the * top left of the structure of the window. Available in Mac * OS X 10.1 and later. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The part code that the mouse location hit in the window. * This parameter only exists if the WindowRef parameter * exists. This saves you the trouble of calling FindWindow, * which is expensive on Mac OS X as it needs to call the * Window Server. Available in Mac OS X 10.3 and later. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the event was * generated. * * --> kEventParamMouseButton (in, typeMouseButton) * Which mouse button was pressed. * * --> kEventParamClickCount (in, typeUInt32) * Whether this is a single click, double click, etc. * * --> kEventParamMouseChord (in, typeUInt32) * Which other mouse buttons were pressed when the event was * generated. Available on Mac OS X only. * * --> kEventParamTabletEventType (in, typeUInt32) * The type of tablet event which generated this mouse event; * contains either kEventTabletPoint or kEventTabletProximity. * Only present if the event was generated from a tablet. * Available in Mac OS X 10.1 and CarbonLib 1.5, and later. * * --> kEventParamTabletPointRec (in, typeTabletPointRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletPoint. Available on Mac OS X 10.1 and CarbonLib * 1.5, and later. * * --> kEventParamTabletProximityRec (in, typeTabletProximityRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletProximity. Available on Mac OS X 10.1 and * CarbonLib 1.5, and later. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework [32-bit only] * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowClickResizeRgn = 33; { * kEventClassWindow / kEventWindowClickCollapseRgn * * Summary: * Sent when the mouse is clicked in the collapse button. * * Discussion: * For all windows, the basic window handler responds to this event * by tracking the click in the collapse button. If the mouse is * released while still in the button, the basic window handler * generates one of the kEventWindowCollapse, * kEventWindowCollapseAll, kEventWindowExpand, or * kEventWindowExpandAll events, depending on the windowÕs original * collapse state and whether the option key was pressed. Note that * this event is not sent for composited windows; the window * collapse button view handles the mouse-down event directly. To * intercept a collapse region click in a composited window, install * a kEventControlClick handler on the windowÕs collapse button view. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that was clicked. * * --> kEventParamMouseLocation (in, typeHIPoint) * The mouse location, in global coordinates. * * --> kEventParamWindowRef (in, typeWindowRef) * The window under the mouse. Available in Mac OS X 10.1 and * later. * * --> kEventParamWindowMouseLocation (in, typeHIPoint) * The window-relative position of the mouse in the window * given in the kEventParamWindowRef parameter. 0,0 is at the * top left of the structure of the window. Available in Mac * OS X 10.1 and later. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The part code that the mouse location hit in the window. * This parameter only exists if the WindowRef parameter * exists. This saves you the trouble of calling FindWindow, * which is expensive on Mac OS X as it needs to call the * Window Server. Available in Mac OS X 10.3 and later. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the event was * generated. * * --> kEventParamMouseButton (in, typeMouseButton) * Which mouse button was pressed. * * --> kEventParamClickCount (in, typeUInt32) * Whether this is a single click, double click, etc. * * --> kEventParamMouseChord (in, typeUInt32) * Which other mouse buttons were pressed when the event was * generated. Available on Mac OS X only. * * --> kEventParamTabletEventType (in, typeUInt32) * The type of tablet event which generated this mouse event; * contains either kEventTabletPoint or kEventTabletProximity. * Only present if the event was generated from a tablet. * Available in Mac OS X 10.1 and CarbonLib 1.5, and later. * * --> kEventParamTabletPointRec (in, typeTabletPointRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletPoint. Available on Mac OS X 10.1 and CarbonLib * 1.5, and later. * * --> kEventParamTabletProximityRec (in, typeTabletProximityRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletProximity. Available on Mac OS X 10.1 and * CarbonLib 1.5, and later. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework [32-bit only] * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowClickCollapseRgn = 34; { * kEventClassWindow / kEventWindowClickCloseRgn * * Summary: * Sent when the mouse is clicked in the close button. * * Discussion: * The standard window handler responds to this event by tracking * the click in the close button. If the mouse is released while * still in the button, the standard window handler generates one of * the kEventWindowClose or kEventWindowCloseAll events, depending * on whether the option key was pressed. Note that this event is * not sent for composited windows; the window close button view * handles the mouse-down event directly. To intercept a close * region click in a composited window, install a kEventControlClick * handler on the windowÕs close button view. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that was clicked. * * --> kEventParamMouseLocation (in, typeHIPoint) * The mouse location, in global coordinates. * * --> kEventParamWindowRef (in, typeWindowRef) * The window under the mouse. Available in Mac OS X 10.1 and * later. * * --> kEventParamWindowMouseLocation (in, typeHIPoint) * The window-relative position of the mouse in the window * given in the kEventParamWindowRef parameter. 0,0 is at the * top left of the structure of the window. Available in Mac * OS X 10.1 and later. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The part code that the mouse location hit in the window. * This parameter only exists if the WindowRef parameter * exists. This saves you the trouble of calling FindWindow, * which is expensive on Mac OS X as it needs to call the * Window Server. Available in Mac OS X 10.3 and later. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the event was * generated. * * --> kEventParamMouseButton (in, typeMouseButton) * Which mouse button was pressed. * * --> kEventParamClickCount (in, typeUInt32) * Whether this is a single click, double click, etc. * * --> kEventParamMouseChord (in, typeUInt32) * Which other mouse buttons were pressed when the event was * generated. Available on Mac OS X only. * * --> kEventParamTabletEventType (in, typeUInt32) * The type of tablet event which generated this mouse event; * contains either kEventTabletPoint or kEventTabletProximity. * Only present if the event was generated from a tablet. * Available in Mac OS X 10.1 and CarbonLib 1.5, and later. * * --> kEventParamTabletPointRec (in, typeTabletPointRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletPoint. Available on Mac OS X 10.1 and CarbonLib * 1.5, and later. * * --> kEventParamTabletProximityRec (in, typeTabletProximityRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletProximity. Available on Mac OS X 10.1 and * CarbonLib 1.5, and later. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework [32-bit only] * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowClickCloseRgn = 35; { * kEventClassWindow / kEventWindowClickZoomRgn * * Summary: * Sent when the mouse is clicked in the zoom button. * * Discussion: * The standard window handler responds to this event by tracking * the click in the zoom button. If the mouse is released while * still in the button, the standard window handler generates one of * the kEventWindowZoom or kEventWindowZoomAll events, depending on * whether the option key was pressed. Note that this event is not * sent for composited windows; the window zoom button view handles * the mouse-down event directly. To intercept a zoom region click * in a composited window, install a kEventControlClick handler on * the windowÕs zoom region view. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that was clicked. * * --> kEventParamMouseLocation (in, typeHIPoint) * The mouse location, in global coordinates. * * --> kEventParamWindowRef (in, typeWindowRef) * The window under the mouse. Available in Mac OS X 10.1 and * later. * * --> kEventParamWindowMouseLocation (in, typeHIPoint) * The window-relative position of the mouse in the window * given in the kEventParamWindowRef parameter. 0,0 is at the * top left of the structure of the window. Available in Mac * OS X 10.1 and later. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The part code that the mouse location hit in the window. * This parameter only exists if the WindowRef parameter * exists. This saves you the trouble of calling FindWindow, * which is expensive on Mac OS X as it needs to call the * Window Server. Available in Mac OS X 10.3 and later. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the event was * generated. * * --> kEventParamMouseButton (in, typeMouseButton) * Which mouse button was pressed. * * --> kEventParamClickCount (in, typeUInt32) * Whether this is a single click, double click, etc. * * --> kEventParamMouseChord (in, typeUInt32) * Which other mouse buttons were pressed when the event was * generated. Available on Mac OS X only. * * --> kEventParamTabletEventType (in, typeUInt32) * The type of tablet event which generated this mouse event; * contains either kEventTabletPoint or kEventTabletProximity. * Only present if the event was generated from a tablet. * Available in Mac OS X 10.1 and CarbonLib 1.5, and later. * * --> kEventParamTabletPointRec (in, typeTabletPointRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletPoint. Available on Mac OS X 10.1 and CarbonLib * 1.5, and later. * * --> kEventParamTabletProximityRec (in, typeTabletProximityRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletProximity. Available on Mac OS X 10.1 and * CarbonLib 1.5, and later. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework [32-bit only] * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowClickZoomRgn = 36; { * kEventClassWindow / kEventWindowClickContentRgn * * Summary: * Sent when the mouse is clicked in the content region. * * Discussion: * The standard window handler responds to this event by checking if * the click should display a contextual menu; if so, and if the * click was in an enabled control, it calls * HandleControlContextualMenuClick. If the click was not in a * control, or if the control does not display a contextual menu, * the standard window handler sends a * kEventWindowContextualMenuSelect event to the window. * * If the click was not a contextual menu click, then the standard * window handler uses HIViewGetViewForMouseEvent to determine the * HIView containing the click. If a view is found, the standard * window handler calls HIViewClick, which will generate a * kEventControlClick event. * * If no view is found that contains the click, or if the containing * view does not handle the click, then the standard window handler * sends a kEventWindowHandleContentClick event. * * Note that this event is not sent for composited windows; all * mouse-downs in a composited window are handled by a view, and * there is no Ócontent regionÓ in a composited window. To intercept * a content region click in a composited window, install a * kEventControlClick handler on the windowÕs content view, or * provide your own HIView subclass. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that was clicked. * * --> kEventParamMouseLocation (in, typeHIPoint) * The mouse location, in global coordinates. * * --> kEventParamWindowRef (in, typeWindowRef) * The window under the mouse. Available in Mac OS X 10.1 and * later. * * --> kEventParamWindowMouseLocation (in, typeHIPoint) * The window-relative position of the mouse in the window * given in the kEventParamWindowRef parameter. 0,0 is at the * top left of the structure of the window. Available in Mac * OS X 10.1 and later. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The part code that the mouse location hit in the window. * This parameter only exists if the WindowRef parameter * exists. This saves you the trouble of calling FindWindow, * which is expensive on Mac OS X as it needs to call the * Window Server. Available in Mac OS X 10.3 and later. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the event was * generated. * * --> kEventParamMouseButton (in, typeMouseButton) * Which mouse button was pressed. * * --> kEventParamClickCount (in, typeUInt32) * Whether this is a single click, double click, etc. * * --> kEventParamMouseChord (in, typeUInt32) * Which other mouse buttons were pressed when the event was * generated. Available on Mac OS X only. * * --> kEventParamTabletEventType (in, typeUInt32) * The type of tablet event which generated this mouse event; * contains either kEventTabletPoint or kEventTabletProximity. * Only present if the event was generated from a tablet. * Available in Mac OS X 10.1 and CarbonLib 1.5, and later. * * --> kEventParamTabletPointRec (in, typeTabletPointRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletPoint. Available on Mac OS X 10.1 and CarbonLib * 1.5, and later. * * --> kEventParamTabletProximityRec (in, typeTabletProximityRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletProximity. Available on Mac OS X 10.1 and * CarbonLib 1.5, and later. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework [32-bit only] * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowClickContentRgn = 37; { * kEventClassWindow / kEventWindowClickProxyIconRgn * * Summary: * Sent when the mouse is clicked in the proxy icon. * * Discussion: * The standard window handler responds to this event by handling * proxy icon dragging. It first sends a kEventWindowProxyBeginDrag * event to allow customization of the DragRef, and then calls * TrackWindowProxyFromExistingDrag. Finally, the standard window * handler sends a kEventWindowProxyEndDrag event. Note that this * event is not sent for composited windows; the window title view * handles the mouse-down event directly. To intercept a proxy icon * region click in a composited window, install a kEventControlClick * handler on the windowÕs title view. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that was clicked. * * --> kEventParamMouseLocation (in, typeHIPoint) * The mouse location, in global coordinates. * * --> kEventParamWindowRef (in, typeWindowRef) * The window under the mouse. Available in Mac OS X 10.1 and * later. * * --> kEventParamWindowMouseLocation (in, typeHIPoint) * The window-relative position of the mouse in the window * given in the kEventParamWindowRef parameter. 0,0 is at the * top left of the structure of the window. Available in Mac * OS X 10.1 and later. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The part code that the mouse location hit in the window. * This parameter only exists if the WindowRef parameter * exists. This saves you the trouble of calling FindWindow, * which is expensive on Mac OS X as it needs to call the * Window Server. Available in Mac OS X 10.3 and later. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the event was * generated. * * --> kEventParamMouseButton (in, typeMouseButton) * Which mouse button was pressed. * * --> kEventParamClickCount (in, typeUInt32) * Whether this is a single click, double click, etc. * * --> kEventParamMouseChord (in, typeUInt32) * Which other mouse buttons were pressed when the event was * generated. Available on Mac OS X only. * * --> kEventParamTabletEventType (in, typeUInt32) * The type of tablet event which generated this mouse event; * contains either kEventTabletPoint or kEventTabletProximity. * Only present if the event was generated from a tablet. * Available in Mac OS X 10.1 and CarbonLib 1.5, and later. * * --> kEventParamTabletPointRec (in, typeTabletPointRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletPoint. Available on Mac OS X 10.1 and CarbonLib * 1.5, and later. * * --> kEventParamTabletProximityRec (in, typeTabletProximityRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletProximity. Available on Mac OS X 10.1 and * CarbonLib 1.5, and later. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework [32-bit only] * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowClickProxyIconRgn = 38; { * kEventClassWindow / kEventWindowClickToolbarButtonRgn * * Summary: * Sent when the mouse is clicked in the toolbar button. * * Discussion: * For all windows, the basic window handler responds to this event * by tracking the click in the toolbar button. If the mouse is * released while still in the button, the basic window handler * sends a kEventWindowToolbarSwitchMode event. Note that this event * is not sent for composited windows; the window toolbar button * view handles the mouse-down event directly. To intercept a * toolbar button region click in a composited window, install a * kEventControlClick handler on the windowÕs toolbar button view. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that was clicked. * * --> kEventParamMouseLocation (in, typeHIPoint) * The mouse location, in global coordinates. * * --> kEventParamWindowRef (in, typeWindowRef) * The window under the mouse. Available in Mac OS X 10.1 and * later. * * --> kEventParamWindowMouseLocation (in, typeHIPoint) * The window-relative position of the mouse in the window * given in the kEventParamWindowRef parameter. 0,0 is at the * top left of the structure of the window. Available in Mac * OS X 10.1 and later. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The part code that the mouse location hit in the window. * This parameter only exists if the WindowRef parameter * exists. This saves you the trouble of calling FindWindow, * which is expensive on Mac OS X as it needs to call the * Window Server. Available in Mac OS X 10.3 and later. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the event was * generated. * * --> kEventParamMouseButton (in, typeMouseButton) * Which mouse button was pressed. * * --> kEventParamClickCount (in, typeUInt32) * Whether this is a single click, double click, etc. * * --> kEventParamMouseChord (in, typeUInt32) * Which other mouse buttons were pressed when the event was * generated. Available on Mac OS X only. * * --> kEventParamTabletEventType (in, typeUInt32) * The type of tablet event which generated this mouse event; * contains either kEventTabletPoint or kEventTabletProximity. * Only present if the event was generated from a tablet. * Available in Mac OS X 10.1 and CarbonLib 1.5, and later. * * --> kEventParamTabletPointRec (in, typeTabletPointRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletPoint. Available on Mac OS X 10.1 and CarbonLib * 1.5, and later. * * --> kEventParamTabletProximityRec (in, typeTabletProximityRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletProximity. Available on Mac OS X 10.1 and * CarbonLib 1.5, and later. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework [32-bit only] * CarbonLib: not available } const kEventWindowClickToolbarButtonRgn = 41; { * kEventClassWindow / kEventWindowClickStructureRgn * * Summary: * Sent when the mouse is clicked in some part of the window * structure other than the window widgets, drag region, or resize * region. * * Discussion: * The standard window handler responds to this event by calling * HIViewGetViewForMouseEvent to determine the HIView containing the * click. If a view is found, the standard window handler calls * HIViewClick, which will generate a kEventControlClick event. Note * that this event is not sent for composited windows; all parts of * the window frame are built from views, and the mouse will never * land outside of a view. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that was clicked. * * --> kEventParamMouseLocation (in, typeHIPoint) * The mouse location, in global coordinates. * * --> kEventParamWindowRef (in, typeWindowRef) * The window under the mouse. Available in Mac OS X 10.1 and * later. * * --> kEventParamWindowMouseLocation (in, typeHIPoint) * The window-relative position of the mouse in the window * given in the kEventParamWindowRef parameter. 0,0 is at the * top left of the structure of the window. Available in Mac * OS X 10.1 and later. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The part code that the mouse location hit in the window. * This parameter only exists if the WindowRef parameter * exists. This saves you the trouble of calling FindWindow, * which is expensive on Mac OS X as it needs to call the * Window Server. Available in Mac OS X 10.3 and later. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the event was * generated. * * --> kEventParamMouseButton (in, typeMouseButton) * Which mouse button was pressed. * * --> kEventParamClickCount (in, typeUInt32) * Whether this is a single click, double click, etc. * * --> kEventParamMouseChord (in, typeUInt32) * Which other mouse buttons were pressed when the event was * generated. Available on Mac OS X only. * * --> kEventParamTabletEventType (in, typeUInt32) * The type of tablet event which generated this mouse event; * contains either kEventTabletPoint or kEventTabletProximity. * Only present if the event was generated from a tablet. * Available in Mac OS X 10.1 and CarbonLib 1.5, and later. * * --> kEventParamTabletPointRec (in, typeTabletPointRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletPoint. Available on Mac OS X 10.1 and CarbonLib * 1.5, and later. * * --> kEventParamTabletProximityRec (in, typeTabletProximityRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletProximity. Available on Mac OS X 10.1 and * CarbonLib 1.5, and later. * * Availability: * Mac OS X: in version 10.1 and later in Carbon.framework [32-bit only] * CarbonLib: not available } const kEventWindowClickStructureRgn = 42; {$endc} {not TARGET_CPU_64} { * kEventClassWindow / kEventWindowCursorChange * * Summary: * Sent when the mouse is moving over the content region of a window. * * Discussion: * This event is used to manage ownership of the cursor. You should * only change the cursor if you receive this event; otherwise, * someone else needed to adjust the cursor and handled the event * (e.g., a TSM Input Method when the mouse is over an inline input * region). This event is only sent to the window itself; it is not * propagated to controls in the window. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window under the mouse. * * --> kEventParamMouseLocation (in, typeQDPoint) * The mouse location in global coordinates. * * --> kEventParamKeyModifiers (in, typeUInt32) * The current keyboard modifiers. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.5 and later } const kEventWindowCursorChange = 40; { * kEventClassWindow / kEventWindowCollapse * * Summary: * A request to collapse a window. * * Discussion: * For all windows, the basic window handler responds to this event * by calling CollapseWindow, passing true for the collapse * parameter, which sends kEventWindowCollapsing and * kEventWindowCollapsed events. This event is generated by the * standard window handler in response to a click in a windowÕs * collapse button. It is also generated by the basic window handler * when Minimize or Collapse is selected from the standard window * menu. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that should collapse. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowCollapse = 66; { * kEventClassWindow / kEventWindowCollapseAll * * Summary: * A request to collapse all windows. * * Discussion: * For all windows, the basic window handler responds to this event * by calling CollapseAllWindows, passing true for the collapse * parameter. CollapseAllWindows simply calls CollapseWindow on each * window; it does not send a kEventWindowCollapse to each window. * This event is generated by the standard window handler in * response to an option-click in a windowÕs collapse button. It is * also generated by the basic window handler when Minimize All or * Collapse All is selected from the standard window menu. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window whose collapse button was clicked. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowCollapseAll = 68; { * kEventClassWindow / kEventWindowExpand * * Summary: * A request to expand a window. * * Discussion: * For all windows, the basic window handler responds to this event * by calling CollapseWindow, passing false for the collapse * parameter, which sends kEventWindowExpanding and * kEventWindowExpanded events. This event is generated by the * standard window handler in responds to a click in a collapsed * windowÕs collapse button. It is also generated by the basic * window handler when Uncollapse is selected from from the standard * window menu provided by CarbonLib. * * Note that you will not receive this event on Mac OS X before a * window is expanded from the Dock, since minimized windows in the * dock donÕt uses collapse buttons to unminimize. However, you will * still receive kEventWindowExpanding and kEventWindowExpanded in * that case. You will receive this event on Mac OS 8 and 9 using * CarbonLib since collapsed windows do have a collapse button there. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that should expand. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowExpand = 69; { * kEventClassWindow / kEventWindowExpandAll * * Summary: * A request to expand all windows. * * Discussion: * For all windows, the basic window handler responds to this event * by calling CollapseAllWindows, passing false for the collapse * parameter. On Mac OS X 10.3 and later, CollapseAllWindows sends a * kEventWindowExpand event to each window; on earlier version of * Mac OS X, and in CarbonLib, it simply calls CollapseWindow on * each window. This event is generated by the standard window * handler in response to an option-click in a windowÕs collapse * button. It is also generated by the basic window handler when * Uncollapse All is selected from the standard window menu provided * by CarbonLib. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window whose collapse button was clicked. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowExpandAll = 71; { * kEventClassWindow / kEventWindowClose * * Summary: * A request to close a window. * * Discussion: * The standard window handler responds to this event by calling * DisposeWindow. This event is generated by the standard window * handler in response to a click in a windowÕs close button. On Mac * OS X 10.3 and later, it is also generated when the Close menu * item is selected from the Dock menu of a minimized window. * * * Your application would typically intercept this event to check if * the windowÕs document is dirty, and display a Save Changes alert * if so. * * In order to support closing minimized windows from the Dock, your * application must provide an event hander for this event, * installed on the windowÕs event target, even if your application * does not use the standard window handler or otherwise use Carbon * events. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that should close. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowClose = 72; { * kEventClassWindow / kEventWindowCloseAll * * Summary: * A request to close all windows. * * Discussion: * The standard window handler responds to this event by sending a * kEventWindowClose event to all visible windows of the same window * class as the target window. This event is generated by the * standard window handler in response to an option-click in a * windowÕs close button. * * In Mac OS X 10.7, it is particularly important to handle this * event (rather than relying on the default window event handler) * if your application adopts the automatic termination capability. * In that case, the OS will automatically add a Close All menu item * to your application's File menu that will generate this event. We * recommend that you handle this event yourself so that you can * implement appropriate UI for closing documents that have unsaved * changes. Since the default handler simply generates a * kEventWindowClose event for each window, if there are multiple * documents with unsaved changes, the result will be multiple * sheets opening at once. This is not the recommended UI for this * case. Instead, your application should allow the user to review * unsaved changes in each document singly. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window whose close button was clicked. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowCloseAll = 74; { * kEventClassWindow / kEventWindowZoom * * Summary: * A request to zoom a window. * * Discussion: * For all windows, the basic window handler responds to this event * by sending a kEventWindowGetIdealSize event to get the windowÕs * ideal size, and then calling ZoomWindowIdeal. This event is * generated by the standard window handler in response to a click * in the windowÕs zoom button. It is also generated by the basic * window handler when Zoom is selected from the standard window * menu. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that should zoom. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The part code (inZoomIn or inZoomOut) that should be passed * to ZoomWindow or ZoomWindowIdeal. This parameter is * optional and may not be present in all instances of this * event. If present, the event handler should determine if * the window is already in the requested state (i.e., if the * part code is inZoomOut and the window is already in the * standard state), and if so, the event handler should not * zoom the window at all. If this parameter is not present, * the event handler should zoom the window based on its * current state. This parameter is available in Mac OS X 10.3 * and later. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowZoom = 75; { * kEventClassWindow / kEventWindowZoomAll * * Summary: * A request to zoom all windows. * * Discussion: * The standard window handler responds to this event by zooming all * visible windows of the same window class as the target window. On * Mac OS X 10.3 and later, it causes each window to zoom by sending * a kEventWindowZoom event to the window; on earlier versions of * Mac OS X, and in CarbonLib, it simply calls ZoomWindowIdeal on * each window. This event is generated by the standard window * handler in response to an option-click on a windowÕs zoom button. * * * After zooming all of the windows, if the windows are being zoomed * out and the window class of the target window is * kDocumentWindowClass, the windows are cascaded by sending a * kEventCommandProcess event with the kHICommandArrangeInFront * command to the target window. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window whose zoom button was clicked. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowZoomAll = 77; { * kEventClassWindow / kEventWindowContextualMenuSelect * * Summary: * A request to display a contextual menu. * * Discussion: * This event is generated by the standard window handler in * response to a contextual menu click in the content area of a * window. In response to such an event, the standard window handler * first checks if the click is on a control, and if so, calls * HandleControlContextualMenuClick. If the click was not on a * control, or if HandleControlContextualMenuClick returned that it * did not handle the click, then the standard window handler sends * kEventWindowContextualMenuSelect to allow the application to * provide its own customized contextual menu. The standard window * handler does not respond to this event itself. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that should collapse. * * --> kEventParamMouseLocation (in, typeHIPoint) * The mouse location, in global coordinates. * * --> kEventParamWindowRef (in, typeWindowRef) * The window under the mouse. Available in Mac OS X 10.1 and * later. * * --> kEventParamWindowMouseLocation (in, typeHIPoint) * The window-relative position of the mouse in the window * given in the kEventParamWindowRef parameter. 0,0 is at the * top left of the structure of the window. Available in Mac * OS X 10.1 and later. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The part code that the mouse location hit in the window. * This parameter only exists if the WindowRef parameter * exists. This saves you the trouble of calling FindWindow, * which is expensive on Mac OS X as it needs to call the * Window Server. Available in Mac OS X 10.3 and later. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the event was * generated. * * --> kEventParamMouseButton (in, typeMouseButton) * Which mouse button was pressed. * * --> kEventParamClickCount (in, typeUInt32) * Whether this is a single click, double click, etc. * * --> kEventParamMouseChord (in, typeUInt32) * Which other mouse buttons were pressed when the event was * generated. Available on Mac OS X only. * * --> kEventParamTabletEventType (in, typeUInt32) * The type of tablet event which generated this mouse event; * contains either kEventTabletPoint or kEventTabletProximity. * Only present if the event was generated from a tablet. * Available in Mac OS X 10.1 and CarbonLib 1.5, and later. * * --> kEventParamTabletPointRec (in, typeTabletPointRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletPoint. Available on Mac OS X 10.1 and CarbonLib * 1.5, and later. * * --> kEventParamTabletProximityRec (in, typeTabletProximityRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletProximity. Available on Mac OS X 10.1 and * CarbonLib 1.5, and later. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowContextualMenuSelect = 78; { * kEventClassWindow / kEventWindowPathSelect * * Summary: * Allows customization of the path-selection popup menu displayed * over a windowÕs title. * * Discussion: * This event is generated by the standard window handler in * response to a click in a windowÕs drag region. In response to * such an event, the standard window handler first calls * IsWindowPathSelectEvent to determine if the click should cause a * path-selection popup menu to be displayed. If so, and if the * window is also hilited and has a proxy icon, the standard window * handler sends a kEventWindowPathSelect event to the window. * * * A handler for this event should put a MenuRef into the event and * return noErr to cause the menu to be displayed as the path * selection popup menu. The menu will not be released by the * standard window handler; however, in Mac OS X 10.4 and later, it * will be retained by the EventRef when added to the event, and * released when the event is destroyed, so a handler for this event * may, on Mac OS X 10.4 and later, release the menu after adding it * to the menu. * * Note! The standard window handler's use of this event was broken * in all releases of CarbonLib and Mac OS X before Mac OS X 10.4; * the MenuRef added to this event was not used to display the path * selection menu. Therefore, this event is effectively useless * before Mac OS X 10.4. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that will display the path-selection popup menu. * * <-- kEventParamMenuRef (out, typeMenuRef) * On exit, contains the menu that should be displayed. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowPathSelect = 79; { * kEventClassWindow / kEventWindowGetIdealSize * * Summary: * A request for the ideal size of a windowÕs content region, for * use during window zooming. * * Discussion: * This event is generated by the basic window handler in response * to kEventWindowZoom. The basic window handler sends this event to * the window to get the windowÕs ideal size, and passes the * resulting size to ZoomWindowIdeal. * * This event is not handled by either the basic or standard window * handlers. If no handler responds to this event, the basic window * handler uses an ideal size based on the size of the monitor on * which the window is located. * * Prior to Mac OS X Mac OS X 10.4, the ZoomWindowIdeal API * malfunctioned if passed an idealSize that was large enough to * cause 16-bit integer overflow when added to the window's current * position. Therefore, when providing an ideal size in response to * this event, you should generally not return values that are close * to 32767. It is better to limit your ideal size to, say, 16K. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window being zoomed. * * <-- kEventParamDimensions (out, typeQDPoint) * On exit, contains the windowÕs ideal size. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowGetIdealSize = 80; { * kEventClassWindow / kEventWindowGetIdealStandardState * * Summary: * Calculates the ideal standard state of a window, given its ideal * size. * * Discussion: * This event is generated by IsWindowInStandardState and * ZoomWindowIdeal. The bounding rect returned by the event handler * is, respectively, compared against the window's current bounds to * determine if the window is in its standard state, and used as the * new window bounds when zooming out. * * The basic window event handler implements this event by computing * an ideal window bounds that fits the window onscreen, given the * desired ideal size. * * An application might handle this event in order to customize the * standard state bounds of a window. For example, if the * application has tool palettes around the edges of a display, it * could handle this event and calculate its own standard state * bounds for a window that prevents the window from zooming under * the tool palettes. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window whose ideal standard state to return. * * --> kEventParamDimensions (in, typeHISize) * The window's ideal content size. This is the size that was * passed by the caller to IsWindowInStandardState or * ZoomWindowIdeal. * * <-- kEventParamBounds (out, typeHIRect) * On exit, contains the content bounds for the window's ideal * standard state. * * Availability: * Mac OS X: in version 10.4 and later in Carbon.framework * CarbonLib: not available } const kEventWindowGetIdealStandardState = 93; { * kEventClassWindow / kEventWindowGetMinimumSize * * Summary: * A request for the minimum size of a windowÕs content region, for * use during window resizing. * * Discussion: * This event is generated by the standard window handler before * resizing a window. On Mac OS X 10.2 and later, the basic window * handler responds to this event by calling GetWindowResizeLimits * and returning the minimum size in the event; on earlier versions * of Mac OS X and CarbonLib, this event is not handled by the basic * or standard window handlers. * * On Mac OS X 10.2 and CarbonLib 1.6 and later, this event is also * generated by ResizeWindow and GrowWindow if the sizeConstraints * parameter is NULL. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window being resized. * * <-- kEventParamDimensions (out, typeQDPoint) * On exit, contains the windowÕs minimum size. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowGetMinimumSize = 81; { * kEventClassWindow / kEventWindowGetMaximumSize * * Summary: * A request for the maximum size of a windowÕs content region, for * use during window resizing. * * Discussion: * This event is generated by the standard window handler before * resizing a window. On Mac OS X 10.2 and later, the basic window * handler responds to this event by calling GetWindowResizeLimits * and returning the maximum size in the event; on earlier versions * of Mac OS X and CarbonLib, this event is not handled by the basic * or standard window handlers. * * On Mac OS X 10.2 and CarbonLib 1.6 and later, this event is also * generated by ResizeWindow and GrowWindow if the sizeConstraints * parameter is NULL. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window being resized. * * <-- kEventParamDimensions (out, typeQDPoint) * On exit, contains the windowÕs minimum size. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowGetMaximumSize = 82; { * kEventClassWindow / kEventWindowConstrain * * Summary: * Requests that a windowÕs position be constrained to the available * window positioning bounds. * * Discussion: * The basic window handler responds to this event by calling * ConstrainWindowToScreen. This event is generated in three * situations: changes in graphics device configuration, changes to * Dock size, and (in Mac OS X 10.6 and later) after a window has * been dragged. In each of these cases, a window which was * previously visible onscreen may become obscured or be totally * offscreen, and should be repositioned back inside the available * window positioning bounds. * * The behavior of the basic window handler may be customized by * modifying the parameters to the event and then allowing the event * to pass through to the basic handler, or an application may * choose to override the event entirely and perform its own window * constraining. * * Applications may also use the * kEventAppAvailableWindowBoundsChanged event to be notified of * changes to a deviceÕs available bounds. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window being constrained. * * --> kEventParamReason (in, typeUInt32) * The reasons why the window is being constrained. This * parameter contains one or more of the * kAvailBoundsChangedFor constants. This parameter is * available only on Mac OS X 10.3 and later. This parameter * is not present on Mac OS X 10.6 and later if the event is * being sent after a window drag. * * --> kEventParamTransactionID (in, typeUInt32) * An integer which is the same for all instances of this * event that are produced by the same configuration change. * For example, if multiple displays are attached, then this * event is sent once for each window on each affected display * after a display configuration change; however, the * transaction ID parameter will the same for each event, so a * handler for this event can correlate events by observing * the transaction ID. This parameter is available only on Mac * OS X 10.3 and later. * * --> kEventParamAvailableBounds (in, typeQDRectangle) * The available window positioning bounds in which the window * should be positioned. Event handlers may change the value * in this parameter and then return eventNotHandledErr to * allow the basic window handler to constrain the window to * the new bounding rect. * * This parameter is used by the basic window handler on Mac * OS X 10.1 and later; on earlier versions of Mac OS X, the * basic window handler always constrains the window to the * rect returned by GetAvailableWindowPositioningBounds for * the windowÕs device. * * --> kEventParamAttributes (in, typeUInt32) * Window constraint options that should be passed to * ConstrainWindowToScreen. This parameter is optional and may * not be present in all instances of this event. If present, * this parameter should be formed from constants in the * WindowConstrainOptions enumeration. * * This parameter is used by the basic window handler on Mac * OS X 10.2 and later; on earlier versions of Mac OS X, or if * this parameter is missing, the basic window handler passes * kWindowConstrainMoveRegardlessOfFit to * ConstrainWindowToScreen in Mac OS X 10.0, and * kWindowConstrainMoveRegardlessOfFit | * kWindowConstrainAllowPartial in Mac OS 10.1 and later. * * --> kEventParamWindowRegionCode (in, typeWindowRegionCode) * A WindowRegionCode that should be passed to * ConstrainWindowToScreen. This parameter is optional and may * not be present in all instances of this event. * * This parameter is used by the basic window handler on Mac * OS X 10.2 and later. On earlier versions of Mac OS X, or if * this parameter is missing, the basic window handler passes * kWindowDragRgn to ConstrainWindowToScreen. * * --> kEventParamRgnHandle (in, typeQDRgnHandle) * The GrayRgn before a graphics device configuration change. * This parameter is optional and may not be present in all * instances of this event. It is present in events generated * on Mac OS X 10.2 and later. * * An event handler may compare this region with the current * GrayRgn to more intelligently determine whether the window * should be constrained to the current GrayRgn. The basic * window handler in Mac OS X 10.2 will not constrain windows * that were not onscreen before the device configuration * change. * * --> kEventParamPreviousDockRect (in, typeHIRect) * The Dock bounding rect before a Dock size change. This * parameter is optional and may not be present in all * instances of this event. It is present in events in events * generated on Mac OS X 10.2 and later. * * --> kEventParamPreviousDockDevice (in, typeCGDisplayID) * The display device on which the Dock was previously * positioned. This parameter is optional and may not be * present in all instances of this event. It is present in * events generated on Mac OS X 10.3 and later. On Mac OS X * 10.3 and later, this parameter is available as a GDHandle * using typeGDHandle; on Mac OS X 10.5 and later, this * parameter is also available as a CGDirectDisplayID using * typeCGDisplayID. * * --> kEventParamCurrentDockRect (in, typeHIRect) * The Dock bounding rect after a Dock size change. This * parameter is optional and may not be present in all * instances of this event. It is present in events in events * generated on Mac OS X 10.2 and later. * * --> kEventParamCurrentDockDevice (in, typeCGDisplayID) * The display device on which the Dock is currently * positioned. This parameter is optional and may not be * present in all instances of this event. It is present in * events generated on Mac OS X 10.3 and later. On Mac OS X * 10.3 and later, this parameter is available as a GDHandle * using typeGDHandle; on Mac OS X 10.5 and later, this * parameter is also available as a CGDirectDisplayID using * typeCGDisplayID. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.5 and later } const kEventWindowConstrain = 83; { * kEventClassWindow / kEventWindowRestoreFromDock * * Summary: * Requests that a collapsed window be restored from the Dock. * * Discussion: * The basic window handler responds to this event by calling * SelectWindow or CollapseWindow(false), depending on whether the * window should be made active. Your application may handle this * event to be notified before a window is restored from the Dock. A * handler for this event should generally either return noErr to * prevent a window from being restored from the Dock, or * eventNotHandledErr to allow the basic handler to restore the * window from the Dock. * * In Mac OS X 10.7 and later, this event cannot be used to prevent * a window from being restored from the Dock. Window restoration is * done asynchronously in Mac OS X 10.7 and later, and this event is * sent as a notification, not a request. * * This event is sent only to the window, and is not propagated past * it. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window to be restored from the Dock. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventWindowRestoreFromDock = 84; { * kEventClassWindow / kEventWindowProxyBeginDrag * * Summary: * Notification that a proxy icon drag is beginning. * * Discussion: * This event includes the DragRef that will be used for the proxy * icon drag. An application handler may attach its own data to the * DragRef as appropriate for the document content. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window whose proxy icon is being dragged. * * --> kEventParamDragRef (in, typeDragRef) * The DragRef that will be used for the proxy icon drag. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowProxyBeginDrag = 128; { * kEventClassWindow / kEventWindowProxyEndDrag * * Summary: * Notification that a proxy icon drag has ended. * * Discussion: * This event is sent regardless of whether the drag completed * successfully, or was canceled by the user. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window whose proxy icon is being dragged. * * --> kEventParamDragRef (in, typeDragRef) * The DragRef that was used for the proxy icon drag. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowProxyEndDrag = 129; {$ifc not TARGET_CPU_64} { * kEventClassWindow / kEventWindowHandleContentClick * * Summary: * The mouse has been clicked in the content region of a window, but * the click is not a contextual menu invocation or a click on a * control. * * Discussion: * This event is generated by the standard window handler in * response to a kEventWindowClickContentRgn event. An application * may handle this event by checking if the mouse click was on a * portion of its own user interface, and responding appropriately * if so. * * Note that this event is not sent for composited windows; all * mouse-downs in a composited window are handled by a view, and * there is no Ócontent regionÓ in a composited window. To intercept * a content region click in a composited window, install a * kEventControlClick handler on the windowÕs content view, or * provide your own HIView subclass. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that was clicked. * * --> kEventParamMouseLocation (in, typeHIPoint) * The mouse location, in global coordinates. * * --> kEventParamWindowRef (in, typeWindowRef) * The window under the mouse. Available in Mac OS X 10.1 and * later. * * --> kEventParamWindowMouseLocation (in, typeHIPoint) * The window-relative position of the mouse in the window * given in the kEventParamWindowRef parameter. 0,0 is at the * top left of the structure of the window. Available in Mac * OS X 10.1 and later. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The part code that the mouse location hit in the window. * This parameter only exists if the WindowRef parameter * exists. This saves you the trouble of calling FindWindow, * which is expensive on Mac OS X as it needs to call the * Window Server. Available in Mac OS X 10.3 and later. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the event was * generated. * * --> kEventParamMouseButton (in, typeMouseButton) * Which mouse button was pressed. * * --> kEventParamClickCount (in, typeUInt32) * Whether this is a single click, double click, etc. * * --> kEventParamMouseChord (in, typeUInt32) * Which other mouse buttons were pressed when the event was * generated. Available on Mac OS X only. * * --> kEventParamTabletEventType (in, typeUInt32) * The type of tablet event which generated this mouse event; * contains either kEventTabletPoint or kEventTabletProximity. * Only present if the event was generated from a tablet. * Available in Mac OS X 10.1 and CarbonLib 1.5, and later. * * --> kEventParamTabletPointRec (in, typeTabletPointRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletPoint. Available on Mac OS X 10.1 and CarbonLib * 1.5, and later. * * --> kEventParamTabletProximityRec (in, typeTabletProximityRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletProximity. Available on Mac OS X 10.1 and * CarbonLib 1.5, and later. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework [32-bit only] * CarbonLib: in CarbonLib 1.3.1 and later } const kEventWindowHandleContentClick = 85; {$endc} {not TARGET_CPU_64} { * kEventClassWindow / kEventWindowGetDockTileMenu * * Summary: * A request for a menu to be displayed by a windowÕs dock tile. * * Discussion: * The basic window handler responds to this event by returning the * menu, if any, that was provided by the SetWindowDockTileMenu API. * For most applications, it will be easier to use the * SetWindowDockTileMenu API directly rather than installing a * handler for this event. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that should collapse. * * <-- kEventParamMenuRef (out, typeMenuRef) * On exit, contains the menu that should be displayed for the * windowÕs Dock tile. The sender of this event will release * the menu after the Dock has displayed it, so if you return * a permanently allocated MenuRef, you should call RetainMenu * on it before returning from your event handler. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventWindowGetDockTileMenu = 90; { * kEventClassWindow / kEventWindowUpdateDockTile * * Summary: * Indicates that your application should redraw its custom * collapsed window Dock tile. * * Discussion: * This event is sent when your application has customized a * collapsed window Dock tile. If your app customizes its window * Dock tile appearance using * CreateQDContextForCollapsedWindowDockTile or * HIWindowCreateCollapsedDockTileContext, then your application * should redraw its window Dock tile in response to this event. * This event is not sent if your application has not customized a * window's Dock tile. * * This event is currently sent in two cases: when the Dock tile * changes size (typically in response to a change in the user * interface scale factor), or when the Dock process is restarted. * In either case, any customization that your application has * previously performed is lost. * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window whose Dock tile should be updated. * * Availability: * Mac OS X: not available * CarbonLib: not available } const kEventWindowUpdateDockTile = 94; { * kEventClassWindow / kEventWindowColorSpaceChanged * * Summary: * Notification that the color space of the window has changed. * * Discussion: * When the kHIWindowBitAutoCalibration attribute is set, this event * is sent when the window's colorspace is changed by the Window * Manager. The standard window handler's response is to paint the * entire window. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window with the updated color space. * * Availability: * Mac OS X: in version 10.6 and later in Carbon.framework * CarbonLib: not available } const kEventWindowColorSpaceChanged = 95; { * kEventClassWindow / kEventWindowRestoredAfterRelaunch * * Summary: * Notification that a window has been restored after application * relaunch. * * Discussion: * This event is sent by the Window Manager when the system caused * your application to be quit and relaunched. Your application will * receive a kAEOpenDocuments Apple Event containing documents that * were open when your application was quit, if it had any. * * For each reopened document, this event will be sent to the * document's window, after it has been restored to its previous * size and position. If your application uses the * ChangeWindowPropertyAttributes API to set the * kWindowPropertyPersistent attribute for a window property, the * property will have been restored to its previous value when your * application receives this event. This event is sent to all * handlers registered for it. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that was restored. * * Availability: * Mac OS X: in version 10.7 and later in Carbon.framework * CarbonLib: not available } const kEventWindowRestoredAfterRelaunch = 96; { * kEventClassWindow / kEventWindowToolbarSwitchMode * * Summary: * A request that the windowÕs toolbar change its display mode. * * Discussion: * For all windows, the basic window handler responds to this event * by changing the display mode of the windowÕs HIToolbar, if any. * If the application uses its own custom toolbar implementation, it * should handle this event itself and respond appropriately. This * event is generated by the basic window handler in response to a * click in the windowÕs toolbar button. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window whose toolbar button was clicked. * * --> kEventParamMouseLocation (in, typeHIPoint) * The mouse location, in global coordinates. * * --> kEventParamWindowRef (in, typeWindowRef) * The window under the mouse. Available in Mac OS X 10.1 and * later. This parameter may not be present in all instances * of this event, even on Mac OS X 10.1 and later. * * --> kEventParamWindowMouseLocation (in, typeHIPoint) * The window-relative position of the mouse in the window * given in the kEventParamWindowRef parameter. 0,0 is at the * top left of the structure of the window. Available in Mac * OS X 10.1 and later. This parameter may not be present in * all instances of this event, even on Mac OS X 10.1 and * later. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The part code that the mouse location hit in the window. * This parameter may not be present in all instances of this * event. This saves you the trouble of calling FindWindow, * which is expensive on Mac OS X as it needs to call the * Window Server. Available in Mac OS X 10.3 and later. This * parameter may not be present in all instances of this * event, even on Mac OS X 10.3 and later. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the event was * generated. * * --> kEventParamMouseButton (in, typeMouseButton) * Which mouse button was pressed. This parameter may not be * present in all instances of this event. * * --> kEventParamClickCount (in, typeUInt32) * Whether this is a single click, double click, etc. This * parameter may not be present in all instances of this event. * * --> kEventParamMouseChord (in, typeUInt32) * Which other mouse buttons were pressed when the event was * generated. Available on Mac OS X only. This parameter may * not be present in all instances of this event, even on Mac * OS X. * * --> kEventParamTabletEventType (in, typeUInt32) * The type of tablet event which generated this mouse event; * contains either kEventTabletPoint or kEventTabletProximity. * Only present if the event was generated from a tablet. * Available in Mac OS X 10.1 and CarbonLib 1.5, and later. * This parameter may not be present in all instances of this * event, even on the previously mentioned platforms. * * --> kEventParamTabletPointRec (in, typeTabletPointRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletPoint. Available on Mac OS X 10.1 and CarbonLib * 1.5, and later. This parameter may not be present in all * instances of this event, even on the previously mentioned * platforms. * * --> kEventParamTabletProximityRec (in, typeTabletProximityRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletProximity. Available on Mac OS X 10.1 and * CarbonLib 1.5, and later. This parameter may not be present * in all instances of this event, even on the previously * mentioned platforms. * * Availability: * Mac OS X: in version 10.1 and later in Carbon.framework * CarbonLib: not available } const kEventWindowToolbarSwitchMode = 150; { * kEventClassWindow / kEventWindowFocusAcquired * * Summary: * Notification that the user (or some other action) has caused the * focus to shift to your window. * * Discussion: * This event is sent to all handlers registered for it. * * The basic window handler responds to this event by forwarding the * event to the focused control in the specified window. This allows * the focused control to invalidate or redraw itself as necessary; * for example, the standard edit-text control responds to this * event by enabling its blinking insertion point. An application * handler may choose to set the focus to custom application content * instead. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that is gaining focus. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowFocusAcquired = 200; { * kEventClassWindow / kEventWindowFocusRelinquish * * Summary: * Notification that a window has lost user focus. * * Discussion: * This event is sent to all handlers registered for it. * * The basic window handler responds to this event by forwarding the * event to the focused control in the specified window. This allows * the focused control to invalidate or redraw itself as necessary; * for example, the standard edit-text control responds to this * event by disabling its blinking insertion point. An application * handler should remove the focus from custom application content * and ensure that the content is redrawn without the focus * highlight. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that is losing focus. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowFocusRelinquish = 201; { * kEventClassWindow / kEventWindowFocusLost * * Summary: * Notification that a focused window has lost focus due to a change * in the modal focus stack. * * Discussion: * This event is sent to a focused window when another window is * pushed onto the modal focus stack. When this happens, the pushed * window becomes the effective focus, and this window ceases to * have the focus. * * This event is sent to all handlers registered for it on the * window. The basic window handler automatically sends this event * to the focused view in the window. The basic view handler * automatically invalidates a view when it receives this event. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that is losing focus. * * Availability: * Mac OS X: in version 10.5 and later in Carbon.framework * CarbonLib: not available } const kEventWindowFocusLost = 205; { * kEventClassWindow / kEventWindowFocusRestored * * Summary: * Notification that a window has regained focus due to a change in * the modal focus stack. * * Discussion: * This event is sent to a window (window A) when the removal of * another window (window B) from the modal focus stack causes * window A to become the effective focus. Typically, window A is * either the modeless focus (the window that was most recently * passed to SetUserFocusWindow), or another window in the modal * focus stack that was underneath window B, and is now topmost on * the stack. * * This event is sent to all handlers registered for it on the * window. The basic window handler automatically sends this event * to the focused view in the window. The basic view handler * automatically invalidates a view when it receives this event. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that is regaining focus. * * Availability: * Mac OS X: in version 10.5 and later in Carbon.framework * CarbonLib: not available } const kEventWindowFocusRestored = 206; { * kEventClassWindow / kEventWindowFocusContent * * Summary: * A request to set the focus to the content area of a window. * * Discussion: * If the content area of your window is not already focused, you * should set the focus to the main part/control/view of the window. * If the content area of your window is already focused, do * nothing. The standard window handler responds to this event by * calling HIViewAdvanceFocus on the windowÕs root control, if the * focus is not already contained within the content root. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window whose content should be focused. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventWindowFocusContent = 202; { * kEventClassWindow / kEventWindowFocusToolbar * * Summary: * A request to set the focus to the toolbar of a window. * * Discussion: * If your windowÕs toolbar is not already focused, you should set * the focus to the first item in the toolbar. If your windowÕs * toolbar is already focused, do nothing. The basic window handler * responds to this event by calling HIViewAdvanceFocus on the * toolbar control, if the focus is not already contained within the * toolbar. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window whose toolbar should be focused. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventWindowFocusToolbar = 203; { * kEventClassWindow / kEventWindowFocusDrawer * * Summary: * A request to set the focus to the drawer of a window. * * Discussion: * If your windowÕs drawer is not already focused, you should set * the focus to the first item in the drawer. If your windowÕs * drawer is already focused, you should move the focus to the next * or previous drawer, if any, depending on whether the modifiers * parameter contains the shift key modifier. The basic window * handler responds to this event by calling SetUserFocusWindow on, * and sending a kEventWindowFocusContent event to, the appropriate * drawer, if the focus is not already contained within the drawer. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window whose drawer should be focused. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the user * requested a focus switch. * * Availability: * Mac OS X: in version 10.4 and later in Carbon.framework * CarbonLib: not available } const kEventWindowFocusDrawer = 204; { * kEventClassWindow / kEventWindowSheetOpening * * Summary: * Notification that a sheet is opening. * * Discussion: * This event is sent to all handlers registered for it. This event * is sent to the sheet, its parent window, and the application * target before the sheet begins opening. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The sheet that is opening. * * Result: * An event handler for this event may return userCanceledErr if the * sheet should not open. Any other return value is ignored and will * still allow the sheet to open. * * Availability: * Mac OS X: in version 10.4 and later in Carbon.framework * CarbonLib: not available } const kEventWindowSheetOpening = 210; { * kEventClassWindow / kEventWindowSheetOpened * * Summary: * Notification that a sheet is open. * * Discussion: * This event is sent to all handlers registered for it. This event * is sent to the sheet, its parent window, and the application * target after the sheet is fully open. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The sheet that opened. * * Availability: * Mac OS X: in version 10.4 and later in Carbon.framework * CarbonLib: not available } const kEventWindowSheetOpened = 211; { * kEventClassWindow / kEventWindowSheetClosing * * Summary: * Notification that a sheet is closing. * * Discussion: * This event is sent to all handlers registered for it. This event * is sent to the sheet, its parent window, and the application * target before the sheet begins closing. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The sheet that is opening. * * Result: * An event handler for this event may return userCanceledErr if the * sheet should not close. Any other return value is ignored and * will still allow the sheet to close. * * Availability: * Mac OS X: in version 10.4 and later in Carbon.framework * CarbonLib: not available } const kEventWindowSheetClosing = 212; { * kEventClassWindow / kEventWindowSheetClosed * * Summary: * Notification that a sheet is closed. * * Discussion: * This event is sent to all handlers registered for it. This event * is sent to the sheet, its parent window, and the application * target after the sheet is fully closed. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The sheet that closed. * * Availability: * Mac OS X: in version 10.4 and later in Carbon.framework * CarbonLib: not available } const kEventWindowSheetClosed = 213; { * kEventClassWindow / kEventWindowDrawerOpening * * Summary: * Notification that a drawer is opening. * * Discussion: * This event is sent to all handlers registered for it. This event * is sent to the drawer, its parent window, and the application * target before the drawer begins opening. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The drawer that is opening. * * Result: * An event handler for this event may return userCanceledErr if the * drawer should not open. Any other return value is ignored and * will still allow the drawer to open. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventWindowDrawerOpening = 220; { * kEventClassWindow / kEventWindowDrawerOpened * * Summary: * Notification that a drawer is open. * * Discussion: * This event is sent to all handlers registered for it. This event * is sent to the drawer, its parent window, and the application * target after the drawer is fully open. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The drawer that opened. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventWindowDrawerOpened = 221; { * kEventClassWindow / kEventWindowDrawerClosing * * Summary: * Notification that a drawer is closing. * * Discussion: * This event is sent to all handlers registered for it. This event * is sent to the drawer, its parent window, and the application * target before the drawer begins closing. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The drawer that is opening. * * Result: * An event handler for this event may return userCanceledErr if the * drawer should not close. Any other return value is ignored and * will still allow the drawer to close. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventWindowDrawerClosing = 222; { * kEventClassWindow / kEventWindowDrawerClosed * * Summary: * Notification that a drawer is closed. * * Discussion: * This event is sent to all handlers registered for it. This event * is sent to the drawer, its parent window, and the application * target after the drawer is fully closed. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The drawer that closed. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventWindowDrawerClosed = 223; { * kEventClassWindow / kEventWindowDrawFrame * * Summary: * Sent by the Window Manager when itÕs time to draw a windowÕs * structure. * * Discussion: * This is the replacement to the old wDraw defProc message (though * it is a special case of the 0 part code indicating to draw the * entire window frame). * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window to draw. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowDrawFrame = 1000; { * kEventClassWindow / kEventWindowDrawPart * * Summary: * Sent by the Window Manager when itÕs time to draw a specific part * of a windowÕs structure, such as the close button. * * Discussion: * This is typically sent during window widget tracking. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window to draw. * * --> kEventParamWindowDefPart (in, typeWindowDefPartCode) * The part to draw. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowDrawPart = 1001; { * kEventClassWindow / kEventWindowGetRegion * * Summary: * Sent by the Window Manager when it needs to get a specific region * from a window, or when the GetWindowRegion API is called. * * Discussion: * Note that the Window Manager caches a window's structure and * content region once they have been calculated. If your window's * structure or content region changes without the window size * changing, you should use ReshapeCustomWindow to force the Window * Manager to request the new structure and content regions. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window whose region to return. * * --> kEventParamWindowRegionCode (in, typeWindowRegionCode) * The region to return. * * --> kEventParamWindowContentBounds (in, typeQDRectangle) * The global bounds of the window's content area. Available * in Mac OS X 10.1 and later. An event handler can use this * parameter to calculate the requested region. Alternately, a * handler can call GetWindowBounds( window, * kWindowGlobalPortRgn ), and work from that rectangle. * * --> kEventParamRgnHandle (in, typeQDRgnHandle) * On entry, contains a valid but empty RgnHandle; you should * place the window region in this RgnHandle. * * The window region should be in either global coordinates or * window coordinates, depending on whether the window uses a * WindowDefProcPtr or HIView to draw its window frame. Prior * to Mac OS X 10.2, all windows used WindowDefProcPtrs. In * Mac OS X 10.2 and later, you can determine at runtime * whether a particular window uses a WindowDefProcPtr-based * window frame by calling HIViewGetKind on the window's root * view (returned by HIViewGetRoot). If the kind field of the * HIViewKind is 'cont', then the window uses a * WindowDefProcPtr to draw its window frame; otherwise, the * window uses an HIView. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowGetRegion = 1002; { * kEventClassWindow / kEventWindowHitTest * * Summary: * Sent when the Window Manager needs to determine what part of a * window would be 'hit' with a given mouse location in global * coordinates. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window to hit-test. * * --> kEventParamMouseLocation (in, typeQDPoint) * The mouse location. * * <-- kEventParamWindowDefPart (out, typeWindowDefPartCode) * On exit, contains the window part that was hit. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowHitTest = 1003; { * kEventClassWindow / kEventWindowInit * * Summary: * Sent by the Window Manager when the window is being created. This * is a hook to allow your window definition to do any * initialization you might need to do. * * Discussion: * This event can be sent more than once to a window if the window * definition function for the window is changed; see the note under * kEventWindowDispose. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window being created. * * <-- kEventParamWindowFeatures (out, typeUInt32) * On exit, your event handler should store the window * features in this parameter. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowInit = 1004; { * kEventClassWindow / kEventWindowDispose * * Summary: * Sent by the Window Manager to notify the window definition that * it should dispose of any private data structures attached to the * window. * * Discussion: * Note that this event does not directly correspond with * destruction of the window; the Window Manager occasionally needs * to change the window definition of a window (for example, when * ChangeWindowAttributes is used to change the visual appearance of * a window), and in that case, the window will receive a * kEventWindowDispose followed by a kEventWindowInit so that the * old and new window definitions can disconnect and connect to the * window. If you need to know when a window is really being * destroyed, install a handler for kEventWindowClosed. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window being destroyed. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowDispose = 1005; { * kEventClassWindow / kEventWindowDragHilite * * Summary: * Sent by the Window Manager when it is time to draw/erase any drag * hilite in the window structure. * * Discussion: * This is typically sent from within HiliteWindowFrameForDrag. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window being hilited. * * --> kEventParamWindowDragHiliteFlag (in, typeBoolean) * Whether to draw (true) or erase (false) the hilite. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowDragHilite = 1006; { * kEventClassWindow / kEventWindowModified * * Summary: * Sent by the Window Manager when it is time to redraw window * structure to account for a change in the document modified state. * * Discussion: * This is typically sent from within SetWindowModified. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that was modified. * * --> kEventParamWindowModifiedFlag (in, typeBoolean) * The new modified state. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowModified = 1007; { * kEventClassWindow / kEventWindowSetupProxyDragImage * * Summary: * Sent by the Window Manager when it is time to generate a drag * image for the window proxy. * * Discussion: * This is typically sent from within BeginWindowProxyDrag. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window whose proxy is being dragged. * * <-- kEventParamWindowProxyGWorldPtr (out, typeGWorldPtr) * On exit, contains a GWorld you allocate which contains the * drag image. This parameter is required on Mac OS X 10.0 and * Mac OS X 10.1. On Mac OS X 10.2 and later, you may * optionally omit this parameter and instead provide a drag * image using a CGImageRef stored in the * kEventParamCGImageRef parameter. If both parameters are * provided, the contents of kEventParamCGImageRef will * override this parameter. If this parameter is provided, the * toolbox will free the GWorld inside EndWindowProxyDrag. * * <-- kEventParamCGImageRef (out, typeCGImageRef) * On exit, contains a CGImageRef you allocate which contains * the drag image. This parameter is supported on Mac OS X * 10.2 and later. You may optionally omit this parameter and * instead provide a drag image using a GWorld stored in the * kEventParamWindowProxyGWorldPtr parameter. If both * parameters are provided, this parameter will override the * contents of kEventParamWindowProxyGWorldPtr. If this * parameter is provided, the toolbox will free the CGImageRef * inside EndWindowProxyDrag. * * --> kEventParamWindowProxyImageRgn (in, typeQDRgnHandle) * The region you modify to contain the clip region for the * GWorld. * * --> kEventParamWindowProxyOutlineRgn (in, typeQDRgnHandle) * The region you modify to contain the drag outline used when * the GWorld cannot be used. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowSetupProxyDragImage = 1008; { * kEventClassWindow / kEventWindowStateChanged * * Summary: * Sent by the Window Manager when a particular window state changes. * * Discussion: * See the state-change flags in MacWindows.h. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window whose state was changed. * * --> kEventParamWindowStateChangedFlags (in, typeUInt32) * The state change flags * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowStateChanged = 1009; { * kEventClassWindow / kEventWindowMeasureTitle * * Summary: * Sent when the Window Manager needs to know how much space the * windowÕs title area takes up. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window whose title to measure. * * <-- kEventParamWindowTitleFullWidth (out, typeSInt16) * On exit, contains the length of the whole title area. * * <-- kEventParamWindowTitleTextWidth (out, typeSInt16) * On exit, contains the length just the title text. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowMeasureTitle = 1010; { * kEventClassWindow / kEventWindowDrawGrowBox * * Summary: * When the DrawGrowIcon API is called, this event is sent to the * window to tell it to draw the grow box. * * Discussion: * This is a compatibility event harkening back to the old days * before Mac OS 8. Not very useful these days. This is only really * needed for windows that do not have the grow box integrated into * the window frame. Scroll bar delimiter lines are also drawn. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window whose grow box to draw. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowDrawGrowBox = 1011; { * kEventClassWindow / kEventWindowGetGrowImageRegion * * Summary: * This is a special way for a window to override the standard * resize outline for windows that do not do live resizing. * * Discussion: * As the user resizes the window, this event is sent with the * current size the user has chosen expressed as a rectangle. You * should calculate your window outline and modify the * kEventParamRgnHandle parameter to reflect your desired outline. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window whose grow image to return. * * --> kEventParamWindowGrowRect (in, typeQDRectangle) * The windowÕs global port bounds. * * --> kEventParamRgnHandle (in, typeQDRgnHandle) * The region to modify. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventWindowGetGrowImageRegion = 1012; { * kEventClassWindow / kEventWindowPaint * * Summary: * When the Window Manager needs to paint a window (e.g, when a * window is first displayed), the kEventWindowPaint event is sent * to allow the window to control all aspect of painting, including * the window frame. * * Discussion: * If a window does not respond to this event, the Window Manager * ends up sending kEventWindowDrawFrame and then erasing the window * to the window content color as usual. This is mostly used for * specialty windows, such as help tags or appliance apps might have. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window to paint. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventWindowPaint = 1013; { * kEventClassWindow / kEventWindowAttributesChanged * * Summary: * Sent by the Window Manager when a windowÕs attributes have * changed. * * Discussion: * This event is only sent to windows that use an HIView-based * window frame. It is not sent to windows that use a WDEF-based * window frame. At the time that the event is sent, the window's * attributes have already been changed, so an event hander for this * event can simply call GetWindowAttributes to get the new * attributes. This event is sent to all handlers registered for it * on the window event target. It does not propagate past the window. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window whose attributes have changed. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventWindowAttributesChanged = 1019; { * kEventClassWindow / kEventWindowTitleChanged * * Summary: * Sent by the Window Manager when a windowÕs title changes. * * Discussion: * In Mac OS X 10.2 through 10.4, this event is only sent to windows * that use an HIView to draw their window frames. Windows that use * a WDEF to draw their frames do not receive this event on those * versions of Mac OS X. In Mac OS X 10.5 and later, this event is * always sent when a windowÕs title changes, regardless of whether * the window uses an HIView or WDEF to draw its frame. This event * is sent to all handlers registered for it on the window event * target. It does not propagate past the window. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window whose title was changed. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventWindowTitleChanged = 1020; { * kEventClassWindow / kEventWindowGetFullScreenContentSize * * Summary: * Allows a window to customize its fullscreen size. * * Discussion: * Sent to a window prior to that window entering fullscreen. A * default fullscreen content size will already be present in the * kEventParamDimensions parameter. A handler may override this * value with a custom content size. The window's actual fullscreen * size is subject to various constraints HIToolbox might impose due * to screen limitations or other reasons, so the window must be * prepared for the window to be resized to a size different than * the one specified via this event. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window whose fullscreen content size is being fetched. * * --> kEventParamDimensions (in, typeHISize) * On entry, the window's proposed fullscreen content size; on * exit, the fullscreen content size that is desired by the * event handler. * * Availability: * Mac OS X: in version 10.7 and later in Carbon.framework * CarbonLib: not available } const kEventWindowGetFullScreenContentSize = 240; { * kEventClassWindow / kEventWindowFullScreenEnterStarted * * Summary: * Notification sent to a window prior to starting its enter * fullscreen animation. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window about to enter fullscreen. * * Availability: * Mac OS X: in version 10.7 and later in Carbon.framework * CarbonLib: not available } const kEventWindowFullScreenEnterStarted = 241; { * kEventClassWindow / kEventWindowFullScreenEnterCompleted * * Summary: * Notification sent to a window after finishing its enter * fullscreen animation. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that just entered fullscreen. * * Availability: * Mac OS X: in version 10.7 and later in Carbon.framework * CarbonLib: not available } const kEventWindowFullScreenEnterCompleted = 242; { * kEventClassWindow / kEventWindowFullScreenExitStarted * * Summary: * Notification sent to a window prior to starting its exit * fullscreen animation. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window about to exit fullscreen. * * Availability: * Mac OS X: in version 10.7 and later in Carbon.framework * CarbonLib: not available } const kEventWindowFullScreenExitStarted = 243; { * kEventClassWindow / kEventWindowFullScreenExitCompleted * * Summary: * Notification sent to a window after finishing its exit fullscreen * animation OR after failing to enter fullscreen. * * Discussion: * In addition to the normal case of a fullscreen window that * animates out of fullscreen, this event is also sent if there's a * failure when attempting to enter full screen. That is, it's * possible for a window to receive this event very soon after * kEventWindowFullScreenEnterStarted, and a handler should be * prepared to deal with this possibility. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeWindowRef) * The window that just exited fullscreen. * * Availability: * Mac OS X: in version 10.7 and later in Carbon.framework * CarbonLib: not available } const kEventWindowFullScreenExitCompleted = 244; {--------------------------------------------------------------------------------------} { Menu Events } {--------------------------------------------------------------------------------------} { kEventClassMenu quick reference: kEventMenuBeginTracking = 1, kEventMenuEndTracking = 2, kEventMenuChangeTrackingMode = 3, kEventMenuOpening = 4, kEventMenuClosed = 5, kEventMenuTargetItem = 6, kEventMenuMatchKey = 7, kEventMenuEnableItems = 8, kEventMenuPopulate = 9, kEventMenuMeasureItemWidth = 100, kEventMenuMeasureItemHeight = 101, kEventMenuDrawItem = 102, kEventMenuDrawItemContent = 103, kEventMenuDispose = 1001, kEventMenuCalculateSize = 1004, -- menu content view events -- kEventMenuCreateFrameView = 1005, kEventMenuGetFrameBounds = 1006, kEventMenuBecomeScrollable = 1007, kEventMenuCeaseToBeScrollable = 1008, -- menu bar visibility events -- kEventMenuBarShown = 2000, kEventMenuBarHidden = 2001 } { * Menu context location flags * * Discussion: * Menu context location flags indicate the location of a menu in a * menu-related Carbon event. } const { * Indicates that this menu is inserted in the menubar, or is a * (directly or indirectly) a submenu of a menu that is inserted in * the menubar. If this flag is not set, the menu is a popup menu or * submenu of a popup. } kMenuContextMenuBar = 1 shl 0; { * Menu context type flags * * Discussion: * Menu context type flags indicate the type of a menu in a * menu-related Carbon event. } const { * Indicates that this menu is a pull-down menu inserted in the * menubar. } kMenuContextPullDown = 1 shl 8; { * Indicates that this menu is a popup menu being displayed by * PopUpMenuSelect. } kMenuContextPopUp = 1 shl 9; { * Indicates that this menu is a submenu of some other pull-down or * popup menu. } kMenuContextSubmenu = 1 shl 10; { * Menu context usage flags * * Discussion: * Menu context usage flags indicate the reason why a menu-related * Carbon event is being sent. } const { * Indicates that this Carbon event has been sent during a menubar * tracking session. } kMenuContextMenuBarTracking = 1 shl 16; { * Indicates that this Carbon event has been sent during a popup menu * tracking session. In Mac OS X 10.6 and later, * kMenuContextContextualMenu may also be set if the popup menu is a * contextual menu. } kMenuContextPopUpTracking = 1 shl 17; { * Indicates that this Carbon event has been sent during command key * matching. When this context flag is set, an event handler only * needs to update the command keys and enable state of its menu * items; it does not need to update menu item text or icons. } kMenuContextKeyMatching = 1 shl 18; { * Indicates that this Carbon event has been sent at idle time to * update the enabled state of the menus. Available on Mac OS X 10.1 * and later, and in CarbonLib 1.5 and later; on earlier releases, * the kMenuContextKeyMatching flag is set when an event is sent * during menu enabling. } kMenuContextMenuEnabling = 1 shl 19; { * Indicates that this Carbon event has been sent during during a * search for a menu item command ID by the * CountMenuItemsWithCommandID or GetIndMenuItemWithCommandID APIs. * When this context flag is set, an event handler only needs to * update the command IDs of its menu items; it does not need to * update menu item text, command keys, icons, or enable state. * Available on Mac OS X 10.2 and CarbonLib 1.6. } kMenuContextCommandIDSearch = 1 shl 20; { * Indicates that this Carbon event has been sent prior to inspection * of the menu contents. When this context flag is set, the menu is * not going to be displayed. Typically, this context flag is used * when a menu is inspected by the accessibility API or by the * Spotlight Help system. When this context flag is set, an event * handler may check the menu context content-update flags to * determine if any menu item content does not need to be updated. * Available on Mac OS X 10.5 and later. } kMenuContextInspection = 1 shl 22; { * Indicates that this Carbon event has been sent during display of a * contextual menu. When this flag is set, the * kMenuContextPopUpTracking flag will also be set (since contextual * menus are always also popup menus). Available in Mac OS X 10.6 and * later. } kMenuContextContextualMenu = 1 shl 23; { * Menu context content-update flags * * Discussion: * Menu context content-update flags indicate which parts of a * menu's content do not need to be updated in response to a * menu-related Carbon event. A Carbon event handler may use these * flags to avoid unnecessary work and optimize its handling of the * event. If a flag is not set, the event handler should generally * update the relevant state unless it knows from other menu context * flags that updating certain state is unnecessary (see comments * for menu context usage flags about which state can be ignored for * certain usages). These flags are available on Mac OS X 10.5 and * later. } const { * Indicates that the sender of the Carbon event does not need the * menu item text to be updated. } kMenuContextDontUpdateText = 1 shl 24; { * Indicates that the sender of the Carbon event does not need the * menu item command key to be updated. } kMenuContextDontUpdateKey = 1 shl 25; { * Indicates that the sender of the Carbon event does not need the * menu item icon to be updated. } kMenuContextDontUpdateIcon = 1 shl 26; { * Indicates that the sender of the Carbon event does not need the * menu item to be properly enabled or disabled. } kMenuContextDontUpdateEnabled = 1 shl 27; { * Summary: * Menu direction } const { * Indicates that the menu should be placed to the right of its * parent. } kHIMenuRightDirection = 0; { * Indicates that the menu should be placed to the left of its parent. } kHIMenuLeftDirection = 1; { * Indicates that the menu should be centered on its parent. } kHIMenuCenterDirection = 2; { * kEventClassMenu / kEventMenuBeginTracking * * Summary: * The user has begun tracking the menubar or a pop-up menu. * * Discussion: * This event is sent to all handlers registered for it. It is sent * first to the menu specified in the direct object parameter, if * any, and then to the user focus target. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeMenuRef) * The root of the menu hierarchy being tracked. If tracking a * popup menu, this parameter is the popup; if tracking the * menubar, this parameter is the root menu on Mac OS X, but * is NULL in CarbonLib. * * --> kEventParamCurrentMenuTrackingMode (in, typeMenuTrackingMode) * Indicates whether the user is tracking the menus using the * mouse or the keyboard. Contains either * kMenuTrackingModeMouse or kMenuTrackingModeKeyboard. * * --> kEventParamMenuContext (in, typeUInt32) * Menu context flags indicating what type of menu is being * tracked. This parameter is available on Mac OS X 10.1 and * later, and CarbonLib 1.5 and later. * * Result: * The handler may return userCanceledErr to stop menu tracking. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventMenuBeginTracking = 1; { * kEventClassMenu / kEventMenuEndTracking * * Summary: * The user has finished tracking the menubar or a popup menu * * Discussion: * This event is sent to all handlers registered for it. It is sent * first to the menu specified in the direct object parameter, if * any, and then to the user focus target. * * In Mac OS X 10.3 and later, when a menu tracking session ends, * the Menu Manager now sends kEventMenuEndTracking to every menu * that was opened during the session, in addition to the root menu. * This is done to allow menus with dynamic content to remove that * content at the end of menu tracking; for example, a menu * containing many IconRefs might wish to load the IconRefs * dynamically in response to a kEventMenuPopulate, and remove them * in response to kEventMenuEndTracking, to avoid the memory * overhead of keeping the IconRef data in memory while the menu is * not being displayed. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeMenuRef) * The root of the menu hierarchy being tracked. If tracking a * popup menu, this parameter is the popup; if tracking the * menubar, this parameter is the root menu on Mac OS X, but * is NULL in CarbonLib. * * --> kEventParamMenuContext (in, typeUInt32) * Menu context flags indicating what type of menu was being * tracked. This parameter is available on Mac OS X 10.1 and * later, and CarbonLib 1.5 and later. * * --> kEventParamMenuDismissed (in, typeUInt32) * Contains an indication of why menu tracking ended; this * will be one of the kHIMenuDismissedBy constants in Menus.h. * This parameter is available on Mac OS X 10.3 and later. * * --> kEventParamEventRef (in, typeEventRef) * Contains the event that caused the menu tracking session to * end (typically, a keyboard or mouse event, but potentially * other events as well). This parameter is available in Mac * OS X 10.5 and later, but is not guaranteed to be present in * all cases; check your return value from GetEventParameter, * and do not assume that the parameter is always available. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventMenuEndTracking = 2; { * kEventClassMenu / kEventMenuChangeTrackingMode * * Summary: * The user has switched from selecting a menu with the mouse to * selecting with the keyboard, or from selecting with the keyboard * to selecting with the mouse. * * Discussion: * This event is sent to all handlers registered for it. It is sent * first to the menu specified in the direct object parameter, and * then to the user focus target. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeMenuRef) * The root of the menu hierarchy being tracked. If tracking a * popup menu, this parameter is the popup; if tracking the * menubar, this parameter is the root menu. * * --> kEventParamCurrentMenuTrackingMode (in, typeMenuTrackingMode) * Indicates whether the user was previously tracking the * menus using the mouse or the keyboard. Contains either * kMenuTrackingModeMouse or kMenuTrackingModeKeyboard. * * --> kEventParamNewMenuTrackingMode (in, typeMenuTrackingMode) * Indicates whether the user is now tracking the menus using * the mouse or the keyboard. Contains either * kMenuTrackingModeMouse or kMenuTrackingModeKeyboard. * * --> kEventParamMenuContext (in, typeUInt32) * Menu context flags indicating what type of menu is being * tracked. * * Availability: * Mac OS X: in version 10.1 and later in Carbon.framework * CarbonLib: not available } const kEventMenuChangeTrackingMode = 3; { * kEventClassMenu / kEventMenuOpening * * Summary: * A menu is opening. * * Discussion: * This event is sent to all handlers registered for it. It is sent * each time that the menu is opened (i.e., more than once during a * given tracking session if the user opens the menu multiple * times). It is sent before the menu is actually drawn, so you can * update the menu contents (including making changes that will * alter the menu size) and the new contents will be drawn correctly. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeMenuRef) * The menu being opened. * * --> kEventParamMenuFirstOpen (in, typeBoolean) * Whether this is the first time this menu has been opened * during this menu tracking session. * * --> kEventParamMenuContext (in, typeUInt32) * The context in which this menu is opening. Available on Mac * OS X and CarbonLib 1.5 and later. * * Result: * On Mac OS X, the handler may return userCanceledErr to prevent * this menu from opening * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventMenuOpening = 4; { * kEventClassMenu / kEventMenuClosed * * Summary: * A menu has been closed. * * Discussion: * This event is sent to all handlers registered for it. It is sent * after the menu is hidden. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeMenuRef) * The menu being closed. * * --> kEventParamMenuContext (in, typeUInt32) * The context in which this menu is closing. Available on Mac * OS X 10.1 and later, and CarbonLib 1.5 and later. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventMenuClosed = 5; { * kEventClassMenu / kEventMenuTargetItem * * Summary: * The mouse is moving over a particular menu item. * * Discussion: * This event is sent to all handlers registered for it. It is sent * for both enabled and disabled items. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeMenuRef) * The menu being tracked. * * --> kEventParamMenuItemIndex (in, typeMenuItemIndex) * The menu item under the mouse. * * --> kEventParamMenuCommand (in, typeMenuCommand) * The command ID associated with this menu item. * * --> kEventParamMenuContext (in, typeUInt32) * The context in which this menu being tracked. Available on * Mac OS X 10.1 and later, and CarbonLib 1.5 and later. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventMenuTargetItem = 6; { * kEventClassMenu / kEventMenuMatchKey * * Summary: * A menu is about to be examined for items that match a command key * event. * * Discussion: * A handler for this event may perform its own command key matching * and override the Menu ManagerÕs default matching algorithms. * Returning noErr from your handler indicates that you have found a * match. The handler for this event should not examine submenus of * this menu for a match; a separate event will be sent for each * submenu. * * Handlers for this event must be installed directly on the menu * containing the item to be matched. To improve performance of * command key matching, the Menu Manager only sends this event if * the menu itself has a handler; if a handler for this event is * installed on any other event target, it will not receive the * event. * * In CarbonLib and Mac OS X through version 10.3, the Menu Manager * sends a kEventMenuEnableItems event to the menu before sending * kEventMenuMatchKey. In Mac OS X 10.4 and later, the Menu Manager * no longer sends kEventMenuEnableItems (or the resulting * kEventCommandUpdateStatus events) to the menu; a handler for * kEventMenuMatchKey is expected to determine on its own whether a * matching menu item is enabled. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeMenuRef) * The menu being searched for a command key match. * * --> kEventParamEventRef (in, typeEventRef) * The keyboard input event that should be checked for a * match. Currently this event is always kEventRawKeyDown, but * in the future it may be kEventTextInputUnicodeForKeyEvent. * When called from IsMenuKeyEvent, this parameter contains * the EventRef that was passed to IsMenuKeyEvent; when called * from MenuKey or MenuEvent, this parameter contains an event * created from the information passed to MenuKey or * MenuEvent. Note that in the MenuKey case, no virtual * keycode (kEventParamKeyCode) or key modifiers * (kEventParamKeyModifiers) will be available. * * --> kEventParamMenuEventOptions (in, typeMenuEventOptions) * Options from the MenuEventOptions enum that control how the * menu should be searched for a command key. This parameter * contains the options that were passed to IsMenuKeyEvent, or * 0 if called from MenuKey or MenuEvent. The only option that * your handler will need to obey is * kMenuEventIncludeDisabledItems; other options are * irrelevant for an event handler. * * --> kEventParamMenuContext (in, typeUInt32) * The context in which this menu is being searched for a * command key. Available on Mac OS X 10.1 and later, and * CarbonLib 1.5 and later. * * <-- kEventParamMenuItemIndex (out, typeMenuItemIndex) * On exit, contains the menu item index that matched the * event. * * Result: * If your handler finds a match, it should set the * kEventParamMenuItemIndex parameter to contain the item index of * the matching item, and return noErr. If it does not find a match, * it should return menuItemNotFoundErr. Any other return value will * cause the Menu Manager to use its default command key matching * algorithm for this menu. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventMenuMatchKey = 7; { * kEventClassMenu / kEventMenuEnableItems * * Summary: * A request that the items in the menu be properly enabled or * disabled according to the current state of the application. * * Discussion: * This event is sent from inside MenuKey, MenuEvent, and * IsMenuKeyEvent before those APIs examine the menu for an item * that matches a keyboard event. It is also sent during menu * tracking before a menu is first made visible; it is sent * immediately after kEventMenuOpening, once per menu per menu * tracking session. It is also sent to the top-level menus in the * menubar when the application is idle after user input has * occurred, to allow the menu titles to be enabled or disabled * appropriately according to the current user focus. You can * distinquish between all these cases by examining the contents of * the kEventParamMenuContext parameter. * * If you install an event handler for kEventCommandProcess, you * should also install a handler for either kEventMenuEnableItems or * kEventCommandUpdateStatus. This is necessary because the Carbon * event system will attempt to match command keys against the * available menus before returning the keyboard event to your * application via WaitNextEvent. If you have menu command event * handlers installed for your menu items, your handlers will be * called without your ever receiving the keyboard event or calling * MenuKey/MenuEvent/IsMenuKeyEvent yourself. Therefore, you have no * opportunity to enable your menu items properly other than from a * kEventMenuEnableItems or kEventCommandUpdateStatus handler. * * * It is not necessary to handle this event if you do not install * kEventCommandProcess handlers for your menu items; in that case, * the command key event will be returned from WaitNextEvent or * ReceiveNextEvent as normal, and you can set up your menus before * calling MenuKey/MenuEvent/ IsMenuKeyEvent. * * This event is sent first to the target menu, and then to the user * focus target. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeMenuRef) * The menu being enabled. * * --> kEventParamEnableMenuForKeyEvent (in, typeBoolean) * Indicates whether this menu should be enabled for key event * matching (true) or because the menu itself is about to * become visible (false). If true, only the item enable * state, command key, command key modifiers, and (optionally) * the command key glyph need to be correct. If false, the * entire menu item contents must be correct. This may be * useful if you have custom menu content that is expensive to * prepare. * * --> kEventParamMenuContext (in, typeUInt32) * The context in which this menu is being enabled. Available * on Mac OS X and CarbonLib 1.3.1 and later. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventMenuEnableItems = 8; { * kEventClassMenu / kEventMenuPopulate * * Summary: * kEventMenuPopulate is intended to be handled by applications that * dynamically create their menu contents just-in-time before the * menu is displayed. A handler for this event can add items to tbe * menu that will be displayed or searched for a command key. * * Discussion: * This event is sent to all handlers registered for it. Previously, * kEventMenuOpening was recommended for the purpose of dynamically * updating menu content. kEventMenuPopulate is now recommended * because it will be sent by the Menu Manager before it searches a * menu for a matching command key, to allow a handler to * dynamically add menu items that may have command key equivalents * to the menu; kEventMenuOpening is only sent before the menu is * displayed. kEventMenuPopulate is also sent just before * kEventMenuOpening as a menu is being displayed. Finally, * kEventMenuPopulate is only sent once per menu tracking session * for a given menu, even if that menu is closed and opened multiple * times by the user; kEventMenuOpening is sent each time that the * menu is displayed. * * You can distinguish the command-key case from the * menu-being-displayed case by examining the contents of the * kEventParamMenuContext parameter; the kMenuContextKeyMatching * flag will be set if the event is sent during command key * matching, and either the kMenuContextMenuBarTracking or * kMenuContextPopUpTracking flags will be sent if the event is sent * before actual display of the menu. * * In Mac OS X 10.2 and CarbonLib 1.6, kEventMenuPopulate is also * sent to menus before the menu is searched for a command ID by the * CountMenuItemsWithCommandID and GetIndMenuItemWithCommandID APIs. * You can distinguish this case by checking for the * kMenuContextCommandIDSearch flag in the kEventParamMenuContext * parameter. In this case, the event also includes a * kEventParamMenuCommand parameter with the command ID being * searched for as the event parameter data. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeMenuRef) * The menu to be populated. * * --> kEventParamMenuContext (in, typeUInt32) * The context in which this menu is being populated. * * --> kEventParamMenuCommand (in, typeMenuCommand) * If this event is sent by CountMenuItemsWithCommandID or * GetIndMenuItemWithCommandID, this parameter contains the * command ID for which the API is searching. Available on Mac * OS X 10.2 and CarbonLib 1.6. * * Availability: * Mac OS X: in version 10.1 and later in Carbon.framework * CarbonLib: in CarbonLib 1.5 and later } const kEventMenuPopulate = 9; { * kEventClassMenu / kEventMenuDispose * * Summary: * Sent when a menu definition should disconnect itself from a menu. * * Discussion: * This event is sent to all handlers registered for it. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeMenuRef) * The menu being destroyed. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventMenuDispose = 1001; { * kEventClassMenu / kEventMenuMeasureItemWidth * * Summary: * Requests measurement of the width of a menu item. * * Discussion: * Sent by the standard menu definition when a menu item has the * kMenuItemAttrCustomDraw attribute. Handlers for this event should * be installed directly on the menu. A handler for this event may * respond by providing a customized width for the menu item. If no * handler is installed, the standard menu definition provides a * default handler that will return the standard width for the item. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeMenuRef) * The menu that is being measured. * * --> kEventParamMenuItemIndex (in, typeMenuItemIndex) * The menu item that is being measured. * * <-- kEventParamMenuItemWidth (out, typeSInt16) * On exit, contains the menu item width. * * Availability: * Mac OS X: in version 10.1 and later in Carbon.framework * CarbonLib: in CarbonLib 1.5 and later } const kEventMenuMeasureItemWidth = 100; { * kEventClassMenu / kEventMenuMeasureItemHeight * * Summary: * Requests measurement of the height of a menu item. * * Discussion: * Sent by the standard menu definition when a menu item has the * kMenuItemAttrCustomDraw attribute. Handlers for this event should * be installed directly on the menu. A handler for this event may * respond by providing a customized height for the menu item. If no * handler is installed, the standard menu definition provides a * default handler that will return the standard height for the item. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeMenuRef) * The menu that is being measured. * * --> kEventParamMenuItemIndex (in, typeMenuItemIndex) * The menu item that is being measured. * * <-- kEventParamMenuItemHeight (out, typeSInt16) * On exit, contains the menu item height. * * Availability: * Mac OS X: in version 10.1 and later in Carbon.framework * CarbonLib: in CarbonLib 1.5 and later } const kEventMenuMeasureItemHeight = 101; { * kEventClassMenu / kEventMenuDrawItem * * Summary: * Requests drawing of an entire menu item, including its background. * * Discussion: * Sent by the standard menu definition when a menu item has the * kMenuItemAttrCustomDraw attribute. Handlers for this event should * be installed directly on the menu. A handler for this event may * respond by completely overriding the drawing of the menu item. * The item should be drawn into the current port if using * QuickDraw, or into the provided CGContextRef if using * CoreGraphics. If no handler is installed, the standard menu * definition provides a default handler that calls * DrawThemeMenuItem to draw the menu item background and content. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeMenuRef) * The menu being drawn. * * --> kEventParamCurrentBounds (in, typeQDRectangle) * The bounds of the menu, in global coordinates * * --> kEventParamMenuItemIndex (in, typeMenuItemIndex) * The menu item being drawn. * * --> kEventParamMenuItemBounds (in, typeQDRectangle) * The bounds of the menu item, in local coordinates of the * current port. * * --> kEventParamMenuVirtualTop (in, typeSInt32) * The virtual top coordinate of the menu, in global * coordinates. * * --> kEventParamMenuVirtualBottom (in, typeSInt32) * The virtual bottom coordinate of the menu, in global * coordinates. * * --> kEventParamMenuDrawState (in, typeThemeMenuState) * The ThemeMenuState of the menu. * * --> kEventParamMenuItemType (in, typeThemeMenuItemType) * The type of menu item. * * --> kEventParamCGContextRef (in, typeCGContextRef) * The CG context in which the menu item should be drawn. Note * that this context has Cartesian coordinates, with (0,0) at * the bottom left, while the item bounds passed in the event * has QuickDraw coordinates, with (0,0) at the top left. To * align the context coordinates with the item bounds, use the * value stored in the kEventParamMenuContextHeight parameter * (if available), or else the height of the current port to * flip the context with CGContextTranslateCTM( context, 0, * height ) and CGContextScaleCTM( context, 1, -1 ). * * --> kEventParamMenuContextHeight (in, typeCGFloat) * The height of the drawing surface to which the CGContext * draws. You can use the value in this parameter to flip the * orientation of the context, or to adjust the coordinates of * the rectangle parameters in this event. This parameter is * available on Mac OS X 10.5 and later. * * <-- kEventParamMenuMarkBounds (out, typeQDRectangle) * On exit, contains the bounds of the menu item mark * character. Not present if the item has no mark. Added to * the event by the standard menu definitionÕs handler, if the * event is allowed to pass through. * * <-- kEventParamMenuIconBounds (out, typeQDRectangle) * On exit, contains the bounds of the menu item icon. Not * present if the item has no icon. Added to the event by the * standard menu definitionÕs handler, if the event is allowed * to pass through. * * <-- kEventParamMenuTextBounds (out, typeQDRectangle) * On exit, contains the bounds of the menu itemÕs text. Added * to the event by the standard menu definitionÕs handler, if * the event is allowed to pass through. * * <-- kEventParamMenuTextBaseline (out, typeSInt16) * On exit, contains the baseline of the menu itemÕs text. * Added to the event by the standard menu definitionÕs * handler, if the event is allowed to pass through. * * <-- kEventParamMenuCommandKeyBounds (out, typeQDRectangle) * On exit, contains the bounds of the menu item command key. * Not present if the item has no command key. Added to the * event by the standard menu definitionÕs handler, if the * event is allowed to pass through. * * Availability: * Mac OS X: in version 10.1 and later in Carbon.framework * CarbonLib: in CarbonLib 1.5 and later } const kEventMenuDrawItem = 102; { * kEventClassMenu / kEventMenuDrawItemContent * * Summary: * Requests drawing of a menu itemÕs content: its text, command key, * icon, etc. * * Discussion: * Sent by the standard menu definition when a menu item has the * kMenuItemAttrCustomDraw attribute. Handlers for this event should * be installed directly on the menu. A handler for this event may * respond by overriding the drawing of the menu item content: the * mark character, icon, text, and command key information. At the * time when this event is sent, the background of the menu item has * already been drawn using the standard system appearance, and if * the item is selected, the background is drawn with a hilite. The * item should be drawn into the current port if using QuickDraw, or * into the provided CGContextRef if using CoreGraphics. If no * handler is installed, the standard menu definition provides a * default handler that draws the standard menu item content. The * standard handler also adds event parameters to the event * indicating the bounding boxes of the different portions of the * menu item content (mark, icon, text, and command keys), and an * event parameter with the baseline of the menu item text; this * allows handlers to use CallNextEventHandler to call through to * the standard system handler, and then modify the system * appearance by drawing on top of the standard content. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeMenuRef) * The menu being drawn. * * --> kEventParamMenuItemIndex (in, typeMenuItemIndex) * The menu item being drawn. * * --> kEventParamMenuItemBounds (in, typeQDRectangle) * The bounds of the menu item, in local coordinates of the * current port. * * --> kEventParamDeviceDepth (in, typeSInt16) * The bit depth of the GDevice on which the menu is being * drawn. * * --> kEventParamDeviceColor (in, typeBoolean) * Whether the GDevice on which the menu is being drawn is in * black&white or color mode. * * --> kEventParamCGContextRef (in, typeCGContextRef) * The CG context in which the menu item should be drawn. Note * that this context has Cartesian coordinates, with (0,0) at * the bottom left, while the item bounds passed in the event * has QuickDraw coordinates, with (0,0) at the top left. To * align the context coordinates with the item bounds, use the * value stored in the kEventParamMenuContextHeight parameter * (if available), or else the height of the current port to * flip the context with CGContextTranslateCTM( context, 0, * height ) and CGContextScaleCTM( context, 1, -1 ). * * --> kEventParamMenuContextHeight (in, typeCGFloat) * The height of the drawing surface to which the CGContext * draws. You can use the value in this parameter to flip the * orientation of the context, or to adjust the coordinates of * the rectangle parameters in this event. This parameter is * available on Mac OS X 10.5 and later. * * <-- kEventParamMenuMarkBounds (out, typeQDRectangle) * On exit, contains the bounds of the menu item mark * character. Not present if the item has no mark. Added to * the event by the standard menu definitionÕs handler, if the * event is allowed to pass through. * * <-- kEventParamMenuIconBounds (out, typeQDRectangle) * On exit, contains the bounds of the menu item icon. Not * present if the item has no icon. Added to the event by the * standard menu definitionÕs handler, if the event is allowed * to pass through. * * <-- kEventParamMenuTextBounds (out, typeQDRectangle) * On exit, contains the bounds of the menu itemÕs text. Added * to the event by the standard menu definitionÕs handler, if * the event is allowed to pass through. * * <-- kEventParamMenuTextBaseline (out, typeSInt16) * On exit, contains the baseline of the menu itemÕs text. * Added to the event by the standard menu definitionÕs * handler, if the event is allowed to pass through. * * <-- kEventParamMenuCommandKeyBounds (out, typeQDRectangle) * On exit, contains the bounds of the menu item command key. * Not present if the item has no command key. Added to the * event by the standard menu definitionÕs handler, if the * event is allowed to pass through. * * Availability: * Mac OS X: in version 10.1 and later in Carbon.framework * CarbonLib: in CarbonLib 1.5 and later } const kEventMenuDrawItemContent = 103; { * kEventClassMenu / kEventMenuCalculateSize * * Summary: * Requests that a menu calculate its total size. * * Discussion: * Sent by CalcMenuSize to request that the menu calculate its size. * The Menu Manager provides a default handler for all menus that * calls the menu's MDEF or menu content view to determine the menu * size. Applications will typically not need to handle this event; * a custom menu definition or menu content view should use * kMenuSizeMsg or kEventControlGetOptimalBounds to calculate its * size. * * Note that if the menu uses an MDEF, the MDEF will set the menu's * width and height in response to kMenuSizeMsg. The default handler * for this event saves the old width and height before calling the * MDEF and restores them afterwards. CalcMenuSize will set the * final menu width and height based on the dimensions returned from * this event; applications may override this event to customize the * width or height of a menu by modifying the kEventParamDimensions * parameter. * * This event is sent only to the menu, and is not propagated past * it. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeMenuRef) * The menu being measured. * * --> kEventParamControlRef (in, typeControlRef) * If the menu uses a content view, this parameter contains * the HIViewRef that should calculate the menu's size. This * parameter will not be present if the menu uses an MDEF. * * --> kEventParamGDevice (in, typeGDHandle) * If the menu uses an MDEF, this parameter contains the * GDevice on which the menu will be displayed. This parameter * will not be present if the menu uses a content view. * * --> kEventParamAvailableBounds (in, typeQDRectangle) * If the menu uses an MDEF, this parameter contains a * bounding rect in global coordinates inside of which the * menu should be displayed. This parameter is optional and * may not be present in all instances of this event; if not * present, the GDevice's bounds should be used instead. This * parameter will not be present if the menu uses a content * view. * * <-- kEventParamDimensions (out, typeHISize) * On exit, contains the menu's size. * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available } const kEventMenuCalculateSize = 1004; { * kEventClassMenu / kEventMenuCreateFrameView * * Summary: * Requests that a menu content view create the HIView that will * used to draw the menu window frame. * * Discussion: * The HIMenuView class provides a default handler for this event * that creates an instance of the standard menu window frame view. * * * This event is sent only to the menu content view, and is not * propagated past the view. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamEventRef (in, typeEventRef) * The initialization event that should be used to create the * view. A handler for this event may add its own parameters * to this event. * * --> kEventParamMenuType (in, typeThemeMenuType) * The type of menu frame (pull-down, popup, or hierarchical) * that is needed. * * <-- kEventParamMenuFrameView (out, typeControlRef) * On exit, contains the newly created menu frame view. * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available } const kEventMenuCreateFrameView = 1005; { * kEventClassMenu / kEventMenuGetFrameBounds * * Summary: * Requests that a menu content view calculate the bounding rect, in * global coordinates, of the menu window frame that should contain * the menu. * * Discussion: * This event is sent by the Menu Manager before displaying * pull-down, popup, and hierarchical menus. It provides an * opportunity for the menu content view to determine the position * of the menu frame based on the position of the menu title, parent * menu item, or popup menu location. * * The HIMenuView class provides a default handler for this event * that calculates an appropriate location based on the bounds of * the menu, the available screen space, and the frame metrics of * the menu window content view. * * This event is sent only to the menu content view, and is not * propagated past the view. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamMenuType (in, typeThemeMenuType) * The type of menu (pull-down, popup, or hierarchical) that * is being displayed. * * --> kEventParamMenuIsPopup (in, typeBoolean) * Whether this menu originated from a popup menu. Primarily * useful to distinguish between hierarchical menus that are * submenus of pull-down menus, and hierarchical menus that * are submenus of popup menus. * * --> kEventParamMenuFrameView (in, typeControlRef) * The menu window frame view. * * --> kEventParamMenuDirection (in, typeMenuDirection) * The suggested direction (left or right) which the view * should attempt to use when positioning the menu window. For * pull-down menus, this will typically be * kHIMenuRightDirection; for hierarchical menus, it will be * the same direction as the parent menu. * * --> kEventParamMenuItemBounds (in, typeHIRect) * The bounds, in global coordinates, of the parent menu title * (for pull-down menus), the parent menu item (for * hierarchical menus), or the popup location (for popup * menus). * * --> kEventParamDisplayDevice (in, typeCGDisplayID) * The display device on which the menu should be displayed. * On Mac OS X 10.3 and later, this parameter is available as * a GDHandle using typeGDHandle; on Mac OS X 10.5 and later, * this parameter is also available as a CGDirectDisplayID * using typeCGDisplayID. * * --> kEventParamAvailableBounds (in, typeHIRect) * The available bounds, in global coordinates, inside which * the menu should be displayed. The menu should not extend * outside of these bounds. * * --> kEventParamParentMenu (in, typeMenuRef) * Only available when kEventParamMenuType is * kThemeMenuTypeHierarchical. The parent menu of this menu. * * --> kEventParamParentMenuItem (in, typeMenuItemIndex) * Only available when kEventParamMenuType is * kThemeMenuTypeHierarchical. The parent menu item of this * menu. * * --> kEventParamMenuPopupItem (in, typeMenuItemIndex) * Only available when kEventParamMenuType is * kThemeMenuTypePopUp. The item in the menu that should be * positioned at the popup location, or zero if no item should * be positioned there. * * <-- kEventParamBounds (out, typeHIRect) * On exit, contains the bounding rect, in global coordinates, * of the menu window. The handler should add this parameter * to the event. * * <-- kEventParamOrigin (out, typeHIPoint) * On exit, contains the origin to which the menu content view * should be scrolled before the menu is displayed. * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available } const kEventMenuGetFrameBounds = 1006; { * kEventClassMenu / kEventMenuBecomeScrollable * * Summary: * Requests that a menu content view prepare to be scrollable, by * installing the appropriate event handlers, timers, etc. * * Discussion: * This event is sent by the Menu Manager when a menu becomes the * most recently opened menu in the menu hierarchy. It is an * indication that this menu content view is now a candidate for * scrolling. * * The Menu Manager provides a default handler for this event that * installs event handlers to provide automatic scrolling behavior * for HIView-based menus. * * If a menu content view does not wish to use the Menu Manager's * default scrolling support, it can override this event and return * noErr to prevent the event from being propagated to the Menu * Manager's default handler. * * This event is sent only to the menu content view, and is not * propagated past the view. * * Mac OS X threading: * Not thread safe * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available } const kEventMenuBecomeScrollable = 1007; { * kEventClassMenu / kEventMenuCeaseToBeScrollable * * Summary: * Requests that a menu content view cease to be scrollable. * * Discussion: * This event is sent by the Menu Manager when a menu ceases to be * the most recently opened menu. This occurs when the menu is * closed, or when a submenu of the most recently opened menu is * opened. It is an indication that this menu content view is no * longer a candidate for scrolling. * * The Menu Manager provides a default handler for this event that * removes event handlers installed in response to * kEventMenuBecomeScrollable. * * This event is sent only to the menu content view, and is not * propagated past the view. * * Mac OS X threading: * Not thread safe * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available } const kEventMenuCeaseToBeScrollable = 1008; { * kEventClassMenu / kEventMenuBarShown * * Summary: * Notification that the menubar in the frontmost process has been * shown. * * Discussion: * This event is sent to all handlers registered for it. This event * will be sent to registered handlers in all processes when the * front process shows its menubar. This event is sent only to the * application target. * * Mac OS X threading: * Not thread safe * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available } const kEventMenuBarShown = 2000; { * kEventClassMenu / kEventMenuBarHidden * * Summary: * Notification that the menubar in the frontmost process has been * hidden. * * Discussion: * This event is sent to all handlers registered for it. This event * will be sent to registered handlers in all processes when the * front process hides its menubar. This event is sent only to the * application target. * * Mac OS X threading: * Not thread safe * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available } const kEventMenuBarHidden = 2001; {--------------------------------------------------------------------------------------} { Command Events } {--------------------------------------------------------------------------------------} { kEventClassCommand quick reference: kEventCommandProcess = 1, kEventCommandUpdateStatus = 2 } { * kEventClassCommand / kEventCommandProcess * * Summary: * A command has been invoked and the application should handle it. * * Discussion: * This event is sent when the user chooses a menu item or clicks a * control. Any menu item selection, from either the menubar, a * popup or contextual menu, or a popup or bevel button control, * will cause this event to be sent; if the menu item does not have * a command ID, the commandID field of the HICommand parameter will * be zero, but the event will still contain a valid MenuRef and * MenuItemIndex. Controls will send this event only if the control * has a non-zero command ID set with SetControlCommandID. * * Some senders of this event will also include the modifier keys * that were pressed by the user when the command was invoked, but * this parameter is optional and may not be present in all * instances of this event. * * When a command event is sent from a menu, a MenuContext parameter * will be included on Mac OS X 10.2 and CarbonLib 1.6, indicating * whether the command was sent from a menu in the menubar * (kMenuContextMenuBar will be set) or from a popup menu * (kMenuContextMenuBar will not be set). The MenuContext parameter * also indicates whether the event was sent by a selection of a * menu item with the mouse (kMenuContextMenuBarTracking or * kMenuContextPopUpTracking will be set), or by a command key press * (kMenuContextKeyMatching will be set). If you need to determine * the source of a command event on a Carbon release prior to Mac OS * X 10.2 or CarbonLib 1.6, we recommend installing a * kEventMenuEnableItems handler on each menu and caching the * MenuContext parameter in the EnableItems event in a menu * property; when you receive the CommandProcess event, look up the * cached MenuContext. * * It is essential that your event handler for this event return * eventNotHandledErr for any command events that you do not handle, * especially for commands that are sent from menus attached to * popup or bevel button controls; if, for example, you return noErr * for command events sent in response to a menu selection from a * popup button, the Menu Manager will return zero from * PopUpMenuSelect, and the popup button control will not know that * an item was selected from the popup menu and will not redraw with * the new selection. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeHICommand) * The command to be handled. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the command * was invoked by the user. This parameter is optional and may * not be present in all instances of this event. * * --> kEventParamMenuContext (in, typeUInt32) * If the command was contained in a menu, information about * the menu. This parameter is optional and may not be present * in all instances of this event. Available in Mac OS X 10.2 * and CarbonLib 1.6, and later. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventCommandProcess = 1; { * kEventClassCommand / kEventCommandUpdateStatus * * Summary: * A command-generating user interface element requires updating. * * Discussion: * When you receive this event, you should update the necessary UI * elements in your application to reflect the current status of the * command. For example, if the command has the kHICommandFromMenu * bit set, you should update the menu item state, menu item text, * and so on, to reflect the current reality in your application. If * the menu item is the "Undo" item, and the last editing change to * the document was a Cut operation, then you might set the text to * "Undo Cut" and enable the menu item. * * Currently, this event is only sent for menu items; it is not used * to update the status of controls. * * Note that when responding to this event, you should only update * the status of the single user interface element (a menu item, for * example) described by the HICommand structure; you should not * update the status of the entire menu or of all menus in the * menubar. You will receive a separate UpdateStatus event for each * menu item in a menu, and each item should be updated * individually. When updating a menu item, you should generally not * use Enable/DisableMenuCommand; these APIs search the entire menu * hierarchy for the command ID. Instead, just call * Enable/DisableMenuItem directly, passing the menu and menu item * index that are provided to you in the HICommand structure. * * * You may wish to optimize your handling of the UpdateStatus event * by examining the MenuContext parameter to the event. This * parameter indicates the context in which the command requires * updating. For example, if the menu context parameter has the * kMenuContextKeyMatching bit set, you know that the update request * is being sent in while search for a menu item that matches a * command key. This knowledge can help you avoid unnecessary work; * if your menu item for this command has no command key, for * example, you can ignore this event when the KeyMatching bit is * set because your menu item will never match a command key * anyways, regardless of whether it is enabled or disabled. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeHICommand) * The command to be updated. * * --> kEventParamMenuContext (in, typeUInt32) * If the command was contained in a menu, information about * the menu and the context of the command updating request. * This parameter is optional and may not be present in all * instances of this event. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventCommandUpdateStatus = 2; { HI Commands } { * Summary: * Common command IDs } const { * The OK button in a dialog or alert. } kHICommandOK = FourCharCode('ok '); { * The Cancel button in a dialog or alert. } kHICommandCancel = FourCharCode('not!'); { * The application should quit. The default application handler * responds to this command by generating a kAEQuit AppleEvent. } kHICommandQuit = FourCharCode('quit'); { * The application should quit, and any file-based document windows * currently open should be closed when the application is next * launched. This command is assigned to the "Quit and Discard * Windows" menu item in Mac OS X 10.7 in all applications. The * default application handler responds to this command by generating * a kAEQuit AppleEvent, and discarding the list of currently open * document windows. When the application is next launched, no * documents will be reopened. Available on Mac OS X 10.7 and later. } kHICommandQuitAndDiscardWindows = FourCharCode('qudw'); { * The application should quit, and any file-based document windows * currently open should be reopened when the application is next * launched. This command is assigned to the "Quit and Keep Windows" * menu item in Mac OS X 10.7 in all applications. The default * application handler responds to this command by generating a * kAEQuit AppleEvent, and by making a note of the currently open * document windows. When the application is next launched, any * documents that were open at quit will be automatically reopened. * Available on Mac OS X 10.7 and later. } kHICommandQuitAndKeepWindows = FourCharCode('qukw'); { * The last editing operation should be undone. } kHICommandUndo = FourCharCode('undo'); { * The last editing operation should be redone. } kHICommandRedo = FourCharCode('redo'); { * The selected items should be cut. } kHICommandCut = FourCharCode('cut '); { * The selected items should be copied. } kHICommandCopy = FourCharCode('copy'); { * The contents of the clipboard should be pasted. } kHICommandPaste = FourCharCode('past'); { * The selected items should be deleted. } kHICommandClear = FourCharCode('clea'); { * All items in the active window should be selected. } kHICommandSelectAll = FourCharCode('sall'); { * The application should be hidden. The Menu Manager will respond to * this command automatically; your application does not need to * handle it. } kHICommandHide = FourCharCode('hide'); { * Other applications should be hidden. The Menu Manager will respond * to this command automatically; your application does not need to * handle it. } kHICommandHideOthers = FourCharCode('hido'); { * All applications should become visible. The Menu Manager will * respond to this command automatically; your application does not * need to handle it. } kHICommandShowAll = FourCharCode('shal'); { * The Preferences menu item has been selected. } kHICommandPreferences = FourCharCode('pref'); { * The active window should be zoomed in or out. The default * application handler will respond to this event automatically; your * application does not need to handle it, but you may want to * install a Carbon event handler for kEventWindowGetIdealSize to * return the ideal size for your document windows. } kHICommandZoomWindow = FourCharCode('zoom'); { * The active window should be minimized. The default application * handler will respond to this event automatically; your application * does not need to handle it. } kHICommandMinimizeWindow = FourCharCode('mini'); { * All collapsable windows should be minimized. The default * application handler will respond to this event automatically; your * application does not need to handle it. } kHICommandMinimizeAll = FourCharCode('mina'); { * The active window should be maximized. Only sent on Mac OS 9. The * default application handler will respond to this event * automatically; your application does not need to handle it. } kHICommandMaximizeWindow = FourCharCode('maxi'); { * All collapsable windows should be maximized. This command is not * sent or handled on Mac OS X. } kHICommandMaximizeAll = FourCharCode('maxa'); { * All document-class windows should be arranged in a stack. The * default application handler will respond to this event * automatically; your application does not need to handle it. } kHICommandArrangeInFront = FourCharCode('frnt'); { * All windows of this application should be brought in front of * windows from other applications. Only sent on Mac OS X. The * default application handler will respond to this event * automatically; your application does not need to handle it. } kHICommandBringAllToFront = FourCharCode('bfrt'); { * This command ID is used as a placeholder to mark the separator * item dividing the Zoom/Minimize/Maximize/Arrange menu items in the * standard Window menu from the menu items listing the visible * windows. If you need to add your own menu items to the standard * Window menu before the window list section, you can look for the * menu item with this command ID using GetIndMenuItemWithCommandID, * and insert your menu items before the item with this ID. } kHICommandWindowListSeparator = FourCharCode('wldv'); { * This command ID is used as a placeholder to mark the end of the * window list section of the standard Window menu. If you need to * add your own menu items to the standard Window menu after the * window list section, you can look for the menu item with this * command ID using GetIndMenuItemWithCommandID, and insert your * items after the item with this ID. } kHICommandWindowListTerminator = FourCharCode('wlst'); { * A window in the standard Window menu has been selected and should * be activated. In Mac OS X 10.3, this command is also sent by the * toolbox whenever it needs to activate a window in your * application; for example, it is used when a window is selected * from the application's Dock menu, and when a window that uses the * standard window event handler is clicked. The default application * handler will respond to this event automatically; your application * does not need to handle it. * * This event is not always sent to the window being selected. When a * window item from the standard window menu is chosen, a * kEventCommandProcess event with kHICommandSelectWindow is sent to * the user focus window, as normal for menu-generated commands, * rather than to the window that should be selected. In Mac OS X * 10.5 and later, your application can determine which window would * be selected in this case by checking for a menu item property on * the originating menu item in the standard window menu. The * originating item is recorded in the menuRef and menuItemIndex * fields of the HICommand structure. This item will have a property * of kHIWindowMenuCreator/kHIWindowMenuWindowTag containing the * window that will be selected. } kHICommandSelectWindow = FourCharCode('swin'); { * The Rotate Windows hotkey (cmd-~ by default) has been pressed, and * non-floating windows should be rotated so that the window after * the active window is activated. The default application handler * will respond to this event automatically; your application does * not need to handle it. } kHICommandRotateWindowsForward = FourCharCode('rotw'); { * The Rotate Windows hotkey (cmd-~ by default) has been pressed, and * non-floating windows should be rotated so that the window before * the active window is activated. The default application handler * will respond to this event automatically; your application does * not need to handle it. } kHICommandRotateWindowsBackward = FourCharCode('rotb'); { * The floating window focus hotkey (ctl-F6 by default) has been * pressed, and floating windows should be rotated so that the window * after the focused window is activated. The default application * handler will respond to this event automatically; your application * does not need to handle it. } kHICommandRotateFloatingWindowsForward = FourCharCode('rtfw'); { * The floating window focus hotkey (ctl-F6 by default) has been * pressed, and floating windows should be rotated so that the window * before the focused window is activated. The default application * handler will respond to this event automatically; your application * does not need to handle it. } kHICommandRotateFloatingWindowsBackward = FourCharCode('rtfb'); { * The window should enter full screen mode if not currently in full * screen mode, or vice-versa. The default application handler will * respond to this event automatically; your application does not * need to handle it. The default handler will also set the text of a * menu item with this command ID automatically to either "Enter Full * Screen" or "Exit Full Screen", and disable or enable the menu item * appropriately, depending on the fullscreen support and state of * the focused window. Available on Mac OS X 10.7 and later. } kHICommandToggleFullScreen = FourCharCode('fsm '); { * The About menu item has been selected. In Mac OS X 10.3 and later, * RunApplicationEventLoop installs a handler for this command ID on * the application target, and will handle this event automatically * by calling HIAboutBox. Your application may install its own * handler if it wishes to display a customized about box. } kHICommandAbout = FourCharCode('abou'); { * A new document or item should be created. } kHICommandNew = FourCharCode('new '); { * The user wants to open an existing document. } kHICommandOpen = FourCharCode('open'); { * The active window should be closed. This command would typically * be generated by a Close menu item. On Mac OS X 10.3 and later, the * default application handler responds to this command by sending a * kEventWindowClose event; on earlier systems, only the standard * window event handler responded to this event. } kHICommandClose = FourCharCode('clos'); { * All active windows should be closed. The default application * handler responds to this command by sending a kEventWindowCloseAll * event to the frontmost document window. A "Close All" menu item * with this command ID is automatically added to the File menu of * applications that adopt the automatic termination capability in * Mac OS X 10.7. An application that wants to provide its own Close * All menu item should use this command ID; in that case, the OS * will recognize that the application has already provided the Close * All item, and will not add another one. Available on Mac OS X 10.7 * and later. } kHICommandCloseAll = FourCharCode('cloa'); { * The file relating to the active window should be closed. This * command would typically be used by applications that allow opening * multiple windows for the same file. There is no default behavior * for this command ID. } kHICommandCloseFile = FourCharCode('clof'); { * The active document should be saved. } kHICommandSave = FourCharCode('save'); { * The user wants to save the active document under a new name. } kHICommandSaveAs = FourCharCode('svas'); { * The contents of the active document should be reverted to the last * saved version. } kHICommandRevert = FourCharCode('rvrt'); { * The active window should be printed. } kHICommandPrint = FourCharCode('prnt'); { * The user wants to configure the current page margins, formatting, * and print options. } kHICommandPageSetup = FourCharCode('page'); { * The applicationÕs help book should be displayed. Used by the Help * Manager when it adds the " Help" menu item to the Help * menu. The Help Manager installs a handler for this command ID on * the Help menu returned by HMGetHelpMenu, and will respond to this * event automatically; your application does not need to handle it. } kHICommandAppHelp = FourCharCode('ahlp'); { * The character palette needs to be shown. Events with this command * ID are only generated in Mac OS X 10.3 and later. The toolbox will * respond to this event automatically; your application does not * need to handle it. } kHICommandShowCharacterPalette = FourCharCode('chrp'); { * Display the spelling panel if it is not already visible. Events * with this command ID are only generated in Mac OS X 10.4 and * later. If spell checking has been enabled in MLTE or an * HITextView then this command is handled automatically. } kHICommandShowSpellingPanel = FourCharCode('shsp'); { * Spell check the document now. Events with this command ID are * only generated in Mac OS X 10.4 and later. If spell checking has * been enabled in MLTE or an HITextView then this command is handled * automatically. } kHICommandCheckSpelling = FourCharCode('cksp'); kHICommandChangeSpelling = FourCharCode('chsp'); { * Begin interactive spell checking. Events with this command ID are * only generated in Mac OS X 10.4 and later. If spell checking has * been enabled in MLTE or an HITextView then this command is handled * automatically. } kHICommandCheckSpellingAsYouType = FourCharCode('aspc'); { * Ignore this word while spell checking this text view. Events with * this command ID are only generated in Mac OS X 10.4 and later. If * spell checking has been enabled in MLTE or an HITextView then this * command is handled automatically. } kHICommandIgnoreSpelling = FourCharCode('igsp'); { * Learn this spelling for all documents. Events with this command * ID are only generated in Mac OS X 10.4 and later. If spell * checking has been enabled in MLTE or an HITextView then this * command is handled automatically. } kHICommandLearnWord = FourCharCode('lrwd'); { * Starts listening to spoken dictation. A menu item with this * command ID is inserted automatically into the Edit menu. An * application may choose to insert its own menu item with this * command ID at a custom location in the Edit menu, if appropriate. * By default, the menu item is always enabled. An application that * has its own text editing engine should look for this command ID in * its kEventCommandUpdateStatus event handler and enable or disable * the menu item appropriately according to keyboard focus. Available * in Mac OS X 10.8 and later. } kHICommandStartDictation = FourCharCode('sdct'); { * Summary: * Values for the attributes field of the HICommand and * HICommandExtended structures. * * Discussion: * These bit masks are mutually exclusive; only one should be set at * any given time. Some HICommand and HICommandExtended structures * will have an attributes value of zero; in this case, there is no * information available about the source of the command. } const { * Indicates that the command originates from a menu item. The * HICommand.menu and HICommandExtended.source.menu fields are valid. * This bit is set for commands generated from menu items in all * versions of CarbonLib and Mac OS X. } kHICommandFromMenu = 1 shl 0; { * Indicates that the command originates from a control. The * HICommandExtended.source.control field is valid. This bit was * introduced in Mac OS X 10.2 and CarbonLib 1.6. It is never set in * earlier versions of Mac OS X or CarbonLib. } kHICommandFromControl = 1 shl 1; { * Indicates that the command originates from a window. The * HICommandExtended.source.window field is valid. This bit was * introduced in Mac OS X 10.2 and CarbonLib 1.6. It is never set in * earlier versions of Mac OS X or CarbonLib. } kHICommandFromWindow = 1 shl 2; { * HICommand * * Summary: * Information about a command dispatched from a menu. * * Discussion: * The HICommand structure was introduced in CarbonLib 1.1 and Mac * OS X 10.0. It is provided as the direct object of * kEventClassCommand events. Command events are typically generated * by either a control/view object or a menu item. } type HICommand = record { * Flags indicating what other fields of the structure are valid. } attributes: UInt32; { * The command ID that was generated. } commandID: UInt32; menuRef: MenuRef_fix; menuItemIndex: MenuItemIndex_fix; end; HICommandPtr = ^HICommand; { * HICommandExtended * * Summary: * Information about a command dispatched from a menu, control, or * window. * * Discussion: * The HICommandExtended structure was introduced in Mac OS X 10.2 * and CarbonLib 1.6. However, because the HICommand and * HICommandExtended structures are exactly the same size and have * the same fields at the same offsets, you may use an * HICommandExtended structure at runtime while running on any * version of CarbonLib or Mac OS X. The only difference is that the * Extended structure has a union that allows you to get type-safe * access to the source object. The originator of the command * determines whether the structure actually contains a ControlRef, * WindowRef, MenuRef, or nothing at all; you can determine what's * in the command by checking the attributes field. * * For example, on Mac OS X 10.2 and later, when a pushbutton is * clicked, the Control Manager will send a command event containing * the pushbutton's command ID, and will also set the * kHICommandFromControl bit in the attributes field and store the * button's ControlRef in the source.control field. On Mac OS X 10.0 * and 10.1, the same command event would be sent, but the * kHICommandFromControl attribute would not be set, and the * source.control field would be uninitialized. Your code can use an * HICommandExtended structure when running on 10.0 or 10.1, as long * as it first checks for kHICommandFromControl before accessing the * source.control field. } type HICommandExtended = record { * Flags indicating what other fields of the structure are valid. } attributes: UInt32; { * The command ID that was generated. } commandID: UInt32; case SInt16 of 0: ( control: ControlRef; ); 1: ( window: WindowRef; ); 2: (menuRef: MenuRef_fix; menuItemIndex: MenuItemIndex_fix; ); end; HICommandExtendedPtr = ^HICommandExtended; {--------------------------------------------------------------------------------------} { Control Events } {--------------------------------------------------------------------------------------} { kEventClassControl quick reference: // lifespan kEventControlInitialize = 1000, kEventControlDispose = 1001, kEventControlGetOptimalBounds = 1003, kEventControlOptimalBoundsChanged = 1004, kEventControlDefInitialize = kEventControlInitialize, kEventControlDefDispose = kEventControlDispose, // event handling kEventControlHit = 1, kEventControlSimulateHit = 2, kEventControlHitTest = 3, kEventControlDraw = 4, kEventControlApplyBackground = 5, kEventControlApplyTextColor = 6, kEventControlSetFocusPart = 7, kEventControlGetFocusPart = 8, kEventControlActivate = 9, kEventControlDeactivate = 10, kEventControlSetCursor = 11, kEventControlContextualMenuClick = 12, kEventControlClick = 13, kEventControlGetNextFocusCandidate = 14, kEventControlGetAutoToggleValue = 15, kEventControlInterceptSubviewClick = 16, kEventControlGetClickActivation = 17, kEventControlDragEnter = 18, kEventControlDragWithin = 19, kEventControlDragLeave = 20, kEventControlDragReceive = 21, kEventControlInvalidateForSizeChange = 22, kEventControlTrackingAreaEntered = 23, // in HIView.h kEventControlTrackingAreaExited = 24, // in HIView.h // tracking kEventControlTrack = 51, kEventControlGetScrollToHereStartPoint = 52, kEventControlGetIndicatorDragConstraint = 53, kEventControlIndicatorMoved = 54, kEventControlGhostingFinished = 55, kEventControlGetActionProcPart = 56, // accessors kEventControlGetPartRegion = 101, kEventControlGetPartBounds = 102, kEventControlSetData = 103, kEventControlGetData = 104, kEventControlGetSizeConstraints = 105, kEventControlGetFrameMetrics = 106, // notification kEventControlValueFieldChanged = 151, kEventControlAddedSubControl = 152, kEventControlRemovingSubControl = 153, kEventControlBoundsChanged = 154, kEventControlVisibilityChanged = 157, kEventControlTitleChanged = 158, kEventControlOwningWindowChanged = 159, kEventControlHiliteChanged = 160, kEventControlEnabledStateChanged = 161, kEventControlLayoutInfoChanged = 162, kEventControlFocusPartChanged = 164, // miscellaneous kEventControlArbitraryMessage = 201 } { * kEventClassControl / kEventControlClick * * Summary: * A mouse down event occurred over a control. * * Discussion: * This event is sent when a non-contextual-menu click occurs over a * control; a contextual menu click generates * kEventControlContextualMenuClick instead. * * The handler of this event is responsible for two things: first, * the handler must set the keyboard focus to the control if the * control takes focus on clicks; look for the * kControlGetsFocusOnClick feature bit and call an API such as * SetKeyboardFocus. Second, the handler must call one of the * control tracking APIs: HIViewClick, HandleControlClick, or * TrackControl. The standard window handler does both of these * things. * * Warning: Beware of handling kEventControlClick events! This is * usually NOT the event you really want to handle. * kEventControlClick is a request to "please click this control," * not "allow a control definition to track the mouse." If you are * implementing or overriding a control definitionÕs or HIViewÕs * support for tracking the mouse, you should handle * kEventControlTrack instead. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control that was clicked. * * --> kEventParamMouseLocation (in, typeHIPoint) * The mouse location, in global coordinates. * * --> kEventParamWindowRef (in, typeWindowRef) * The window under the mouse. * * --> kEventParamWindowMouseLocation (in, typeHIPoint) * The window-relative position of the mouse in the window * given in the kEventParamWindowRef parameter. 0,0 is at the * top left of the structure of the window. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The part code that the mouse location hit in the window. * This parameter only exists if the WindowRef parameter * exists. This saves you the trouble of calling FindWindow, * which is expensive on Mac OS X as it needs to call the * Window Server. Available in Mac OS X 10.3 and later. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the event was * generated. * * --> kEventParamMouseButton (in, typeMouseButton) * Which mouse button was pressed. * * --> kEventParamClickCount (in, typeUInt32) * Whether this is a single click, double click, etc. * * --> kEventParamMouseChord (in, typeUInt32) * Which other mouse buttons were pressed when the event was * generated. Available on Mac OS X only. * * --> kEventParamTabletEventType (in, typeUInt32) * The type of tablet event which generated this mouse event; * contains either kEventTabletPoint or kEventTabletProximity. * Only present if the event was generated from a tablet. * * --> kEventParamTabletPointRec (in, typeTabletPointRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletPoint. * * --> kEventParamTabletProximityRec (in, typeTabletProximityRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletProximity. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.3.1 and later } const kEventControlClick = 13; { * kEventClassControl / kEventControlHit * * Summary: * Sent by TrackControl and HandleControlClick after handling a * click in a control. * * Discussion: * This event indicates that a control has been manipulated by the * user and that the user released the mouse button over some part * of the control. It is sent automatically by the Control Manager * when the control tracking code returns a non-zero part * code. * * You might want to handle this event in a custom control * definition if your control definition has special behavior after * the control has been tracked. You can also handle this event in * application code, to be notified after a control has been * tracked; however, from the application level, it is generally * preferred to provide a command ID for the control and handle * kEventCommandProcess instead of kEventControlHit. Handling * kEventCommandProcess is more generic and allows the same code to * handle events from both controls and menu items. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control that was tracked. * * --> kEventParamControlPart (in, typeControlPartCode) * The control part that the mouse was over when it was * released. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the mouse was * released. * * --> kEventParamClickCount (in, typeUInt32) * Whether the original mouse-down on the control was a single * click, double click, etc. This parameter is optional and * may not be present in all instances of this event. Assume a * click count of 1 if this parameter is not present. * Available in Mac OS X 10.5 and later. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later } const kEventControlHit = 1; { * kEventClassControl / kEventControlInitialize * * Summary: * Allows the control to initialize private data. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control that is being created. * * --> kEventParamInitCollection (in, typeCollection) * Initialization data supplied to CreateCustomControl. * * <-- kEventParamControlFeatures (out, typeUInt32) * On exit, your event handler should supply the control * features flags. NOTE: On Mac OS X 10.3 and later, this is * deprecated in favor of using the HIViewChangeFeatures API. * Instead of supplying this parameter, just call * HIViewChangeFeatures. Also, this parameter can only be used * to supply features for the original kControlFoo features, * not the new kHIViewFoo features. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventControlInitialize = 1000; { * kEventClassControl / kEventControlDispose * * Summary: * Allows the control to dispose of private data. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control that is being destroyed. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventControlDispose = 1001; { * kEventClassControl / kEventControlGetOptimalBounds * * Summary: * Allows the control to report its best size and its text baseline * based on its current settings. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control whose optimal bounds to return. * * <-- kEventParamControlOptimalBounds (out, typeHIRect) * On exit, contains the controlÕs optimal bounds. * * <-- kEventParamControlOptimalBaselineOffset (out, typeSInt16) * On exit, contains the controlÕs optimal baseline offset: * the distance from the top of the controlÕs optimal bounds * to the baseline of the control text, if any. This parameter * is optional and does not need to be provided if it doesnÕt * apply for your control. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventControlGetOptimalBounds = 1003; { * kEventClassControl / kEventControlOptimalBoundsChanged * * Summary: * Sent by a view to itself (and thence to its superviews) to * indicate that its optimal bounds have changed. Superviews may use * this event as notification that they should relayout their * subviews (but handling this event is completely optional). * * Discussion: * This event is created and sent by a view itself; it is not sent * by HIToolbox. The event must be sent using * SendEventToEventTargetWithOptions, passing * kEventTargetSendToAllHandlers. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The view whose optimal bounds has changed. * * Availability: * Mac OS X: in version 10.5 and later in Carbon.framework * CarbonLib: not available } const kEventControlOptimalBoundsChanged = 1004; { * kEventClassControl / kEventControlSimulateHit * * Summary: * Sent when your control should simulate a click in response to * some other action, such as a return key for a default button. * * Discussion: * Note that this event is solely meant to provide visual feedback * that a control was clicked. For example, the push button control * hilites itself briefly in response to this event. This event does * not cause other events (such as kEventControlHit or * kEventCommandProcess) to be sent. To fully simulate the results * of clicking on a control, you can use the HIViewSimulateClick * API, which sends a kEventControlSimulateHit event and also sends * the kEventControlHit and kEventCommandProcess events that would * normally result from a click on a control. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control for which a hit should be simulated. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that should be used for the * simulated hit. * * <-> kEventParamControlPart (in/out, typeControlPartCode) * On entry, contains the part code for which the control * should simulate a hit. On exit, the control may modify this * parameter to reflect the same sort of part code that it * would pass back while handling kEventControlTrack. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventControlSimulateHit = 2; { * kEventClassControl / kEventControlHitTest * * Summary: * Sent when someone wants to find out what part of your control is * at a given point in local coordinates. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control to hit-test. * * --> kEventParamMouseLocation (in, typeQDPoint) * The point to hit-test. For controls in non-compositing * windows, this coordinate is in local coordinates of the * owning window; for controls in compositing windows, this * coordinate is in view-local coordinates. * * <-- kEventParamControlPart (out, typeControlPartCode) * On exit, contains the part code of the control part that * was hit, or kControlNoPart if no part was hit. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventControlHitTest = 3; { * kEventClassControl / kEventControlDraw * * Summary: * Sent when your control should draw itself. The event can * optionally contain a port in which to draw and a part to * constrain drawing to. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control to be drawn. * * --> kEventParamControlPart (in, typeControlPartCode) * The control part code to draw. This parameter is optional * and may not be present in all instances of this event. Draw * the entire control if the parameter is not present. * * --> kEventParamGrafPort (in, typeGrafPtr) * The GrafPort into which to draw the control. This parameter * is optional and may not be present in all instances of this * event. Draw into the current port if the parameter is not * present. * * --> kEventParamRgnHandle (in, typeQDRgnHandle) * A region describing the area that needs to be redrawn; you * may constrain your drawing to this region. This parameter * is only provided on Mac OS X 10.2 and later, and only in * certain situations in compositing mode (when the view is * visible, etc). Draw the entire control if the parameter is * not present. * * --> kEventParamShape (in, typeHIShapeRef) * An HIShapeRef describing the area that needs to be redrawn; * you may constrain your drawing to this area. This parameter * is only provided on Mac OS X 10.4 and later, and only in * certain situations in compositing mode (when the view is * visible, etc). Draw the entire control if the parameter is * not present. * * --> kEventParamCGContextRef (in, typeCGContextRef) * The CGContext into which to draw the control. This * parameter is only provided on Mac OS X 10.2 and later, and * only when the owning window uses compositing mode. The * context is already transformed and clipped appropriately * for view-local drawing. If this parameter is present, you * should always use it; this will be extremely important to * allow printing of controls. If this parameter is not * present (prior to Mac OS X 10.2, or in a non-compositing * window), and you want to draw with CoreGraphics, you can * create your own CGContext with QDBeginCGContext. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventControlDraw = 4; {$ifc not TARGET_CPU_64} { * kEventClassControl / kEventControlApplyBackground * * Summary: * Sent when your control should apply its background color or * pattern to the specified port so that subcontrols of this control * can properly erase. * * Discussion: * This event is used for non-composited control drawing. When an * embedded control in a non-composited window draws, it first * erases its bounding rect. Before calling EraseRect or EraseRgn, * the control calls SetUpControlBackground, which sends this event * to parent controls of the embedded control that have the * kControlHasSpecialBackground feature flag. An embedding control * may respond to this event by setting the background color or * pattern of the specified GrafPort; this color or pattern will * then be used by the embedded control when it erases its * bounds. * * Note that an embedding control should not actually draw its * background in response to this event; doing so would not have any * effect, because the embedded control will erase any drawing * shortly anyways. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control which should apply a background color or * pattern. * * --> kEventParamControlSubControl (in, typeControlRef) * The subcontrol that is about to draw. * * --> kEventParamControlDrawDepth (in, typeSInt16) * The bit depth of the GDevice on which the subcontrol will * be drawn. * * --> kEventParamControlDrawInColor (in, typeBoolean) * Whether the GDevice on which the subcontrol will be drawn * is in color or black & white. * * --> kEventParamGrafPort (in, typeGrafPtr) * The port to which the background color or pattern should be * applied. This parameter is optional and may not be present * in all instances of this event. Apply the background to the * current port if this parameter is not present. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventControlApplyBackground = 5; {$endc} {not TARGET_CPU_64} { * kEventClassControl / kEventControlApplyTextColor * * Summary: * Sent when your control should apply a color or pattern to the * specified port and context so a subcontrol can draw text which * looks appropriate for your controlÕs background. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control which should apply a text color. * * --> kEventParamControlSubControl (in, typeControlRef) * The subcontrol that is about to draw. * * --> kEventParamControlDrawDepth (in, typeSInt16) * The bit depth of the GDevice on which the subcontrol will * be drawn. * * --> kEventParamControlDrawInColor (in, typeBoolean) * Whether the GDevice on which the subcontrol will be drawn * is in color or black & white. * * --> kEventParamCGContextRef (in, typeCGContextRef) * The CGContext to which the text color should be applied. * This parameter is optional and may not be present in all * instances of this event. * * --> kEventParamGrafPort (in, typeGrafPtr) * The GrafPort to which the text color should be applied. * This parameter is optional and may not be present in all * instances of this event. Apply to the current port if this * parameter is not present. * * <-- kEventParamControlDrawEngraved (out, typeBoolean) * On exit, contains a Boolean indicating whether your control * wants the subcontrol to draw its text engraved. If your * control does not want the subcontrol to draw engraved text, * you may leave this parameter empty. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventControlApplyTextColor = 6; { * kEventClassControl / kEventControlGetNextFocusCandidate * * Summary: * Sent so that a given control can customize the focus order of its * subcontrols. * * Discussion: * The recipient will receive a start subcontrol in the * kEventParamStartControl parameter and a focusing direction in the * kEventParamControlPart parameter. You must only pass back * subcontrols of yourself (or NULL) when receiving this event; if * you do otherwise, the Control ManagerÕs behavior is undefined. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamControlPart (in, typeControlPartCode) * A focusing meta-part code, either kControlFocusNextPart or * kControlFocusPrevPart. * * --> kEventParamStartControl (in, typeControlRef) * The starting point from which to search for the next or * previous control. This parameter is optional and may not be * present in all instances of this event. Find the first * subcontrol in the appropriate focusing direction if this * parameter is not present or if it contains NULL. * * <-- kEventParamNextControl (out, typeControlRef) * On exit, should contain the next or previous subcontrol; if * there is no next subcontrol in the given focusing * direction, the recipient must either exclude the * kEventParamNextControl parameter or set it to NULL * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventControlGetNextFocusCandidate = 14; { * kEventClassControl / kEventControlGetAutoToggleValue * * Summary: * This event is sent when the Control Manager is about to * autotoggle a control. You can specify the toggled value to use * based on the current value of your control. * * Discussion: * The Control Manager provides default behavior for this event. If * the event is not handled by a control, the default handler * automatically provides this mapping: if the controlÕs value is 1, * the toggled value is 0. If the controlÕs value is any other * value, the toggled value is 1. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control that is being toggled. * * --> kEventParamControlPart (in, typeControlPartCode) * The control part that is being toggled. * * <-- kEventParamControlValue (out, typeSInt32) * On exit, contains the new control value. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventControlGetAutoToggleValue = 15; { * kEventClassControl / kEventControlInterceptSubviewClick * * Summary: * This is sent when the HIViewGetViewForMouseEvent API is called, * to allow embedding controls to intercept clicks in their embedded * controls. * * Discussion: * The Control Manager sends this event before descending into any * subviews. Controls can override this to intercept clicks which * would normally be destined for their children. For example, the * HIToolbar control intercepts cmd-clicks to handle dragging its * children. To accomplish this, it overrides this event, looking * for the command key modifier. When the command key is pressed, * the view just returns noErr as the result from its event handler. * This tells the Control Manager to stop descending and return the * view that it called as the mouse event destination. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control that is being given a chance to intercept a * click. This parameter is only available in Mac OS X 10.5 * and later. * * --> kEventParamEventRef (in, typeEventRef) * The mouse-down event to intercept. * * Result: * An operating system result code. Return noErr to indicate that * this view intercepted the click, or eventNotHandledErr to allow * subviews of this view to take the click. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventControlInterceptSubviewClick = 16; { * kEventClassControl / kEventControlGetClickActivation * * Summary: * Sent when a click occurs in a window. Allows the control to * determine whether the window should be activated and whether the * click should be handled. * * Discussion: * This is very much like the window class version of this event. * The difference is that the mouse location is view- or * port-relative. This event is actually a copy of the mouse down * event, and so it has all the parameters that such an event would * have (modifiers, button number, etc.). * * When handling a click, this event is sent first, and is sent only * to the control that was clicked; it is not propagated to the * embedder of the clicked control. If the event is not handled, * then a kEventWindowGetClickActivation event is sent to the window * that was clicked. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control that was clicked. * * <-- kEventParamClickActivation (out, typeClickActivationResult) * On exit, indicates how the click should be handled. Should * be set a ClickActivationResult constant from Controls.h. * * --> kEventParamMouseLocation (in, typeHIPoint) * The mouse location, in view-local coordinates if the * controlÕs owning window is composited, or port-local * coordinates if not. * * --> kEventParamWindowRef (in, typeWindowRef) * The window under the mouse. * * --> kEventParamWindowMouseLocation (in, typeHIPoint) * The window-relative position of the mouse in the window * given in the kEventParamWindowRef parameter. 0,0 is at the * top left of the structure of the window. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The part code that the mouse location hit in the window. * This parameter only exists if the WindowRef parameter * exists. This saves you the trouble of calling FindWindow, * which is expensive on Mac OS X as it needs to call the * Window Server. Available in Mac OS X 10.3 and later. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the event was * generated. * * --> kEventParamMouseButton (in, typeMouseButton) * Which mouse button was pressed. * * --> kEventParamClickCount (in, typeUInt32) * Whether this is a single click, double click, etc. * * --> kEventParamMouseChord (in, typeUInt32) * Which other mouse buttons were pressed when the event was * generated. Available on Mac OS X only. * * --> kEventParamTabletEventType (in, typeUInt32) * The type of tablet event which generated this mouse event; * contains either kEventTabletPoint or kEventTabletProximity. * Only present if the event was generated from a tablet. * * --> kEventParamTabletPointRec (in, typeTabletPointRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletPoint. * * --> kEventParamTabletProximityRec (in, typeTabletProximityRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletProximity. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventControlGetClickActivation = 17; { * kEventClassControl / kEventControlDragEnter * * Summary: * A drag has entered your control. * * Discussion: * If you at all wish to handle the drag, you must return true in * the kEventParamControlWouldAcceptDrop parameter from your event * handler in response to this event. If you return * eventNotHandledErr, do not supply a * kEventParamControlWouldAcceptDrop parameter, or set its value to * false, you will not receive 'within' or 'leave' messages, nor * will you be eligible to receive the drop. This is done to try to * be as efficient as possible when sending events during the drag * operation. * * Note that in order to receive this event, you must first call the * SetAutomaticControlDragTrackingEnabledForWindow API, passing true * for the inTracks parameter, and then call the * SetControlDragTrackingEnabled API, again passing true for the * inTracks parameter. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control that is the drag target. * * --> kEventParamDragRef (in, typeDragRef) * The DragRef for the drag. * * <-- kEventParamControlWouldAcceptDrop (out, typeBoolean) * The control would accept the drop. Return true in this * parameter if your view wants to track and possibly receive * this drag. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventControlDragEnter = 18; { * kEventClassControl / kEventControlDragWithin * * Summary: * A drag has moved with your airspace (but not on any subcontrol). * * Discussion: * Your control will typically respond to this event by drawing its * drag highlight. If the user moves into a subcontrol, it becomes * the target of the drag and your control will not receive 'within' * messages any longer. * * Note that in order to receive this event, you must first call the * SetAutomaticControlDragTrackingEnabledForWindow API, passing true * for the inTracks parameter, and then call the * SetControlDragTrackingEnabled API, again passing true for the * inTracks parameter. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control that is the drag target. * * --> kEventParamDragRef (in, typeDragRef) * The DragRef for the drag. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventControlDragWithin = 19; { * kEventClassControl / kEventControlDragLeave * * Summary: * A drag is leaving your view. * * Discussion: * Your control will typically respond to this event by removing its * drag highlight. * * Note that in order to receive this event, you must first call the * SetAutomaticControlDragTrackingEnabledForWindow API, passing true * for the inTracks parameter, and then call the * SetControlDragTrackingEnabled API, again passing true for the * inTracks parameter. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control that is the drag target. * * --> kEventParamDragRef (in, typeDragRef) * The DragRef for the drag. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventControlDragLeave = 20; { * kEventClassControl / kEventControlDragReceive * * Summary: * Congratulations, you are the lucky recipient of a drag. Enjoy it. * * Discussion: * Note that in order to receive this event, you must first call the * SetAutomaticControlDragTrackingEnabledForWindow API, passing true * for the inTracks parameter, and then call the * SetControlDragTrackingEnabled API, again passing true for the * inTracks parameter. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control that is the drag target. * * --> kEventParamDragRef (in, typeDragRef) * The DragRef for the drag. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventControlDragReceive = 21; { * kEventClassControl / kEventControlSetFocusPart * * Summary: * Sent when your control is gaining, losing, or changing the focus. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control that is gaining, losing, or changing focus. * * --> kEventParamControlFocusEverything (in, typeBoolean) * Indicates whether to allowing focusing on a part that * doesnÕt accept general keyboard input, such as a push * button, or if only traditionally focusable parts such as * edit fields and list boxes should be allowed to gain focus. * This parameter is optional and may not be present in all * instances of this event. Restrict focus to traditionally * focusable parts if this parameter is not present. * * <-> kEventParamControlPart (in/out, typeControlPartCode) * On entry, a part code that may be either an actual control * part or a control focus meta-part. This parameter may be * one of kControlFocusNoPart (if the control is losing * focus), kControlFocusNextPart (if the next part in the * control should be focused), kControlFocusPrevPart (if the * previous part in the control should be focused), or an * actual control part (if that specific part should be * focused). On exit, your event handler should store the * actual part code that was focused into this parameter. Your * control must always allow the focus to be removed (when * this parameter is kControlFocusNoPart on entry). * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventControlSetFocusPart = 7; { * kEventClassControl / kEventControlGetFocusPart * * Summary: * Sent when your the Control Manager wants to know what part of * your control is currently focused. Set the kEventParamControlPart * param to your currently focused part. * * Discussion: * The Control Manager provides default behavior for this event. If * the event is not handled by a control, the default handler * returns the part of the control that was most recently focused. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control for which to get the current focus. * * <-- kEventParamControlPart (out, typeControlPartCode) * On exit, contains the current focus for this control. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventControlGetFocusPart = 8; { * kEventClassControl / kEventControlActivate * * Summary: * Sent when your control becomes active as a result of a call to * ActivateControl. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control that was activated. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventControlActivate = 9; { * kEventClassControl / kEventControlDeactivate * * Summary: * Sent when your control becomes inactive as a result of a call to * DeactivateControl. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control that was deactivated. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventControlDeactivate = 10; { * kEventClassControl / kEventControlSetCursor * * Summary: * Sent when your control is asked to change the cursor as a result * of a call to HandleControlSetCursor. * * Discussion: * Note that the standard window event handler does not call * HandleControlSetCursor, and therefore, your control will not * ordinarily receive this event. Your host application must call * HandleControlSetCursor itself in order for your control to * receive this event. On Mac OS X 10.2 and later, we recommend * using mouse tracking regions in your control to be notified when * to change the cursor, rather than using this event. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control that should set the cursor. * * --> kEventParamMouseLocation (in, typeQDPoint) * The mouse location, in view-local coordinates if the * controlÕs owning window is composited, or port-local * coordinates if not. * * --> kEventParamKeyModifiers (in, typeUInt32) * The current keyboard modifiers. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventControlSetCursor = 11; { * kEventClassControl / kEventControlContextualMenuClick * * Summary: * Sent when your control is asked to display a contextual menu as a * result of a call to HandleControlContextualMenuClick. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control that was clicked. * * --> kEventParamMouseLocation (in, typeQDPoint) * The mouse location, in view-local coordinates if the * controlÕs owning window is composited, or port-local * coordinates if not. In Mac OS X 10.2 and earlier, however, * this parameter was incorrectly in global coordinates. * * --> kEventParamWindowRef (in, typeWindowRef) * The window under the mouse. Available in Mac OS X 10.3 and * later. * * --> kEventParamWindowMouseLocation (in, typeHIPoint) * The window-relative position of the mouse in the window * given in the kEventParamWindowRef parameter. 0,0 is at the * top left of the structure of the window. Available in Mac * OS X 10.3 and later. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The part code that the mouse location hit in the window. * This parameter only exists if the WindowRef parameter * exists. This saves you the trouble of calling FindWindow, * which is expensive on Mac OS X as it needs to call the * Window Server. Available in Mac OS X 10.3 and later. * * --> kEventParamKeyModifiers (in, typeUInt32) * The keyboard modifiers that were pressed when the event was * generated. Available in Mac OS X 10.3 and later. * * --> kEventParamMouseButton (in, typeMouseButton) * Which mouse button was pressed. Available in Mac OS X 10.3 * and later. * * --> kEventParamClickCount (in, typeUInt32) * Whether this is a single click, double click, etc. * Available in Mac OS X 10.3 and later. * * --> kEventParamMouseChord (in, typeUInt32) * Which other mouse buttons were pressed when the event was * generated. Available in Mac OS X 10.3 and later. * * --> kEventParamTabletEventType (in, typeUInt32) * The type of tablet event which generated this mouse event; * contains either kEventTabletPoint or kEventTabletProximity. * Only present if the event was generated from a tablet. * Available in Mac OS X 10.3 and later. * * --> kEventParamTabletPointRec (in, typeTabletPointRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletPoint. Available in Mac OS X 10.3 and later. * * --> kEventParamTabletProximityRec (in, typeTabletProximityRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletProximity. Available in Mac OS X 10.3 and later. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventControlContextualMenuClick = 12; { * kEventClassControl / kEventControlTrack * * Summary: * Sent to allow a control definition to track the mouse in response * to a call to HIViewClick, HandleControlClick, etc. * * Discussion: * This event is only sent to controls that return a non-zero * control part code from kEventControlHitTest. If you are * implementing a custom HIView and you need to receive this event, * you must also handle kEventControlHitTest and place a valid * control part code into the parameter, and return noErr. * * This event is sent from within HIViewClick and * HandleControlClick. The default handling of this event is the * Control ManagerÕs normal tracking logic; this is good enough for * simple controls (such as push buttons) and controls with simple * indicators (such as scroll bars and sliders). You should only * need to handle or override this event if you are trying to do * more complex tracking, such as displaying a menu in the middle of * tracking. * * In Mac OS X 10.4 and later, when this event is sent in response * to a click in a compositing window, the event will include all of * the fields of the kEventControlClick event, including * kEventParamMouseButton, kEventParamClickCount, and so on. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control to track. * * --> kEventParamMouseLocation (in, typeQDPoint) * The mouse location, in view-local coordinates if the * controlÕs owning window is composited, or port-local * coordinates if not. * * <-> kEventParamKeyModifiers (in/out, typeUInt32) * The current keyboard modifiers. On exit, the event handler * may update this parameter with the modifiers that were * pressed when tracking ended; these modifiers will be * included in the kEventCommandProcess event that is sent by * the Control Manager. * * --> kEventParamControlAction (in, typeControlActionUPP) * The control action proc that should be called by the * control during tracking. * * <-- kEventParamControlPart (out, typeControlPartCode) * On exit, contains the part code of the control part that * was selected when tracking ended, or kControlNoPart if no * part was selected. If the part code is non-zero, the * Control Manager will automatically send kEventControlHit * and kEventCommandProcess events. * * --> kEventParamWindowRef (in, typeWindowRef) * The window under the mouse. This parameter is only * available in Mac OS X 10.4 and later, and is only included * for clicks in a compositing window or if the application * calls HIViewClick itself. * * --> kEventParamWindowMouseLocation (in, typeHIPoint) * The window-relative position of the mouse in the window * given in the kEventParamWindowRef parameter. 0,0 is at the * top left of the structure of the window. This parameter is * only available in Mac OS X 10.4 and later, and is only * included for clicks in a compositing window or if the * application calls HIViewClick itself. * * --> kEventParamWindowPartCode (in, typeWindowPartCode) * The part code that the mouse location hit in the window. * This parameter only exists if the WindowRef parameter * exists. This saves you the trouble of calling FindWindow, * which is expensive on Mac OS X as it needs to call the * Window Server. This parameter is only available in Mac OS X * 10.4 and later, and is only included for clicks in a * compositing window or if the application calls HIViewClick * itself. * * --> kEventParamMouseButton (in, typeMouseButton) * Which mouse button was pressed. This parameter is only * available in Mac OS X 10.4 and later, and is only included * for clicks in a compositing window or if the application * calls HIViewClick itself. * * --> kEventParamClickCount (in, typeUInt32) * Whether this is a single click, double click, etc. This * parameter is only available in Mac OS X 10.4 and later, and * is only included for clicks in a compositing window or if * the application calls HIViewClick itself. * * --> kEventParamMouseChord (in, typeUInt32) * Which other mouse buttons were pressed when the event was * generated. This parameter is only available in Mac OS X * 10.4 and later, and is only included for clicks in a * compositing window or if the application calls HIViewClick * itself. * * --> kEventParamTabletEventType (in, typeUInt32) * The type of tablet event which generated this mouse event; * contains either kEventTabletPoint or kEventTabletProximity. * Only present if the event was generated from a tablet. This * parameter is only available in Mac OS X 10.4 and later, and * is only included for clicks in a compositing window or if * the application calls HIViewClick itself. * * --> kEventParamTabletPointRec (in, typeTabletPointRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletPoint. This parameter is only available in Mac * OS X 10.4 and later, and is only included for clicks in a * compositing window or if the application calls HIViewClick * itself. * * --> kEventParamTabletProximityRec (in, typeTabletProximityRec) * Further information about the tablet event which generated * this mouse event. Present if the the * kEventParamTabletEventType parameter contains * kEventTabletProximity. This parameter is only available in * Mac OS X 10.4 and later, and is only included for clicks in * a compositing window or if the application calls * HIViewClick itself. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventControlTrack = 51; { * kEventClassControl / kEventControlGetScrollToHereStartPoint * * Summary: * Sent so your control can support Scroll To Here behavior during * tracking. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control for which to retrieve the Scroll To Here point. * * <-> kEventParamMouseLocation (in/out, typeQDPoint) * On entry, a point in view-local coordinates if the * controlÕs owning window is composited, or port-local * coordinates if not, which provides the location at which * the user clicked to request Scroll To Here behavior. On * exit, this parameter should contain the mouse location in * view-local or port-local coordinates where a click would * have needed to be to cause your indicator to be dragged to * the incoming mouse location. * * --> kEventParamKeyModifiers (in, typeUInt32) * The current keyboard modifiers. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventControlGetScrollToHereStartPoint = 52; { * kEventClassControl / kEventControlGetIndicatorDragConstraint * * Summary: * Sent so your control can constrain the movement of its indicator * during tracking. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control that is being tracked. * * --> kEventParamMouseLocation (in, typeQDPoint) * The mouse location, in view-local coordinates if the * controlÕs owning window is composited, or port-local * coordinates if not. * * --> kEventParamKeyModifiers (in, typeUInt32) * The current keyboard modifiers. * * <-- kEventParamControlIndicatorDragConstraint (out, typeIndicatorDragConstraint) * On exit, contains an IndicatorDragConstraint structure. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventControlGetIndicatorDragConstraint = 53; { * kEventClassControl / kEventControlIndicatorMoved * * Summary: * Sent during live-tracking of the indicator so your control can * update its value based on the new indicator position. During * non-live tracking, this event lets you redraw the indicator ghost * at the appropriate place. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control that is being tracked. * * --> kEventParamControlIndicatorRegion (in, typeQDRgnHandle) * The new indicator region. * * --> kEventParamControlIsGhosting (in, typeBoolean) * Indicates whether the control is using non-live-tracking * (true) or live tracking (false). * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventControlIndicatorMoved = 54; { * kEventClassControl / kEventControlGhostingFinished * * Summary: * Sent at the end of non-live indicator tracking so your control * can update its value based on the final ghost location. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control that was being tracked. * * --> kEventParamControlIndicatorOffset (in, typeQDPoint) * The final offset of the indicator. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventControlGhostingFinished = 55; { * kEventClassControl / kEventControlGetActionProcPart * * Summary: * Sent during tracking so your control can alter the part that is * passed to its action proc based on modifier keys, etc. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control being tracked. * * --> kEventParamKeyModifiers (in, typeUInt32) * The current keyboard modifiers. * * <-> kEventParamControlPart (in/out, typeControlPartCode) * On entry, the proposed control part that will be sent to * the action proc. Your handler may modify this parameter * based on its own criteria (which modifier keys are pressed, * for example). * * <-- kEventParamControlPartAutoRepeats (out, typeBoolean) * On output, a flag to the standard control tracking loop in * the Control Manager indicating whether to autorepeat when * the user presses and holds on certain parts of your custom * control. The autorepeat timing curve is the same as that * used for the buttons/page areas of scroll bars. This * parameter is observed by the Control Manager in Mac OS X * 10.2 and later. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventControlGetActionProcPart = 56; { * kEventClassControl / kEventControlGetPartRegion * * Summary: * Sent by the GetControlRegion, HIViewCopyPartShape, and similar * APIs when a client wants to get a particular region or shape of * your control. * * Discussion: * This event is sent to your handler in order to fetch both regions * and shapes from your view. Shapes will only be requested on Mac * OS X 10.4 and later. There are two strategies for handling this * event: the non-shape savvy way and the shape savvy way. The shape * savvy way avoids costly conversions between regions and shapes * which can slow your view's performance. * * Non-shape savvy way: Get the region out of the * kEventParamControlRegion parameter and modify it appropriately to * reflect the desired part. Before the advent of shapes, this was * the only method for handling this event. If you always handle the * event this way on Mac OS X 10.4 and later, you may force the * Control Manager to convert the region to a shape, which adversely * affects performance. * * Shape savvy way: Get the value of the * kEventParamControlPrefersShape parameter. If the parameter * doesn't exist or if its value is false, handle this event in the * non-shape savvy way as described above. If the parameter exists * and has a value of true, allocate an immutable shape that * represents the given part of your view and use SetEventParameter * to add the shape to the event in the kEventParamShape parameter. * You may now release the shape, since it was retained by * SetEventParameter. If for some reason you are unwilling or unable * to provide a shape for the given part, you may still fall back to * the non-shape savvy method. * * NOTE: If your handler attempts to pre- or post-process some other * handler's processing of this event by calling * CallNextEventHandler, you MUST NOT rely on the value of the * kEventParamControlPrefersShape parameter being preserved across * the call to CallNextEventHandler. This event may dynamically * modify itself depending on how any given handler acts upon it. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control whose region/shape to return. * * --> kEventParamControlPart (in, typeControlPartCode) * The control part code whose region/shape to return. * * --> kEventParamControlPrefersShape (in, typeBoolean) * A Boolean indicating whether your view may respond to this * event by adding a kEventParamShape parameter to it instead * of modifying the region in the kEventParamControlRegion * parameter. If the parameter is false, you must respond to * the event by modifying the region in the * kEventParamControlRegion parameter; you may not add a * kEventParamShape parameter. If the parameter is true, you * may Ñ but are not required to Ñ respond to the event by * adding the kEventParamShape parameter; if you choose not * to, you must respond to the event by modifying the region * in the kEventParamControlRegion parameter. This parameter * will only be present on Mac OS X 10.4 and later. In fact, * even on Mac OS X 10.4 it is an optional parameter and will * not always be present. If this parameter is not present, * you should act as though its value were false. * * --> kEventParamControlRegion (in, typeQDRgnHandle) * A pre-allocated RgnHandle. Unless your handler is allowed * to and chooses to add a kEventParamShape parameter (see the * discussion of kEventParamControlPrefersShape above), your * handler should get the RgnHandle from the event and set the * region contents appropriately. If your handler adds a * kEventParamShape parameter to the event, it must neither * get nor modify this parameter. * * <-- kEventParamShape (out, typeHIShapeRef) * If your handler is allowed to and chooses to provide a * shape (see the discussion of kEventParamControlPrefersShape * above), your handler should create a new, immutable shape * and return it in this parameter. After you call * SetEventParameter, you may release the shape, as it will be * retained by SetEventParameter and released when the event * is destroyed. If your handler gets or modifies the * kEventParamControlRegion parameter, it must not set this * parameter. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventControlGetPartRegion = 101; { * kEventClassControl / kEventControlGetPartBounds * * Summary: * Sent when a client wants to get a particular rectangle of your * control when it may be more efficient than asking for a region. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control whose bounds to return. * * --> kEventParamControlPart (in, typeControlPartCode) * The control part whose bounds to return. * * <-- kEventParamControlPartBounds (out, typeHIRect) * On exit, contains the bounds of the specified part. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventControlGetPartBounds = 102; { * kEventClassControl / kEventControlSetData * * Summary: * Sent by the SetControlData API when a client wants to change an * arbitrary setting of your control. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control for which to set data. * * --> kEventParamControlPart (in, typeControlPartCode) * The control part for which to set data. * * --> kEventParamControlDataTag (in, typeEnumeration) * The type of data to set. * * --> kEventParamControlDataBuffer (in, typePtr) * A pointer to the data. * * --> kEventParamControlDataBufferSize (in, typeByteCount) * The size of the data. * * On Mac OS X 10.4 and earlier, this parameter uses * typeSInt32, and you must retrieve it using that constant. * On Mac OS X 10.5 and later, to support 64-bit data sizes, * this parameter uses typeByteCount. For 64-bit * compatibility, you must use typeByteCount when retrieving * this parameter; for 32-bit targets, however, you may * continue to use typeSInt32 if you wish, or switch to * typeByteCount. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventControlSetData = 103; { * kEventClassControl / kEventControlGetData * * Summary: * Sent by the GetControlData API when a client wants to get an * arbitrary setting of your control. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control from which to get data. * * --> kEventParamControlPart (in, typeControlPartCode) * The control part for which to get data. * * --> kEventParamControlDataTag (in, typeEnumeration) * The type of data to get. * * --> kEventParamControlDataBuffer (in, typePtr) * A buffer in which to write the data. * * <-> kEventParamControlDataBufferSize (in/out, typeByteCount) * On entry, the size of the data buffer. On exit, the amount * of data that was available. * * On Mac OS X 10.4 and earlier, this parameter uses * typeSInt32, and you must retrieve it using that constant. * On Mac OS X 10.5 and later, to support 64-bit data sizes, * this parameter uses typeByteCount. For 64-bit * compatibility, you must use typeByteCount when retrieving * this parameter; for 32-bit targets, however, you may * continue to use typeSInt32 if you wish, or switch to * typeByteCount. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventControlGetData = 104; { * kEventClassControl / kEventControlGetSizeConstraints * * Summary: * Sent by the HIViewGetSizeConstraints API to allow your custom * control/view to specify its minimum and maximum size. * * Discussion: * This is different from the optimal size event above. The optimal * size might be larger than a viewÕs minimum size. A parent view * can use this information to help it lay out subviews. The toolbar * control uses this information to help lay out toolbar items, for * example. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control for which to get size constraints. * * <-- kEventParamMinimumSize (out, typeHISize) * On exit, contains the controlÕs minimum size. * * <-- kEventParamMaximumSize (out, typeHISize) * On exit, contains the controlÕs maximum size. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventControlGetSizeConstraints = 105; { * kEventClassControl / kEventControlGetFrameMetrics * * Summary: * Sent when a control client needs to determine the width of the * controlÕs structure region. * * Discussion: * This event is not sent automatically by the Control Manager at * any time, but may be sent by control clients during various * layout operations. For example, the Window Manager will send this * event to a window frame HIView to determine the window structure * widths, and the Menu Manager will send this event to a menu * content view to determine the content structure widths. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control for which to get frame metrics. * * <-- kEventParamControlFrameMetrics (out, typeControlFrameMetrics) * On exit, contains the controlÕs frame metrics. * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available } const kEventControlGetFrameMetrics = 106; { * kEventClassControl / kEventControlValueFieldChanged * * Summary: * Sent when your controlÕs value, min, max, or view size has * changed. Useful so other entities can watch for changes to your * controlÕs value. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control whose value, min, max, or view size has changed. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventControlValueFieldChanged = 151; { * kEventClassControl / kEventControlAddedSubControl * * Summary: * Sent when a control was embedded within your control. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control that gained a new subcontrol. * * --> kEventParamControlSubControl (in, typeControlRef) * The subcontrol that was added. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventControlAddedSubControl = 152; { * kEventClassControl / kEventControlRemovingSubControl * * Summary: * Sent when one of your child controls will be removed from your * control. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control that will be losing a subcontrol. * * --> kEventParamControlSubControl (in, typeControlRef) * The subcontrol that will be removed. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventControlRemovingSubControl = 153; { * kEventClassControl / kEventControlBoundsChanged * * Summary: * Sent when your controlÕs bounding rectangle has changed. * * Discussion: * If you want to generate an efficient invalid region in response * to a size change, you need to handle * kEventControlInvalidateForSizeChange. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control whose bounds have changed. * * --> kEventParamAttributes (in, typeUInt32) * Flags indicating how the bounds changed, including * kControlBoundsChangeSizeChanged and * kControlBoundsChangePositionChanged. * * --> kEventParamOriginalBounds (in, typeQDRectangle) * The controlÕs bounds before the change. This is the * controlÕs frame bounds; for a compositing view, this * bounding rect is in the parent viewÕs coordinate system, * and for a non-compositing view, it is in local GrafPort * coordinates. * * --> kEventParamPreviousBounds (in, typeQDRectangle) * The controlÕs bounds before the change. This parameter * always has the same value as the kEventParamOriginalBounds * parameter. * * --> kEventParamCurrentBounds (in, typeQDRectangle) * The controlÕs new bounds. This is the controlÕs frame * bounds; for a compositing view, this bounding rect is in * the parent viewÕs coordinate system, and for a * non-compositing view, it is in local GrafPort coordinates. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventControlBoundsChanged = 154; { * kEventClassControl / kEventControlInvalidateForSizeChange * * Summary: * Sent when a control's size changes so it can invalidate the area * of itself that needs to be redrawn. * * Discussion: * Handle this event by calling HIViewSetNeedsDisplayInRegion with a * region that properly reflects the area of your control that needs * to be redrawn after a size change. The default handler for this * event will invalidate the entire control. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control whose size has changed. * * --> kEventParamOriginalBounds (in, typeQDRectangle) * The controlÕs bounds before the change. * * --> kEventParamCurrentBounds (in, typeQDRectangle) * The controlÕs new bounds. * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available } const kEventControlInvalidateForSizeChange = 22; { * kEventClassControl / kEventControlVisibilityChanged * * Summary: * Sent when a control is hidden or shown. This is here to support * custom views/controls which need to update information when the * visibility changes. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control whose visibility has changed. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventControlVisibilityChanged = 157; { * kEventClassControl / kEventControlOwningWindowChanged * * Summary: * Sent when your controlÕs owning window has changed. Useful to * udpate any dependencies that your control has on its owning * window. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control whose owning window has changed. * * --> kEventParamAttributes (in, typeUInt32) * Currently unused. * * --> kEventParamControlOriginalOwningWindow (in, typeWindowRef) * The controlÕs original owning window. * * --> kEventParamControlCurrentOwningWindow (in, typeWindowRef) * The controlÕs new owning window. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventControlOwningWindowChanged = 159; { * kEventClassControl / kEventControlTitleChanged * * Summary: * Sent when the title of your control changes. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control whose title has changed. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventControlTitleChanged = 158; { * kEventClassControl / kEventControlHiliteChanged * * Summary: * Sent when the hilite state changes in a control. This is here to * support custom views/controls which need to update information * when the hilite state changes. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control whose hilite has changed. * * --> kEventParamControlPreviousPart (in, typeControlPartCode) * The previously hilited part. * * --> kEventParamControlCurrentPart (in, typeControlPartCode) * The newly hilited part. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventControlHiliteChanged = 160; { * kEventClassControl / kEventControlEnabledStateChanged * * Summary: * Sent when the enabled state changes in a control. This is here to * support custom views/controls which need to update information * when the enabled state changes. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control whose enabled state has changed. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventControlEnabledStateChanged = 161; { * kEventClassControl / kEventControlLayoutInfoChanged * * Summary: * Sent when the layout info changes in a control. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control whose layout info has changed. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework * CarbonLib: not available } const kEventControlLayoutInfoChanged = 162; { * kEventClassControl / kEventControlFocusPartChanged * * Summary: * Sent when the focused part changes in a control. * * This event is sent only to the control, and is not propagated * past it. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control whose focused part has changed. * * --> kEventParamControlPreviousPart (in, typeControlPartCode) * The previously focused part. This value will be zero when * the control is gaining focus. * * --> kEventParamControlCurrentPart (in, typeControlPartCode) * The newly focused part. This value will be zero when the * control is losing focus. * * Availability: * Mac OS X: in version 10.5 and later in Carbon.framework * CarbonLib: not available } const kEventControlFocusPartChanged = 164; {$ifc not TARGET_CPU_64} { * kEventClassControl / kEventControlArbitraryMessage * * Summary: * Sent by the SendControlMessage API when someone is trying to send * an old-style CDEF message to your control. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeControlRef) * The control that is receiving the message. * * --> kEventParamControlMessage (in, typeSInt16) * The message. * * --> kEventParamControlParam (in, typeRefCon) * The inParam parameter from SendControlMessage. * * On Mac OS X 10.4 and earlier, this parameter uses * typeSInt32, and you must retrieve it using that constant. * On Mac OS X 10.5 and later, to support 64-bit refcon * values, this parameter uses typeRefCon. For 64-bit * compatibility, you must use typeRefCon when retrieving this * parameter; for 32-bit targets, however, you may continue to * use typeSInt32 if you wish, or switch to typeRefCon. * * <-- kEventParamControlResult (out, typeSInt32) * On exit, contains the result that should be returned from * SendControlMessage. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventControlArbitraryMessage = 201; {$endc} {not TARGET_CPU_64} { * Summary: * Control bounds change event attributes * * Discussion: * When the toolbox sends out a kEventControlBoundsChanged event, it * also sends along a parameter containing attributes of the event. * These attributes can be used to determine what aspect of the * control changed (position, size, or both). } const { * The dimensions of the control (width and height) changed. } kControlBoundsChangeSizeChanged = 1 shl 2; { * The top left corner (position) changed. } kControlBoundsChangePositionChanged = 1 shl 3; {--------------------------------------------------------------------------------------} { Tablet Events (and tablet data in mouse events) } {--------------------------------------------------------------------------------------} { kEventClassTablet quick reference: kEventTabletPoint = 1, kEventTabletProximity = 2, } { * kEventClassTablet / kEventTabletPoint * * Summary: * Indicates that the pen has moved on or near a tablet. * * Discussion: * Same as deprecated kEventTabletPointer. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamTabletPointRec (in, typeTabletPointRec) * Tablet information for the event. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventTabletPoint = 1; { * kEventClassTablet / kEventTabletProximity * * Summary: * Indicates that the pen has entered or exited proximity of a * tablet. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamTabletProximityRec (in, typeTabletProximityRec) * Tablet information for the event. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: not available } const kEventTabletProximity = 2; type TabletPointRecPtr = ^TabletPointRec; TabletPointRec = record absX: SInt32; { absolute x coordinate in tablet space at full tablet resolution } absY: SInt32; { absolute y coordinate in tablet space at full tablet resolution } absZ: SInt32; { absolute z coordinate in tablet space at full tablet resolution } buttons: UInt16; { one bit per button - bit 0 is first button - 1 = closed } pressure: UInt16; { scaled pressure value; MAXPRESSURE=(2^16)-1, MINPRESSURE=0 } tiltX: SInt16; { scaled tilt x value; range is -((2^15)-1) to (2^15)-1 (-32767 to 32767) } tiltY: SInt16; { scaled tilt y value; range is -((2^15)-1) to (2^15)-1 (-32767 to 32767) } rotation: UInt16; { Fixed-point representation of device rotation in a 10.6 format } tangentialPressure: SInt16; { tangential pressure on the device; range same as tilt } deviceID: UInt16; { system-assigned unique device ID - matches to deviceID field in proximity event } vendor1: SInt16; { vendor-defined signed 16-bit integer } vendor2: SInt16; { vendor-defined signed 16-bit integer } vendor3: SInt16; { vendor-defined signed 16-bit integer } end; type TabletPointerRec = TabletPointRec; TabletPointerRecPtr = ^TabletPointerRec; TabletProximityRecPtr = ^TabletProximityRec; TabletProximityRec = record vendorID: UInt16; { vendor-defined ID - typically will be USB vendor ID } tabletID: UInt16; { vendor-defined tablet ID - typically will be USB product ID for the tablet } pointerID: UInt16; { vendor-defined ID of the specific pointing device } deviceID: UInt16; { system-assigned unique device ID - matches to deviceID field in tablet event } systemTabletID: UInt16; { system-assigned unique tablet ID } vendorPointerType: UInt16; { vendor-defined pointer type } pointerSerialNumber: UInt32; { vendor-defined serial number of the specific pointing device } uniqueID: UInt64; { vendor-defined unique ID for this pointer } capabilityMask: UInt32; { mask representing the capabilities of the device. } { capability bits are defined in the tablet capability } { masks section of } pointerType: UInt8; { type of pointing device - enum to be defined } enterProximity: UInt8; { non-zero = entering; zero = leaving } end; {--------------------------------------------------------------------------------------} { Volume Events } {--------------------------------------------------------------------------------------} { kEventClassVolume quick reference: kEventVolumeMounted = 1, // new volume mounted kEventVolumeUnmounted = 2 // volume has been ejected or unmounted } const typeFSVolumeRefNum = FourCharCode('voln'); { FSVolumeRefNum} { * kEventClassVolume / kEventVolumeMounted * * Summary: * A new volume has been mounted (or new media inserted). * * Discussion: * This event is sent to all handlers registered for it. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeFSVolumeRefNum) * The volume refnum of the volume that was mounted. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.3.1 and later } const kEventVolumeMounted = 1; { * kEventClassVolume / kEventVolumeUnmounted * * Summary: * An existing volume has been unmounted (or media ejected). * * Discussion: * This event is sent to all handlers registered for it. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDirectObject (in, typeFSVolumeRefNum) * The volume refnum of the volume that was unmounted. At the * point when this event is sent, this is no longer a valid * volume refnum, and cannot be passed to any File Manager * API; it is useful only for comparison with cached volume * refnums in your own data structures. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.3.1 and later } const kEventVolumeUnmounted = 2; {--------------------------------------------------------------------------------------} { Appearance Events } {--------------------------------------------------------------------------------------} { kEventClassAppearance quick reference: kEventAppearanceScrollBarVariantChanged = 1 } { * kEventClassAppearance / kEventAppearanceScrollBarVariantChanged * * Summary: * The scroll bar variant has changed. Available on Mac OS X 10.1 * and later. * * Discussion: * This event is sent to all handlers registered for it on Mac OS X * 10.3 and later. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamNewScrollBarVariant (in, typeSInt16) * The new scroll bar variant. * * Availability: * Mac OS X: in version 10.1 and later in Carbon.framework * CarbonLib: not available } const kEventAppearanceScrollBarVariantChanged = 1; {--------------------------------------------------------------------------------------} { Services Events } {--------------------------------------------------------------------------------------} { kEventClassService quick reference: Services are a feature by which applications can communicate with one another to request and provide services. This communication happens either through the Pasteboard or Scrap Manager. When an event is sent that requires communication for processing or servicing a request, you will need to use the pasteboard or scrap given in the kEventParamPasteboardRef and kEventParamScrapRef parameters of the event in order to communicate. When your app requests a service, it is usually acting on data that is currently selected or in focus. Therefore all of the Services events are sent to the UserFocus event target.

Service events are available on Mac OS X 10.1 and later. kEventServiceCopy = 1, kEventServicePaste = 2, kEventServiceGetTypes = 3, kEventServicePerform = 4 } { * kEventClassService / kEventServiceCopy * * Summary: * The user has invoked a service that requires the application to * update the given pasteboard or scrap in the * kEventParamPasteboardRef and kEventParamScrapRef parameters with * appropriate data from the focus. * * Discussion: * On Mac OS X 10.3 and later, this event includes both a * PasteboardRef and a ScrapRef. A handler for this event should * provide its data using either Pasteboard or Scrap Manager APIs, * and the corresponding pasteboard or scrap reference, depending on * which is more convenient or appropriate. Data only needs to be * placed on one of the pasteboard or scrap; it does not need to be * placed on both. Data written to the pasteboard will also be * available on the scrap, and vice versa. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamPasteboardRef (in, typePasteboardRef) * Data from the current selection should be placed into this * pasteboard. This parameter is provided on Mac OS X 10.3 and * later. * * --> kEventParamScrapRef (in, typeScrapRef) * Data from the current selection should be placed into this * scrap. * * Availability: * Mac OS X: in version 10.1 and later in Carbon.framework * CarbonLib: not available } const kEventServiceCopy = 1; { * kEventClassService / kEventServicePaste * * Summary: * The user has invoked a service that requires the application to * update the current focus with data from the pasteboard or scrap * given in the kEventParamPasteboardRef and kEventParamScrapRef * parameters. * * Discussion: * On Mac OS X 10.3 and later, this event includes both a * PasteboardRef and a ScrapRef. A handler for this event should * retrieve its data using either Pasteboard or Scrap Manager APIs, * and the corresponding pasteboard or scrap reference, depending on * which is more convenient or appropriate. Data only needs to be * read from one of the pasteboard or scrap; it does not need to be * read from both. Data available on the pasteboard will also be * available on the scrap, and vice versa. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamPasteboardRef (in, typePasteboardRef) * The current selection should be replaced by data from this * pasteboard. This parameter is provided on Mac OS X 10.3 and * later. * * --> kEventParamScrapRef (in, typeScrapRef) * The current selection should be replaced by data from this * scrap. * * Availability: * Mac OS X: in version 10.1 and later in Carbon.framework * CarbonLib: not available } const kEventServicePaste = 2; { * kEventClassService / kEventServiceGetTypes * * Summary: * The Services Manager needs to know what types of data the * application can copy and paste to and from the pasteboard or * scrap in order to update the Services menu to enable items that * the user can select. * * Discussion: * This event sends two CFMutableArrayRefs for the application to * add the types to: the kEventParamServiceCopyTypes and the * kEventParamServicePasteTypes parameters. The types that are added * are CFStringRefs. There is a convenience function, * CreateTypeStringWithOSType, which takes an OSType and will create * a CFStringRef that you can add to the array(s). * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamServiceCopyTypes (in, typeCFMutableArrayRef) * Add CFStringRefs to this array to report the types that can * be copied from the current selection. These strings will be * released automatically after the event is handled. * * --> kEventParamServicePasteTypes (in, typeCFMutableArrayRef) * Add CFStringRefs to this array to report the types that can * be pasted into the currently focused object. These strings * will be released automatically after the event is handled. * * Availability: * Mac OS X: in version 10.1 and later in Carbon.framework * CarbonLib: not available } const kEventServiceGetTypes = 3; { * kEventClassService / kEventServicePerform * * Summary: * If the application is a service provider, this event will get * sent when a service is requested of the app. * * Discussion: * On Mac OS X 10.3 and later, this event includes both a * PasteboardRef and a ScrapRef. A handler for this event may * provide its data using either Pasteboard or Scrap Manager APIs, * and the corresponding pasteboard or scrap reference, depending on * which is more convenient or appropriate. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamPasteboardRef (in, typePasteboardRef) * The pasteboard that should be used to send and receive data * from the requester. This parameter is only provided on Mac * OS X 10.3 and later. * * --> kEventParamScrapRef (in, typeScrapRef) * The scrap that should be used to send and receive data from * the requester. * * --> kEventParamServiceMessageName (in, typeCFStringRef) * A string with the name of the advertised service that was * invoked. * * --> kEventParamServiceUserData (in, typeCFStringRef) * Extra data provided by the requestor. * * Availability: * Mac OS X: in version 10.1 and later in Carbon.framework * CarbonLib: not available } const kEventServicePerform = 4; {$ifc not TARGET_CPU_64} { * CreateTypeStringWithOSType() * * Discussion: * This routine is used to convert an OSType to a CFStringRef that * services will understand. * * Mac OS X threading: * Not thread safe * * Parameters: * * inType: * The OSType that needs to be converted to a CFString. * * Result: * A CFStringRef that contains the string that corresponds to the * given OSType. This follows CoreFoundation semantics in that it * will return NULL for failure, and because it is a "Create" * function you will need to CFRelease this string when it is no * longer needed. * * Availability: * Mac OS X: in version 10.1 and later in Carbon.framework [32-bit only] * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.1 and later * Non-Carbon CFM: not available } function CreateTypeStringWithOSType( inType: OSType ): CFStringRef; external name '_CreateTypeStringWithOSType'; (* AVAILABLE_MAC_OS_X_VERSION_10_1_AND_LATER *) {$endc} {not TARGET_CPU_64} { * kHIServicesMenuProviderName * * Discussion: * A CFDictionaryRef key in a dictionary returned by * CopyServicesMenuCommandKeys. The value for this key is the name * of the service provider represented as a CFString. } {$ifc USE_CFSTR_CONSTANT_MACROS} {$definec kHIServicesMenuProviderName CFSTRP('kHIServicesMenuProviderName')} {$endc} { * kHIServicesMenuItemName * * Discussion: * A CFDictionaryRef key in a dictionary returned by * CopyServicesMenuCommandKeys. The value for this key is the name * of the menu item represented as a CFString. } {$ifc USE_CFSTR_CONSTANT_MACROS} {$definec kHIServicesMenuItemName CFSTRP('kHIServicesMenuItemName')} {$endc} { * kHIServicesMenuCharCode * * Discussion: * A CFDictionaryRef key in a dictionary returned by * CopyServicesMenuCommandKeys. The value for this key is the * character code of the menu item shortcut, represented as a * CFString. } {$ifc USE_CFSTR_CONSTANT_MACROS} {$definec kHIServicesMenuCharCode CFSTRP('kHIServicesMenuCharCode')} {$endc} { * kHIServicesMenuKeyModifiers * * Discussion: * A CFDictionaryRef key in a dictionary returned by * CopyServicesMenuCommandKeys. The value for this key is the * keyboard modifiers of the menu item shortcut in Menu Manager * modifiers format, represented as a CFNumber. } {$ifc USE_CFSTR_CONSTANT_MACROS} {$definec kHIServicesMenuKeyModifiers CFSTRP('kHIServicesMenuKeyModifiers')} {$endc} {$ifc not TARGET_CPU_64} { * CopyServicesMenuCommandKeys() * * Summary: * Returns an array of CFDictionaryRefs containing information about * the command-key short cuts for items in the application services * menu. * * Discussion: * Each array entry is a CFDictionaryRef, and each dictionary * contains information about a single command key shortcut for * items in the application's Services menu. Each dictionary * contains the following keys: kHIServicesMenuProviderName, * kHIServicesMenuItemName, kHIServicesMenuCharCode, and * kHIServicesMenuKeyModifiers. The array must be released by the * caller; the dictionaries do not need to be released (they will be * auto-released when the array is released). * * Mac OS X threading: * Not thread safe * * Parameters: * * outCommandKeyArray: * On exit, contains an array of the values of the Services menu * items that have command key shortcuts associated with them. * * Result: * An operating system status code. * * Availability: * Mac OS X: in version 10.4 and later in Carbon.framework [32-bit only] * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.4 and later * Non-Carbon CFM: not available } function CopyServicesMenuCommandKeys( var outCommandKeyArray: CFArrayRef ): OSStatus; external name '_CopyServicesMenuCommandKeys'; (* AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER *) {--------------------------------------------------------------------------------------} { System Events } {--------------------------------------------------------------------------------------} { kEventClassSystem quick reference: kEventSystemTimeDateChanged = 2, kEventSystemDisplaysAsleep = 3, kEventSystemDisplaysAwake = 4, kEventSystemDisplayReconfigured = 6, kEventSystemUserSessionActivated = 10, kEventSystemUserSessionDeactivated = 11 } { * kEventClassSystem / kEventSystemTimeDateChanged * * Summary: * The system time and/or date has changed via the preferences panel. * * Discussion: * This event is sent to all handlers registered for it on the * application event target. * * Mac OS X threading: * Not thread safe * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available } {$endc} {not TARGET_CPU_64} const kEventSystemTimeDateChanged = 2; { * kEventClassSystem / kEventSystemDisplaysAsleep * * Summary: * All connected displays have gone to sleep. * * Discussion: * This event is sent to all handlers registered for it on the * application event target. * * Mac OS X threading: * Not thread safe * * Availability: * Mac OS X: in version 10.4 and later in Carbon.framework * CarbonLib: not available } const kEventSystemDisplaysAsleep = 3; { * kEventClassSystem / kEventSystemDisplaysAwake * * Summary: * All connected displays have awoken. * * Discussion: * This event is sent to all handlers registered for it on the * application event target. * * Mac OS X threading: * Not thread safe * * Availability: * Mac OS X: in version 10.4 and later in Carbon.framework * CarbonLib: not available } const kEventSystemDisplaysAwake = 4; { * kEventClassSystem / kEventSystemDisplayReconfigured * * Summary: * Notification that the Display configuration has changed * * Discussion: * This event is sent to all handlers registered for it on the * application event target. When this event is received, * applications may wish to update geometry and color depth usage or * perform a redraw based on the new configuration. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamDisplayChangeFlags (in, typeCGDisplayChangeFlags) * The CGDisplayChangeSummaryFlags specifying what display * config changes occurred. See * CoreGraphics/CGDisplayConfiguration.h for more information * on these flags. * * Availability: * Mac OS X: in version 10.5 and later in Carbon.framework * CarbonLib: not available } const kEventSystemDisplayReconfigured = 6; { * kEventClassSystem / kEventSystemUserSessionActivated * * Summary: * The current user login session has been activated. * * Discussion: * This event is sent to all handlers registered for it on the * application event target. It is sent when the Fast User Switching * feature of Mac OS X 10.3 is used to activate the login session in * which the current application is running. * * Mac OS X threading: * Not thread safe * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available } const kEventSystemUserSessionActivated = 10; { * kEventClassSystem / kEventSystemUserSessionDeactivated * * Summary: * The current user login session has been deactivated. * * Discussion: * This event is sent to all handlers registered for it on the * application event target. It is sent when the Fast User Switching * feature of Mac OS X 10.3 is used to switch to another user's * login session. * * Mac OS X threading: * Not thread safe * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available } const kEventSystemUserSessionDeactivated = 11; {--------------------------------------------------------------------------------------} { Installing Event Handlers } {--------------------------------------------------------------------------------------} {$ifc not TARGET_CPU_64} { * GetWindowEventTarget() * * Discussion: * Returns the EventTargetRef for the specified window. Once you * obtain this reference, you can send events to the target and * install an event handler on it. * * Mac OS X threading: * Not thread safe * * Parameters: * * inWindow: * The window to return the target for. * * Result: * An EventTargetRef. * * 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 GetWindowEventTarget( inWindow: WindowRef ): EventTargetRef; external name '_GetWindowEventTarget'; (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *) { * GetControlEventTarget() * * Discussion: * Returns the EventTargetRef for the specified control. Once you * obtain this reference, you can send events to the target and * install event handler on it. * * Mac OS X threading: * Not thread safe * * Parameters: * * inControl: * The control to return the target for. * * Result: * An EventTargetRef. * * 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 GetControlEventTarget( inControl: ControlRef ): EventTargetRef; external name '_GetControlEventTarget'; (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *) { * GetMenuEventTarget() * * Discussion: * Returns the EventTargetRef for the specified menu. Once you * obtain this reference, you can send events to the target and * install event handler on it. * * Mac OS X threading: * Not thread safe * * Parameters: * * inMenu: * The menu to return the target for. * * Result: * An EventTargetRef. * * 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 GetMenuEventTarget( inMenu: MenuRef ): EventTargetRef; external name '_GetMenuEventTarget'; (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *) {$endc} {not TARGET_CPU_64} { * GetApplicationEventTarget() * * Discussion: * Returns the EventTargetRef for the application. Once you obtain * this reference, you can send events to the target and install * event handler on it. * * Mac OS X threading: * Not thread safe * * Result: * An EventTargetRef. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later * Non-Carbon CFM: not available } function GetApplicationEventTarget: EventTargetRef; external name '_GetApplicationEventTarget'; (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *) {$ifc not TARGET_CPU_64} { * GetUserFocusEventTarget() * * Discussion: * Returns the EventTargetRef for the current user focus at the time * of the call. Keyboard events are always sent to this target. * Events that are sent to this target are automatically propagated * to the following other targets: first to the focused control in * the focused window, then up the control hierarchy to the focused * window itself, and then to the application target. * * Note that command key processing occurs before key events are * sent to this target; to intercept key events before command key * processing occurs, install a handler on the event dispatcher * target instead of this target. * * Mac OS X threading: * Not thread safe * * Result: * An EventTargetRef. * * 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 GetUserFocusEventTarget: EventTargetRef; external name '_GetUserFocusEventTarget'; (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *) {$endc} {not TARGET_CPU_64} { * GetEventDispatcherTarget() * * Discussion: * Returns the EventTargetRef for the standard toolbox dispatcher. * You typically would never need to use this, but there are some * exotic apps that need to pick events off the event queue and call * the dispatcher themselves. This allows you to do just that * instead of calling RunApplicationEventLoop to handle it all. * * Mac OS X threading: * Not thread safe * * Result: * An EventTargetRef. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.3 and later * Non-Carbon CFM: not available } function GetEventDispatcherTarget: EventTargetRef; external name '_GetEventDispatcherTarget'; (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *) { * GetEventMonitorTarget() * * Summary: * Returns the event monitor target. * * Discussion: * The event monitor target is a special event target used to * monitor user input events across all processes. When an event * handler is installed on the event monitor target, the Carbon * Event Manager examines the EventTypeSpec for user input event * types, such as mouse-down, mouse-up, key-down, and so forth. It * then requests that the WindowServer make copies of any of these * events that are sent to any process, and deliver them to the * current process also. These events are queued into the main * threadÕs event queue, and during normal event dispatching are * sent directly to the event handlers installed on the event * monitor target. Monitored events are not sent through the normal * event dispatching path for the current process; they will pass * through the event dispatcher target, and will then be sent * directly to the event monitor target. * * Handlers installed on the event monitor target will only receive * events when the current application is inactive. When the current * application is active, all event flow occurs through the event * dispatcher target, and no events are sent to the event monitor * target. * * Currently, the event monitor supports the following event kinds: * kEventRawKeyDown, kEventRawKeyUp, kEventRawKeyRepeat, * kEventRawKeyModifiersChanged, kEventMouseDown, kEventMouseUp, * kEventMouseMoved, kEventMouseDragged, kEventMouseWheelMoved, * kEventTabletPoint, and kEventTabletProximity. * * Note that both Carbon and Cocoa password edit text controls * enable a secure input mode while the focus is on the control, * which prevents keyboard events from being passed to other * applications. This prevents the monitoring event target from * being used to sniff password keystrokes. * * For added security, GetEventMonitorTarget requires that "Enable * access for assistive devices" be checked in the Universal Access * preference pane in order to monitor RawKeyDown, RawKeyUp, and * RawKeyRepeat events. If this control is not checked, you can * still install handlers for these events on the event monitor * target, but no events of these types will be sent to your * handler. Administrator privileges are required to enable this * feature. You can determine whether this control is checked using * the AXAPIEnabled API in AXUIElement.h. * * Mac OS X threading: * Not thread safe * * Result: * An EventTargetRef. * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.3 and later * Non-Carbon CFM: not available } function GetEventMonitorTarget: EventTargetRef; external name '_GetEventMonitorTarget'; (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *) (* #define InstallApplicationEventHandler( handler, numTypes, list, userData, outHandlerRef ) \ InstallEventHandler( GetApplicationEventTarget(), (handler), (numTypes), (list), (userData), (outHandlerRef) ) #define InstallHIObjectEventHandler( target, handler, numTypes, list, userData, outHandlerRef ) \ InstallEventHandler( HIObjectGetEventTarget( target ), (handler), (numTypes), (list), (userData), (outHandlerRef) ) #define InstallWindowEventHandler( target, handler, numTypes, list, userData, outHandlerRef ) \ InstallEventHandler( GetWindowEventTarget( target ), (handler), (numTypes), (list), (userData), (outHandlerRef) ) #define InstallControlEventHandler( target, handler, numTypes, list, userData, outHandlerRef ) \ InstallEventHandler( GetControlEventTarget( target ), (handler), (numTypes), (list), (userData), (outHandlerRef) ) #define InstallMenuEventHandler( target, handler, numTypes, list, userData, outHandlerRef ) \ InstallEventHandler( GetMenuEventTarget( target ), (handler), (numTypes), (list), (userData), (outHandlerRef) ) #define HIViewInstallEventHandler( target, handler, numTypes, list, userData, outHandlerRef ) \ InstallEventHandler( HIObjectGetEventTarget( (HIObjectRef) (target) ), (handler), (numTypes), (list), (userData), (outHandlerRef) ) { You can use the following macro in your code to allow you to set up an event handler lazily. You pass the name of your event handler in. You should use this with caution on Mac OS 9 systems since it could cause heap fragmentation. } #define DEFINE_ONE_SHOT_HANDLER_GETTER( x ) \ EventHandlerUPP Get ## x ## UPP() \ { \ static EventHandlerUPP sHandler = NULL; \ \ if ( sHandler == NULL ) \ sHandler = NewEventHandlerUPP( x ); \ \ return sHandler; \ } #define SendEventToApplication( e ) \ SendEventToEventTarget( (e), GetApplicationEventTarget() ) #define SendEventToHIObject( e, t ) \ SendEventToEventTarget( (e), HIObjectGetEventTarget( t ) ) #define SendEventToWindow( e, t ) \ SendEventToEventTarget( (e), GetWindowEventTarget( t ) ) #define SendEventToControl( e, t ) \ SendEventToEventTarget( (e), GetControlEventTarget( t ) ) #define SendEventToMenu( e, t ) \ SendEventToEventTarget( (e), GetMenuEventTarget( t ) ) #define SendEventToUserFocus( e ) \ SendEventToEventTarget( (e), GetUserFocusEventTarget() ) *) {======================================================================================} { ¥ Command Routines } {======================================================================================} { * ProcessHICommand() * * Summary: * Sends a kEventCommandProcess event. * * Discussion: * ProcessHICommand is a convenience function for dispatching * kEventCommandProcesss events. Normally these events are created * and dispatched automatically by the toolbox when a menu item or * control is selected, but you may need to dispatch an event * yourself at times. This API creates a CommandProcess event, adds * the specified HICommand structure as an event parameter, and * sends the event to the user focus target for handling. * * If you need to send a CommandProcess event to some other target, * or you need to add other event parameters to the event besides * the HICommand structure, it is correct and supported to simply * create the event yourself and send it to the desired target, * without using this API. * * Mac OS X threading: * Not thread safe * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.1 and later * Non-Carbon CFM: not available } function ProcessHICommand( const (*var*) inCommand: HICommand ): OSStatus; external name '_ProcessHICommand'; (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *) {--------------------------------------------------------------------------------------} { ¥ Event Loop Routines } {--------------------------------------------------------------------------------------} {$ifc not TARGET_CPU_64} { * RunApplicationEventLoop() * * Discussion: * This routine is used as the main event loop for a Carbon * Event-based application. Once entered, this function waits for * events to arrive and dispatches them to your event handlers * automatically. * * Mac OS X threading: * Not thread safe * * 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 } procedure RunApplicationEventLoop; external name '_RunApplicationEventLoop'; (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *) { * QuitApplicationEventLoop() * * Discussion: * This routine is used to quit the RunApplicationEventLoop * function. Typically, your application doesn't need to call this. * If your application has the Quit menu item tagged with the * kHICommandQuit Menu Command ID, the toolbox will automatically * call this for your application, automatically terminating your * event loop. If your application wants to do pre-processing before * the event loop exits, it should intercept either the * kHICommandQuit menu command, or the kEventAppQuit event. * * Mac OS X threading: * Not thread safe * * 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 } procedure QuitApplicationEventLoop; external name '_QuitApplicationEventLoop'; (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *) {--------------------------------------------------------------------------------------} { ¥ Event Modality routines } {--------------------------------------------------------------------------------------} { * RunAppModalLoopForWindow() * * Discussion: * This routine is used as a replacement to ModalDialog to drive a * Carbon Event-based modal dialog. Once called, this routine will * not exit until QuitAppModalLoopForWindow is called. Calls to * RunAppModalLoopForWindow can be nested, as long as each call is * made on a different window. The window must be visible when * calling RunAppModalLoopForWindow; otherwise, windowWrongStateErr * is returned. In Mac OS X 10.0.x, RunAppModalLoopForWindow will * fail to re-enable the menubar before exiting if you dispose of * the window during the modal loop (for example, from a Carbon * event handler). You can work around this bug by retaining the * window before calling RunAppModalLoopForWindow, and releasing it * afterwards. * * Mac OS X threading: * Not thread safe * * Parameters: * * inWindow: * The window you wish to behave modally. * * Result: * An operating system status code. windowWrongStateErr will be * returned if the window is invisible. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework [32-bit only] * CarbonLib: in CarbonLib 1.3 and later * Non-Carbon CFM: not available } function RunAppModalLoopForWindow( inWindow: WindowRef ): OSStatus; external name '_RunAppModalLoopForWindow'; (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *) { * QuitAppModalLoopForWindow() * * Discussion: * This routine is used to quit a currently running call to * RunAppModalLoopForWindow, i.e. it terminates a modal loop. * Typically this would be called from a handler you have installed * on the modal window in question when the user clicks the * appropriate button, etc. * * Mac OS X threading: * Not thread safe * * Parameters: * * inWindow: * The window for which to quit the modal state. * * Result: * An operating system status code. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework [32-bit only] * CarbonLib: in CarbonLib 1.3 and later * Non-Carbon CFM: not available } function QuitAppModalLoopForWindow( inWindow: WindowRef ): OSStatus; external name '_QuitAppModalLoopForWindow'; (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *) { * BeginAppModalStateForWindow() * * Discussion: * This routine is a lower level routine than * RunAppModalLoopForWindow. It can be used if you wish to enter an * app modal state for a window, but need to control the event loop * yourself for whatever reason. In most cases, you would use * RunAppModalLoopForWindow. Once you begin your app modal state, * the menu bar will disable and prepare for the modal situation. * The window must be visible when calling * BeginAppModalStateForWindow; otherwise, windowWrongStateErr is * returned. Calls to BeginAppModalStateForWindow can be nested, as * long as each call is made on a different window. In Mac OS 10.0.x * and CarbonLib 1.3.1, BeginAppModalStateForWindow can only be * called on a window once; future calls will return an error. This * bug is fixed in Mac OS 10.1 and CarbonLib 1.4. * * Mac OS X threading: * Not thread safe * * Parameters: * * inWindow: * The window you wish to behave modally. * * Result: * An operating system status code. windowWrongStateErr will be * returned if the window is invisible. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework [32-bit only] * CarbonLib: in CarbonLib 1.3 and later * Non-Carbon CFM: not available } function BeginAppModalStateForWindow( inWindow: WindowRef ): OSStatus; external name '_BeginAppModalStateForWindow'; (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *) { * EndAppModalStateForWindow() * * Discussion: * This routine ends an app modal state started with * BeginAppModalStateForWindow. * * Mac OS X threading: * Not thread safe * * Parameters: * * inWindow: * The window you wish to stop acting as app modal. * * Result: * An operating system status code. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework [32-bit only] * CarbonLib: in CarbonLib 1.3 and later * Non-Carbon CFM: not available } function EndAppModalStateForWindow( inWindow: WindowRef ): OSStatus; external name '_EndAppModalStateForWindow'; (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *) {--------------------------------------------------------------------------------------} { ¥ Global HotKey API } {--------------------------------------------------------------------------------------} {$endc} {not TARGET_CPU_64} type EventHotKeyIDPtr = ^EventHotKeyID; EventHotKeyID = record signature: OSType; id: UInt32; end; type EventHotKeyRef = ^OpaqueEventHotKeyRef; { an opaque type } OpaqueEventHotKeyRef = record end; { * HotKeyOptions * * Summary: * Constants for the inOptions parameter of RegisterEventHotKey. } const { * No options specified. } kEventHotKeyNoOptions = 0; { * Hot keys are normally non-exclusive: when the key is pressed, * notification events are sent to all registrants for that hotkey. * Registering an exclusive hotkey prevents non-exclusive registrants * for the same key code and modifiers from receiving notification * events, as long as the exclusive registrant is enabled. When the * exclusive entry is disabled or removed, or the owning app goes * away, non-exclusive registrants will be able to receive * notifications as normal. * * While a key is registered as an exclusive key, non-exclusive * registrations are accepted as normal, but will not receive * notification events until the exclusive hot key is disabled, * removed, or the owning app goes away. * * An error is returned when an attempt is made to register an * exclusive key while another hot key is already registered for that * key code and modifiers. *
This option is available in Mac OS X 10.5 and later. } kEventHotKeyExclusive = 1 shl 0; { * RegisterEventHotKey() * * Discussion: * Registers a global hot key based on the virtual key code and * modifiers you pass in. Only one such combination can exist for * the current application, i.e. multiple entities in the same * application cannot register for the same hot key combination. The * same hot key can, however, be registered by multiple * applications. This means that multiple applications can * potentially be notified when a particular hot key is requested. * In Mac OS X 10.5 and later, you can request exclusive * registration for your process only by passing * kEventHotKeyExclusive for the inOptions parameter. * * Mac OS X threading: * Not thread safe * * Parameters: * * inHotKeyCode: * The virtual key code of the key to watch * * inHotKeyModifiers: * The keyboard modifiers to look for. On Mac OS X 10.2 or * earlier, this parameter must be non-zero, i.e. there must be a * modifier specified. On Mac OS X 10.3 or later, you may pass * zero. * * inHotKeyID: * The application-specified hot key ID. You will receive this in * the kEventHotKeyPressed event as the direct object parameter. * * inTarget: * The target to notify when the hot key is pressed. * * inOptions: * In Mac OS X 10.5 and later, you may pass either zero or * kEventHotKeyExclusive. Prior to Mac OS X 10.5, you must pass * zero. * * outRef: * The EventHotKeyRef that represents your new hot key. You need * this if you later wish to unregister it. * * Result: * An operating system status code. eventHotKeyExistsErr is returned * if an attempt is made to register a hotkey using the * kEventHotKeyExclusive option when another process has already * registered the same hotkey using the kEventHotKeyExclusive option. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.3 and later * Non-Carbon CFM: not available } function RegisterEventHotKey( inHotKeyCode: UInt32; inHotKeyModifiers: UInt32; inHotKeyID: EventHotKeyID; inTarget: EventTargetRef; inOptions: OptionBits; var outRef: EventHotKeyRef ): OSStatus; external name '_RegisterEventHotKey'; (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *) { * UnregisterEventHotKey() * * Discussion: * Unregisters a global hot key that was previously registered with * the RegisterEventHotKey API. You do not need to unregister a hot * key when your application terminates; the system will take care * of that for you. This would be used if the user changes a hot key * for something in your application - you would unregister the * previous key and register your new key. * * Mac OS X threading: * Not thread safe * * Parameters: * * inHotKey: * The EventHotKeyRef to unregister. * * Result: * An operating system status code. * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework * CarbonLib: in CarbonLib 1.3 and later * Non-Carbon CFM: not available } function UnregisterEventHotKey( inHotKey: EventHotKeyRef ): OSStatus; external name '_UnregisterEventHotKey'; (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER *) { * kHISymbolicHotKeyCode * * Discussion: * A CFDictionaryRef key in a dictionary returned by * CopySymbolicHotKeys. The value for this key is the virtual * keycode of the hotkey, represented as a CFNumber. } {$ifc USE_CFSTR_CONSTANT_MACROS} {$definec kHISymbolicHotKeyCode CFSTRP('kHISymbolicHotKeyCode')} {$endc} { * kHISymbolicHotKeyModifiers * * Discussion: * A CFDictionaryRef key in a dictionary returned by * CopySymbolicHotKeys. The value for this key is the keyboard * modifiers of the hotkey, represented as a CFNumber. } {$ifc USE_CFSTR_CONSTANT_MACROS} {$definec kHISymbolicHotKeyModifiers CFSTRP('kHISymbolicHotKeyModifiers')} {$endc} { * kHISymbolicHotKeyEnabled * * Discussion: * A CFDictionaryRef key in a dictionary returned by * CopySymbolicHotKeys. The value for this key is the enable state * of the hotkey, represented as a CFBoolean. } {$ifc USE_CFSTR_CONSTANT_MACROS} {$definec kHISymbolicHotKeyEnabled CFSTRP('kHISymbolicHotKeyEnabled')} {$endc} { * CopySymbolicHotKeys() * * Summary: * Returns an array of CFDictionaryRefs containing information about * the system-wide symbolic hotkeys that are defined in the Keyboard * preferences pane. * * Discussion: * The hotkey info returned by this API describes the system-wide * hotkeys such as the Screen Capture, Universal Access, and * Keyboard Navigation keys. It does not include customized * application-specific command keys. * * Each array entry is a CFDictionaryRef, and each dictionary * contains information about a single hotkey. There is currently no * way to determine which hotkey in the Keyboards preference pane * corresponds to a specific dictionary. Each dictionary contains * the following keys: kHISymbolicHotKeyCode, * kHISymbolicHotKeyModifiers, and kHISymbolicHotKeyEnabled. The * array must be released by the caller; the dictionaries do not * need to be released (they will be auto-released when the array is * released). * * Note that this API will require O(number of hotkeys) to run, and * the number of hotkeys will increase in the future, so do not call * this API unnecessarily or in highly performance-sensitive code. * * Mac OS X threading: * Not thread safe * * Parameters: * * outHotKeyArray: * On exit, contains an array of the values of all symbolic hot * keys. * * Result: * An operating system result code; currently, noErr and memFullErr * may be returned. * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.3 and later * Non-Carbon CFM: not available } function CopySymbolicHotKeys( var outHotKeyArray: CFArrayRef ): OSStatus; external name '_CopySymbolicHotKeys'; (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *) { * Summary: * Parameters to the PushSymbolicHotKeyMode API. } const { * All hotkeys are enabled. } kHIHotKeyModeAllEnabled = 0; { * All hotkeys are disabled. } kHIHotKeyModeAllDisabled = 1 shl 0; { * All hotkeys are disabled except for the Universal Access hotkeys * (zooming, white-on-black, and enhanced contrast). } kHIHotKeyModeAllDisabledExceptUniversalAccess = 1 shl 1; { * PushSymbolicHotKeyMode() * * Summary: * Sets a new mode for enabling or disabling symbolic hotkeys. * * Discussion: * The Event Manager keeps a stack of hotkey modes that have been * requested using the PushSymbolicHotKeyMode API. The most recently * pushed mode is the mode that is currently in use. * * Because disabling hotkeys can significantly affect the usability * of Mac OS X, applications are only allowed to disable hotkeys if * the "Enable access for assistive devices" checkbox is checked in * the Universal Access preference pane. If this feature is not * enabled, PushSymbolicHotKeyMode will still push the mode request * onto the mode stack and return a valid token, but the actual * hotkey mode will not change. * * If an application that pushes a new hotkey mode is frontmost, * then the new mode (if it disables any hotkeys) will only be * active while the application remains frontmost. If the * application is deactivated or exits without reenabling hotkeys, * the hotkey mode will automatically revert to the previous mode. * * Mac OS X threading: * Not thread safe * * Parameters: * * inOptions: * The symbolic hotkey mode that is requested. * * Result: * A token that should be passed to PopSymbolicHotKeyMode to remove * this mode request from the stack. * * 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 PushSymbolicHotKeyMode( inOptions: OptionBits ): UnivPtr; external name '_PushSymbolicHotKeyMode'; (* AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER *) { * PopSymbolicHotKeyMode() * * Summary: * Removes a hotkey mode request from the hotkey mode stack. * * Discussion: * This API removes a mode request from the mode stack. If this * request was the topmost request in the stack, the actual hotkey * mode will change to the next request in the stack; if there are * other mode requests on top of this one on the stack, the actual * mode will not change. * * Mac OS X threading: * Not thread safe * * Parameters: * * inToken: * A hotkey mode token that was returned by PushSymbolicHotKeyMode. * * 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 } procedure PopSymbolicHotKeyMode( inToken: UnivPtr ); external name '_PopSymbolicHotKeyMode'; (* AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER *) { * GetSymbolicHotKeyMode() * * Summary: * Returns the current hotkey mode in use. * * Mac OS X threading: * Not thread safe * * Result: * The mode request at the top of the hotkey mode stack. If there * are no requests on the stack, it returns zero, indicating that * hotkeys are currently enabled. * * Note that even if hotkeys are enabled in the current process, * hotkeys can still be disabled for the current user session if * they are disabled by some other process. * * Note that if "Enable access for assistive devices" is not checked * in the Universal Access preference pane, then even if this API * returns a non-zero value, the actual hotkey mode will still be * that all hotkeys are enabled. * * 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 GetSymbolicHotKeyMode: OptionBits; external name '_GetSymbolicHotKeyMode'; (* AVAILABLE_MAC_OS_X_VERSION_10_4_AND_LATER *) {--------------------------------------------------------------------------------------} { Ink Events } {--------------------------------------------------------------------------------------} const kEventParamInkTextRef = FourCharCode('iwrd'); { typePtr } kEventParamInkKeyboardShortcut = FourCharCode('ikbd'); { typeBoolean } kEventParamInkGestureKind = FourCharCode('gknd'); { typeUInt32 } kEventParamInkGestureBounds = FourCharCode('gbnd'); { typeHIRect } kEventParamInkGestureHotspot = FourCharCode('ghot'); { typeHIPoint } { * kEventClassInk / kEventInkPoint * * Summary: * A mouse event will be handled as an Ink point and used for * recognition. * * Discussion: * The Ink manager has determined that the mouse event in * kEventParamEventRef should be used for recognition. If the * application handles the event and returns noErr, then the Ink * Manager does nothing further with the mouse event. If the * application returns any other value (including * eventNotHandledErr), the point will be processed normally by the * Ink Manager. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamEventRef (in, typeEventRef) * The mouse event being handled. * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available } const kEventInkPoint = 10; { * kEventClassInk / kEventInkGesture * * Summary: * An Ink gesture has been generated. * * Discussion: * This Ink event is sent when the Ink Manager has recognized the * current ink phrase as one of the known system gestures. * Applications can install a handler for these events, to provide * targeted gestures and support for context-dependent (tentative) * gestures. Applications should return noErr if they handled the * gesture. If the gesture was context-dependent and does not apply * to the current situation, then return eventNotHandledErr. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamInkGestureKind (in, typeUInt32) * Kind of gesture. * * --> kEventParamInkGestureBounds (in, typeHIRect) * Bounds of the gesture in global coordinates. * * --> kEventParamInkGestureHotspot (in, typeHIPoint) * Hotspot for the gesture in global coordinates. * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available } const kEventInkGesture = 11; { * kEventClassInk / kEventInkText * * Summary: * A recognized word from the Ink Manager. * * Discussion: * The Ink Manager has recognized a word. kEventParamInkTextRef * contains the InkTextRef with all of the information about the * word. See Ink.h for more information. * * Mac OS X threading: * Not thread safe * * Parameters: * * --> kEventParamInkTextRef (in, typePtr) * The InkTextRef containing the data for the recognized word. * * --> kEventParamInkKeyboardShortcut (in, typeBoolean) * Is this likely a keyboard shortcut? (Command or Control key * is held down and the top-choice alternate text is a single * character.) * * Availability: * Mac OS X: in version 10.3 and later in Carbon.framework * CarbonLib: not available } const kEventInkText = 12; {--------------------------------------------------------------------------------------} { ¥ DEPRECATED } { All functions below this point are either deprecated (they continue to function } { but are not the most modern nor most efficient solution to a problem), or they are } { completely unavailable on Mac OS X. } {--------------------------------------------------------------------------------------} {$ifc not TARGET_CPU_64} {--------------------------------------------------------------------------------------} { ¥ MouseTrackingRegions } {--------------------------------------------------------------------------------------} { * MouseTrackingRef * * Discussion: * MouseTrackingRef *** DEPRECATED *** * * Deprecated: * Applications should use HIViewTrackingAreas, described in * HIView.h, instead of MouseTrackingRegions and their associated * settings. * * A MouseTrackingRef is an object that controls the generation of * mouse-enter and mouse-exit events. When the user moves the mouse * into a tracking region, a kEventClassMouse/kEventMouseEntered * event is sent to the app. When the user moves the mouse out of a * tracking region, an event of type * kEventClassMouse/kEventMouseExited is sent. * * Mouse tracking regions are uniquely identified within the scope * of a window by a MouseTrackingRegionID which is a client * signature/id pair. The client signature should be any unique * four-character constant that does not have entirely lowercase * characters; a good choice is the usual DTS-registered creator * OSType, but you can use any constant that you like. * * Mouse tracking regions can overlap, but are not exclusive. Mouse * motion events are generated for each of the tracking areas * intersected by the mouse. * * Mouse tracking regions are initially enabled. You can explicitly * disable a mouse tracking area to prevent mouse-enter/exit events * from being generated. * * Unlike global mouse-moved events, mouse-enter and mouse-exit * events are generated while your app is in the background. If this * is not considered desirable, disable the tracking areas while the * application is in the background. * * MouseTrackingRefs become invalid when the window that they are * bound to is disposed. } type MouseTrackingRef = ^OpaqueMouseTrackingRef; { an opaque type } OpaqueMouseTrackingRef = record end; { * MouseTrackingOptions * * Discussion: * MouseTrackingOptions *** DEPRECATED *** * * Deprecated: * Applications should use HIViewTrackingAreas, described in * HIView.h, instead of MouseTrackingRegions and their associated * settings. * * These values define how the userÕs region is handled by the Mouse * Tracking Region API. They define the behavior throughout the life * of the Mouse Tracking Region. For example, if a region is created * with the option of kMouseTrackingOptionsGlobalClip then all * operations on this region will be interpreted in global * coordinates and will be clipped to the owning windowÕs structure. } type MouseTrackingOptions = UInt32; const { * The region is expected in local coordinates and mouse movement * tracking is clipped to the owning windowÕs content region. } kMouseTrackingOptionsLocalClip = 0; { * The region is expected in global coordinates and mouse movement * tracking is clipped to the owning windowÕs structure region. } kMouseTrackingOptionsGlobalClip = 1; { * Standard options. The region will be handled in local coordinates * and remain clipped against the windows content region. } kMouseTrackingOptionsStandard = kMouseTrackingOptionsLocalClip; type MouseTrackingRegionID = record signature: OSType; id: SInt32; end; {$endc} {not TARGET_CPU_64} { Creation} {$ifc not TARGET_CPU_64} { * CreateMouseTrackingRegion() *** DEPRECATED *** * * Deprecated: * Use HIView-based tracking areas instead of MouseTrackingRegions. * In this case, use HIViewNewTrackingArea(), defined in HIView.h, * instead of CreateMouseTrackingRegion(). * * Discussion: * Creates a mouse tracking region and installs it into the window * system. * * Mac OS X threading: * Not thread safe * * Parameters: * * inWindow: * The window that will contain the created region. * * inRegion: * The region for which you will receive entered/exit events. * * inClip: * A region to clip inRegion against (can be NULL). * * inOptions: * The options which define whether inRegion is given in global or * local coordinates. If local coordinates are used, inRegion will * be clipped against the window's current content region; if * global coordinates are used, inRegion will be clipped against * the window's current structure region. All clipping occurs * against the regions as they are at the moment when the tracking * region is created; changes to the window content or structure * regions after the tracking region is created will not affect * the tracking region. * * inID: * The signature/id pair which uniquely defines this region. Note * that if you are creating both LocalClip and GlobalClip tracking * regions for a given window, the global regions must use a * different inID.signature value from the local regions. * * inRefCon: * Any user defined value. This value can be retrieved later by * calling GetMouseTrackingRegionRefCon on the MouseTrackingRef. * * inTargetToNotify: * The event target that should receive kEventMouseEntered/Exited * events for this tracking region. If NULL, the windowÕs event * target receives these events. * * outTrackingRef: * A reference to the newly created mouse tracking region. This * reference will also be provided in the * kEventMouseEntered/Exited events sent to your event target. * * Result: * An operating system status code. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework [32-bit only] but deprecated in 10.4 * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later * Non-Carbon CFM: not available } function CreateMouseTrackingRegion( inWindow: WindowRef; inRegion: RgnHandle; inClip: RgnHandle { can be NULL }; inOptions: MouseTrackingOptions; inID: MouseTrackingRegionID; inRefCon: UnivPtr; inTargetToNotify: EventTargetRef { can be NULL }; var outTrackingRef: MouseTrackingRef ): OSStatus; external name '_CreateMouseTrackingRegion'; (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER_BUT_DEPRECATED_IN_MAC_OS_X_VERSION_10_4 *) { * RetainMouseTrackingRegion() *** DEPRECATED *** * * Deprecated: * Use HIView-based tracking areas, described in HIView.h, instead * of MouseTrackingRegions. * * Discussion: * Retains the MouseTrackingRef. * * Mac OS X threading: * Not thread safe * * Parameters: * * inMouseRef: * A valid MouseTrackingRef to retain. * * Result: * An operating system status code. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework [32-bit only] but deprecated in 10.4 * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later * Non-Carbon CFM: not available } function RetainMouseTrackingRegion( inMouseRef: MouseTrackingRef ): OSStatus; external name '_RetainMouseTrackingRegion'; (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER_BUT_DEPRECATED_IN_MAC_OS_X_VERSION_10_4 *) { * ReleaseMouseTrackingRegion() *** DEPRECATED *** * * Deprecated: * Use HIView-based tracking areas instead of MouseTrackingRegions. * In this case, use HIViewDisposeTrackingArea(), defined in * HIView.h, instead of ReleaseMouseTrackingRegion(). * * Discussion: * Releases the MouseTrackingRef. Since mouse tracking regions are * bound to a window, they are automatically released when the * window is disposed of. * * Mac OS X threading: * Not thread safe * * Parameters: * * inMouseRef: * A valid MouseTrackingRef to release. * * Result: * An operating system status code. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework [32-bit only] but deprecated in 10.4 * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later * Non-Carbon CFM: not available } function ReleaseMouseTrackingRegion( inMouseRef: MouseTrackingRef ): OSStatus; external name '_ReleaseMouseTrackingRegion'; (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER_BUT_DEPRECATED_IN_MAC_OS_X_VERSION_10_4 *) { * ChangeMouseTrackingRegion() *** DEPRECATED *** * * Deprecated: * Use HIView-based tracking areas instead of MouseTrackingRegions. * In this case, use HIViewChangeTrackingArea(), defined in * HIView.h, instead of ChangeMouseTrackingRegion(). * * Discussion: * Changes the MouseTrackingRefs region and optionally, its clip. * This will not change the enabled state or options of the region. * * Mac OS X threading: * Not thread safe * * Parameters: * * inMouseRef: * A valid MouseTrackingRef to modify. * * inRegion: * The region to set as the mouse tracking region. * * inClip: * An optional clip to clip inRegion against (may be NULL). * * Result: * An operating system status code. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework [32-bit only] but deprecated in 10.4 * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later * Non-Carbon CFM: not available } function ChangeMouseTrackingRegion( inMouseRef: MouseTrackingRef; inRegion: RgnHandle; inClip: RgnHandle { can be NULL } ): OSStatus; external name '_ChangeMouseTrackingRegion'; (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER_BUT_DEPRECATED_IN_MAC_OS_X_VERSION_10_4 *) { * ClipMouseTrackingRegion() *** DEPRECATED *** * * Deprecated: * Use HIView-based tracking areas, described in HIView.h, instead * of MouseTrackingRegions. * * Discussion: * Adjust the region to clip the MouseTrackingRef against. This can * be used in the case where a window is resized or when a * previously obscured region becomes exposed. * * Mac OS X threading: * Not thread safe * * Parameters: * * inMouseRef: * A valid MouseTrackingRef to adjust. * * inRegion: * A new region to clip inMouseRef against (can be NULL). If NULL, * standard clipping will be provided. * * Result: * An operating system status code. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework [32-bit only] but deprecated in 10.4 * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later * Non-Carbon CFM: not available } function ClipMouseTrackingRegion( inMouseRef: MouseTrackingRef; inRegion: RgnHandle ): OSStatus; external name '_ClipMouseTrackingRegion'; (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER_BUT_DEPRECATED_IN_MAC_OS_X_VERSION_10_4 *) { Accessors} { * GetMouseTrackingRegionID() *** DEPRECATED *** * * Deprecated: * Use HIView-based tracking areas instead of MouseTrackingRegions. * In this case, use HIViewGetTrackingAreaID(), defined in HIView.h, * instead of GetMouseTrackingRegionID(). * * Discussion: * Retrieves the MouseTrackingRegionID of the given * MouseTrackingRef. Can be used to determine if the region belongs * to your app, and if so, which region it is. * * Mac OS X threading: * Not thread safe * * Parameters: * * inMouseRef: * A valid MouseTrackingRef from which to obtain the * MouseTrackingRegionID. * * outID: * Receives the MouseTrackingRegionID. * * Result: * An operating system status code. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework [32-bit only] but deprecated in 10.4 * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later * Non-Carbon CFM: not available } function GetMouseTrackingRegionID( inMouseRef: MouseTrackingRef; var outID: MouseTrackingRegionID ): OSStatus; external name '_GetMouseTrackingRegionID'; (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER_BUT_DEPRECATED_IN_MAC_OS_X_VERSION_10_4 *) { * GetMouseTrackingRegionRefCon() *** DEPRECATED *** * * Deprecated: * Use HIView-based tracking areas, described in HIView.h, instead * of MouseTrackingRegions. * * Discussion: * Retrieves the RefCon from the given mouse tracking region. * * Mac OS X threading: * Not thread safe * * Parameters: * * inMouseRef: * A valid MouseTrackingRef from which to obtain the refcon. * * outRefCon: * Receives the refcon that was provided to * CreateMouseTrackingRegion. * * Result: * An operating system status code. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework [32-bit only] but deprecated in 10.4 * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later * Non-Carbon CFM: not available } function GetMouseTrackingRegionRefCon( inMouseRef: MouseTrackingRef; var outRefCon: UnivPtr ): OSStatus; external name '_GetMouseTrackingRegionRefCon'; (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER_BUT_DEPRECATED_IN_MAC_OS_X_VERSION_10_4 *) { Geometry} { * MoveMouseTrackingRegion() *** DEPRECATED *** * * Deprecated: * Use HIView-based tracking areas, described in HIView.h, instead * of MouseTrackingRegions. * * Discussion: * Moves the given mouse tracking region by the specified delta. It * can also optionally reclip the region, such as if the region is * scrolled within a pane. * * Mac OS X threading: * Not thread safe * * Parameters: * * inMouseRef: * A valid MouseTrackingRef to move. * * deltaH: * The horizontal delta to move the MouseTrackingRef. * * deltaV: * The vertical delta to move the MouseTrackingRef. * * inClip: * A region to optionally clip against (can be NULL). * * Result: * An operating system status code. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework [32-bit only] but deprecated in 10.4 * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later * Non-Carbon CFM: not available } function MoveMouseTrackingRegion( inMouseRef: MouseTrackingRef; deltaH: SInt16; deltaV: SInt16; inClip: RgnHandle { can be NULL } ): OSStatus; external name '_MoveMouseTrackingRegion'; (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER_BUT_DEPRECATED_IN_MAC_OS_X_VERSION_10_4 *) { Enable/disable} { * SetMouseTrackingRegionEnabled() *** DEPRECATED *** * * Deprecated: * Use HIView-based tracking areas, described in HIView.h, instead * of MouseTrackingRegions. * * Discussion: * Set the enabled state of the mouse tracking region * * Mac OS X threading: * Not thread safe * * Parameters: * * inMouseRef: * A valid MouseTrackingRef to modify. * * inEnabled: * Indicate whether this region should be enabled (true) or * disabled (false). * * Result: * An operating system status code. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework [32-bit only] but deprecated in 10.4 * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later * Non-Carbon CFM: not available } function SetMouseTrackingRegionEnabled( inMouseRef: MouseTrackingRef; inEnabled: Boolean ): OSStatus; external name '_SetMouseTrackingRegionEnabled'; (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER_BUT_DEPRECATED_IN_MAC_OS_X_VERSION_10_4 *) { Namespace operators } { * ClipWindowMouseTrackingRegions() *** DEPRECATED *** * * Deprecated: * Use HIView-based tracking areas, described in HIView.h, instead * of MouseTrackingRegions. * * Discussion: * Bulk clip operation to modify the region that all mouse tracking * regions with the given signature will be clipped against. * * Mac OS X threading: * Not thread safe * * Parameters: * * inWindow: * The window that contains the regions with the given signature * that you are interested in updating. * * inSignature: * The signature of the mouse tracking regions that will be * reclipped. * * inClip: * The region to clip all of the regions against (can be NULL). If * NULL, standard clipping will be provided. * * Result: * An operating system status code. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework [32-bit only] but deprecated in 10.4 * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later * Non-Carbon CFM: not available } function ClipWindowMouseTrackingRegions( inWindow: WindowRef; inSignature: OSType; inClip: RgnHandle { can be NULL } ): OSStatus; external name '_ClipWindowMouseTrackingRegions'; (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER_BUT_DEPRECATED_IN_MAC_OS_X_VERSION_10_4 *) { * MoveWindowMouseTrackingRegions() *** DEPRECATED *** * * Deprecated: * Use HIView-based tracking areas, described in HIView.h, instead * of MouseTrackingRegions. * * Discussion: * Bulk move operation to move all regions with the given signature * the specified delta. An optional clip can be provided to reclip * the regions against, such as in the case of the regions are being * scrolled within a pane. * * Mac OS X threading: * Not thread safe * * Parameters: * * inWindow: * The window that contains the regions with the given signature * that you are interested in moving. * * inSignature: * The signature of the mouse tracking regions that will be moved. * * deltaH: * The horizontal delta to move all of the regions. * * deltaV: * The vertical delta to move all of the regions. * * inClip: * An optional clipping region to clip against (can be NULL). If * NULL, standard clipping will be provided. * * Result: * An operating system status code. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework [32-bit only] but deprecated in 10.4 * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later * Non-Carbon CFM: not available } function MoveWindowMouseTrackingRegions( inWindow: WindowRef; inSignature: OSType; deltaH: SInt16; deltaV: SInt16; inClip: RgnHandle { can be NULL } ): OSStatus; external name '_MoveWindowMouseTrackingRegions'; (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER_BUT_DEPRECATED_IN_MAC_OS_X_VERSION_10_4 *) { * SetWindowMouseTrackingRegionsEnabled() *** DEPRECATED *** * * Deprecated: * Use HIView-based tracking areas, described in HIView.h, instead * of MouseTrackingRegions. * * Discussion: * Bulk set the enabled state of the mouse tracking regions of the * given signature belonging to the given window. * * Mac OS X threading: * Not thread safe * * Parameters: * * inWindow: * The window which contains the mouse tracking regions that you * are interested in modifying. * * inSignature: * The signature of the mouse tracking regions whose enabled state * you wish to modify. * * inEnabled: * Indicates whether the regions should be enabled (true) or * disabled (false). * * Result: * An operating system status code. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework [32-bit only] but deprecated in 10.4 * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later * Non-Carbon CFM: not available } function SetWindowMouseTrackingRegionsEnabled( inWindow: WindowRef; inSignature: OSType; inEnabled: Boolean ): OSStatus; external name '_SetWindowMouseTrackingRegionsEnabled'; (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER_BUT_DEPRECATED_IN_MAC_OS_X_VERSION_10_4 *) { * ReleaseWindowMouseTrackingRegions() *** DEPRECATED *** * * Deprecated: * Use HIView-based tracking areas, described in HIView.h, instead * of MouseTrackingRegions. * * Discussion: * Bulk release the mouse tracking regions with the given signature. * * Mac OS X threading: * Not thread safe * * Parameters: * * inWindow: * The window to which the regions to be released belong. * * inSignature: * The signature of the regions to be released. * * Result: * An operating system status code. * * Availability: * Mac OS X: in version 10.2 and later in Carbon.framework [32-bit only] but deprecated in 10.4 * CarbonLib: not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later * Non-Carbon CFM: not available } function ReleaseWindowMouseTrackingRegions( inWindow: WindowRef; inSignature: OSType ): OSStatus; external name '_ReleaseWindowMouseTrackingRegions'; (* AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATER_BUT_DEPRECATED_IN_MAC_OS_X_VERSION_10_4 *) {======================================================================================} { EVENT-BASED OBJECT CLASSES } { *** DEPRECATED *** } { Here it is - the replacement for classic defprocs. This is also a convenient way } { to create toolbox objects (windows, etc.) that have a specific behavior without } { installing handlers on each instance of the object. With a toolbox object class, } { you register your class, then use special creation routines to create objects of } { that class. The event handlers are automatically installed and ready to go. } { Note that on Mac OS X 10.2 and later, we recommend using the HIObject API } { HIObjectRegisterSubclass rather than RegisterToolboxObjectClass. This API is } { considered deprecated on Mac OS X 10.2 and later. } {======================================================================================} {$endc} {not TARGET_CPU_64} type ToolboxObjectClassRef = ^OpaqueToolboxObjectClassRef; { an opaque type } OpaqueToolboxObjectClassRef = record end; {$ifc not TARGET_CPU_64} { * RegisterToolboxObjectClass() *** DEPRECATED *** * * Mac OS X threading: * Not thread safe * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework [32-bit only] but deprecated in 10.4 * CarbonLib: in CarbonLib 1.1 and later * Non-Carbon CFM: not available } function RegisterToolboxObjectClass( inClassID: CFStringRef; inBaseClass: ToolboxObjectClassRef { can be NULL }; inNumEvents: ItemCount; {const} inEventList: {variable-size-array} EventTypeSpecPtr; inEventHandler: EventHandlerUPP; inEventHandlerData: UnivPtr; var outClassRef: ToolboxObjectClassRef ): OSStatus; external name '_RegisterToolboxObjectClass'; (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER_BUT_DEPRECATED_IN_MAC_OS_X_VERSION_10_4 *) { * UnregisterToolboxObjectClass() *** DEPRECATED *** * * Mac OS X threading: * Not thread safe * * Availability: * Mac OS X: in version 10.0 and later in Carbon.framework [32-bit only] but deprecated in 10.4 * CarbonLib: in CarbonLib 1.1 and later * Non-Carbon CFM: not available } function UnregisterToolboxObjectClass( inClassRef: ToolboxObjectClassRef ): OSStatus; external name '_UnregisterToolboxObjectClass'; (* AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATER_BUT_DEPRECATED_IN_MAC_OS_X_VERSION_10_4 *) {--------------------------------------------------------------------------------------} { Obsolete constant names - use the new ones. } {--------------------------------------------------------------------------------------} {$endc} {not TARGET_CPU_64} const kEventParamTabletPointerRec = FourCharCode('tbrc'); { typeTabletPointerRec -- deprecated, for compatibility only} typeTabletPointerRec = FourCharCode('tbrc'); { kEventParamTabletPointerRec -- deprecated, for compatibility only} const kEventWindowDefDrawFrame = kEventWindowDrawFrame; kEventWindowDefDrawPart = kEventWindowDrawPart; kEventWindowDefGetRegion = kEventWindowGetRegion; kEventWindowDefHitTest = kEventWindowHitTest; kEventWindowDefInit = kEventWindowInit; kEventWindowDefDispose = kEventWindowDispose; kEventWindowDefDragHilite = kEventWindowDragHilite; kEventWindowDefModified = kEventWindowModified; kEventWindowDefSetupProxyDragImage = kEventWindowSetupProxyDragImage; kEventWindowDefStateChanged = kEventWindowStateChanged; kEventWindowDefMeasureTitle = kEventWindowMeasureTitle; kEventWindowDefDrawGrowBox = kEventWindowDrawGrowBox; kEventWindowDefGetGrowImageRegion = kEventWindowGetGrowImageRegion; const kEventClassEPPC = kEventClassAppleEvent; kEventHighLevelEvent = kEventAppleEvent; const kEventUpdateActiveInputArea = kEventTextInputUpdateActiveInputArea; kEventUnicodeForKeyEvent = kEventTextInputUnicodeForKeyEvent; kEventOffsetToPos = kEventTextInputOffsetToPos; kEventPosToOffset = kEventTextInputPosToOffset; kEventShowHideBottomWindow = kEventTextInputShowHideBottomWindow; kEventGetSelectedText = kEventTextInputGetSelectedText; const kEventProcessCommand = kEventCommandProcess; kEventTabletPointer = kEventTabletPoint; {--------------------------------------------------------------------------------------} { Obsolete typedefs. } {--------------------------------------------------------------------------------------} type EventClassID = UInt32; EventClass = UInt32; EventType = UInt32; { OBSOLETE CONSTANTS} const kMouseTrackingMousePressed = kMouseTrackingMouseDown; kMouseTrackingMouseReleased = kMouseTrackingMouseUp; const kEventControlGetSubviewForMouseEvent = kEventControlInterceptSubviewClick; {$endc} {TARGET_OS_MAC} {$ifc not defined MACOSALLINCLUDE or not MACOSALLINCLUDE} end. {$endc} {not MACOSALLINCLUDE}