NSTextView

Other topics

Creating an NSTextView

Graphically

In XCode a simple NSTextView can be created by dragging and dropping one from the Object Library.

Dragging an NSTextView object from the Object Library to a window in Interface Builder.

This NSTextView sits inside an NSScrollView that is automatically set to expand vertically with the text view. Make sure when option(⌥)-dragging you make connections to the text view and not the scroll view.

Showing contents of NSScrollView to show hierarchy location of NSTextView.

Programmatically

Creating an NSTextView programmatically allows for greater control and customization. It is slightly more difficult and requires knowledge of the text system to use it to its full potential. More info about the text system and more is available here. The basics required to make a text view programmatically are as follows:

  • Three other objects are required for a fully functioning NSTextView to work:

    1. An NSLayoutManager - performs glyph/character layout.
    2. An NSTextContainer - controls graphical space that glyphs/characters can inhabit.
    3. An NSTextStorage - holds the actual string data that NSTextView displays.
  • An NSTextStorage can have many NSLayoutManager's, but an NSLayoutManager can only have one NSTextStorage. This is useful if you wish to show the same data in different ways at the same time.

  • NSLayoutManager's can have many NSTextContainer's. Useful for paginated text.

  • NSTextView's can only have one NSTextContainer at a time.

  • Certain things built into NSTextView are off limits at the time of writing. For example built-in Find-and-Replace functions are not able to be customized, but can be overridden with custom functions.

More information on ways to use the text system can be found here.

Now for the code. This code will create a simple NSTextView, with not even scrolling. Such things like scrolling and pagination will be in another example.

Objective-C

// This code resides in an NSDocument object's windowControllerDidLoadNib:(NSWindowController *)windowController method.
// This is done simply because it is easy and automatically gets called upon.

// This method is also where the following NSRect variable gets size information. We need this information for this example.
NSRect windowFrame = windowController.window.contentView.frame;
NSTextStorage *textStorage = [[NSTextStorage alloc] initWithString:@"Example text!"];
NSLayoutManager *manager = [[NSLayoutManager alloc] init];
NSTextContainer *container = [[NSTextContainer alloc] initWithContainerSize:NSMakeSize(windowFrame.size.width, windowFrame.size.height)];
NSTextView *textView = [[NSTextView alloc] initWithFrame:windowFrame textContainer:container];

[textStorage addLayoutManager:manager];
[manager addTextContainer:container];
[windowController.window setContentView:textView];

Congratulations! You have made an NSTextView programmatically!

enter image description here

Contributors

Topic Id: 8880

Example Ids: 27660

This site is not affiliated with any of the contributors.