| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695 | {     File:       QD/ATSUnicodeDrawing.h      Contains:   ATSUI drawing, measuring, and highlighting functions.      Version:    Quickdraw-150~1      Copyright:  © 2003 by Apple Computer, Inc., all rights reserved.      Bugs?:      For bug reports, consult the following page on                 the World Wide Web:                      http://www.freepascal.org/bugs.html }{	  Pascal Translation:  Peter N Lewis, <[email protected]>, 2004 }{    Modified for use with Free Pascal    Version 200    Please report any bugs to <[email protected]>}{$mode macpas}{$packenum 1}{$macro on}{$inline on}{$CALLING MWPASCAL}unit ATSUnicodeDrawing;interface{$setc UNIVERSAL_INTERFACES_VERSION := $0342}{$setc GAP_INTERFACES_VERSION := $0200}{$ifc not defined USE_CFSTR_CONSTANT_MACROS}    {$setc USE_CFSTR_CONSTANT_MACROS := TRUE}{$endc}{$ifc defined CPUPOWERPC and defined CPUI386}	{$error Conflicting initial definitions for CPUPOWERPC and CPUI386}{$endc}{$ifc defined FPC_BIG_ENDIAN and defined FPC_LITTLE_ENDIAN}	{$error Conflicting initial definitions for FPC_BIG_ENDIAN and FPC_LITTLE_ENDIAN}{$endc}{$ifc not defined __ppc__ and defined CPUPOWERPC}	{$setc __ppc__ := 1}{$elsec}	{$setc __ppc__ := 0}{$endc}{$ifc not defined __i386__ and defined CPUI386}	{$setc __i386__ := 1}{$elsec}	{$setc __i386__ := 0}{$endc}{$ifc defined __ppc__ and __ppc__ and defined __i386__ and __i386__}	{$error Conflicting definitions for __ppc__ and __i386__}{$endc}{$ifc defined __ppc__ and __ppc__}	{$setc TARGET_CPU_PPC := TRUE}	{$setc TARGET_CPU_X86 := FALSE}{$elifc defined __i386__ and __i386__}	{$setc TARGET_CPU_PPC := FALSE}	{$setc TARGET_CPU_X86 := TRUE}{$elsec}	{$error Neither __ppc__ nor __i386__ is defined.}{$endc}{$setc TARGET_CPU_PPC_64 := FALSE}{$ifc defined FPC_BIG_ENDIAN}	{$setc TARGET_RT_BIG_ENDIAN := TRUE}	{$setc TARGET_RT_LITTLE_ENDIAN := FALSE}{$elifc defined FPC_LITTLE_ENDIAN}	{$setc TARGET_RT_BIG_ENDIAN := FALSE}	{$setc TARGET_RT_LITTLE_ENDIAN := TRUE}{$elsec}	{$error Neither FPC_BIG_ENDIAN nor FPC_LITTLE_ENDIAN are defined.}{$endc}{$setc ACCESSOR_CALLS_ARE_FUNCTIONS := TRUE}{$setc CALL_NOT_IN_CARBON := FALSE}{$setc OLDROUTINENAMES := FALSE}{$setc OPAQUE_TOOLBOX_STRUCTS := TRUE}{$setc OPAQUE_UPP_TYPES := TRUE}{$setc OTCARBONAPPLICATION := TRUE}{$setc OTKERNEL := FALSE}{$setc PM_USE_SESSION_APIS := TRUE}{$setc TARGET_API_MAC_CARBON := TRUE}{$setc TARGET_API_MAC_OS8 := FALSE}{$setc TARGET_API_MAC_OSX := TRUE}{$setc TARGET_CARBON := TRUE}{$setc TARGET_CPU_68K := FALSE}{$setc TARGET_CPU_MIPS := FALSE}{$setc TARGET_CPU_SPARC := FALSE}{$setc TARGET_OS_MAC := TRUE}{$setc TARGET_OS_UNIX := FALSE}{$setc TARGET_OS_WIN32 := FALSE}{$setc TARGET_RT_MAC_68881 := FALSE}{$setc TARGET_RT_MAC_CFM := FALSE}{$setc TARGET_RT_MAC_MACHO := TRUE}{$setc TYPED_FUNCTION_POINTERS := TRUE}{$setc TYPE_BOOL := FALSE}{$setc TYPE_EXTENDED := FALSE}{$setc TYPE_LONGLONG := TRUE}uses MacTypes,TextCommon,Quickdraw,ATSLayoutTypes,ATSUnicodeTypes;{$ALIGN MAC68K}{ ---------------------------------------------------------------------------- }{  ATSUI drawing and measuring                                                 }{ ---------------------------------------------------------------------------- }{ *  ATSUDrawText() *   *  Summary: *    Draws a specified range of text in a QuickDraw graphics port or *    Quartz graphics context. *   *  Discussion: *    Before calling ATSUDrawText, you will most likely want to call *    ATSUSetLayoutControls to set a value for the kATSUCGContextTag *    attribute in order to specify your current graphics context. *    Otherwise, ATSUI will attempt to draw using Quickdraw style text *    rendering in whatever Quickdraw GrafPort is currently active (use *    SetPort to determine the currently active Quickdraw GrafPort, see *    Quickdraw.h). Carbon applications can create a CGContext from a *    Quickdraw GrafPort using the functions QDBeginCGContext and *    QDEndCGContext (see Quickdraw.h). Cocoa applications can call the *    method "graphicsPort" on the current NSGraphicsContext in order *    to get a CGContextRef to pass into ATSUI (use the method *    "currentContext" to obtain the current NSGraphicsContext, see *    NSGraphicsContext.h for more information). ATSUDrawText examines *    the text layout object to ensure that each of the characters in *    the range is assigned to a style run. If there are gaps between *    style runs, ATSUI assigns the characters in the gap to the style *    run that precedes (in storage order) the gap. If there is no *    style run at the beginning of the text range, ATSUI assigns these *    characters to the first style run it finds. If there is no style *    run at the end of the text range, ATSUI assigns the remaining *    characters to the last style run it finds. If you want to draw a *    range of text that spans multiple lines, you should call *    ATSUDrawText for each line of text to draw, even if all the lines *    are in the same text layout object. You should adjust the *    iLineOffset parameter to reflect the beginning of each line to be *    drawn. Please note that when drawing into a GrafPort, calls to *    QDSwapTextFlags have no effect on ATSUI text rendering. The *    proper way to achieve Quartz text rendering from ATSUI is to use *    the kATSUCGContextTag attribute to specify a CGContextRef in each *    ATSUTextLayout before calling ATSUDrawText. *   *  Parameters: *     *    iTextLayout: *      A layout containing text to draw. *     *    iLineOffset: *      The starting offset of the range of text to draw. To specify *      the beginning of the text buffer, pass kATSUFromTextBeginning *      for this parameter. *     *    iLineLength: *      The length of the range of text to draw. To specify a range *      that continues to the end of the text buffer, pass *      kATSUToTextEnd for this parameter. *     *    iLocationX: *      The x-coordinate of the origin (in either the current graphics *      port or Quartz graphics context) of the line containing the *      text range to render. Note that the ATSUTextMeasurement type is *      defined as a Fixed value, so you must ensure that your *      coordinates are converted to Fixed values before passing them *      to this function (see FixMath.h for conversion functions). Pass *      the constant kATSUUseGrafPortPenLoc to draw relative to the *      current pen location in the current graphics port. *     *    iLocationY: *      The y-coordinate of the origin (in either the current graphics *      port or Quartz graphics context) of the line containing the *      text range to render. Note that the ATSUTextMeasurement type is *      defined as a Fixed value, so you must ensure that your *      coordinates are converted to Fixed values before passing them *      to this function (see FixMath.h for conversion functions). Pass *      the constant kATSUUseGrafPortPenLoc to draw relative to the *      current pen location in the current graphics port. *   *  Result: *    On success, noErr is returned. See MacErrors.h for possible error *    codes. *   *  Availability: *    Mac OS X:         in version 10.0 and later in ApplicationServices.framework *    CarbonLib:        in CarbonLib 1.0 and later *    Non-Carbon CFM:   in ATSUnicodeLib 8.5 and later }// AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATERfunction ATSUDrawText( iTextLayout: ATSUTextLayout; iLineOffset: UniCharArrayOffset; iLineLength: UniCharCount; iLocationX: ATSUTextMeasurement; iLocationY: ATSUTextMeasurement ): OSStatus; external name '_ATSUDrawText';{ *  ATSUGetUnjustifiedBounds() *   *  Summary: *    Obtains the typographic bounding rectangle for a line of text *    prior to final layout. *   *  Discussion: *    This function calculates the typographic bounds (in coordinates *    independent of the rendering device) for a line of text. Note *    that ATSUGetUnjustifiedBounds calculates these bounds prior to *    the text's final layout, and therefore, the calculated bounds *    might not reflect those of the final laid-out line. *    Justification, truncation, and device level positioning are not *    taken into account. To obtain the typographic bounds of a line *    after it is laid out, you can call the function *    ATSUGetGlyphBounds. For more infomration about the difference *    between typographic and image bounds, please refer to the ATSUI *    documentation. Note that ATSUGetUnjustifiedBounds treats the *    specified text range as a single line. That is, if the range of *    text you specify is less than a line, it nevertheless treats the *    initial character in the range as the start of a line, for *    measuring purposes. If the range of text extends beyond a line, *    ATSUGetUnjustifiedBounds ignores soft line breaks, again, *    treating the text as a single line. *   *  Parameters: *     *    iTextLayout: *      The text layout object to obtain bounds information for. *     *    iLineStart: *      The start of the line of text to obtain bounds information for. *      To indicate that the line starts at the beginning of the text *      buffer, you can pass the constant kATSUFromTextBeginning . To *      specify the entire text buffer, pass kATSUFromTextBeginning in *      this parameter and kATSUToTextEnd in the iLineLength parameter. *     *    iLineLength: *      The length of the line to obtain bounds information for. If you *      want the line to extend to the end of the text buffer, you can *      pass the constant kATSUToTextEnd . *     *    oTextBefore: *      On return, the value specifies the starting point of the *      typographic bounds for the line, relative to the origin (0,0) *      of the line and taking into account cross-stream shifting. Note *      that the ATSUMeasureText function might produce negative values *      for the typographic starting point of the line if, for example, *      the initial character of the line is allowed to hang into the *      margin. For horizontal text, this value corresponds to the left *      side of the bounding rectangle. *     *    oTextAfter: *      On return, the end point of the typographic bounds for the *      line, relative to the origin (0,0) of the line and taking into *      account cross-stream shifting. For horizontal text, this value *      corresponds to the right side of the bounding rectangle. *     *    oAscent: *      On return, the typographic bounds for the line, relative to the *      origin (0,0) of the line and taking into account cross-stream *      shifting. For horizontal text, this value corresponds to the *      top side of the bounding rectangle. *     *    oDescent: *      On return, the typographic bounds for the line, relative to the *      origin (0,0) of the line and taking into account cross-stream *      shifting. For horizontal text, this value corresponds to the *      bottom side of the bounding rectangle. *   *  Result: *    On success, noErr is returned. See MacErrors.h for possible error *    codes. *   *  Availability: *    Mac OS X:         in version 10.2 and later in ApplicationServices.framework *    CarbonLib:        not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later *    Non-Carbon CFM:   not available }// AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATERfunction ATSUGetUnjustifiedBounds( iTextLayout: ATSUTextLayout; iLineStart: UniCharArrayOffset; iLineLength: UniCharCount; var oTextBefore: ATSUTextMeasurement; var oTextAfter: ATSUTextMeasurement; var oAscent: ATSUTextMeasurement; var oDescent: ATSUTextMeasurement ): OSStatus; external name '_ATSUGetUnjustifiedBounds';{ *  ATSUMeasureTextImage() *   *  Summary: *    Obtains the image bounding rectangle for a line of text after *    final layout. *   *  Discussion: *    This function obtains the image bounds of a laid-out line of *    text. These bounds are described by the smallest rectangle that *    completely encloses the filled or framed parts of a block of *    textÑthat is, the text's "inked" glyphs. In measuring the line, *    the ATSUMeasureTextImage function takes into account line *    rotation, alignment, and justification, as well as other *    characteristics that affect layout, such as hanging punctuation. *    (If the line is rotated, the sides of the rectangle are parallel *    to the coordinate axes and encompass the rotated line.) If no *    attributes are set for the line, ATSUMeasureTextImage uses the *    global attributes set for the text layout object. Because the *    height of the image bounding rectangle is determined by the *    actual device metrics, ATSUMeasureTextImage ignores any *    previously set line ascent and descent values for the line it is *    measuring. *   *  Parameters: *     *    iTextLayout: *      The text layout for which to obtain image bounds. *     *    iLineOffset: *      The first character of the line to examine. To indicate that *      the specified line starts at the beginning of the text buffer, *      you can pass the constant kATSUFromTextBeginning . To specify *      the entire text buffer, pass kATSUFromTextBeginning in this *      parameter and kATSUToTextEnd in the iLineLength parameter. *     *    iLineLength: *      The length of the text range. If you want the range of text to *      extend to the end of the text buffer, you can pass the constant *      kATSUToTextEnd . However, the image bounds is restricted to the *      line in which iLineOffset resides. *     *    iLocationX: *      The x-coordinate of the line's origin in the current graphics *      port or Quartz graphics context. Pass the constant *      kATSUUseGrafPortPenLoc for the dimensions of the bounds *      relative to the current pen location in the current graphics *      port or graphics context. You can pass 0to obtain only the *      dimensions of the bounding rectangle relative to one another, *      not their actual onscreen position. *     *    iLocationY: *      The y-coordinate of the line's origin in the current graphics *      port or Quartz graphics context. Pass the constant *      kATSUUseGrafPortPenLoc for the dimensions of the bounds *      relative to the current pen location in the current graphics *      port or graphics context. You can pass 0to obtain only the *      dimensions of the bounding rectangle relative to one another, *      not their actual onscreen position. *     *    oTextImageRect: *      On return, the dimensions of the image bounding rectangle for *      the text, offset by the values specified in the iLocationX and *      iLocationY parameters. If the line is rotated, the sides of the *      rectangle are parallel to the coordinate axis. *   *  Result: *    On success, noErr is returned. See MacErrors.h for possible error *    codes. *   *  Availability: *    Mac OS X:         in version 10.0 and later in ApplicationServices.framework *    CarbonLib:        in CarbonLib 1.0 and later *    Non-Carbon CFM:   in ATSUnicodeLib 8.5 and later }// AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATERfunction ATSUMeasureTextImage( iTextLayout: ATSUTextLayout; iLineOffset: UniCharArrayOffset; iLineLength: UniCharCount; iLocationX: ATSUTextMeasurement; iLocationY: ATSUTextMeasurement; var oTextImageRect: Rect ): OSStatus; external name '_ATSUMeasureTextImage';{ *  ATSUGetGlyphBounds() *   *  Summary: *    Obtains the typographic bounds of a line of glyphs after final *    layout. *   *  Discussion: *    This function produces the enclosing trapezoid(s) that represent *    the typographic bounds for glyphs in a final, laid-out range of *    text. You typically call this function when you need to obtain an *    enclosing trapezoid for a line, taking rotation and all other *    layout attributes into account. ATSUI determines the height of *    each trapezoid by examining any line ascent and descent attribute *    values you may have set for the line. If you have not set these *    attributes for the line, the ATSUGetGlyphBounds function uses any *    line ascent and descent values you may have set for the text *    layout object containing the line. If these are not set, *    ATSUGetGlyphBounds uses the font's natural line ascent and *    descent values for the line. If these are previously set, *    ATSUGetGlyphBounds uses the ATSUStyle ascent and or *    descent/leading values. Note that the coordinates produced for *    the trapezoid(s) are offset by the amount specified in the *    iTextBasePointX and iTextBasePointY parameters. If your goal in *    calling the ATSUGetGlyphBounds function is to obtain metrics for *    drawing the typographic bounds on the screen, pass the position *    of the origin of the line in the current graphics port or *    graphics context in these parameters. This enables *    ATSUGetGlyphBounds to match the trapezoids to their onscreen *    image. When the range specified by the iBoundsCharStart and *    iBoundsCharLength parameters covers an entire line, you are *    guaranteed to receive only one trapezoid on return. Otherwise, *    multiple trapezoids may be returned to cover incomplete sections *    of bidi runs. In such cases, you would typically call *    ATSUGetGlyphBounds twice, as follows: (1) Pass NULL for the *    oGlyphBounds parameter, 0 for the iMaxNumberOfBounds parameter, *    and valid values for the other parameters. The ATSUGetGlyphBounds *    function returns the actual number of trapezoids needed to *    enclose the glyphs in the oActualNumberOfBounds parameter. (2) *    Allocate enough space for a buffer of the returned size, then *    call the function again, passing a valid pointer to the buffer in *    the oGlyphBounds parameter. On return, the buffer contains the *    trapezoids for the glyphs' typographic bounds. To obtain the *    typographic bounds of a line of text prior to line layout, call *    the function ATSUGetUnjustifiedBounds. To calculate the image *    bounding rectangle for a final laid-out line, call the function *    ATSUMeasureTextImage. For more infomration about the difference *    between typographic and image bounds, please refer to the ATSUI *    documentation. *   *  Parameters: *     *    iTextLayout: *      The text layout object for which glyph bounds are to be *      obtained. *     *    iTextBasePointX: *      The x-coordinate of the origin of the line containing the *      glyphs in the current graphics port or Quartz graphics context. *      Pass the constant kATSUUseGrafPortPenLoc to obtain the glyph *      bounds relative to the current pen location in the current *      graphics port or graphics context. You may pass 0 to obtain *      only the dimensions of the bounds relative to one another, not *      their actual onscreen position. *     *    iTextBasePointY: *      The y-coordinate of the origin of the line containing the *      glyphs in the current graphics port or Quartz graphics context. *      Pass the constant kATSUUseGrafPortPenLoc to obtain the glyph *      bounds relative to the current pen location in the current *      graphics port or graphics context. You may pass 0 to obtain *      only the dimensions of the bounds relative to one another, not *      their actual onscreen position. *     *    iBoundsCharStart: *      The offset from the beginning of the text buffer to the *      character corresponding to the first glyph to measure. To *      indicate that the text range starts at the beginning of the *      text buffer, you can pass the constant kATSUFromTextBeginning. *     *    iBoundsCharLength: *      The length of text range to measure. If you want the range to *      extend to the end of the text buffer, you can pass the constant *      kATSUToTextEnd. *     *    iTypeOfBounds: *      The type of bounds you wish to obtain. See ATSLayoutTypes.h for *      a list of possible values to pass in here. *     *    iMaxNumberOfBounds: *      The maximum number of bounding trapezoids to obtain. Typically, *      this is equivalent to the number of bounds in the oGlyphBounds *      array. To determine this value, see the Discussion. *     *    oGlyphBounds: *      A pointer to memory you have allocated for an array of *      ATSTrapezoid values. On return, the array contains a trapezoid *      representing the typographic bounds for glyphs in the text *      range. If the specified range of text encloses nested *      bidirectional text, ATSUGetGlyphBounds produces multiple *      trapezoids defining these regions.In ATSUI 1.1, the maximum *      number of enclosing trapezoids that can be returned is 31; in *      ATSUI 1.2, the maximum number is 127. If you pass a range that *      covers an entire line, ATSUGetGlyphBounds always returns only 1 *      trapezoid. If you are uncertain of how much memory to allocate *      for this array, see the Discussion. can be NULL *     *    oActualNumberOfBounds: *      On return, the value specifies the actual number of enclosing *      trapezoids bounding the specified characters. This may be *      greater than the value you provide in the iMaxNumberOfBounds *      parameter. can be NULL *   *  Result: *    On success, noErr is returned. See MacErrors.h for possible error *    codes. *   *  Availability: *    Mac OS X:         in version 10.0 and later in ApplicationServices.framework *    CarbonLib:        in CarbonLib 1.0 and later *    Non-Carbon CFM:   in ATSUnicodeLib 8.6 and later }// AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATERfunction ATSUGetGlyphBounds( iTextLayout: ATSUTextLayout; iTextBasePointX: ATSUTextMeasurement; iTextBasePointY: ATSUTextMeasurement; iBoundsCharStart: UniCharArrayOffset; iBoundsCharLength: UniCharCount; iTypeOfBounds: UInt16; iMaxNumberOfBounds: ItemCount; oGlyphBounds: ATSTrapezoidPtr; var oActualNumberOfBounds: ItemCount ): OSStatus; external name '_ATSUGetGlyphBounds';{ ---------------------------------------------------------------------------- }{  ATSUI line breaking                                                         }{ ---------------------------------------------------------------------------- }{ *  ATSUBatchBreakLines() *   *  Summary: *    Soft wraps a range of text in a layout to a constant line width. *   *  Discussion: *    Equivalent to repeatedly calling the ATSUBreakLine function with *    the parameter iUseAsSoftLineBreak set to true. Use this function *    to gain a substantial performance increase over the use of *    ATSUBreakLine. It will set soft breaks in a layout for multiple *    lines in a single call. It assumes constant line width. Soft line *    breaks within a layout are what divide it into lines. You can *    manipulate the soft breaks that are currently set within a layout *    using the functions ATSUGetSoftLineBreaks, ATSUSetSoftLineBreak, *    and ATSUClearSoftLineBreaks. *   *  Parameters: *     *    iTextLayout: *      The layout containing text to be soft wrapped. *     *    iRangeStart: *      Beginning offset for the rage of text to be soft wrapped. *     *    iRangeLength: *      The length of the range of text to be soft wrapped. *     *    iLineWidth: *      The line width at which to force soft wrapping of text. Note *      that this parameter is of type ATSUTextMeasurement, which is *      defined as Fixed. See FixMath.h for conversion routines for *      fixed point values. *     *    oBreakCount: *      On return, the number of soft breaks that were set in the *      layout. Use this to determine how much memory to allocate when *      calling ATSUGetSoftLineBreaks. can be NULL *   *  Result: *    On success, noErr is returned. See MacErrors.h for possible error *    codes. *   *  Availability: *    Mac OS X:         in version 10.2 and later in ApplicationServices.framework *    CarbonLib:        not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later *    Non-Carbon CFM:   not available }// AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATERfunction ATSUBatchBreakLines( iTextLayout: ATSUTextLayout; iRangeStart: UniCharArrayOffset; iRangeLength: UniCharCount; iLineWidth: ATSUTextMeasurement; oBreakCount: ItemCountPtr ): OSStatus; external name '_ATSUBatchBreakLines';{ *  ATSUBreakLine() *   *  Summary: *    Soft wraps a single line of text within a layout. *   *  Discussion: *    This function will automatically determine the optimal place to *    set a soft break in a given range of text. It suggests a soft *    line break each time it encounters a hard line break character *    such as a carriage return, line feed, form feed, line separator, *    or paragraph separator. If ATSUBreakLine does not encounter a *    hard line break, it uses the line width you specify to determine *    how many characters fit on a line and suggests soft line breaks *    accordingly. You can loop over ATSUBreakLine, repeatedly calling *    it on the same layout, until all the text in the entire layout *    has been soft wrapped. However, for maximum efficiency, you *    should use ATSUBatchBreakLines. ATSUBreakLine should only be used *    if you have special needs, such as a non-constant line width. *   *  Parameters: *     *    iTextLayout: *      The layout containing text to be soft wrapped. *     *    iLineStart: *      The beginning of the line you wish to soft wrap. To specify the *      beginning of the text buffer, pass the constant *      kATSUFromTextBeginning. *     *    iLineWidth: *      The line width at which to force soft wrapping of text. Note *      that this parameter is of type ATSUTextMeasurement, which is *      defined as Fixed. See FixMath.h for conversion routines for *      fixed point values. *     *    iUseAsSoftLineBreak: *      A Boolean value indicating whether ATSUBreakLine should *      automatically set the line break produced in the oLineBreak *      parameter. If true ,ATSUBreakLine sets the line break and *      clears any previously-set soft line breaks that precede the new *      break in the line but lie after the offset specified by *      iLineStart. You should ususally pass true for this parameter, *      unless you plan to use ATSUSetSoftLineBreak to set the soft *      break somewhere other than what is suggested by ATSUBreakLine. *     *    oLineBreak: *      On return, the value specifies the soft line break as *      determined by ATSUBreakLine. If the value returned is the same *      value as specified in iLineStart , you have made an input *      parameter error. In this case, check to make sure that the line *      width specified in iLineWidth is big enough for ATSUBreakLine *      to perform line breaking. ATSUBreakLine does not return an *      error in this case. *   *  Result: *    On success, noErr is returned. TSUI usually calculates a soft *    line break to be at the beginning of the first word that does ont *    fit on the line. But if ATSUBreakLine calculates the most optimal *    line break to be in the middle of a word, it returns the result *    code kATSULineBreakInWord. Note that ATSUI produces a line break *    in the middle of a word only as a last resort. See MacErrors.h *    for other possible error codes. can be NULL *   *  Availability: *    Mac OS X:         in version 10.0 and later in ApplicationServices.framework *    CarbonLib:        in CarbonLib 1.0 and later *    Non-Carbon CFM:   in ATSUnicodeLib 8.5 and later }// AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATERfunction ATSUBreakLine( iTextLayout: ATSUTextLayout; iLineStart: UniCharArrayOffset; iLineWidth: ATSUTextMeasurement; iUseAsSoftLineBreak: Boolean; oLineBreak: UniCharArrayOffsetPtr ): OSStatus; external name '_ATSUBreakLine';{ *  ATSUSetSoftLineBreak() *   *  Summary: *    Sets a soft line break at the specified point in a text layout. *   *  Discussion: *    You should typically only call ATSUSetSoftLineBreak to set line *    breaks when you are using your own line-breaking algorithm to *    calculate these breaks. For optimal performance, you should use *    ATSUBatchBreakLines to both calculate and set soft line breaks in *    your text. After calling ATSUSetSoftLineBreak , you should call *    the function ATSUGetUnjustifiedBounds to determine whether the *    characters still fit within the line, which is necessary due to *    end-of-line effects such as swashes. *   *  Parameters: *     *    iTextLayout: *      The layout in which to set the soft break. *     *    iLineBreak: *      An offset into the text buffer specifying the location to set *      the soft break at. *   *  Result: *    On success, noErr is returned. See MacErrors.h for possible error *    codes. *   *  Availability: *    Mac OS X:         in version 10.0 and later in ApplicationServices.framework *    CarbonLib:        in CarbonLib 1.0 and later *    Non-Carbon CFM:   in ATSUnicodeLib 8.5 and later }// AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATERfunction ATSUSetSoftLineBreak( iTextLayout: ATSUTextLayout; iLineBreak: UniCharArrayOffset ): OSStatus; external name '_ATSUSetSoftLineBreak';{ *  ATSUGetSoftLineBreaks() *   *  Summary: *    Obtains the soft line breaks that are currently set in a given *    text range. *   *  Discussion: *    Typically you use the function ATSUGetSoftLineBreaks by calling *    it twice, as follows: (1) Pass valid values for the iTextLayout, *    iRangeStart, iRangeLength, and oBreakCount parameters. Pass NULL *    for the oBreaks parameter and 0 for the iMaximumBreaks parameter. *    ATSUGetSoftLineBreaks returns the size of the font array in the *    oBreakCount parameter. (2) Allocate enough space for an array of *    the returned size, then call the function again, passing a valid *    pointer in the oBreaks parameter. On return, the pointer refers *    to an array containing the text range's soft line breaks. If you *    have just called ATSUBatchBreakLines, the oBreakCount parameter *    will give you the value you would normally obtain from step 1, *    allowing you to skip this step in such cases. *   *  Parameters: *     *    iTextLayout: *      A text layout to obtain a list of soft breaks from. *     *    iRangeStart: *      The beginning of the range of text for which to obtain a list *      of softbreaks. To indicate that the specified text range starts *      at the beginning of the text buffer, you can pass the constant *      kATSUFromTextBeginning, To specify the entire text buffer, pass *      kATSUFromTextBeginning in this parameter and kATSUToTextEnd in *      the iRangeLength parameter. *     *    iRangeLength: *      The end of the range of text for which to obtain a list of *      softbreaks. If you want the range of text to extend to the end *      of the text buffer, you can pass the constant kATSUToTextEnd. *     *    iMaximumBreaks: *      The maximum number of soft line breaks to obtain. Typically, *      this is equivalent to the number of UniCharArrayOffset values *      for which you have allocated memory in the oBreaks array. To *      determine this value, see the Discussion. *     *    oBreaks: *      On return, the array contains offsets from the beginning of the *      text buffer to each of the soft line breaks in the text range. *      If you are uncertain of how much memory to allocate for this *      array, see the Discussion. can be NULL *     *    oBreakCount: *      On return, the number of soft breaks set in iTextLayout. Note *      that this value may be greater than what you pass in for *      iMaximumBreaks. can be NULL *   *  Result: *    On success, noErr is returned. See MacErrors.h for possible error *    codes. *   *  Availability: *    Mac OS X:         in version 10.0 and later in ApplicationServices.framework *    CarbonLib:        in CarbonLib 1.0 and later *    Non-Carbon CFM:   in ATSUnicodeLib 8.5 and later }// AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATERfunction ATSUGetSoftLineBreaks( iTextLayout: ATSUTextLayout; iRangeStart: UniCharArrayOffset; iRangeLength: UniCharCount; iMaximumBreaks: ItemCount; oBreaks: UniCharArrayOffsetPtr; oBreakCount: ItemCountPtr ): OSStatus; external name '_ATSUGetSoftLineBreaks';{ *  ATSUClearSoftLineBreaks() *   *  Summary: *    Unsets any currently set soft breaks in a range of text. *   *  Discussion: *    This function clears all previously set soft line breaks for the *    specified text range and clears any associated layout caches as *    well. *   *  Parameters: *     *    iTextLayout: *      The text layout object for which to remove line breaks. *     *    iRangeStart: *      The beginning of the text range over which to clear soft line *      breaks. To indicate that the specified text range starts at the *      beginning of the text buffer, you can pass the constant *      kATSUFromTextBeginning . To specify the entire text buffer, *      pass kATSUFromTextBeginning in this parameter and *      kATSUToTextEnd in the iRangeLength parameter. *     *    iRangeLength: *      The length of the text range over which to clear soft line *      breaks. If you want the range of text to extend to the end of *      the text buffer, you can pass the constant kATSUToTextEnd. *   *  Result: *    On success, noErr is returned. See MacErrors.h for possible error *    codes. *   *  Availability: *    Mac OS X:         in version 10.0 and later in ApplicationServices.framework *    CarbonLib:        in CarbonLib 1.0 and later *    Non-Carbon CFM:   in ATSUnicodeLib 8.5 and later }// AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATERfunction ATSUClearSoftLineBreaks( iTextLayout: ATSUTextLayout; iRangeStart: UniCharArrayOffset; iRangeLength: UniCharCount ): OSStatus; external name '_ATSUClearSoftLineBreaks';{ ---------------------------------------------------------------------------- }{  ATSUI highlighting                                                          }{ ---------------------------------------------------------------------------- }{ *  ATSUSetHighlightingMethod() *   *  Summary: *    Specifies the methods ATSUI will use for highlighting and *    unhighlighting text in a given layout. *   *  Discussion: *    By default, ATSUI highlights text by "inverting" the region *    containing the text, that is, its background color. Although *    inversion provides satisfactory highlighting in most cases, it *    does not always provide the best result for grayscale text. (Mac *    OS X sets a lower threshold for antialiasing, while in Mac OS 9 *    grayscale text can be turned off by the user.) In Mac OS X, when *    using a Quartz graphics context, you can instruct ATSUI to use *    the redraw method of highlighting, rather than simple inversion. *    (Note that Cocoa applications always use the redraw method of *    highlighting.) The redraw method allows for accurate highlighting *    of more complex backgrounds, such as those containing multiple *    colors, patterns, or pictures. To set redrawing on, call the *    ATSUSetHighlightingMethod function and specify that the redraw *    method be used (by passing kRedrawHighlighting in the iMethod *    parameter). If you specify the redraw method of highlighting when *    you call ATSUSetHighlightingMethod, then you must also specify *    how the background is to be redrawn when the function *    ATSUUnhighlightText is called. ATSUI can restore the desired *    background in one of two ways, depending on the background's *    complexity: (1) When the background is a single color (such as *    white), ATSUI can readily unhighlight the background. In such a *    case, you specify the background color that ATSUI uses by calling *    ATSUSetHighlightingMethod and setting iUnhighlightData.dataType *    to kATSUBackgroundColor and providing the background color in *    iUnhighlightData.unhighlightData. With these settings defined, *    when you call ATSUUnhighlightText, ATSUI simply calculates the *    previously highlighted area, repaints it with the specified *    background color, and then redraws the text. (2) When the *    background is more complex (containing, for example, multiple *    colors, patterns, or pictures), you must provide a redraw *    background callback function when you call *    ATSUSetHighlightingMethod. You do this by setting *    iUnhighlightData.dataType to kATSUBackgroundCallback and *    providing a RedrawBackgroundUPP in *    iUnhighlightData.unhighlightData . Then when you call *    ATSUUnhighlightText and ATSUI calls your callback, you are *    responsible for redrawing the background of the unhighlighted *    area. If you choose to also redraw the text, then your callback *    should return false as a function result. If your callback *    returns true ATSUI redraws any text that needs to be redrawn. See *    RedrawBackgroundProcPtr for additional information.  *   *  Parameters: *     *    iTextLayout: *      The layout to which this highlight method should be applied. *     *    iMethod: *      The type of highlighting to use; inversion *      (kInvertHighlighting) or redrawing (kRedrawHighlighting). The *      default is inversion. If you are happy with that technique *      there is no reason to call this function. *     *    iUnhighlightData: *      Data needed to redraw the background or NULL if inversion is *      being chosen. See the definition of ATSUUnhighlightData for *      more information about the possible contents of this structure. *      Also see the Discussion for this function. can be NULL *   *  Result: *    On success, noErr is returned. See MacErrors.h for possible error *    codes. *   *  Availability: *    Mac OS X:         in version 10.0 and later in ApplicationServices.framework *    CarbonLib:        not available in CarbonLib 1.x, is available on Mac OS X version 10.0 and later *    Non-Carbon CFM:   not available }// AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATERfunction ATSUSetHighlightingMethod( iTextLayout: ATSUTextLayout; iMethod: ATSUHighlightMethod; iUnhighlightData: ATSUUnhighlightDataPtr ): OSStatus; external name '_ATSUSetHighlightingMethod';{ *  ATSUHighlightText() *   *  Summary: *    Renders a highlighted range of text at a specified location in a *    QuickDraw graphics port or Quartz graphics context. *   *  Discussion: *    When the user selects a series of glyphs, the characters in *    memory corresponding to the glyphs make up the selection range *    and should be highlighted to indicate where the next editing *    operation is to occur. The characters in a selection range are *    always contiguous in memory, but their corresponding glyphs are *    not necessarily so onscreen. If the selection range crosses a *    direction boundary, it is appropriate to display discontinuous *    highlighting. The ATSUHighlightText function renders a *    highlighted range of text at a specified location in a QuickDraw *    graphics port or Quartz graphics context, using the highlight *    information in the graphics port or context. ATSUHighlightText *    automatically produces discontinuous highlighting, if needed. You *    typically call the ATSUHighlightText function every time you need *    to draw or redraw highlighted text. *   *  Parameters: *     *    iTextLayout: *      A layout containing text to be highlighted. *     *    iTextBasePointX: *      The x-coordinate of the origin (in either the current graphics *      port or in a Quartz graphics context) of the line containing *      the text range. Pass the constant kATSUUseGrafPortPenLoc to *      draw relative to the current pen location in the current *      graphics port. *     *    iTextBasePointY: *      The y-coordinate of the origin (in either the current graphics *      port or in a Quartz graphics context) of the line containing *      the text range. Pass the constant kATSUUseGrafPortPenLoc to *      draw relative to the current pen location in the current *      graphics port. *     *    iHighlightStart: *      The first character of the text range to be highlighted. If the *      text range spans multiple lines, you should call *      ATSUHighlightText for each line, passing the offset *      corresponding to the beginning of the new line to draw with *      each call. To indicate that the specified text range starts at *      the beginning of the text buffer, you can pass the constant *      kATSUFromTextBeginning. To specify the entire text buffer, pass *      kATSUFromTextBeginning in this parameter and kATSUToTextEnd in *      the iHighlightLength parameter. *     *    iHighlightLength: *      The length of the text range to be highlighted. To indicate *      that the text range extends to the end of the text buffer, pass *      the constant kATSUToTextEnd. *   *  Result: *    On success, noErr is returned. See MacErrors.h for possible error *    codes. *   *  Availability: *    Mac OS X:         in version 10.0 and later in ApplicationServices.framework *    CarbonLib:        in CarbonLib 1.0 and later *    Non-Carbon CFM:   in ATSUnicodeLib 8.5 and later }// AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATERfunction ATSUHighlightText( iTextLayout: ATSUTextLayout; iTextBasePointX: ATSUTextMeasurement; iTextBasePointY: ATSUTextMeasurement; iHighlightStart: UniCharArrayOffset; iHighlightLength: UniCharCount ): OSStatus; external name '_ATSUHighlightText';{ *  ATSUUnhighlightText() *   *  Summary: *    Renders a previously highlighted range of text in an *    unhighlighted state. *   *  Discussion: *    This function renders a previously highlighted range of text in *    an unhighlighted state. You should always call *    ATSUUnhighlightText after calling the function ATSUHighlightText *    to properly redraw the unhighlighted text and background. If the *    inversion method of highlighting was used, when you call *    ATSUUnhighlightText, it merely undoes the inversion and renders *    the text. If the redraw method of highlighting was used, *    ATSUUnhighlightText turns off the highlighting and restores the *    desired background. Depending on the complexity of the *    background, ATSUI restores the background in one of two ways: *    filling in a solid color, or repainting the background using a *    callback. See the function ATSUSetHighlightingMethod and the *    definition ATSUUnhighlightData for more information. *   *  Parameters: *     *    iTextLayout: *      A layout containing text to be unhighlighted. *     *    iTextBasePointX: *      The x-coordinate of the origin (in either the current graphics *      port or in a Quartz graphics context) of the line containing *      the text range. Pass the constant kATSUUseGrafPortPenLoc to *      draw relative to the current pen location in the current *      graphics port. *     *    iTextBasePointY: *      The y-coordinate of the origin (in either the current graphics *      port or in a Quartz graphics context) of the line containing *      the text range. Pass the constant kATSUUseGrafPortPenLoc to *      draw relative to the current pen location in the current *      graphics port. *     *    iHighlightStart: *      The first character of the text range to be unhighlighted. If *      the text range spans multiple lines, you should call *      ATSUUnhighlightText for each line, passing the offset *      corresponding to the beginning of the new line to draw with *      each call. To indicate that the specified text range starts at *      the beginning of the text buffer, you can pass the constant *      kATSUFromTextBeginning. To specify the entire text buffer, pass *      kATSUFromTextBeginning in this parameter and kATSUToTextEnd in *      the iHighlightLength parameter. *     *    iHighlightLength: *      The length of the text range to be unhighlighted. To indicate *      that the text range extends to the end of the text buffer, pass *      the constant kATSUToTextEnd. *   *  Result: *    On success, noErr is returned. See MacErrors.h for possible error *    codes. *   *  Availability: *    Mac OS X:         in version 10.0 and later in ApplicationServices.framework *    CarbonLib:        in CarbonLib 1.0 and later *    Non-Carbon CFM:   in ATSUnicodeLib 8.5 and later }// AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATERfunction ATSUUnhighlightText( iTextLayout: ATSUTextLayout; iTextBasePointX: ATSUTextMeasurement; iTextBasePointY: ATSUTextMeasurement; iHighlightStart: UniCharArrayOffset; iHighlightLength: UniCharCount ): OSStatus; external name '_ATSUUnhighlightText';{ *  ATSUGetTextHighlight() *   *  Summary: *    Obtains the highlight region for a range of text. *   *  Discussion: *    Use this function to obtain the screen region that ATSUI would *    normally highlight automatically when ATSUHighlightText is *    called. This is useful if you wish to perform your own *    highlighting. *   *  Parameters: *     *    iTextLayout: *      A layout containing text to be highlighted. *     *    iTextBasePointX: *      The x-coordinate of the origin (in either the current graphics *      port or in a Quartz graphics context) of the line containing *      the text range. Pass the constant kATSUUseGrafPortPenLoc to *      draw relative to the current pen location in the current *      graphics port. *     *    iTextBasePointY: *      The y-coordinate of the origin (in either the current graphics *      port or in a Quartz graphics context) of the line containing *      the text range. Pass the constant kATSUUseGrafPortPenLoc to *      draw relative to the current pen location in the current *      graphics port. *     *    iHighlightStart: *      The first character of the text range to be highlighted. If the *      text range spans multiple lines, you should call *      ATSUGetTextHighlight for each line, passing the offset *      corresponding to the beginning of the new line to draw with *      each call. To indicate that the specified text range starts at *      the beginning of the text buffer, you can pass the constant *      kATSUFromTextBeginning. To specify the entire text buffer, pass *      kATSUFromTextBeginning in this parameter and kATSUToTextEnd in *      the iHighlightLength parameter. *     *    iHighlightLength: *      The length of the text range to be highlighted. To indicate *      that the text range extends to the end of the text buffer, pass *      the constant kATSUToTextEnd. *     *    oHighlightRegion: *      On return, ATSUGetTextHighlight produces a MacRegion structure *      containing the highlight region for the specified range of *      text. In the case of discontinuous highlighting, the region *      consists of multiple components, with MacRegion.rgnBBox *      specifying the bounding box around the entire area of *      discontinuous highlighting. *   *  Result: *    On success, noErr is returned. See MacErrors.h for possible error *    codes. *   *  Availability: *    Mac OS X:         in version 10.0 and later in ApplicationServices.framework *    CarbonLib:        in CarbonLib 1.0 and later *    Non-Carbon CFM:   in ATSUnicodeLib 8.5 and later }// AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATERfunction ATSUGetTextHighlight( iTextLayout: ATSUTextLayout; iTextBasePointX: ATSUTextMeasurement; iTextBasePointY: ATSUTextMeasurement; iHighlightStart: UniCharArrayOffset; iHighlightLength: UniCharCount; oHighlightRegion: RgnHandle ): OSStatus; external name '_ATSUGetTextHighlight';{ *  ATSUHighlightInactiveText() *   *  Summary: *    Highlights text using the standard Mac OS X UI convention for an *    inactive window or UI pane. *   *  Discussion: *    Use this function to redraw text when a window or UI pane *    containing highlighted text becomes inactive. Once the window or *    UI pane becomes active again, call ATSUHighlightText to *    rehighlight the text in active mode. *   *  Parameters: *     *    iTextLayout: *      A layout containing text to be highlighted. *     *    iTextBasePointX: *      The x-coordinate of the origin (in either the current graphics *      port or in a Quartz graphics context) of the line containing *      the text range. Pass the constant kATSUUseGrafPortPenLoc to *      draw relative to the current pen location in the current *      graphics port. *     *    iTextBasePointY: *      The y-coordinate of the origin (in either the current graphics *      port or in a Quartz graphics context) of the line containing *      the text range. Pass the constant kATSUUseGrafPortPenLoc to *      draw relative to the current pen location in the current *      graphics port. *     *    iHighlightStart: *      The first character of the text range to be highlighted. If the *      text range spans multiple lines, you should call *      ATSUHighlightInactiveText for each line, passing the offset *      corresponding to the beginning of the new line to draw with *      each call. To indicate that the specified text range starts at *      the beginning of the text buffer, you can pass the constant *      kATSUFromTextBeginning. To specify the entire text buffer, pass *      kATSUFromTextBeginning in this parameter and kATSUToTextEnd in *      the iHighlightLength parameter. *     *    iHighlightLength: *      The length of the text range to be highlighted. To indicate *      that the text range extends to the end of the text buffer, pass *      the constant kATSUToTextEnd. *   *  Result: *    On success, noErr is returned. See MacErrors.h for possible error *    codes. *   *  Availability: *    Mac OS X:         in version 10.2 and later in ApplicationServices.framework *    CarbonLib:        not available in CarbonLib 1.x, is available on Mac OS X version 10.2 and later *    Non-Carbon CFM:   not available }// AVAILABLE_MAC_OS_X_VERSION_10_2_AND_LATERfunction ATSUHighlightInactiveText( iTextLayout: ATSUTextLayout; iTextBasePointX: ATSUTextMeasurement; iTextBasePointY: ATSUTextMeasurement; iHighlightStart: UniCharArrayOffset; iHighlightLength: UniCharCount ): OSStatus; external name '_ATSUHighlightInactiveText';{ ---------------------------------------------------------------------------- }{  ATSUI hit-testing                                                           }{ ---------------------------------------------------------------------------- }{ *  ATSUPositionToOffset() *   *  Summary: *    Obtains the memory offset for the glyph edge nearest a mouse-down *    event. *   *  Discussion: *    The process of hit-testing text obtains the location of a *    mouse-down event relative both to the position of onscreen glyphs *    and to the corresponding offset between character codes in *    memory. You can then use the location information obtained by *    hit-testing to set the insertion point (that is, the caret) or *    selection range (for highlighting). Hit-testing text is *    complicated by the fact that a given line of text may be *    bidirectional. Therefore, the onscreen order of glyphs may not *    readily correspond to the storage order of the corresponding *    character codes. And the concept of which glyph comes "first" in *    a line of text cannot always be limited to the visual terms *    "left" and "right." Because of these complexities, it is more *    accurate to speak in terms of "leading" and "trailing" edges to *    glyphs. A "leading edge" is defined as the edge of a glyph that *    you first encounter when you read the text that includes that *    glyph. For example, when reading Roman text, you first encounter *    the left edge of a Roman glyph. Similarly, the "trailing edge" is *    defined as the edge of the glyph encountered last. This function *    produces the memory offset corresponding to the glyph edge *    nearest the event. If the mouse-down event occurs at a line *    direction boundary or within a glyph cluster, *    ATSUPositionToOffset produces two offsets. You can then provide *    the offset(s) to the ATSUOffsetToPosition function to obtain the *    actual caret position(s) for the event. When you call the *    ATSUPositionToOffset function, ATSUI examines the Unicode *    directionality of the character corresponding to the event *    location. The ATSUPositionToOffset function produces a value of *    true in the oIsLeading parameter if the offset is leading (that *    is, more closely associated with the subsequent character in *    memory and therefore indicative of a left-to-right line *    direction). It produces a value of false if the offset is *    trailing (that is, more closely associated with the preceding *    character in memory and indicative of a right-to-left line *    direction). Finally, note that when the event occurs beyond the *    leftmost or rightmost caret positions of the line (not taking *    into account line rotation), such that no glyph corresponds to *    the location of the hit, the ATSUPositionToOffset function *    produces the primary offset of the closest edge of the line to *    the input location. The oIsLeading flag depends on the *    directionality of the closest glyph and the side of the line to *    which the input location is closest. In this case, the secondary *    offset is equal to the primary offset, since no glyph was hit. *   *  Parameters: *     *    iTextLayout: *      The layout object in which the mouse-down event occurred. *     *    iLocationX: *      The x-coordinate of the event, in local coordinates, relative *      to the origin of the line where the event occurred. That is, to *      specify the x-coordinate value, you should subtract the *      x-coordinate of the line origin from the x-coordinate of the *      hit point (in local coordinates). You can pass the constant *      kATSUUseGrafPortPenLoc for the location of the mouse-down event *      relative to the current pen location in the current graphics *      port. *     *    iLocationY: *      The y-coordinate of the event, in local coordinates, relative *      to the origin of the line where the event occurred. That is, to *      specify the y-coordinate value, you should subtract the *      y-coordinate of the line origin from the y-coordinate of the *      hit point (in local coordinates). You can pass the constant *      kATSUUseGrafPortPenLoc for the location of the mouse-down event *      relative to the current pen location in the current graphics *      port. *     *    ioPrimaryOffset: *      On input, a pointer to a UniCharArrayOffset value specifying *      the offset corresponding to the beginning of the line where the *      event occurred. On return, the value specifies the offset *      corresponding to the glyph edge that is visually closest to the *      event. To determine whether this offset indicates the leading *      or trailing edge of the glyph, you can examine the value *      produced in the oIsLeading parameter. *     *    oIsLeading: *      On return, the value indicates whether the offset produced in *      the ioPrimaryOffset parameter is leading or trailing. The *      function ATSUPositionToOffset produces a value of true if the *      offset is leading (that is, more closely associated with the *      subsequent character in memory). It produces a value of false *      if the offset is trailing (that is, more closely associated *      with the preceding character in memory). *     *    oSecondaryOffset: *      On return, the value typically specifies the same offset as *      that produced in the ioPrimaryOffset parameter, unless the *      event occurred within a glyph cluster or at a line direction *      boundary. If so, the value specifies a secondary offset. The *      secondary offset is associated with the glyph that has a *      different direction from the primary line direction. *   *  Result: *    On success, noErr is returned. See MacErrors.h for possible error *    codes. *   *  Availability: *    Mac OS X:         in version 10.0 and later in ApplicationServices.framework *    CarbonLib:        in CarbonLib 1.0 and later *    Non-Carbon CFM:   in ATSUnicodeLib 8.5 and later }// AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATERfunction ATSUPositionToOffset( iTextLayout: ATSUTextLayout; iLocationX: ATSUTextMeasurement; iLocationY: ATSUTextMeasurement; var ioPrimaryOffset: UniCharArrayOffset; var oIsLeading: Boolean; var oSecondaryOffset: UniCharArrayOffset ): OSStatus; external name '_ATSUPositionToOffset';{ *  ATSUOffsetToPosition() *   *  Summary: *    Obtains the caret position(s) corresponding to a memory offset. *   *  Discussion: *    This function produces two structures of type ATSUCaret. These *    structures contain the pen positioning information needed to draw *    the caret(s) for the event, specified relative to the origin of *    the line in the current graphics port or graphics context. *    Specifically, the ATSUCaret structures contain x-y coordinates *    for both the caret's starting and ending pen positions (the *    latter taking into account line rotation, caret slanting, and *    split-caret appearances). If the offset you pass to *    ATSUOffsetToPosition is at a line boundary, the structure *    produced in the oMainCaret parameter contains the starting and *    ending pen locations for the high caret, while the oSecondCaret *    parameter contains the corresponding values for the low caret. If *    the offset is not at a line boundary, both parameters contain the *    starting and ending pen locations of the main caret. Because you *    provide the ATSUOffsetToPosition function an offset relative to *    the origin of the line where the hit occurred, *    ATSUOffsetToPosition produces positioning information that is *    also relative. Therefore, you must transform the positions *    produced by the ATSUOffsetToPosition function before drawing the *    caret(s). To transform the caret location(s), add the starting *    and ending caret coordinates to the coordinates of the origin of *    the line in which the hit occurred. For example, if *    ATSUOffsetToPosition produces starting and ending pen locations *    of (25,0), (25,25) in the oMainCaret parameter (and the *    oSecondCaret parameter contains the same coordinates, meaning *    that the caret was not split), you would add these to the *    position of the origin of the line in the graphics port or *    context. If the position of the line origin was at (50,50), then *    the starting and ending pen locations of the caret would be *    (75,50), (75,75). *   *  Parameters: *     *    iTextLayout: *      The layout containing the offset. *     *    iOffset: *      The offset into the text buffer for which you wish to obtain a *      caret position. To respond to a mouse-down event, pass the *      offset returned in the ioPrimaryOffset parameter from the *      function ATSUPositionToOffset. That is, the offset *      corresponding to the glyph edge closest to the event. *     *    iIsLeading: *      A Boolean value indicating whether the offset corresponds to *      the leading or trailing edge of the glyph. You can obtain this *      information from the function ATSUPositionToOffset. This value *      is relevant if the offset occurs at a line direction boundary *      or within a glyph cluster. *     *    oMainCaret: *      On return, contains the starting and ending pen locations of *      the high caret if the value produced in oCaretIsSplit is true. *      If the value is false, the structure contains the starting and *      ending pen locations of the main caret. *     *    oSecondCaret: *      On return, contains the starting and ending pen locations of *      the low caret if the value passed back in the oCaretIsSplit *      parameter is true. If the value is false, the structure *      contains the starting and ending pen locations of the main *      caret (that is, the same values as the oMainCaret parameter). *     *    oCaretIsSplit: *      On return, indicates whether the offset specified in the *      iOffset parameter occurs at a line direction boundary. If true, *      the offset occurs at a line direction boundary; otherwise, *      false. *   *  Result: *    On success, noErr is returned. See MacErrors.h for possible error *    codes. *   *  Availability: *    Mac OS X:         in version 10.0 and later in ApplicationServices.framework *    CarbonLib:        in CarbonLib 1.0 and later *    Non-Carbon CFM:   in ATSUnicodeLib 8.5 and later }// AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATERfunction ATSUOffsetToPosition( iTextLayout: ATSUTextLayout; iOffset: UniCharArrayOffset; iIsLeading: Boolean; var oMainCaret: ATSUCaret; var oSecondCaret: ATSUCaret; var oCaretIsSplit: Boolean ): OSStatus; external name '_ATSUOffsetToPosition';{ *  ATSUPositionToCursorOffset() *   *  Summary: *    Obtains the memory offset for the glyph edge nearest a mouse-down *    event, after a move of the specified length. *   *  Discussion: *    This function produces the memory offset for the glyph edge *    nearest a mouse-down event, after a move of the specified length. *    This offset corresponds to where an insertion point would be *    placed after the move. *   *  Parameters: *     *    iTextLayout: *      The layout in which the mouse down event occured. *     *    iLocationX: *      The x-coordinate of the event, in local coordinates, relative *      to the origin of the line where the event occurred. That is, to *      specify the x-coordinate value, you should subtract the *      x-coordinate of the line origin from the x-coordinate of the *      hit point (in local coordinates). You can pass the constant *      kATSUUseGrafPortPenLoc for the location of the mouse-down event *      relative to the current pen location in the current graphics *      port. *     *    iLocationY: *      The y-coordinate of the event, in local coordinates, relative *      to the origin of the line where the event occurred. That is, to *      specify the y-coordinate value, you should subtract the *      y-coordinate of the line origin from the y-coordinate of the *      hit point (in local coordinates). You can pass the constant *      kATSUUseGrafPortPenLoc for the location of the mouse-down event *      relative to the current pen location in the current graphics *      port. *     *    iMovementType: *      A constant specifying the type of cursor movement to use. See *      the definition of ATSUCursorMovementType for possible values to *      pass for this parameter. *     *    ioPrimaryOffset: *      On input, the offset corresponding to the beginning of the line *      where the event occurred. On return, the offset corresponding *      to the glyph edge nearest the event, after a movement of the *      specified type. This offset corresponds to where the insertion *      point would be placed after the move. To determine whether this *      offset indicates the leading or trailing edge of the glyph, you *      can examine the value produced in the oIsLeading parameter. *     *    oIsLeading: *      On return, the value indicates whether the offset produced in *      the ioPrimaryOffset parameter is leading or trailing. The *      ATSUPositionToOffset function produces a value of true if the *      offset is leading (that is, more closely associated with the *      subsequent character in memory). It produces a value of false *      if the offset is trailing (that is, more closely associated *      with the preceding character in memory). *     *    oSecondaryOffset: *      On return, the value typically specifies the same offset as *      that produced in the ioPrimaryOffset parameter, unless the *      event occurred within a glyph cluster or at a line direction *      boundary. If so, the value specifies the secondary offset, for *      the glyph edge furthest from the event. *   *  Result: *    On success, noErr is returned. See MacErrors.h for possible error *    codes. *   *  Availability: *    Mac OS X:         in version 10.0 and later in ApplicationServices.framework *    CarbonLib:        in CarbonLib 1.5 and later *    Non-Carbon CFM:   in ATSUnicodeLib 9.2.2 and later }// AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATERfunction ATSUPositionToCursorOffset( iTextLayout: ATSUTextLayout; iLocationX: ATSUTextMeasurement; iLocationY: ATSUTextMeasurement; iMovementType: ATSUCursorMovementType; var ioPrimaryOffset: UniCharArrayOffset; var oIsLeading: Boolean; var oSecondaryOffset: UniCharArrayOffset ): OSStatus; external name '_ATSUPositionToCursorOffset';{ *  ATSUOffsetToCursorPosition() *   *  Summary: *    Obtains the caret position(s) corresponding to a memory offset, *    after a move of the specified length. *   *  Discussion: *    Use this function in conjunction with ATSUPositionToCursorOffset *    to determine where to draw the caret after a mouse-down event. *    The movement type parameter allows you to have the cursor "snap" *    to different parts of the text depending on the type of movement *    selected (i.e., words or characters). See the definition of *    ATSUCursorMovementType for more information on possible values. *   *  Parameters: *     *    iTextLayout: *      The text layout object in which the mouse-down event occurred. *     *    iOffset: *      The offset corresponding to the glyph edge nearest the event, *      after a movement of the specified type. You can obtain this *      value by examining the offset produced in the ioPrimaryOffset *      parameter of the function ATSUPositionToCursorOffset. *     *    iIsLeading: *      A Boolean value indicating whether the specified offset *      corresponds to the leading or trailing edge of the glyph. You *      can obtain this information from the function *      ATSUPositionToCursorOffset . This value is relevant if the *      offset occurs at a line direction boundary or within a glyph *      cluster. *     *    iMovementType: *      A constant specifying the unit of cursor movement. See the *      definition of ATSUCursorMovementType for possible values to *      pass for this parameter. *     *    oMainCaret: *      On return, the structure contains the starting and ending pen *      locations of the high caret if the value produced in the *      oCaretIsSplit parameter is true. If the value is false, the *      structure contains the starting and ending pen locations of the *      main caret. *     *    oSecondCaret: *      On return, the structure contains the starting and ending pen *      locations of the low caret if the value passed back in the *      oCaretIsSplit parameter is true. If the value is false, the *      structure contains the starting and ending pen locations of the *      main caret (that is, the same values as the oMainCaret *      parameter). *     *    oCaretIsSplit: *      On return, the value indicates whether the offset specified in *      the iOffset parameter occurs at a line direction boundary. If *      true, the offset occurs at a line direction boundary; *      otherwise, false. *   *  Result: *    On success, noErr is returned. See MacErrors.h for possible error *    codes. *   *  Availability: *    Mac OS X:         in version 10.0 and later in ApplicationServices.framework *    CarbonLib:        in CarbonLib 1.5 and later *    Non-Carbon CFM:   in ATSUnicodeLib 9.2.2 and later }// AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATERfunction ATSUOffsetToCursorPosition( iTextLayout: ATSUTextLayout; iOffset: UniCharArrayOffset; iIsLeading: Boolean; iMovementType: ATSUCursorMovementType; var oMainCaret: ATSUCaret; var oSecondCaret: ATSUCaret; var oCaretIsSplit: Boolean ): OSStatus; external name '_ATSUOffsetToCursorPosition';{ ---------------------------------------------------------------------------- }{  ATSUI cursor movement                                                       }{ ---------------------------------------------------------------------------- }{ *  ATSUNextCursorPosition() *   *  Summary: *    Obtains the memory offset for the insertion point that follows *    the current insertion point in storage order, as determined by a *    move of the specified length and type. *   *  Discussion: *    Together with ATSUPreviousCursorPosition, this function allows an *    application to "walk" the text buffer in storage order, moving *    the cursor by a specified amount and movement type at each step. *    To move through the text buffer in screen order, use the *    functions ATSURightwardCursorPosition and *    ATSULeftwardCursorPosition. *   *  Parameters: *     *    iTextLayout: *      The layout in which to perform the cursor movement. *     *    iOldOffset: *      The previous cursor position. *     *    iMovementType: *      A constant specifying the unit of cursor movement. See the *      definition of ATSUCursorMovementType for possible values to *      pass for this parameter. *     *    oNewOffset: *      On return, the new cursor position. *   *  Result: *    On success, noErr is returned. See MacErrors.h for possible error *    codes. *   *  Availability: *    Mac OS X:         in version 10.0 and later in ApplicationServices.framework *    CarbonLib:        in CarbonLib 1.0 and later *    Non-Carbon CFM:   in ATSUnicodeLib 8.5 and later }// AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATERfunction ATSUNextCursorPosition( iTextLayout: ATSUTextLayout; iOldOffset: UniCharArrayOffset; iMovementType: ATSUCursorMovementType; var oNewOffset: UniCharArrayOffset ): OSStatus; external name '_ATSUNextCursorPosition';{ *  ATSUPreviousCursorPosition() *   *  Summary: *    Obtains the memory offset for the insertion point that preceeds *    the current insertion point in storage order, as determined by a *    move of the specified length and type. *   *  Discussion: *    Together with ATSUNextCursorPosition, this function allows an *    application to "walk" the text buffer in storage order, moving *    the cursor by a specified amount and movement type at each step. *    To move through the text buffer in screen order, use the *    functions ATSURightwardCursorPosition and *    ATSULeftwardCursorPosition. *   *  Parameters: *     *    iTextLayout: *      The layout in which to perform the cursor movement. *     *    iOldOffset: *      The previous cursor position. *     *    iMovementType: *      A constant specifying the unit of cursor movement. See the *      definition of ATSUCursorMovementType for possible values to *      pass for this parameter. *     *    oNewOffset: *      On return, the new cursor position. *   *  Result: *    On success, noErr is returned. See MacErrors.h for possible error *    codes. *   *  Availability: *    Mac OS X:         in version 10.0 and later in ApplicationServices.framework *    CarbonLib:        in CarbonLib 1.0 and later *    Non-Carbon CFM:   in ATSUnicodeLib 8.5 and later }// AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATERfunction ATSUPreviousCursorPosition( iTextLayout: ATSUTextLayout; iOldOffset: UniCharArrayOffset; iMovementType: ATSUCursorMovementType; var oNewOffset: UniCharArrayOffset ): OSStatus; external name '_ATSUPreviousCursorPosition';{ *  ATSURightwardCursorPosition() *   *  Summary: *    Obtains the memory offset for the insertion point that is to the *    right of the current insertion point, as determined by a move of *    the specified length and type. *   *  Discussion: *    Together with ATSULeftwardCursorPosition, this function allows an *    application to "walk" the text buffer in screen order, moving the *    cursor by a specified amount and movement type at each step. To *    move through the text buffer in storage order, use the functions *    ATSUNextCursorPosition and ATSUPreviousCursorPosition. Note that *    if you are drawing the cursor after a cursor move, you should use *    ATSUOffsetToPosition to obtain an ATSUCaret that determines the *    on screen location of the new cursor position. Always store the *    ATSUCaret from the previous cursor position as well, as this can *    help determine which caret to use in the case of a split caret. *    When performing leftward and rightward cursor movement, always *    use the caret closest to the previous caret. This maintains *    visual order when moving the cursor on screen. *   *  Parameters: *     *    iTextLayout: *      The layout in which to perform the cursor movement. *     *    iOldOffset: *      The previous cursor position. *     *    iMovementType: *      A constant specifying the unit of cursor movement. See the *      definition of ATSUCursorMovementType for possible values to *      pass for this parameter. *     *    oNewOffset: *      On return, the new cursor position. *   *  Result: *    On success, noErr is returned. See MacErrors.h for possible error *    codes. *   *  Availability: *    Mac OS X:         in version 10.0 and later in ApplicationServices.framework *    CarbonLib:        in CarbonLib 1.0 and later *    Non-Carbon CFM:   in ATSUnicodeLib 8.5 and later }// AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATERfunction ATSURightwardCursorPosition( iTextLayout: ATSUTextLayout; iOldOffset: UniCharArrayOffset; iMovementType: ATSUCursorMovementType; var oNewOffset: UniCharArrayOffset ): OSStatus; external name '_ATSURightwardCursorPosition';{ *  ATSULeftwardCursorPosition() *   *  Summary: *    Obtains the memory offset for the insertion point that is to the *    left of the current insertion point, as determined by a move of *    the specified length and type. *   *  Discussion: *    Together with ATSURightwardCursorPosition, this function allows *    an application to "walk" the text buffer in screen order, moving *    the cursor by a specified amount and movement type at each step. *    To move through the text buffer in storage order, use the *    functions ATSUNextCursorPosition and ATSUPreviousCursorPosition. *    Note that if you are drawing the cursor after a cursor move, you *    should use ATSUOffsetToPosition to obtain an ATSUCaret that *    determines the on screen location of the new cursor position. *    Always store the ATSUCaret from the previous cursor position as *    well, as this can help determine which caret to use in the case *    of a split caret. When performing leftward and rightward cursor *    movement, always use the caret closest to the previous caret. *    This maintains visual order when moving the cursor on screen. *   *  Parameters: *     *    iTextLayout: *      The layout in which to perform the cursor movement. *     *    iOldOffset: *      The previous cursor position. *     *    iMovementType: *      A constant specifying the unit of cursor movement. See the *      definition of ATSUCursorMovementType for possible values to *      pass for this parameter. *     *    oNewOffset: *      On return, the new cursor position. *   *  Result: *    On success, noErr is returned. See MacErrors.h for possible error *    codes. *   *  Availability: *    Mac OS X:         in version 10.0 and later in ApplicationServices.framework *    CarbonLib:        in CarbonLib 1.0 and later *    Non-Carbon CFM:   in ATSUnicodeLib 8.5 and later }// AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATERfunction ATSULeftwardCursorPosition( iTextLayout: ATSUTextLayout; iOldOffset: UniCharArrayOffset; iMovementType: ATSUCursorMovementType; var oNewOffset: UniCharArrayOffset ): OSStatus; external name '_ATSULeftwardCursorPosition';{ Functions listed beyond this point are either deprecated or not recommended }{ *  ATSUMeasureText() *   *  Discussion: *    This function is no longer recommended. Please use *    ATSUGetUnjustifiedBounds instead. *   *  Availability: *    Mac OS X:         in version 10.0 and later in ApplicationServices.framework *    CarbonLib:        in CarbonLib 1.0 and later *    Non-Carbon CFM:   in ATSUnicodeLib 8.5 and later }// AVAILABLE_MAC_OS_X_VERSION_10_0_AND_LATERfunction ATSUMeasureText( iTextLayout: ATSUTextLayout; iLineStart: UniCharArrayOffset; iLineLength: UniCharCount; var oTextBefore: ATSUTextMeasurement; var oTextAfter: ATSUTextMeasurement; var oAscent: ATSUTextMeasurement; var oDescent: ATSUTextMeasurement ): OSStatus; external name '_ATSUMeasureText';end.
 |