home *** CD-ROM | disk | FTP | other *** search
/ OpenStep (Enterprise) / OpenStepENTCD.toast / OEDEV / DEV.Z / NSTextView.h < prev    next >
Text File  |  1996-09-09  |  11KB  |  244 lines

  1. /*
  2.         NSTextView.h
  3.         Application Kit
  4.         Copyright (c) 1994-1996, NeXT Software, Inc.
  5.         All rights reserved.
  6. */
  7.  
  8. #ifndef STRICT_OPENSTEP
  9.  
  10. // NSTextView is a NSText subclass that displays the glyphs laid out in one NSTextContainer.
  11.  
  12. #import <AppKit/NSText.h>
  13. #import <AppKit/NSInputManager.h>
  14. #import <AppKit/NSTextAttachment.h>
  15. #import <AppKit/AppKitDefines.h>
  16.  
  17. @class NSTextContainer;
  18. @class NSTextStorage;
  19. @class NSLayoutManager;
  20. @class NSRulerView;
  21. @class NSRulerMarker;
  22.  
  23. typedef enum _NSSelectionGranularity {
  24.     NSSelectByCharacter = 0,
  25.     NSSelectByWord = 1,
  26.     NSSelectByParagraph = 2,
  27. } NSSelectionGranularity;
  28.  
  29. typedef enum _NSSelectionAffinity {
  30.     NSSelectionAffinityUpstream = 0,
  31.     NSSelectionAffinityDownstream = 1,
  32. } NSSelectionAffinity;
  33.  
  34. @interface NSTextView : NSText <NSTextInput> {
  35.     // no ivars allowed, use _ivars slot from superclass
  36. }
  37.  
  38. /**************************** Initializing ****************************/
  39.  
  40. + (void)registerForServices;
  41.     // This is sent each time a view is initialized.  If you subclass you should ensure that you only register once.
  42.  
  43. - (id)initWithFrame:(NSRect)frameRect textContainer:(NSTextContainer *)container;
  44.     // Designated Initializer. container may be nil.
  45.  
  46. - (id)initWithFrame:(NSRect)frameRect;
  47.     // This variant will create the text network (textStorage, layoutManager, and a container).
  48.  
  49. /***************** Get/Set the container and other stuff *****************/
  50.  
  51. - (NSTextContainer *)textContainer;
  52. - (void)setTextContainer:(NSTextContainer *)container;
  53.     // The set method should not be called directly, but you might want to override it.  Gets or sets the text container for this view.  Setting the text container marks the view as needing display.  The text container calls the set method from its setTextView: method.
  54.  
  55. - (void)replaceTextContainer:(NSTextContainer *)newContainer;
  56.     // This method should be used instead of the primitive -setTextContainer: if you need to replace a view's text container with a new one leaving the rest of the web intact.  This method deals with all the work of making sure the view doesn't get deallocated and removing the old container from the layoutManager and replacing it with the new one.
  57.  
  58. - (void)setTextContainerInset:(NSSize)inset;
  59. - (NSSize)textContainerInset;
  60.     // The textContianerInset determines the padding that the view provides around the container.  The container's origin will be inset by this amount from the bounds point {0,0} and padding will be left to the right and below the container of the same amount.  This inset affects the view sizing in response to new layout and is used by the rectangular text containers when they track the view's frame dimensions.
  61.  
  62. - (NSPoint)textContainerOrigin;
  63. - (void)invalidateTextContainerOrigin;
  64.     // The container's origin in the view is determined from the current usage of the container, the container inset, and the view size.  textContainerOrigin returns this point.  invalidateTextContainerOrigin is sent automatically whenever something changes that causes the origin to possibly move.  You usually do not need to call invalidate yourself. 
  65.  
  66. - (NSLayoutManager *)layoutManager;
  67. - (NSTextStorage *)textStorage;
  68.     // Convenience methods
  69.  
  70. /************************* Key binding entry-point *************************/
  71.  
  72. - (void)insertText:(NSString *)insertString;
  73.     // This method is the funnel point for text insertion after keys pass through the key binder.
  74.  
  75. /*************************** Sizing methods ***************************/
  76.  
  77. - (void)setConstrainedFrameSize:(NSSize)desiredSize;
  78.     // Sets the frame size of the view to desiredSize constrained within min and max size.
  79.  
  80. /***************** New miscellaneous API above and beyond NSText *****************/
  81.  
  82. - (void)setAlignment:(NSTextAlignment)alignment range:(NSRange)range;
  83.     // These complete the set of range: type set methods. to be equivalent to the set of non-range taking varieties.
  84.  
  85. - (void)pasteAsPlainText:(id)sender;
  86. - (void)pasteAsRichText:(id)sender;
  87.     // These methods are like paste: (from NSResponder) but they restrict the acceptable type of the pasted data.  They are suitable as menu actions for appropriate "Paste As" submenu commands.
  88.  
  89. /*************************** New Font menu commands ***************************/
  90.  
  91. - (void)turnOffKerning:(id)sender;
  92. - (void)tightenKerning:(id)sender;
  93. - (void)loosenKerning:(id)sender;
  94. - (void)useStandardKerning:(id)sender;
  95. - (void)turnOffLigatures:(id)sender;
  96. - (void)useStandardLigatures:(id)sender;
  97. - (void)useAllLigatures:(id)sender;
  98. - (void)raiseBaseline:(id)sender;
  99. - (void)lowerBaseline:(id)sender;
  100.  
  101. /*************************** Ruler support ***************************/
  102.  
  103. - (void)rulerView:(NSRulerView *)ruler didMoveMarker:(NSRulerMarker *)marker;
  104. - (void)rulerView:(NSRulerView *)ruler didRemoveMarker:(NSRulerMarker *)marker;
  105. - (void)rulerView:(NSRulerView *)ruler didAddMarker:(NSRulerMarker *)marker;
  106. - (BOOL)rulerView:(NSRulerView *)ruler shouldMoveMarker:(NSRulerMarker *)marker;
  107. - (BOOL)rulerView:(NSRulerView *)ruler shouldAddMarker:(NSRulerMarker *)marker;
  108. - (float)rulerView:(NSRulerView *)ruler willMoveMarker:(NSRulerMarker *)marker toLocation:(float)location;
  109. - (BOOL)rulerView:(NSRulerView *)ruler shouldRemoveMarker:(NSRulerMarker *)marker;
  110. - (float)rulerView:(NSRulerView *)ruler willAddMarker:(NSRulerMarker *)marker atLocation:(float)location;
  111. - (void)rulerView:(NSRulerView *)ruler handleMouseDown:(NSEvent *)event;
  112.  
  113. /*************************** Fine display control ***************************/
  114.  
  115. - (void)setNeedsDisplayInRect:(NSRect)rect avoidAdditionalLayout:(BOOL)flag;
  116.  
  117. - (BOOL)shouldDrawInsertionPoint;
  118. - (void)drawInsertionPointInRect:(NSRect)rect color:(NSColor *)color turnedOn:(BOOL)flag;
  119.  
  120. /*************************** Especially for subclassers ***************************/
  121.  
  122. - (void)updateRuler;
  123. - (void)updateFontPanel;
  124.  
  125. - (NSArray *)acceptableDragTypes;
  126. - (void)updateDragTypeRegistration;
  127.  
  128. - (NSRange)selectionRangeForProposedRange:(NSRange)proposedCharRange granularity:(NSSelectionGranularity)granularity;
  129.  
  130.  
  131. @end
  132.  
  133. @interface NSTextView (NSSharing)
  134.  
  135. // The methods in this category deal with settings that need to be shared by all the NSTextViews of a single NSLayoutManager.  Many of these methods are overrides of NSText or NSResponder methods.
  136.  
  137. /*************************** Selected/Marked range ***************************/
  138.  
  139. - (void)setSelectedRange:(NSRange)charRange affinity:(NSSelectionAffinity)affinity stillSelecting:(BOOL)stillSelectingFlag;
  140. - (NSSelectionAffinity)selectionAffinity;
  141. - (NSSelectionGranularity)selectionGranularity;
  142. - (void)setSelectionGranularity:(NSSelectionGranularity)granularity;
  143.  
  144. - (void)setSelectedTextAttributes:(NSDictionary *)attributeDictionary;
  145. - (NSDictionary *)selectedTextAttributes;
  146.  
  147. - (void)setInsertionPointColor:(NSColor *)color;
  148. - (NSColor *)insertionPointColor;
  149.  
  150. - (void)updateInsertionPointStateAndRestartTimer:(BOOL)restartFlag;
  151.  
  152. - (NSRange)markedRange;
  153.  
  154. - (void)setMarkedTextAttributes:(NSDictionary *)attributeDictionary;
  155. - (NSDictionary *)markedTextAttributes;
  156.  
  157. /*************************** Other NSTextView methods ***************************/
  158.  
  159. - (void)setRulerVisible:(BOOL)flag;
  160. - (BOOL)usesRuler;
  161. - (void)setUsesRuler:(BOOL)flag;
  162.  
  163. - (int)spellCheckerDocumentTag;
  164.  
  165. - (NSDictionary *)typingAttributes;
  166. - (void)setTypingAttributes:(NSDictionary *)attrs;
  167.  
  168. - (BOOL)shouldChangeTextInRange:(NSRange)affectedCharRange replacementString:(NSString *)replacementString;
  169. - (void)didChangeText;
  170.  
  171. - (NSRange)rangeForUserTextChange;
  172. - (NSRange)rangeForUserCharacterAttributeChange;
  173. - (NSRange)rangeForUserParagraphAttributeChange;
  174.  
  175. /*************************** NSText methods ***************************/
  176.  
  177. - (BOOL)isSelectable;
  178. - (void)setSelectable:(BOOL)flag;
  179. - (BOOL)isEditable;
  180. - (void)setEditable:(BOOL)flag;
  181. - (BOOL)isRichText;
  182. - (void)setRichText:(BOOL)flag;
  183. - (BOOL)importsGraphics;
  184. - (void)setImportsGraphics:(BOOL)flag;
  185. - (id)delegate;
  186. - (void)setDelegate:(id)anObject;
  187. - (BOOL)isFieldEditor;
  188. - (void)setFieldEditor:(BOOL)flag;
  189. - (BOOL)usesFontPanel;
  190. - (void)setUsesFontPanel:(BOOL)flag;
  191. - (BOOL)isRulerVisible;
  192. - (void)setBackgroundColor:(NSColor *)color;
  193. - (NSColor *)backgroundColor;
  194. - (void)setDrawsBackground:(BOOL)flag;
  195. - (BOOL)drawsBackground;
  196.  
  197. - (NSRange)selectedRange;
  198. - (void)setSelectedRange:(NSRange)charRange;
  199.  
  200. /*************************** NSResponder methods ***************************/
  201.  
  202. - (BOOL)resignFirstResponder;
  203. - (BOOL)becomeFirstResponder;
  204.  
  205. /*************************** Smart copy/paste/delete support ***************************/
  206.  
  207. - (BOOL)smartInsertDeleteEnabled;
  208. - (void)setSmartInsertDeleteEnabled:(BOOL)flag;
  209. - (NSRange)smartDeleteRangeForProposedRange:(NSRange)proposedCharRange;
  210. - (void)smartInsertForString:(NSString *)pasteString replacingRange:(NSRange)charRangeToReplace beforeString:(NSString **)beforeString afterString:(NSString **)afterString;
  211.  
  212. @end
  213.  
  214. // Note that all delegation messages come from the first textView
  215.  
  216. @interface NSObject (NSTextViewDelegate)
  217.  
  218. - (void)textView:(NSTextView *)textView clickedOnCell:(id <NSTextAttachmentCell>)cell inRect:(NSRect)cellFrame;    // Delegate only.
  219.  
  220. - (void)textView:(NSTextView *)textView doubleClickedOnCell:(id <NSTextAttachmentCell>)cell inRect:(NSRect)cellFrame;
  221.     // Delegate only.
  222.  
  223. - (void)textView:(NSTextView *)view draggedCell:(id <NSTextAttachmentCell>)cell inRect:(NSRect)rect event:(NSEvent *)event;    // Delegate only
  224.  
  225. - (NSRange)textView:(NSTextView *)textView willChangeSelectionFromCharacterRange:(NSRange)oldSelectedCharRange toCharacterRange:(NSRange)newSelectedCharRange;
  226.     // Delegate only.
  227.  
  228. - (void)textViewDidChangeSelection:(NSNotification *)notification;
  229.  
  230. - (BOOL)textView:(NSTextView *)textView shouldChangeTextInRange:(NSRange)affectedCharRange replacementString:(NSString *)replacementString;
  231.     // Delegate only.  If characters are changing, replacementString is what will replace the affectedCharRange.  If attributes only are changing, replacementString will be nil.
  232.  
  233. - (BOOL)textView:(NSTextView *)textView doCommandBySelector:(SEL)commandSelector;
  234.  
  235. @end
  236.  
  237. APPKIT_EXTERN NSString *NSTextViewWillChangeNotifyingTextViewNotification;
  238.     // NSOldNotifyingTextView -> the old view, NSNewNotifyingTextView -> the new view.  The text view delegate is not automatically registered to receive this notification because the text machinery will automatically switch over the delegate to observe the new first text view as the first text view changes.
  239.  
  240. APPKIT_EXTERN NSString *NSTextViewDidChangeSelectionNotification;
  241.     // NSOldSelectedCharacterRange -> NSValue with old range.
  242.  
  243. #endif
  244.