Class RichTextModel
StyledTextModel based on a collection of styled segments.
This model is suitable for relatively small documents as it has neither disk storage backing nor storage of incremental changes.
- Since:
- 24
-
Nested Class Summary
Nested classes/interfaces declared in class StyledTextModel
StyledTextModel.Listener -
Property Summary
PropertiesTypePropertyDescriptionfinal DoublePropertySpecifies the default tab stop interval for tabs beyond the last stop provided by the paragraph'sStyleAttributeMap.TAB_STOPSattribute, if any.Properties declared in class StyledTextModel
redoable, undoable -
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final doubleThis value of thedefaultTabStopsProperty()disables the default tab stops, making a tab characters appear as a single space.static final doubleThis value of thedefaultTabStopsProperty()results in a legacy behavior where the tab spacing corresponds to 8 spaces. -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionprotected voidapplyParagraphStyle(int index, StyleAttributeMap attrs) Applies paragraph styles in the specified paragraph.protected voidapplyStyle(int index, int start, int end, StyleAttributeMap attrs, boolean merge) Applies style to the specified text range within a single paragraph.final DoublePropertySpecifies the default tab stop interval for tabs beyond the last stop provided by the paragraph'sStyleAttributeMap.TAB_STOPSattribute, if any.final doubleGets the value of thedefaultTabStopsproperty.getParagraph(int index) Returns aRichParagraphat the given model index.getPlainText(int index) Returns the plain text string for the specified paragraph.getStyleAttributeMap(StyleResolver resolver, TextPos pos) Returns theStyleAttributeMapof the character at the specified position'scharIndex.protected voidinsertLineBreak(int index, int offset) Inserts a line break at the specified position.protected voidinsertParagraph(int index, Supplier<Region> generator) Inserts a paragraph that contains a singleRegion.protected intinsertTextSegment(int index, int offset, String text, StyleAttributeMap attrs) This method is called to insert a single styled text segment at the given position.final booleanIndicates whether the model supports content modifications made viaapplyStyle(),replace(),undo(),redo()methods.protected RichParagraph.BuilderprepareParagraph(int index) Prepares the paragraph by populating a builder with the paragraph content.protected voidremoveRange(TextPos start, TextPos end) Removes the specified text range.final voidsetDefaultTabStops(double value) Sets the value of thedefaultTabStopsproperty.protected voidsetParagraphStyle(int index, StyleAttributeMap attrs) Replaces the paragraph styles in the specified paragraph.intsize()Returns the number of paragraphs in the model.Methods declared in class StyledTextModel
addListener, applyStyle, clamp, clearUndoRedo, documentProperties, export, exportParagraph, fireChangeEvent, fireStyleChangeEvent, getDataFormatHandler, getDocumentEnd, getEndOfParagraphTextPos, getLineEnding, getMarker, getParagraphLength, getSupportedAttributes, getSupportedDataFormats, handleDocumentProperties, isRedoable, isUndoable, isUndoRedoEnabled, read, redo, redoableProperty, registerDataFormatHandler, removeDataFormatHandler, removeListener, replace, replace, setLineEnding, setUndoRedoEnabled, undo, undoableProperty, versionString, write
-
Property Details
-
defaultTabStops
Specifies the default tab stop interval for tabs beyond the last stop provided by the paragraph'sStyleAttributeMap.TAB_STOPSattribute, if any. This is a fixed repeating distance (in pixels) to the next tab stop computed at regular intervals relative to the document content leading edge.Value
DEFAULT_TAB_STOPS_FIXEDresults in a legacy behavior where the tab spacing corresponds to 8 spaces. This may result in milasigned columns when different text segments use different fonts. The valueDEFAULT_TAB_STOPS_DISABLEDdisables the default interval, rendering tab character as a single space.- Default value:
- DEFAULT_TAB_STOPS_FIXED
- Since:
- 27
- See Also:
-
-
Field Details
-
DEFAULT_TAB_STOPS_FIXED
public static final double DEFAULT_TAB_STOPS_FIXEDThis value of thedefaultTabStopsProperty()results in a legacy behavior where the tab spacing corresponds to 8 spaces. This may result in milasigned columns when different text segments use different fonts.- Since:
- 27
- See Also:
-
DEFAULT_TAB_STOPS_DISABLED
public static final double DEFAULT_TAB_STOPS_DISABLEDThis value of thedefaultTabStopsProperty()disables the default tab stops, making a tab characters appear as a single space.- Since:
- 27
- See Also:
-
-
Constructor Details
-
RichTextModel
public RichTextModel()Constructs the empty model.
-
-
Method Details
-
defaultTabStopsProperty
Specifies the default tab stop interval for tabs beyond the last stop provided by the paragraph'sStyleAttributeMap.TAB_STOPSattribute, if any. This is a fixed repeating distance (in pixels) to the next tab stop computed at regular intervals relative to the document content leading edge.Value
DEFAULT_TAB_STOPS_FIXEDresults in a legacy behavior where the tab spacing corresponds to 8 spaces. This may result in milasigned columns when different text segments use different fonts. The valueDEFAULT_TAB_STOPS_DISABLEDdisables the default interval, rendering tab character as a single space.- Default value:
- DEFAULT_TAB_STOPS_FIXED
- Returns:
- the default tab stop interval property
- Since:
- 27
- See Also:
-
setDefaultTabStops
public final void setDefaultTabStops(double value) Sets the value of thedefaultTabStopsproperty.- Property description:
- Specifies the default tab stop interval for tabs beyond the last stop provided
by the paragraph's
StyleAttributeMap.TAB_STOPSattribute, if any. This is a fixed repeating distance (in pixels) to the next tab stop computed at regular intervals relative to the document content leading edge.Value
DEFAULT_TAB_STOPS_FIXEDresults in a legacy behavior where the tab spacing corresponds to 8 spaces. This may result in milasigned columns when different text segments use different fonts. The valueDEFAULT_TAB_STOPS_DISABLEDdisables the default interval, rendering tab character as a single space. - Default value:
- DEFAULT_TAB_STOPS_FIXED
- Parameters:
value- the value for thedefaultTabStopsproperty- Since:
- 27
- See Also:
-
getDefaultTabStops
public final double getDefaultTabStops()Gets the value of thedefaultTabStopsproperty.- Property description:
- Specifies the default tab stop interval for tabs beyond the last stop provided
by the paragraph's
StyleAttributeMap.TAB_STOPSattribute, if any. This is a fixed repeating distance (in pixels) to the next tab stop computed at regular intervals relative to the document content leading edge.Value
DEFAULT_TAB_STOPS_FIXEDresults in a legacy behavior where the tab spacing corresponds to 8 spaces. This may result in milasigned columns when different text segments use different fonts. The valueDEFAULT_TAB_STOPS_DISABLEDdisables the default interval, rendering tab character as a single space. - Default value:
- DEFAULT_TAB_STOPS_FIXED
- Returns:
- the value of the
defaultTabStopsproperty - Since:
- 27
- See Also:
-
isWritable
public final boolean isWritable()Description copied from class:StyledTextModelIndicates whether the model supports content modifications made viaapplyStyle(),replace(),undo(),redo()methods.Note that even when this method returns
false, the model itself may still update its content and fire the change events as a response, for example, to changes in its backing data storage.- Specified by:
isWritablein classStyledTextModel- Returns:
- true if the model supports content modifications
-
size
public int size()Description copied from class:StyledTextModelReturns the number of paragraphs in the model.- Specified by:
sizein classStyledTextModel- Returns:
- number of paragraphs
-
getPlainText
Description copied from class:StyledTextModelReturns the plain text string for the specified paragraph. The returned text string cannot be null and must not contain any control characters other than TAB. The callers must ensure that the value ofindexis within the valid document range, since doing otherwise might result in an exception or undetermined behavior.- Specified by:
getPlainTextin classStyledTextModel- Parameters:
index- the paragraph index in the range (0...StyledTextModel.size())- Returns:
- the non-null paragraph text string
-
getParagraph
Description copied from class:StyledTextModelReturns aRichParagraphat the given model index. The callers must ensure that the value ofindexis within the valid document range, since doing otherwise might result in an exception or undetermined behavior.This method makes no guarantees that the same paragraph instance will be returned for the same model index.
- Specified by:
getParagraphin classStyledTextModel- Parameters:
index- the paragraph index in the range (0...StyledTextModel.size())- Returns:
- the instance of
RichParagraph
-
prepareParagraph
Prepares the paragraph by populating a builder with the paragraph content. This method allows the custom model to add highlights and decorations without affecting the base class storage model.- Parameters:
index- the paragraph index- Returns:
- the builder
- Since:
- 26
-
insertTextSegment
Description copied from class:StyledTextModelThis method is called to insert a single styled text segment at the given position.- Specified by:
insertTextSegmentin classStyledTextModel- Parameters:
index- the paragraph indexoffset- the insertion offset within the paragraphtext- the text to insertattrs- the style attributes- Returns:
- the number of characters inserted
-
insertLineBreak
protected void insertLineBreak(int index, int offset) Description copied from class:StyledTextModelInserts a line break at the specified position.- Specified by:
insertLineBreakin classStyledTextModel- Parameters:
index- the model indexoffset- the text offset
-
removeRange
Description copied from class:StyledTextModelRemoves the specified text range. This method gets called only if the model is editable. The caller guarantees thatstartprecedesend.- Specified by:
removeRangein classStyledTextModel- Parameters:
start- the start of the range to be removedend- the end of the range to be removed, expected to be greater than the start position
-
insertParagraph
Description copied from class:StyledTextModelInserts a paragraph that contains a singleRegion.The model should not cache or otherwise retain references to the created
Regions, as they might be requested multiple times during the lifetime of the model, or by different views.This method allows for embedding
Controls that handle user input. In this case, the model should declare necessary properties and provide bidirectional bindings between the properties in the model and the corresponding properties in the control, as well as handle copy, paste, writing to and reading from I/O streams.- Specified by:
insertParagraphin classStyledTextModel- Parameters:
index- model indexgenerator- code that will be used to create a Node instance
-
applyParagraphStyle
Description copied from class:StyledTextModelApplies paragraph styles in the specified paragraph.- Specified by:
applyParagraphStylein classStyledTextModel- Parameters:
index- the paragraph indexattrs- the paragraph attributes
-
setParagraphStyle
Description copied from class:StyledTextModelReplaces the paragraph styles in the specified paragraph.- Specified by:
setParagraphStylein classStyledTextModel- Parameters:
index- the paragraph indexattrs- the paragraph attributes
-
applyStyle
Description copied from class:StyledTextModelApplies style to the specified text range within a single paragraph. Theendargument may exceed the paragraph length, in which case the outcome should be the same as supplying the paragraph length value.- Specified by:
applyStylein classStyledTextModel- Parameters:
index- the paragraph indexstart- the start offsetend- the end offsetattrs- the character attributesmerge- determines whether to merge with or completely replace the existing attribute map
-
getStyleAttributeMap
Description copied from class:StyledTextModelReturns theStyleAttributeMapof the character at the specified position'scharIndex. When at the end of the document, returns the attributes of the last character.- Specified by:
getStyleAttributeMapin classStyledTextModel- Parameters:
resolver- the style resolverpos- the text position- Returns:
- the style attributes, non-null
-