VGUI TextImage: Difference between revisions
| Aftershock` (talk | contribs)  (Fixed source highlighting) | Thunder4ik (talk | contribs)  m (→Example Usage: Unicodifying, replaced: [[Image: → [[File:) | ||
| (2 intermediate revisions by 2 users not shown) | |||
| Line 14: | Line 14: | ||
| First, lets add a new variable to our class's header file: | First, lets add a new variable to our class's header file: | ||
| <source lang="cpp"> | <source lang="cpp"> | ||
| TextImage* text; | |||
| </source> | </source> | ||
| TextImages can be created via the c++ keyword new with a simple call to TextImage: | TextImages can be created via the c++ keyword new with a simple call to TextImage: | ||
| <source lang="cpp"> | <source lang="cpp"> | ||
|   text = new TextImage( |   text = new TextImage("Text"); | ||
| </source> | </source> | ||
| Line 48: | Line 48: | ||
| Heres what it should look like when you're done: | Heres what it should look like when you're done: | ||
| [[ | [[File:TextImage.jpg]] | ||
| [[Category:VGUI_Controls|T]] | [[Category:VGUI_Controls|T]] | ||
| [[Category:Stubs]] | [[Category:Stubs]] | ||
Latest revision as of 02:10, 9 January 2024
A TextImage is a vgui2 element defined in the vgui_controls library, in the file TextImage.cpp. TextImages are available in all source games. TextImage is not really a full functioning control, it's used by VGUI Label to draw text.
You can, however, use TextImage to draw text, but you will need to call TextImage's paint function, as it is not automatically called.
Example Usage
Before creating anything, we first need to include the TextImage header file and use the vgui namespace.
 #include <vgui_controls/TextImage.h>
 using namespace vgui;
First, lets add a new variable to our class's header file:
TextImage* text;
TextImages can be created via the c++ keyword new with a simple call to TextImage:
 text = new TextImage("Text");
Once we've created our TextImage, we now need to do some configuration, usually done in ApplySchemeSettings:
 void CExample::ApplySchemeSettings( vgui::IScheme *pScheme )
 {
    BaseClass::ApplySchemeSettings( pScheme );
 
    text->SetText("Text");
    text->SetPos(200,200);
    text->SetSize(100,50);
    text->SetFont(pScheme->GetFont( "DefaultVerySmall" ));
    text->SetColor( Color( 200, 255, 200, 255 ) );
 }
As mentioned above, TextImages will not automatically paint themselves, so, we need to paint them. Don't worry, its fairly simple.
 void CExample::Paint()
 {
    BaseClass::Paint();
 
    text->Paint();
 }
Heres what it should look like when you're done:
