TGUI  1.7
Loading...
Searching...
No Matches
TextArea.hpp
1
2//
3// TGUI - Texus' Graphical User Interface
4// Copyright (C) 2012-2024 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#ifndef TGUI_TEXT_AREA_HPP
26#define TGUI_TEXT_AREA_HPP
27
28#include <TGUI/Widgets/Scrollbar.hpp>
29#include <TGUI/Renderers/TextAreaRenderer.hpp>
30#include <TGUI/Text.hpp>
31
33
34TGUI_MODULE_EXPORT namespace tgui
35{
42 class TGUI_API TextArea : public Widget, public DualScrollbarChildInterface
43 {
44 public:
45
46 using Ptr = std::shared_ptr<TextArea>;
47 using ConstPtr = std::shared_ptr<const TextArea>;
48
49 static constexpr const char StaticWidgetType[] = "TextArea";
50
58 TextArea(const char* typeName = StaticWidgetType, bool initRenderer = true);
59
65 TGUI_NODISCARD static TextArea::Ptr create();
66
74 TGUI_NODISCARD static TextArea::Ptr copy(const TextArea::ConstPtr& textArea);
75
80 TGUI_NODISCARD TextAreaRenderer* getSharedRenderer() override;
81 TGUI_NODISCARD const TextAreaRenderer* getSharedRenderer() const override;
82
88 TGUI_NODISCARD TextAreaRenderer* getRenderer() override;
89
97 void setSize(const Layout2d& size) override;
98 using Widget::setSize;
99
105 void setText(String text);
106
112 void addText(String text);
113
119 TGUI_NODISCARD String getText() const;
120
126 void setDefaultText(const String& text);
127
133 TGUI_NODISCARD const String& getDefaultText() const;
134
141 void setSelectedText(std::size_t selectionStartIndex, std::size_t selectionEndIndex);
142
148 TGUI_NODISCARD String getSelectedText() const;
149
160 TGUI_NODISCARD std::size_t getSelectionStart() const;
161
172 TGUI_NODISCARD std::size_t getSelectionEnd() const;
173
182 void setMaximumCharacters(std::size_t maxChars = 0);
183
192 TGUI_NODISCARD std::size_t getMaximumCharacters() const;
193
205 void setTabString(String tabText);
206
214 TGUI_NODISCARD String getTabString() const;
215
223 void setCaretPosition(std::size_t charactersBeforeCaret);
224
232 TGUI_NODISCARD std::size_t getCaretPosition() const;
233
245 TGUI_NODISCARD std::size_t getCaretLine() const;
246
258 TGUI_NODISCARD std::size_t getCaretColumn() const;
259
268 void setReadOnly(bool readOnly = true);
269
278 TGUI_NODISCARD bool isReadOnly() const;
279
286 TGUI_DEPRECATED("Use getVerticalScrollbar->setPolicy(policy) instead") void setVerticalScrollbarPolicy(Scrollbar::Policy policy);
287
294 TGUI_DEPRECATED("Use getVerticalScrollbar->getPolicy() instead") TGUI_NODISCARD Scrollbar::Policy getVerticalScrollbarPolicy() const;
295
302 TGUI_DEPRECATED("Use getHorizontalScrollbar->setPolicy(policy) instead") void setHorizontalScrollbarPolicy(Scrollbar::Policy policy);
303
310 TGUI_DEPRECATED("Use getHorizontalScrollbar->getPolicy() instead") TGUI_NODISCARD Scrollbar::Policy getHorizontalScrollbarPolicy() const;
311
319 TGUI_NODISCARD std::size_t getLinesCount() const;
320
329 void setFocused(bool focused) override;
330
342 void enableMonospacedFontOptimization(bool enable = true);
343
349 TGUI_DEPRECATED("Use getVerticalScrollbar->setValue(value) instead") void setVerticalScrollbarValue(unsigned int value);
350
356 TGUI_DEPRECATED("Use getVerticalScrollbar->getValue() instead") TGUI_NODISCARD unsigned int getVerticalScrollbarValue() const;
357
365 TGUI_DEPRECATED("Use getVerticalScrollbar->getMaxValue() instead") TGUI_NODISCARD unsigned int getVerticalScrollbarMaxValue() const;
366
372 TGUI_DEPRECATED("Use getHorizontalScrollbar->setValue(value) instead") void setHorizontalScrollbarValue(unsigned int value);
373
379 TGUI_DEPRECATED("Use getHorizontalScrollbar->getValue() instead") TGUI_NODISCARD unsigned int getHorizontalScrollbarValue() const;
380
388 TGUI_DEPRECATED("Use getHorizontalScrollbar->getMaxValue() instead") TGUI_NODISCARD unsigned int getHorizontalScrollbarMaxValue() const;
389
395 TGUI_NODISCARD bool isMouseOnWidget(Vector2f pos) const override;
396
400 bool leftMousePressed(Vector2f pos) override;
401
405 void leftMouseReleased(Vector2f pos) override;
406
410 void mouseMoved(Vector2f pos) override;
411
415 void keyPressed(const Event::KeyEvent& event) override;
416
426 bool canHandleKeyPress(const Event::KeyEvent& event) override;
427
431 void textEntered(char32_t key) override;
432
436 bool scrolled(float delta, Vector2f pos, bool touch) override;
437
441 void mouseNoLongerOnWidget() override;
442
446 void leftMouseButtonNoLongerDown() override;
447
449 protected:
450
452 // This function will search after which character the caret should be placed. It will not change the caret position.
454 TGUI_NODISCARD Vector2<std::size_t> findCaretPosition(Vector2f position) const;
455
457 // Gets the index of either m_selStart or m_selEnd
459 TGUI_NODISCARD std::size_t getIndexOfSelectionPos(Vector2<std::size_t> selectionPos) const;
460
462 // Removes the selected characters. This function is called when pressing backspace, delete or a letter while there were
463 // some characters selected.
465 void deleteSelectedCharacters();
466
468 // Inserts text at the current caret position.
469 // If the given string exceeds the maximum character limit,
470 // excess characters from the right side of the string will not be inserted.
472 void insertTextAtCaretPosition(String text);
473
475 // Rearrange the text inside the text area (by using word wrap).
477 void rearrangeText(bool keepSelection, const bool emitCaretChangedPosition = true);
478
480 // Updates the physical size of the scrollbars, as well as the viewport size.
482 void updateScrollbars();
483
485 // This function will split the text into five pieces so that the text can be easily drawn.
487 void updateSelectionTexts();
488
490 // Handles "Backspace" key press
492 void backspaceKeyPressed();
493
495 // Handles "Delete" key press
497 void deleteKeyPressed();
498
500 // Handles "Ctrl+C" key press (or equivalent on macOS)
502 void copySelectedTextToClipboard();
503
505 // Handles "Ctrl+X" key press (or equivalent on macOS)
507 void cutSelectedTextToClipboard();
508
510 // Handles "Ctrl+V" key press (or equivalent on macOS)
512 void pasteTextFromClipboard();
513
515 // Handles "Ctrl+A" key press (or equivalent on macOS)
517 void selectAllText();
518
520 // Handles "PageUp" key press
522 void moveCaretPageUp();
523
525 // Handles "PageDown" key press
527 void moveCaretPageDown();
528
530 // Handles "ArrowLeft" key press
532 void moveCaretLeft(bool shiftPressed);
533
535 // Handles "ArrowRight" key press
537 void moveCaretRight(bool shiftPressed);
538
540 // Handles "Ctrl+ArrowLeft" key press (or equivalent on macOS)
542 void moveCaretWordBegin();
543
545 // Handles "Ctrl+ArrowRight" key press (or equivalent on macOS)
547 void moveCaretWordEnd();
548
555 void draw(BackendRenderTarget& target, RenderStates states) const override;
556
558 private:
559
561 // Implementation of setCaretPosition() that either updates or retains the m_selEnd value.
563 void setCaretPositionImpl(std::size_t charactersBeforeCaret, bool selEndNeedUpdate, bool emitCaretChangedPosition);
564
566 protected:
567
569 // Returns the size without the borders
571 TGUI_NODISCARD Vector2f getInnerSize() const;
572
574 // This function is called every frame with the time passed since the last frame.
576 bool updateTime(Duration elapsedTime) override;
577
579 // Recalculates the positions of the contents of the text area.
581 void recalculatePositions();
582
584 // Recalculates which lines are currently visible.
586 void recalculateVisibleLines();
587
597 TGUI_NODISCARD Signal& getSignal(String signalName) override;
598
604 void rendererChanged(const String& property) override;
605
609 TGUI_NODISCARD std::unique_ptr<DataIO::Node> save(SavingRenderersMap& renderers) const override;
610
614 void load(const std::unique_ptr<DataIO::Node>& node, const LoadingRenderersMap& renderers) override;
615
619 void updateTextSize() override;
620
627 void scrollbarPolicyChanged(Orientation orientation) override;
628
630 // Makes a copy of the widget
632 TGUI_NODISCARD Widget::Ptr clone() const override;
633
635 // Updates m_selEnd with a new value and emits the onCaretPositionChange signal
636 // @param newValue the value to assign to m_selEnd.
638 void updateSelEnd(const Vector2<std::size_t>& newValue);
639
641 public:
642
643 SignalString onTextChange = {"TextChanged"};
644 Signal onSelectionChange = {"SelectionChanged"};
645 Signal onCaretPositionChange = {"CaretPositionChanged"};
646
648 protected:
649
650 String m_text;
651 float m_lineHeight = 24;
652
653 // The width of the largest line
654 float m_maxLineWidth = 0;
655
656 std::vector<String> m_lines;
657
658 // The maximum characters (0 by default, which means no limit)
659 std::size_t m_maxChars = 0;
660
661 // What is known about the visible lines?
662 std::size_t m_topLine = 1;
663 std::size_t m_visibleLines = 1;
664
665 // Information about the selection
666 Vector2<std::size_t> m_selStart;
667 Vector2<std::size_t> m_selEnd;
668 std::pair<Vector2<std::size_t>, Vector2<std::size_t>> m_lastSelection;
669
670 // Information about the caret
671 Vector2f m_caretPosition;
672 bool m_caretVisible = true;
673
674 // The text to insert when Tab is pressed
675 String m_tabText = U"\t";
676
677 Text m_textBeforeSelection;
678 Text m_textSelection1;
679 Text m_textSelection2;
680 Text m_textAfterSelection1;
681 Text m_textAfterSelection2;
682 Text m_defaultText;
683
684 std::vector<FloatRect> m_selectionRects;
685
686 // Is there a possibility that the user is going to double click?
687 bool m_possibleDoubleClick = false;
688
689 bool m_readOnly = false;
690
691 bool m_monospacedFontOptimizationEnabled = false;
692
693 Sprite m_spriteBackground;
694
695 // Cached renderer properties
696 Borders m_bordersCached;
697 Padding m_paddingCached;
698 Color m_borderColorCached;
699 Color m_backgroundColorCached;
700 Color m_caretColorCached;
701 Color m_selectedTextBackgroundColorCached;
702 float m_caretWidthCached = 1;
703
705 };
706
708}
709
711
712#endif // TGUI_TEXT_AREA_HPP
Base class for render targets.
Definition BackendRenderTarget.hpp:46
Wrapper for colors.
Definition Color.hpp:73
Base class for widgets with both a vertical and horizontal scrollbar.
Definition Scrollbar.hpp:673
Wrapper for durations.
Definition Duration.hpp:55
Class to store the position or size of a widget.
Definition Layout.hpp:323
Definition Outline.hpp:38
Scrollbar widget.
Definition Scrollbar.hpp:44
Signal to which the user can subscribe to get callbacks from.
Definition Signal.hpp:61
Definition Sprite.hpp:47
Wrapper class to store strings.
Definition String.hpp:96
Definition TextAreaRenderer.hpp:35
Text area widget.
Definition TextArea.hpp:43
void setTabString(String tabText)
Changes the string that is inserted when the Tab key is pressed.
void setReadOnly(bool readOnly=true)
Makes the text area read-only or make it writable again.
String getText() const
Returns the text of the text area.
const String & getDefaultText() const
Returns the default text of the text area. This is the text drawn when the text area is empty.
std::shared_ptr< const TextArea > ConstPtr
Shared constant widget pointer.
Definition TextArea.hpp:47
TextAreaRenderer * getSharedRenderer() override
Returns the renderer, which gives access to functions that determine how the widget is displayed.
std::size_t getCaretPosition() const
Returns after which character the blinking cursor is currently located.
void addText(String text)
Appends some text to the text that was already in the text area.
std::shared_ptr< TextArea > Ptr
Shared widget pointer.
Definition TextArea.hpp:46
std::size_t getSelectionEnd() const
Returns the index where the selection ends.
static TextArea::Ptr copy(const TextArea::ConstPtr &textArea)
Makes a copy of another text area.
void setText(String text)
Changes the text of the text area.
bool isReadOnly() const
Checks if the text area read-only or writable.
void setMaximumCharacters(std::size_t maxChars=0)
Changes the maximum character limit.
void setCaretPosition(std::size_t charactersBeforeCaret)
Sets the blinking caret to after a specific character.
String getSelectedText() const
Returns the text that you currently have selected.
void setSelectedText(std::size_t selectionStartIndex, std::size_t selectionEndIndex)
Changes which part of the text is selected.
TextAreaRenderer * getRenderer() override
Returns the renderer, which gives access to functions that determine how the widget is displayed.
std::size_t getSelectionStart() const
Returns the index where the selection starts.
static TextArea::Ptr create()
Creates a new text area widget.
std::size_t getCaretLine() const
Returns which line the blinking cursor is currently located on.
std::size_t getMaximumCharacters() const
Returns the maximum character limit.
void setDefaultText(const String &text)
Changes the default text of the text area. This is the text drawn when the text area is empty.
void setSize(const Layout2d &size) override
Changes the size of the text area.
String getTabString() const
Returns the string that is inserted when the Tab key is pressed.
std::size_t getCaretColumn() const
Returns which column the blinking cursor is currently located on.
Backend-independent wrapper around the backend-specific text class.
Definition Text.hpp:48
The parent class for every widget.
Definition Widget.hpp:83
Namespace that contains all TGUI functions and classes.
Definition AbsoluteOrRelativeValue.hpp:38
Orientation
Orientation of the object.
Definition Layout.hpp:52
Definition Event.hpp:38
States used for drawing.
Definition RenderStates.hpp:38