ntextIndent(3tk) | ntext Indentation for the Text Widget | ntextIndent(3tk) |
ntextIndent - ntext Indentation for the Text Widget
package require Tcl 8.5
package require Tk 8.5
package require ntext ?1.0?
::ntext::new_textCopy pathName
::ntext::new_textCut pathName
::ntext::new_textPaste pathName
::ntext::syncIndentColor pathName
The ntext package provides a binding tag named Ntext for use by text widgets in place of the default Text binding tag.
Tk's text widget may be configured to wrap lines of text that are longer than the width of the text area, a feature that is familiar from text editors and word processors. A complete line of text (delimited by newlines, or by the beginning or end of the document) is called a "logical line". When a logical line is wrapped onto more than one line of the display area, these fragments of the logical line are called "display lines".
If a logical line begins with whitespace, then wrapped display lines begin further to the left than the first display line, which can make the text layout untidy and difficult to read. The Ntext binding tag provides facilities so that a text widget in -wrap word mode will automatically indent display lines (other than the first) to match the initial whitespace of the first display line.
This indentation is available to text widgets only in -wrap word mode.
The behavior of Ntext may be configured application-wide by setting the values of a number of namespace variables:
::ntext::classicWrap
No other action is required if this option, and the text widget's -wrap option, are set before any text is entered in the widget, and if text is entered and edited only by the mouse and keyboard. If, instead, text is manipulated by the script, or if the text widget's -wrap option or the value of ::ntext::classicWrap are changed while the widget holds text, then calls to ntext functions are needed to alter the indentation. See the section INDENTING DISPLAY LINES for detailed instructions.
::ntext::indentColor
Coloring is implemented with the text widget tag option -lmargincolor, which is available from Tk 8.6.6 onwards. Ntext indent coloring has no effect in earlier versions of Tk.
The value of ::ntext::indentColor will often be set at startup. If the value is changed when text widgets already exist and contain text, those widgets can be updated by calling command ::ntext::syncIndentColor.
Advanced Use
::ntext::newWrapRegexp
To use Ntext 's display line indentation:
Further instructions apply if the program changes the widget's contents, wrap configuration, or indent configuration.
::ntext::wrapIndent textWidget ?index1? ?index2?
::ntext::wrapIndent textWidget
::ntext::wrapIndent textWidget index1
::ntext::wrapIndent textWidget index1 index2
Usage
This version of ntext is intended to be compatible with all releases of Tk 8.5 and 8.6, and with the branches core-8-5-branch, core-8-6-branch, and trunk in the source code repository for Tk. Any incompatibility with any of these versions, for any Tk windowing system, should be reported as a bug. Please report such in the category ntext of the Tklib Trackers [http://core.tcl.tk/tklib/reportlist].
To switch on Ntext 's indentation and use it in widget .t, using the default indent color #d9d9d9:
package require ntext set ::ntext::classicWrap 0 text .t -wrap word bindtags .t {.t Ntext . all}
package require ntext set ::ntext::classicWrap 0 set ::ntext::indentColor {} text .t -wrap word bindtags .t {.t Ntext . all}
package require ntext set ::ntext::classicWrap 0 set ::ntext::indentColor black text .t -wrap word bindtags .t {.t Ntext . all}
set ::ntext::classicWrap 1 ::ntext::wrapIndent .t
set ::ntext::classicWrap 0 ::ntext::wrapIndent .t 1.0 end
set foo [.t index end] .t insert end {This line was added by the script, not the keyboard!} ::ntext::wrapIndent .t $foo end
set ::ntext::indentColor black ::ntext::syncIndentColor .t
.t configure -wrap char ::ntext::wrapIndent .t
bindtags, ntext, re_syntax, regexp, text
bindtags, re_syntax, regexp, text
1.0 | tklib |