Page Menu
Home
Phorge
Search
Configure Global Search
Log In
Files
F123495
TextEntity.h
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Award Token
Size
6 KB
Referenced Files
None
Subscribers
None
TextEntity.h
View Options
#ifndef _ECHOTEXTENTITY_H_
#define _ECHOTEXTENTITY_H_
#include
<echo/Graphics/SceneEntity.h>
#include
<echo/Graphics/TextMesh.h>
namespace
Echo
{
/**
* TextEntity is a SceneEntity that manages a TextMesh as its mesh.
* This class is just a helper class so you don't have to always create a TextMesh and SceneEntity together.
*/
class
TextEntity
:
public
SceneEntity
{
public
:
/**
* Default constructor.
* You need to use SetFont() and Set() to set the font and content respectively.
*/
TextEntity
()
{
mTextMesh
.
reset
(
new
TextMesh
());
SetMesh
(
mTextMesh
);
}
/**
* Constructor
* @param content UTF8 content.
* @param font The font to use.
*/
TextEntity
(
const
UTF8String
&
content
,
shared_ptr
<
Font
>
font
)
{
mTextMesh
.
reset
(
new
TextMesh
(
content
,
font
));
SetMesh
(
mTextMesh
);
}
~
TextEntity
()
{
}
/**
* Set the font.
* This marks the mesh as out of date which causes the mesh to be rebuilt on the next render (if UpdateMesh()
* has not already been called).
* @note You need to make sure the font contains all of the characters for your content otherwise those characters won't be rendered.
* @param font the Font object, use the FontManager to acquire a font resource.
*/
void
SetFont
(
shared_ptr
<
Font
>
font
)
{
mTextMesh
->
SetFont
(
font
);
NeedUpdate
(
true
);
//Force parent because the AABB to will need updating.
}
/**
* Set the text content.
* @note You need to make sure the font contains all of the characters for your content otherwise those characters won't be rendered.
* @param content UTF8String to build a mesh for, You can use ASCII strings (see UTF8String).
*/
void
Set
(
const
UTF8String
&
content
)
{
mTextMesh
->
Set
(
content
);
NeedUpdate
(
true
);
//Force parent because the AABB to will need updating.
}
/**
* Append to the existing content content.
* @see Set();
*/
void
Append
(
const
UTF8String
&
content
)
{
mTextMesh
->
Append
(
content
);
NeedUpdate
(
true
);
//Force parent because the AABB to will need updating.
}
/**
* Get the dimensions of the text mesh.
* The dimensions returned are the actual mesh size determined when it is built.
* The X component is the width.
* The Y component is the height.
* The Z component will be 0.
* @note If the text is out of date and the mesh needs to be rebuilt then calling
* this method will trigger a mesh rebuild.
* @return The dimensions of the text's mesh.
*/
Vector3
GetTextDimensions
()
const
{
return
mTextMesh
->
GetTextDimensions
();
}
/**
* Calls BuildMesh() passing in the internal content string.
*/
void
UpdateMesh
()
{
mTextMesh
->
UpdateMesh
();
}
/**
* Set the colour of the text.
* @note This modifies the material.
* @param colour
*/
void
SetColour
(
const
Colour
&
colour
)
{
mTextMesh
->
SetColour
(
colour
);
}
/**
* Get the colour of the text.
* @return the colour.
*/
const
Colour
&
GetColour
()
const
{
return
mTextMesh
->
GetColour
();}
/**
* Set the maximum width the text can be.
* The default value for this is 100, which is just arbitrary and intended to give
* some dimension so that you will see something rather than something scaled to 0.
* @see SetUseMaxWidth() for more information.
* @param maxWidth
*/
void
SetMaxWidth
(
f32
maxWidth
)
{
mTextMesh
->
SetMaxWidth
(
maxWidth
);
NeedUpdate
(
true
);
//Force parent because the AABB to will need updating.
}
/**
* Get the max width.
* @see SetUseMaxWidth() for more information.
* @return
*/
f32
GetMaxWidth
()
const
{
return
mTextMesh
->
GetMaxWidth
();}
/**
* Set whether or not to enforce max text width.
* This is enforced per word. If the word plus the current line length will exceed
* the max width the text will be moved to the next line. If a word is longer than
* the max width then scaling to the word will be applied to make it fit.
* @param useMaxWidth
*/
void
SetUseMaxWidth
(
bool
useMaxWidth
)
{
mTextMesh
->
SetUseMaxWidth
(
useMaxWidth
);
NeedUpdate
(
true
);
//Force parent because the AABB to will need updating.
}
/**
* Get whether or not to use the max width option.
* @see SetUseMaxWidth() for more information on this feature.
* @return
*/
bool
GetUseMaxWidth
()
const
{
return
mTextMesh
->
GetUseMaxWidth
();}
/**
* Set the text scale.
* This scale is applied to the text while building the mesh.
* @param textScale
*/
void
SetTextScale
(
f32
textScale
)
{
mTextMesh
->
SetTextScale
(
textScale
);
NeedUpdate
(
true
);
//Force parent because the AABB to will need updating.
}
/**
* Get the text scale.
* @see SetTextScale();
* @return
*/
f32
GetTextScale
()
const
{
return
mTextMesh
->
GetTextScale
();}
/**
* Set the fixed line spacing.
* @see TextMesh::SetLineSpacing().
*/
void
SetLineSpacing
(
f32
fixedLineSpacing
)
{
mTextMesh
->
SetLineSpacing
(
fixedLineSpacing
);
NeedUpdate
(
true
);
//Force parent because the AABB to will need updating.
}
/**
* Get the line spacing.
* @see TextMesh::GetLineSpacing().
*/
f32
GetLineSpacing
()
const
{
return
mTextMesh
->
GetLineSpacing
();}
/**
* Get the line spacing.
* @see TextMesh::GetAbsoluteLineSpacing().
*/
f32
GetAbsoluteLineSpacing
()
const
{
return
mTextMesh
->
GetAbsoluteLineSpacing
();}
/**
* Sets whether or not this Text item should use the Unicode replacement
* character if a glyph can not be found in the font being used.
* @see https://en.wikipedia.org/wiki/Specials_%28Unicode_block%29#Replacement_character
* @param useReplacementCharacterForGlyphFailure true for replacement character, else false.
*/
void
SetUseReplacementCharacter
(
bool
useReplacementCharacterForGlyphFailure
)
{
mTextMesh
->
SetUseReplacementCharacter
(
useReplacementCharacterForGlyphFailure
);
}
/**
* Gets whether or not this Text item should use the Unicode replacement
* character if a glyph can not be found in the font being used.
* @see https://en.wikipedia.org/wiki/Specials_%28Unicode_block%29#Replacement_character
* @return true if the replacement character is to be used, false otherwise.
*/
bool
GetUseReplacementCharacter
(
void
)
const
{
return
mTextMesh
->
GetUseReplacementCharacter
();
}
private
:
shared_ptr
<
TextMesh
>
mTextMesh
;
};
}
#endif
File Metadata
Details
Attached
Mime Type
text/x-c++
Expires
Thu, Jan 16, 1:21 AM (13 h, 44 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
72118
Default Alt Text
TextEntity.h (6 KB)
Attached To
Mode
rEE Echo 3
Attached
Detach File
Event Timeline
Log In to Comment