ad5cd7b16a
match the genesis editor version 1.3.1.921.
407 lines
13 KiB
C++
407 lines
13 KiB
C++
/*!
|
||
@file
|
||
@author Albert Semenov
|
||
@date 11/2007
|
||
*/
|
||
/*
|
||
This file is part of MyGUI.
|
||
|
||
MyGUI is free software: you can redistribute it and/or modify
|
||
it under the terms of the GNU Lesser General Public License as published by
|
||
the Free Software Foundation, either version 3 of the License, or
|
||
(at your option) any later version.
|
||
|
||
MyGUI is distributed in the hope that it will be useful,
|
||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
GNU Lesser General Public License for more details.
|
||
|
||
You should have received a copy of the GNU Lesser General Public License
|
||
along with MyGUI. If not, see <http://www.gnu.org/licenses/>.
|
||
*/
|
||
#ifndef __MYGUI_EDIT_BOX_H__
|
||
#define __MYGUI_EDIT_BOX_H__
|
||
|
||
#include "MyGUI_Prerequest.h"
|
||
#include "MyGUI_TextBox.h"
|
||
#include "MyGUI_TextChangeHistory.h"
|
||
#include "MyGUI_TextIterator.h"
|
||
#include "MyGUI_EventPair.h"
|
||
#include "MyGUI_ScrollViewBase.h"
|
||
|
||
namespace MyGUI
|
||
{
|
||
|
||
typedef delegates::CMultiDelegate1<EditBox*> EventHandle_EditPtr;
|
||
|
||
class MYGUI_EXPORT EditBox :
|
||
public TextBox,
|
||
public ScrollViewBase,
|
||
public MemberObsolete<EditBox>
|
||
{
|
||
MYGUI_RTTI_DERIVED( EditBox )
|
||
|
||
public:
|
||
EditBox();
|
||
|
||
/** Colour interval */
|
||
void setTextIntervalColour(size_t _start, size_t _count, const Colour& _colour);
|
||
|
||
/** Get index of first selected character or ITEM_NONE if nothing selected */
|
||
size_t getTextSelectionStart() const;
|
||
|
||
/** Get index of last selected character or ITEM_NONE if nothing selected */
|
||
size_t getTextSelectionEnd() const;
|
||
|
||
/** Get length of selected text */
|
||
size_t getTextSelectionLength() const;
|
||
|
||
// возвращает текст с тегами
|
||
/** Get _count characters with tags from _start position */
|
||
UString getTextInterval(size_t _start, size_t _count);
|
||
|
||
/** Set selected text interval
|
||
@param _start of interval
|
||
@param _end of interval
|
||
*/
|
||
void setTextSelection(size_t _start, size_t _end);
|
||
|
||
/** Delete selected text */
|
||
void deleteTextSelection();
|
||
|
||
/** Get selected text */
|
||
UString getTextSelection();
|
||
|
||
/** Is any text selected */
|
||
bool isTextSelection() const;
|
||
|
||
/** Colour selected text */
|
||
void setTextSelectionColour(const Colour& _value);
|
||
|
||
/** Set text cursor position */
|
||
void setTextCursor(size_t _index);
|
||
/** Get text cursor position */
|
||
size_t getTextCursor() const;
|
||
|
||
|
||
/** Set edit text applying tags */
|
||
virtual void setCaption(const UString& _value);
|
||
/** Get edit text with tags */
|
||
virtual const UString& getCaption();
|
||
|
||
/** Set edit text without tags */
|
||
void setOnlyText(const UString& _value);
|
||
/** Get edit text without tags */
|
||
UString getOnlyText();
|
||
|
||
/** Get text length excluding tags
|
||
For example "Hello" length is 5
|
||
and "#00FF00Hello!" length is 6
|
||
*/
|
||
size_t getTextLength() const;
|
||
|
||
//! Sets if surplus characters should push characters off the left side rather than ignored
|
||
void setOverflowToTheLeft(bool _value);
|
||
//! Returns true if surplus characters will be pushed off the left rather than ignored
|
||
bool getOverflowToTheLeft() const;
|
||
|
||
//! Sets the max amount of text allowed in the edit field.
|
||
void setMaxTextLength(size_t _value);
|
||
//! Gets the max amount of text allowed in the edit field.
|
||
size_t getMaxTextLength() const;
|
||
|
||
/** Inser text at _index position (text end by default) */
|
||
void insertText(const UString& _text, size_t _index = ITEM_NONE);
|
||
/** Add text */
|
||
void addText(const UString& _text);
|
||
/** Erase _count characters from _start position */
|
||
void eraseText(size_t _start, size_t _count = 1);
|
||
|
||
/** Enable or disable edit read only mode\n
|
||
Read only mode: you can't edit text, but can select it.\n
|
||
Disabled (false) by default.
|
||
*/
|
||
void setEditReadOnly(bool _value);
|
||
/** Get edit read only mode flag */
|
||
bool getEditReadOnly() const;
|
||
|
||
/** Enable or disable edit password mode\n
|
||
Password mode: you see password chars (*** by default) instead text.\n
|
||
Disabled (false) by default.
|
||
*/
|
||
void setEditPassword(bool _value);
|
||
/** Get edit password mode flag */
|
||
bool getEditPassword() const;
|
||
|
||
/** Enable or disable edit multiline mode\n
|
||
Multile mode: new line character moves text to new line.\n
|
||
Otherwise new lines replaced with space and all text is in single line.\n
|
||
Disabled (false) by default.
|
||
*/
|
||
void setEditMultiLine(bool _value);
|
||
/** Get edit multiline mode flag */
|
||
bool getEditMultiLine() const;
|
||
|
||
/** Enable or disable edit static mode\n
|
||
Static mode is same as read only, but you also can't select text.\n
|
||
Disabled (false) by default.
|
||
*/
|
||
void setEditStatic(bool _value);
|
||
/** Get edit static mode flag */
|
||
bool getEditStatic() const;
|
||
|
||
/** Set edit password character ('*' by default) */
|
||
void setPasswordChar(Char _value);
|
||
/** Set edit password character ('*' by default). First character of string used. */
|
||
void setPasswordChar(const UString& _char);
|
||
/** Get edit password character */
|
||
Char getPasswordChar() const;
|
||
|
||
/** Enable or disable edit word wrap mode\n
|
||
Word Wrap mode: move words to new line if they goes out of width.
|
||
Also in this mode you can't edit or select text.\n
|
||
Disabled (false) by default.
|
||
*/
|
||
void setEditWordWrap(bool _value);
|
||
/** Get edit word wrap mode flag */
|
||
bool getEditWordWrap() const;
|
||
|
||
/** Enable or disable tab printing mode\n
|
||
Tab printing mode: when editing text and pressing Tab key it displayed.
|
||
If this mode disabled Tab key ignored.\n
|
||
Disabled (false) by default.
|
||
*/
|
||
void setTabPrinting(bool _value);
|
||
/** Get edit tab printing wrap mode flag */
|
||
bool getTabPrinting() const;
|
||
|
||
/** Get invert selected text color property */
|
||
bool getInvertSelected();
|
||
/** Enable or disable inverting color of selected text\n
|
||
Enabled (true) by default
|
||
*/
|
||
void setInvertSelected(bool _value);
|
||
|
||
//! @copydoc Widget::setPosition(const IntPoint& _value)
|
||
virtual void setPosition(const IntPoint& _value);
|
||
//! @copydoc Widget::setSize(const IntSize& _value)
|
||
virtual void setSize(const IntSize& _value);
|
||
//! @copydoc Widget::setCoord(const IntCoord& _value)
|
||
virtual void setCoord(const IntCoord& _value);
|
||
|
||
/** @copydoc Widget::setPosition(int _left, int _top) */
|
||
void setPosition(int _left, int _top);
|
||
/** @copydoc Widget::setSize(int _width, int _height) */
|
||
void setSize(int _width, int _height);
|
||
/** @copydoc Widget::setCoord(int _left, int _top, int _width, int _height) */
|
||
void setCoord(int _left, int _top, int _width, int _height);
|
||
|
||
/** Show VScroll when text size larger than EditBox */
|
||
void setVisibleVScroll(bool _value);
|
||
/** Get Show VScroll flag */
|
||
bool isVisibleVScroll() const;
|
||
/** Get range of vertical scroll (or 0 if no scroll).
|
||
Range measured in pixels (full text heiht minus EditBox height).
|
||
For example if EditBox is 200 pixels height and 40 lines of text
|
||
30 pixels height each (i.e. 600 pixels total), then return
|
||
value is 400 ( = 600 - 200 ).
|
||
*/
|
||
size_t getVScrollRange() const;
|
||
/** Get current position of vertical scroll (or 0 if no scroll) */
|
||
size_t getVScrollPosition();
|
||
/** Set current position of vertical scroll */
|
||
void setVScrollPosition(size_t _index);
|
||
|
||
/** Show HScroll when text size larger than EditBox */
|
||
void setVisibleHScroll(bool _value);
|
||
/** Get Show HScroll flag */
|
||
bool isVisibleHScroll() const;
|
||
/** Get range of horizontal scroll (or 0 if no scroll).
|
||
Range measured in pixels (full text width minus EditBox width).
|
||
For example if EditBox is 200 pixels width and the longest line
|
||
is 600 pixels width, then return value is 400 ( = 600 - 200 ).
|
||
*/
|
||
size_t getHScrollRange() const;
|
||
/** Get current position of horizontal scroll (or 0 if no scroll) */
|
||
size_t getHScrollPosition();
|
||
/** Set current position of horizontal scroll */
|
||
void setHScrollPosition(size_t _index);
|
||
|
||
|
||
//! @copydoc TextBox::setFontName
|
||
virtual void setFontName(const std::string& _value);
|
||
//! @copydoc TextBox::setFontHeight
|
||
virtual void setFontHeight(int _value);
|
||
|
||
//! @copydoc TextBox::setTextAlign
|
||
virtual void setTextAlign(Align _value);
|
||
//! @copydoc TextBox::setTextColour
|
||
virtual void setTextColour(const Colour& _value);
|
||
|
||
//! @copydoc TextBox::getTextRegion
|
||
virtual IntCoord getTextRegion();
|
||
|
||
//! @copydoc TextBox::getTextSize
|
||
virtual IntSize getTextSize();
|
||
|
||
//! @copydoc TextBox::setTextShadowColour
|
||
virtual void setTextShadowColour(const Colour& _value);
|
||
|
||
//! @copydoc TextBox::setTextShadow
|
||
virtual void setTextShadow(bool _value);
|
||
|
||
/*events:*/
|
||
/** Event : Enter pressed (Ctrl+enter in multiline mode).\n
|
||
signature : void method(MyGUI::EditBox* _sender)
|
||
@param _sender widget that called this event
|
||
*/
|
||
EventPair<EventHandle_WidgetVoid, EventHandle_EditPtr>
|
||
eventEditSelectAccept;
|
||
|
||
/** Event : Text changed.\n
|
||
signature : void method(MyGUI::EditBox* _sender)
|
||
@param _sender widget that called this event
|
||
*/
|
||
EventPair<EventHandle_WidgetVoid, EventHandle_EditPtr>
|
||
eventEditTextChange;
|
||
|
||
protected:
|
||
virtual void initialiseOverride();
|
||
virtual void shutdownOverride();
|
||
|
||
virtual void onMouseDrag(int _left, int _top, MouseButton _id);
|
||
virtual void onKeyLostFocus(Widget* _new);
|
||
virtual void onKeySetFocus(Widget* _old);
|
||
virtual void onKeyButtonPressed(KeyCode _key, Char _char);
|
||
|
||
// потом убрать все нотифи в сраку
|
||
void notifyMouseSetFocus(Widget* _sender, Widget* _old);
|
||
void notifyMouseLostFocus(Widget* _sender, Widget* _new);
|
||
void notifyMousePressed(Widget* _sender, int _left, int _top, MouseButton _id);
|
||
void notifyMouseReleased(Widget* _sender, int _left, int _top, MouseButton _id);
|
||
void notifyMouseDrag(Widget* _sender, int _left, int _top, MouseButton _id);
|
||
void notifyMouseButtonDoubleClick(Widget* _sender);
|
||
|
||
void notifyScrollChangePosition(ScrollBar* _sender, int _position);// expand by genesis-3d
|
||
|
||
void notifyMouseWheel(Widget* _sender, int _rel);
|
||
|
||
// обновление представления
|
||
void updateView();
|
||
void updateViewWithCursor();
|
||
|
||
void eraseView();
|
||
|
||
virtual void setPropertyOverride(const std::string& _key, const std::string& _value);
|
||
|
||
private:
|
||
// устанавливает текст
|
||
void setText(const UString& _text, bool _history);
|
||
// удаляет все что выделенно
|
||
bool deleteTextSelect(bool _history);
|
||
// вставляет текст в указанную позицию
|
||
void insertText(const UString& _text, size_t _index, bool _history);
|
||
// удаляет текст
|
||
void eraseText(size_t _start, size_t _count, bool _history);
|
||
// выделяет цветом выделение
|
||
void setTextSelectColour(const Colour& _colour, bool _history);
|
||
// выделяет цветом диапазон
|
||
void _setTextColour(size_t _start, size_t _count, const Colour& _colour, bool _history);
|
||
|
||
void frameEntered(float _frame);
|
||
|
||
void updateEditState();
|
||
|
||
// обновляет курсор по координате
|
||
void updateSelectText();
|
||
|
||
void resetSelect();
|
||
|
||
// запись в историю данных о позиции
|
||
void commandPosition(size_t _undo, size_t _redo, size_t _length, VectorChangeInfo* _info = nullptr);
|
||
|
||
// команнды отмена и повтор
|
||
bool commandRedo();
|
||
bool commandUndo();
|
||
// объединяет последние две комманды
|
||
void commandMerge();
|
||
// очистка
|
||
void commandResetRedo();
|
||
void commandResetHistory();
|
||
void saveInHistory(VectorChangeInfo* _info = nullptr);
|
||
|
||
// работа с буфером обмена
|
||
void commandCut();
|
||
void commandCopy();
|
||
void commandPast();
|
||
|
||
const UString& getRealString();
|
||
|
||
void setRealString(const UString& _caption);
|
||
|
||
void updateCursorPosition();
|
||
|
||
// размер данных
|
||
virtual IntSize getContentSize();
|
||
// смещение данных
|
||
virtual IntPoint getContentPosition();
|
||
virtual void setContentPosition(const IntPoint& _point);
|
||
// размер окна, через которые видно данные
|
||
virtual IntSize getViewSize();
|
||
// размер на который прокручиваются данные при щелчке по скролу
|
||
virtual size_t getVScrollPage();
|
||
virtual size_t getHScrollPage();
|
||
|
||
virtual Align getContentAlign();
|
||
|
||
protected:
|
||
// нажата ли кнопка
|
||
bool mIsPressed;
|
||
// в фокусе ли кнопка
|
||
bool mIsFocus;
|
||
|
||
bool mCursorActive;
|
||
float mCursorTimer;
|
||
float mActionMouseTimer;
|
||
|
||
// позиция курсора
|
||
size_t mCursorPosition;
|
||
// максимальное колличество
|
||
size_t mTextLength;
|
||
|
||
// выделение
|
||
size_t mStartSelect;
|
||
size_t mEndSelect;
|
||
|
||
// списоки изменений для отмены и повтора
|
||
DequeUndoRedoInfo mVectorUndoChangeInfo;
|
||
DequeUndoRedoInfo mVectorRedoChangeInfo;
|
||
|
||
bool mMouseLeftPressed;
|
||
|
||
bool mModeReadOnly;
|
||
bool mModePassword;
|
||
bool mModeMultiline;
|
||
bool mModeStatic;
|
||
bool mModeWordWrap;
|
||
|
||
bool mTabPrinting;
|
||
|
||
// настоящий текст, закрытый за звездочками
|
||
UString mPasswordText;
|
||
|
||
// для поддержки режима статик, где курсор не нужен
|
||
std::string mOriginalPointer;
|
||
|
||
Char mCharPassword;
|
||
|
||
bool mOverflowToTheLeft;
|
||
size_t mMaxTextLength;
|
||
|
||
ISubWidgetText* mClientText;
|
||
};
|
||
|
||
} // namespace MyGUI
|
||
|
||
#endif // __MYGUI_EDIT_BOX_H__
|