Panda3D
Public Member Functions | Static Public Member Functions | List of all members
TextPropertiesManager Class Reference

This defines all of the TextProperties structures that might be referenced by name from an embedded text string. More...

#include "textPropertiesManager.h"

Public Member Functions

void clear_graphic (const std::string &name)
 Removes the named TextGraphic structure from the manager. More...
 
void clear_properties (const std::string &name)
 Removes the named TextProperties structure from the manager. More...
 
TextGraphic get_graphic (const std::string &name)
 Returns the TextGraphic associated with the indicated name. More...
 
const TextGraphicget_graphic_ptr (const std::string &name)
 Returns a pointer to the TextGraphic with the indicated name, or NULL if there is no graphic with that name. More...
 
TextProperties get_properties (const std::string &name)
 Returns the TextProperties associated with the indicated name. More...
 
const TextPropertiesget_properties_ptr (const std::string &name)
 Returns a pointer to the TextProperties with the indicated name, or NULL if there is no properties with that name. More...
 
bool has_graphic (const std::string &name) const
 Returns true if a TextGraphic structure has been associated with the indicated name, false otherwise. More...
 
bool has_properties (const std::string &name) const
 Returns true if a TextProperties structure has been associated with the indicated name, false otherwise. More...
 
void set_graphic (const std::string &name, const TextGraphic &graphic)
 Defines the TextGraphic associated with the indicated name. More...
 
void set_graphic (const std::string &name, const NodePath &model)
 This flavor of set_graphic implicitly creates a frame for the model using the model's actual computed bounding volume, as derived from NodePath::calc_tight_bounds(). More...
 
void set_properties (const std::string &name, const TextProperties &properties)
 Defines the TextProperties associated with the indicated name. More...
 
void write (std::ostream &out, int indent_level=0) const
 

Static Public Member Functions

static TextPropertiesManagerget_global_ptr ()
 Returns the pointer to the global TextPropertiesManager object. More...
 

Detailed Description

This defines all of the TextProperties structures that might be referenced by name from an embedded text string.

A text string, as rendered by a TextNode, can contain embedded references to one of the TextProperties defined here, by enclosing the name between \1 (ASCII 0x01) characters; this causes a "push" to the named state. All text following the closing \1 character will then be rendered in the new state. The next \2 (ASCII 0x02) character will then restore the previous state for subsequent text.

For instance, "x\1up\1n\2 + y" indicates that the character "x" will be rendered in the normal state, the character "n" will be rendered in the "up" state, and then " + y" will be rendered in the normal state again.

This can also be used to define arbitrary models that can serve as embedded graphic images in a text paragraph. This works similarly; the convention is to create a TextGraphic that describes the graphic image, and then associate it here via the set_graphic() call. Then "\5name\5" will embed the named graphic.

Definition at line 44 of file textPropertiesManager.h.

Member Function Documentation

◆ clear_graphic()

void TextPropertiesManager::clear_graphic ( const std::string &  name)

Removes the named TextGraphic structure from the manager.

Definition at line 176 of file textPropertiesManager.cxx.

◆ clear_properties()

void TextPropertiesManager::clear_properties ( const std::string &  name)

Removes the named TextProperties structure from the manager.

Definition at line 95 of file textPropertiesManager.cxx.

◆ get_global_ptr()

TextPropertiesManager * TextPropertiesManager::get_global_ptr ( )
static

Returns the pointer to the global TextPropertiesManager object.

Definition at line 197 of file textPropertiesManager.cxx.

◆ get_graphic()

TextGraphic TextPropertiesManager::get_graphic ( const std::string &  name)

Returns the TextGraphic associated with the indicated name.

If there was not previously a TextGraphic associated with this name, a warning is printed and then a default TextGraphic structure is associated with the name, and returned.

Call has_graphic() instead to check whether a particular name has been defined.

Definition at line 143 of file textPropertiesManager.cxx.

◆ get_graphic_ptr()

const TextGraphic * TextPropertiesManager::get_graphic_ptr ( const std::string &  name)

Returns a pointer to the TextGraphic with the indicated name, or NULL if there is no graphic with that name.

Definition at line 223 of file textPropertiesManager.cxx.

◆ get_properties()

TextProperties TextPropertiesManager::get_properties ( const std::string &  name)

Returns the TextProperties associated with the indicated name.

If there was not previously a TextProperties associated with this name, a warning is printed and then a default TextProperties structure is associated with the name, and returned.

Call has_properties() instead to check whether a particular name has been defined.

Definition at line 62 of file textPropertiesManager.cxx.

◆ get_properties_ptr()

const TextProperties * TextPropertiesManager::get_properties_ptr ( const std::string &  name)

Returns a pointer to the TextProperties with the indicated name, or NULL if there is no properties with that name.

Definition at line 209 of file textPropertiesManager.cxx.

◆ has_graphic()

bool TextPropertiesManager::has_graphic ( const std::string &  name) const

Returns true if a TextGraphic structure has been associated with the indicated name, false otherwise.

Normally this means set_graphic() has been called with this name, but because get_graphic() will implicitly create a default TextGraphic structure, it may also mean simply that get_graphic() has been called with the indicated name.

Definition at line 166 of file textPropertiesManager.cxx.

◆ has_properties()

bool TextPropertiesManager::has_properties ( const std::string &  name) const

Returns true if a TextProperties structure has been associated with the indicated name, false otherwise.

Normally this means set_properties() has been called with this name, but because get_properties() will implicitly create a default TextProperties structure, it may also mean simply that get_properties() has been called with the indicated name.

Definition at line 85 of file textPropertiesManager.cxx.

◆ set_graphic() [1/2]

void TextPropertiesManager::set_graphic ( const std::string &  name,
const TextGraphic graphic 
)

Defines the TextGraphic associated with the indicated name.

When the name is subsequently encountered in text embedded between \5 characters in a TextNode string, the specified graphic will be embedded in the text at that point.

If there was already a TextGraphic structure associated with this name, it is quietly replaced with the new definition.

Definition at line 109 of file textPropertiesManager.cxx.

◆ set_graphic() [2/2]

void TextPropertiesManager::set_graphic ( const std::string &  name,
const NodePath model 
)

This flavor of set_graphic implicitly creates a frame for the model using the model's actual computed bounding volume, as derived from NodePath::calc_tight_bounds().

Create a TextGraphic object first if you want to have explicit control of the frame.

Definition at line 120 of file textPropertiesManager.cxx.

References NodePath::calc_tight_bounds().

◆ set_properties()

void TextPropertiesManager::set_properties ( const std::string &  name,
const TextProperties properties 
)

Defines the TextProperties associated with the indicated name.

When the name is subsequently encountered in text embedded between \1 characters in a TextNode string, the following text will be rendered with these properties.

If there was already a TextProperties structure associated with this name, it is quietly replaced with the new definition.

Definition at line 48 of file textPropertiesManager.cxx.


The documentation for this class was generated from the following files: