TGUI  1.0-beta
Loading...
Searching...
No Matches
ChatBox.hpp
1
2//
3// TGUI - Texus' Graphical User Interface
4// Copyright (C) 2012-2022 Bruno Van de Velde (vdv_b@tgui.eu)
5//
6// This software is provided 'as-is', without any express or implied warranty.
7// In no event will the authors be held liable for any damages arising from the use of this software.
8//
9// Permission is granted to anyone to use this software for any purpose,
10// including commercial applications, and to alter it and redistribute it freely,
11// subject to the following restrictions:
12//
13// 1. The origin of this software must not be misrepresented;
14// you must not claim that you wrote the original software.
15// If you use this software in a product, an acknowledgment
16// in the product documentation would be appreciated but is not required.
17//
18// 2. Altered source versions must be plainly marked as such,
19// and must not be misrepresented as being the original software.
20//
21// 3. This notice may not be removed or altered from any source distribution.
22//
24
25
26#ifndef TGUI_CHAT_BOX_HPP
27#define TGUI_CHAT_BOX_HPP
28
29
30#include <TGUI/CopiedSharedPtr.hpp>
31#include <TGUI/Widgets/Scrollbar.hpp>
32#include <TGUI/Renderers/ChatBoxRenderer.hpp>
33#include <TGUI/Text.hpp>
34#include <deque>
35
37
38namespace tgui
39{
41
42 class TGUI_API ChatBox : public Widget
43 {
44 public:
45
46 using Ptr = std::shared_ptr<ChatBox>;
47 using ConstPtr = std::shared_ptr<const ChatBox>;
48
49 static constexpr const char StaticWidgetType[] = "ChatBox";
50
51 struct Line
52 {
53 Text text;
54 String string;
55 };
56
57
65 ChatBox(const char* typeName = StaticWidgetType, bool initRenderer = true);
66
67
75
76
85 static ChatBox::Ptr copy(const ChatBox::ConstPtr& chatBox);
86
87
93 const ChatBoxRenderer* getSharedRenderer() const;
94
101
102
111 void setSize(const Layout2d& size) override;
112 using Widget::setSize;
113
114
125 void addLine(const String& text);
126
127
139 void addLine(const String& text, Color color);
140
141
152 void addLine(const String& text, Color color, TextStyles style);
153
154
165 String getLine(std::size_t lineIndex) const;
166
167
176 Color getLineColor(std::size_t lineIndex) const;
177
178
184 TextStyles getLineTextStyle(std::size_t lineIndex) const;
185
186
196 bool removeLine(std::size_t lineIndex);
197
198
204
205
212 std::size_t getLineAmount();
213
214
224 void setLineLimit(std::size_t maxLines);
225
226
236 std::size_t getLineLimit();
237
238
243 void setTextColor(Color color);
244
245
250 const Color& getTextColor() const;
251
252
258
259
265
266
278 void setLinesStartFromTop(bool startFromTop = true);
279
280
291
292
301 void setNewLinesBelowOthers(bool newLinesBelowOthers = true);
302
303
311
312
318 void setScrollbarValue(unsigned int value);
319
320
326 unsigned int getScrollbarValue() const;
327
328
335 bool isMouseOnWidget(Vector2f pos) const override;
336
340 void leftMousePressed(Vector2f pos) override;
341
345 void leftMouseReleased(Vector2f pos) override;
346
350 void mouseMoved(Vector2f pos) override;
351
355 bool mouseWheelScrolled(float delta, Vector2f pos) override;
356
360 void mouseNoLongerOnWidget() override;
361
365 void leftMouseButtonNoLongerDown() override;
366
367
369 private:
370
372 // Recalculates the text attribute of the line
374 void recalculateLineText(Line& line);
375
376
378 // Recalculates all text attributes, recalculate the full text height and update the displayed text
380 void recalculateAllLines();
381
382
384 // Recalculates the space used by all the lines
386 void recalculateFullTextHeight();
387
388
390 // Updates the position of the lines
392 void updateDisplayedText();
393
394
396 // Updates the position and size of the panel and scrollbar
398 void updateRendering();
399
400
402 protected:
403
411 void draw(BackendRenderTarget& target, RenderStates states) const override;
412
413
420 void rendererChanged(const String& property) override;
421
422
426 std::unique_ptr<DataIO::Node> save(SavingRenderersMap& renderers) const override;
427
428
432 void load(const std::unique_ptr<DataIO::Node>& node, const LoadingRenderersMap& renderers) override;
433
434
438 void updateTextSize() override;
439
440
442 // Returns the size without the borders
444 Vector2f getInnerSize() const;
445
446
448 // Makes a copy of the widget
450 Widget::Ptr clone() const override;
451
452
454 protected:
455
456 Color m_textColor = Color::Black;
457 TextStyles m_textStyle;
458
459 std::size_t m_maxLines = 0;
460
461 float m_fullTextHeight = 0;
462
463 bool m_linesStartFromTop = false;
464 bool m_newLinesBelowOthers = true;
465
467
468 std::deque<Line> m_lines;
469
470 Sprite m_spriteBackground;
471
472 // Cached renderer properties
473 Borders m_bordersCached;
474 Padding m_paddingCached;
475 Color m_backgroundColorCached;
476 Color m_borderColorCached;
477
479 };
480
482}
483
485
486#endif // TGUI_TEXT_BOX_HPP
Base class for render targets.
Definition: BackendRenderTarget.hpp:48
Definition: ChatBoxRenderer.hpp:37
Definition: ChatBox.hpp:43
unsigned int getScrollbarValue() const
Returns the thumb position of the scrollbar.
std::size_t getLineAmount()
Returns the amount of lines in the chat box.
std::shared_ptr< const ChatBox > ConstPtr
Shared constant widget pointer.
Definition: ChatBox.hpp:47
void rendererChanged(const String &property) override
Function called when one of the properties of the renderer is changed.
std::shared_ptr< ChatBox > Ptr
Shared widget pointer.
Definition: ChatBox.hpp:46
void load(const std::unique_ptr< DataIO::Node > &node, const LoadingRenderersMap &renderers) override
Loads the widget from a tree of nodes.
ChatBoxRenderer * getRenderer()
Returns the renderer, which gives access to functions that determine how the widget is displayed.
void removeAllLines()
Removes all lines from the chat box.
bool getLinesStartFromTop() const
Returns whether the first lines start from the top or from the bottom of the chat box.
static ChatBox::Ptr create()
Creates a new chat box widget.
void setLinesStartFromTop(bool startFromTop=true)
Lets the first lines start from the top or from the bottom of the chat box.
void addLine(const String &text, Color color)
Adds a new line of text to the chat box.
std::size_t getLineLimit()
Returns the maximum amount of lines in the chat box.
void addLine(const String &text, Color color, TextStyles style)
Adds a new line of text to the chat box.
const Color & getTextColor() const
Returns the default color of the text.
std::unique_ptr< DataIO::Node > save(SavingRenderersMap &renderers) const override
Saves the widget as a tree node in order to save it to a file.
bool isMouseOnWidget(Vector2f pos) const override
Returns whether the mouse position (which is relative to the parent widget) lies on top of the widget...
void addLine(const String &text)
Adds a new line of text to the chat box.
bool getNewLinesBelowOthers() const
Returns whether new lines are added below the other lines or above them.
static ChatBox::Ptr copy(const ChatBox::ConstPtr &chatBox)
Makes a copy of another chat box.
void updateTextSize() override
Called when the text size is changed (either by setTextSize or via the renderer)
Color getLineColor(std::size_t lineIndex) const
Returns the color of the requested line.
void setSize(const Layout2d &size) override
Changes the size of the chat box.
void setNewLinesBelowOthers(bool newLinesBelowOthers=true)
Sets whether new lines are added below the other lines or above them.
ChatBoxRenderer * getSharedRenderer()
Returns the renderer, which gives access to functions that determine how the widget is displayed.
void draw(BackendRenderTarget &target, RenderStates states) const override
Draw the widget to a render target.
TextStyles getTextStyle() const
Returns the default text style.
TextStyles getLineTextStyle(std::size_t lineIndex) const
Returns the text style of the requested line.
void setScrollbarValue(unsigned int value)
Changes the thumb position of the scrollbar.
void setTextColor(Color color)
Changes the default color of the text.
void setTextStyle(TextStyles style)
Changes the default text style.
String getLine(std::size_t lineIndex) const
Returns the contents of the requested line.
void setLineLimit(std::size_t maxLines)
Sets a maximum amount of lines in the chat box.
bool removeLine(std::size_t lineIndex)
Removes the requested line.
Widget::Ptr clone() const override
Makes a copy of the widget if you don't know its exact type.
Wrapper for colors.
Definition: Color.hpp:63
Definition: CopiedSharedPtr.hpp:40
Class to store the position or size of a widget.
Definition: Layout.hpp:284
Definition: Outline.hpp:39
Definition: Sprite.hpp:45
Wrapper class to store strings.
Definition: String.hpp:79
Wrapper for text styles.
Definition: TextStyle.hpp:58
Definition: Text.hpp:48
The parent class for every widget.
Definition: Widget.hpp:70
std::shared_ptr< Widget > Ptr
Shared widget pointer.
Definition: Widget.hpp:73
Namespace that contains all TGUI functions and classes.
Definition: AbsoluteOrRelativeValue.hpp:36
Definition: ChatBox.hpp:52
States used for drawing.
Definition: RenderStates.hpp:39