1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-25 15:35:23 +00:00
2010-07-08 00:23:28 +02:00

504 lines
20 KiB
C++
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/*!
@file
@author Albert Semenov
@date 11/2007
@module
*/
/*
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_WIDGET_H__
#define __MYGUI_WIDGET_H__
#include "MyGUI_Prerequest.h"
#include "MyGUI_Any.h"
#include "MyGUI_ICroppedRectangle.h"
#include "MyGUI_ISubWidgetRect.h"
#include "MyGUI_ISubWidgetText.h"
#include "MyGUI_LayerItem.h"
#include "MyGUI_WidgetUserData.h"
#include "MyGUI_WidgetEvent.h"
#include "MyGUI_IWidgetCreator.h"
#include "MyGUI_ResourceSkin.h"
#include "MyGUI_IObject.h"
namespace MyGUI
{
class MYGUI_EXPORT Widget :
public IObject,
public ICroppedRectangle,
public LayerItem,
public UserData,
public WidgetEvent,
public IWidgetCreator,
public delegates::IDelegateUnlink
{
// для вызова закрытых деструкторов
friend class IWidgetCreator;
MYGUI_RTTI_BASE( Widget )
public:
Widget();
/** Create child widget
@param _type widget type
@param _skin widget skin
@param _coord int coordinates of widget (_left, _top, _width, _height)
@param _align widget align (possible values can be found in enum Align)
@param _name if needed (you can use it for finding widget by name later)
*/
Widget* createWidgetT(const std::string& _type, const std::string& _skin, const IntCoord& _coord, Align _align, const std::string& _name = "");
/** See Widget::createWidgetT(const std::string& _type, const std::string& _skin, const IntCoord& _coord, Align _align, const std::string& _name = "") */
Widget* createWidgetT(const std::string& _type, const std::string& _skin, int _left, int _top, int _width, int _height, Align _align, const std::string& _name = "");
/** Create widget using coordinates relative to parent. see Widget::createWidgetT(const std::string& _type, const std::string& _skin, const IntCoord& _coord, Align _align, const std::string& _name = "") */
Widget* createWidgetRealT(const std::string& _type, const std::string& _skin, const FloatCoord& _coord, Align _align, const std::string& _name = "");
/** Create widget using coordinates relative to parent. see Widget::createWidgetT(const std::string& _type, const std::string& _skin, const IntCoord& _coord, Align _align, const std::string& _name = "") */
Widget* createWidgetRealT(const std::string& _type, const std::string& _skin, float _left, float _top, float _width, float _height, Align _align, const std::string& _name = "");
// templates for creating widgets by type
/** Same as Widget::createWidgetT but return T pointer instead of Widget* */
template <typename T>
T* createWidget(const std::string& _skin, const IntCoord& _coord, Align _align, const std::string& _name = "")
{
return static_cast<T*>(createWidgetT(T::getClassTypeName(), _skin, _coord, _align, _name));
}
/** Same as Widget::createWidgetT but return T pointer instead of Widget* */
template <typename T>
T* createWidget(const std::string& _skin, int _left, int _top, int _width, int _height, Align _align, const std::string& _name = "")
{
return static_cast<T*>(createWidgetT(T::getClassTypeName(), _skin, IntCoord(_left, _top, _width, _height), _align, _name));
}
/** Same as Widget::createWidgetRealT but return T* instead of Widget* */
template <typename T>
T* createWidgetReal(const std::string& _skin, const FloatCoord& _coord, Align _align, const std::string& _name = "")
{
return static_cast<T*>(createWidgetRealT(T::getClassTypeName(), _skin, _coord, _align, _name));
}
/** Same as Widget::createWidgetRealT but return T* instead of Widget* */
template <typename T>
T* createWidgetReal(const std::string& _skin, float _left, float _top, float _width, float _height, Align _align, const std::string& _name = "")
{
return static_cast<T*>(createWidgetRealT(T::getClassTypeName(), _skin, _left, _top, _width, _height, _align, _name));
}
/** Create child widget
@param _style Child, Popup or Overlapped widget style
@param _type widget type
@param _skin widget skin
@param _coord int coordinates of widget (_left, _top, _width, _height)
@param _align widget align (possible values can be found in enum Align)
@param _name if needed (you can use it for finding widget by name later)
*/
Widget* createWidgetT(WidgetStyle _style, const std::string& _type, const std::string& _skin, const IntCoord& _coord, Align _align, const std::string& _layer = "", const std::string& _name = "");
/** Same as Widget::createWidgetT but return T* instead of Widget* */
template <typename T>
T* createWidget(WidgetStyle _style, const std::string& _skin, const IntCoord& _coord, Align _align, const std::string& _layer = "", const std::string& _name = "")
{
return static_cast<T*>(createWidgetT(_style, T::getClassTypeName(), _skin, _coord, _align, _layer, _name));
}
//! Get name of widget
const std::string& getName() const { return mName; }
/** Set widget position (position of left top corner) */
virtual void setPosition(const IntPoint& _value);
/** Set widget size */
virtual void setSize(const IntSize& _value);
/** Set widget position and size */
virtual void setCoord(const IntCoord& _value);
/** See Widget::setPosition(const IntPoint& _pos) */
void setPosition(int _left, int _top) { setPosition(IntPoint(_left, _top)); }
/** See Widget::setSize(const IntSize& _size) */
void setSize(int _width, int _height) { setSize(IntSize(_width, _height)); }
/** See Widget::setCoord(const IntCoord& _coord) */
void setCoord(int _left, int _top, int _width, int _height) { setCoord(IntCoord(_left, _top, _width, _height)); }
/** Set widget position (position of left top corner)*/
void setRealPosition(const FloatPoint& _value);
/** Set widget size */
void setRealSize(const FloatSize& _value);
/** Set widget position and size*/
void setRealCoord(const FloatCoord& _value);
/** See Widget::setRealPosition(const FloatPoint& _point) */
void setRealPosition(float _left, float _top) { setRealPosition(FloatPoint(_left, _top)); }
/** See Widget::setRealSize(const FloatSize& _size) */
void setRealSize(float _width, float _height) { setRealSize(FloatSize(_width, _height)); }
/** See Widget::setRealPosition(const FloatCoord& _coord) */
void setRealCoord(float _left, float _top, float _width, float _height) { setRealCoord(FloatCoord(_left, _top, _width, _height)); }
/** Hide or show widget */
virtual void setVisible(bool _value);
/** Set align */
virtual void setAlign(Align _value);
/** Set widget caption */
virtual void setCaption(const UString& _value);
/** Get widget caption */
virtual const UString& getCaption();
/** Set widget opacity */
void setAlpha(float _value);
/** Get widget opacity */
float getAlpha() { return mAlpha; }
/** Enable or disable inherits alpha mode */
void setInheritsAlpha(bool _value);
/** Get inherits alpha mode flag */
bool isInheritsAlpha() { return mInheritsAlpha; }
/** Set widget's state */
bool setState(const std::string& _value);
void setColour(const Colour& _value);
// являемся ли мы рутовым виджетом
/** Is this widget is root widget (root == without parents) */
bool isRootWidget() { return nullptr == mCroppedParent; }
/** Get parent widget or nullptr if no parent */
Widget* getParent() { return mParent; }
/** Get child widgets Enumerator */
EnumeratorWidgetPtr getEnumerator();
/** Get child count */
size_t getChildCount();
/** Get child by index (index from 0 to child_count - 1) */
Widget* getChildAt(size_t _index);
/** Find widget by name (search recursively through all childs starting from this widget) */
Widget* findWidget(const std::string& _name);
/** Set need key focus flag */
void setNeedKeyFocus(bool _value) { mNeedKeyFocus = _value; }
/** Is need key focus
If disable this widget won't be reacting on keyboard at all.\n
Enabled (true) by default.
*/
bool isNeedKeyFocus() { return mNeedKeyFocus; }
/** Set need mouse focus flag */
void setNeedMouseFocus(bool _value) { mNeedMouseFocus = _value; }
/** Is need mouse focus
If disable this widget won't be reacting on mouse at all.\n
Enabled (true) by default.
*/
bool isNeedMouseFocus() { return mNeedMouseFocus; }
/** Set inherits mode flag
This mode makes all child widgets pickable even if widget don't
need mouse focus (was set setNeedKeyFocus(false) ).\n
Disabled (false) by default.
*/
void setInheritsPick(bool _value) { mInheritsPick = _value; }
/** Get inherits mode flag */
bool isInheritsPick() { return mInheritsPick; }
/** Set picking mask for widget */
void setMaskPick(const std::string& _filename);
/** Enable or disable widget */
virtual void setEnabled(bool _value);
/** Enable or disable widget without changing widget's state */
void setEnabledSilent(bool _value) { mEnabled = _value; }
/** Is widget enabled */
bool isEnabled() { return mEnabled; }
/** Set mouse pointer for this widget */
void setPointer(const std::string& _value) { mPointer = _value; }
/** Get mouse pointer name for this widget */
const std::string& getPointer();
/** Get widget's layer, return "" if widget is not root widget (root == without parents) */
const std::string& getLayerName();
/** Get rect where child widgets placed */
IntCoord getClientCoord();
/** Get clien area widget or nullptr if widget don't have client */
Widget* getClientWidget() { return mWidgetClient; }
/** Get text sub widget or nullptr if no text sub widget */
ISubWidgetText * getSubWidgetText() { return mText; }
/** Get sub widget of first texture or nullptr if no sub widget with texture */
ISubWidgetRect * getSubWidgetMain() { return mMainSkin; }
/** Set need tool tip mode flag. Enable this if you need tool tip events for widget */
void setNeedToolTip(bool _value);
/** Get need tool tip mode flag */
bool getNeedToolTip() { return mNeedToolTip; }
/** Enable or disable tooltip event */
void setEnableToolTip(bool _value);
/** Get tool tip enabled flag */
bool getEnableToolTip() { return mEnableToolTip; }
/** Detach widget from widgets hierarchy
@param _layer Attach to specified layer (if any)
*/
void detachFromWidget(const std::string& _layer = "");
/** Attach widget to parent
@param _style Child widget type
@param _layer Attach to specified layer (if any)
@note you might also need to call void Widget::setWidgetStyle(WidgetStyle _style);
to set widget style (widget attached with MyGUI::WidgetStyle::Popup by default)
*/
void attachToWidget(Widget* _parent, WidgetStyle _style = WidgetStyle::Child, const std::string& _layer = "");
/** Change widget skin */
void changeWidgetSkin(const std::string& _skinname);
/** Set widget style.
@param _layer Attach to specified layer (if any)
@note When choosing WidgetStyle::Popup style you also need attach widget to layer
see LayerManager::attachToLayerNode
*/
void setWidgetStyle(WidgetStyle _style, const std::string& _layer = "");
/** Get widget style */
WidgetStyle getWidgetStyle() { return mWidgetStyle; }
/** Set any widget property
@param _key Property name (for example Widget_Alpha or Edit_MultiLine)
@param _value Value converted to string
*/
virtual void setProperty(const std::string& _key, const std::string& _value);
/*internal:*/
// метод для запроса номера айтема и контейнера
virtual void _getContainer(Widget*& _container, size_t& _index);
// дает приоритет виджету при пиккинге
void _forcePeek(Widget* _widget);
void _setUVSet(const FloatRect& _rect);
virtual void _setTextureName(const std::string& _texture);
virtual const std::string& _getTextureName();
IWidgetCreator * _getIWidgetCreator() { return mIWidgetCreator; }
IntCoord _getTextRegion();
IntSize _getTextSize();
void _setFontName(const std::string& _font);
const std::string& _getFontName();
void _setFontHeight(int _height);
int _getFontHeight();
void _setTextAlign(Align _align);
Align _getTextAlign();
void _setTextColour(const Colour& _colour);
const Colour& _getTextColour();
// устанавливает строку заменив /n на реальный перенос
void setCaptionWithNewLine(const std::string& _value);
virtual void _initialise(WidgetStyle _style, const IntCoord& _coord, Align _align, ResourceSkin* _info, Widget* _parent, ICroppedRectangle * _croppedParent, IWidgetCreator * _creator, const std::string& _name);
/*obsolete:*/
#ifndef MYGUI_DONT_USE_OBSOLETE
MYGUI_OBSOLETE("use : void Widget::setCoord(const IntCoord& _coord)")
void setPosition(const IntCoord& _coord) { setCoord(_coord); }
MYGUI_OBSOLETE("use : void Widget::setCoord(int _left, int _top, int _width, int _height)")
void setPosition(int _left, int _top, int _width, int _height) { setCoord(_left, _top, _width, _height); }
MYGUI_OBSOLETE("use : void Widget::setEnableToolTip")
void enableToolTip(bool _enable) { setEnableToolTip(_enable); }
MYGUI_OBSOLETE("use : void setInheritsPick(bool _inherits)")
void setInheritsPeek(bool _inherits) { setInheritsPick(_inherits); }
MYGUI_OBSOLETE("use : bool isInheritsPick()")
bool isInheritsPeek() { return isInheritsPick(); }
MYGUI_OBSOLETE("use : void setMaskPick(const std::string& _filename)")
void setMaskPeek(const std::string& _filename) { setMaskPick(_filename); }
MYGUI_OBSOLETE("use : const IntCoord& StaticText::getTextRegion()")
IntCoord getTextCoord() { return _getTextRegion(); }
MYGUI_OBSOLETE("use : IntSize StaticText::getTextSize()")
IntSize getTextSize() { return _getTextSize(); }
MYGUI_OBSOLETE("use : void StaticText::setFontName(const std::string& _font)")
void setFontName(const std::string& _font) { _setFontName(_font); }
MYGUI_OBSOLETE("use : const std::string& StaticText::getFontName()")
const std::string& getFontName() { return _getFontName(); }
MYGUI_OBSOLETE("use : void StaticText::setFontHeight(int _height)")
void setFontHeight(int _height) { _setFontHeight(_height); }
MYGUI_OBSOLETE("use : int StaticText::getFontHeight()")
int getFontHeight() { return _getFontHeight(); }
MYGUI_OBSOLETE("use : void StaticText::setTextAlign(Align _align)")
void setTextAlign(Align _align) { _setTextAlign(_align); }
MYGUI_OBSOLETE("use : Align StaticText::getTextAlign()")
Align getTextAlign() { return _getTextAlign(); }
MYGUI_OBSOLETE("use : void StaticText::setTextColour(const Colour& _colour)")
void setTextColour(const Colour& _colour) { _setTextColour(_colour); }
MYGUI_OBSOLETE("use : const Colour& StaticText::getTextColour()")
const Colour& getTextColour() { return _getTextColour(); }
#endif // MYGUI_DONT_USE_OBSOLETE
protected:
// все создание только через фабрику
Widget(WidgetStyle _style, const IntCoord& _coord, Align _align, ResourceSkin* _info, Widget* _parent, ICroppedRectangle * _croppedParent, IWidgetCreator * _creator, const std::string& _name);
virtual ~Widget();
virtual void baseChangeWidgetSkin(ResourceSkin* _info);
void _updateView(); // обновления себя и детей
void _setAlign(const IntSize& _oldsize, bool _update);
void _setAlign(const IntCoord& _oldcoord, bool _update);
// создает виджет
virtual Widget* baseCreateWidget(WidgetStyle _style, const std::string& _type, const std::string& _skin, const IntCoord& _coord, Align _align, const std::string& _layer, const std::string& _name);
// удяляет неудачника
virtual void _destroyChildWidget(Widget* _widget);
// удаляет всех детей
virtual void _destroyAllChildWidget();
// запрашиваем у конейтера айтем по позиции мыши
virtual size_t _getContainerIndex(const IntPoint& _point) { return ITEM_NONE; }
// сброс всех данных контейнера, тултипы и все остальное
virtual void _resetContainer(bool _update);
virtual void baseUpdateEnable();
// наследуемся он LayerInfo
virtual ILayerItem * getLayerItemByPoint(int _left, int _top);
virtual const IntCoord& getLayerItemCoord() { return mCoord; }
private:
void frameEntered(float _frame);
void initialiseWidgetSkin(ResourceSkin* _info, const IntSize& _size);
void shutdownWidgetSkin(bool _deep = false);
void _updateAlpha();
void _updateAbsolutePoint();
// для внутреннего использования
void _setInheritsVisible(bool _value);
bool _isInheritsVisible() { return mInheritsVisible; }
void _setInheritsEnable(bool _value);
bool _isInheritsEnable() { return mInheritsEnabled; }
// показывает скрывает все сабскины
void _setSubSkinVisible(bool _visible);
float _getRealAlpha() { return mRealAlpha; }
// добавляет в список виджет
virtual void _linkChildWidget(Widget* _widget);
// удаляет из списка
virtual void _unlinkChildWidget(Widget* _widget);
protected:
// список всех стейтов
MapWidgetStateInfo mStateInfo;
// информация о маске для пикинга
MaskPickInfo const * mMaskPickInfo;
MaskPickInfo mOwnMaskPickInfo;
// вектор всех детей виджетов
VectorWidgetPtr mWidgetChild;
// вектор детей скина
VectorWidgetPtr mWidgetChildSkin;
// вектор всех детей сабскинов
VectorSubWidget mSubSkinChild;
// указатель на окно текста
ISubWidgetText * mText;
// указатель на первый не текстовой сабскин
ISubWidgetRect * mMainSkin;
// доступен ли на виджет
bool mEnabled;
bool mInheritsEnabled;
// скрыты ли все сабскины при выходе за границу
bool mSubSkinsVisible;
// для иерархического скрытия
bool mInheritsVisible;
// прозрачность и флаг наследования альфы нашего оверлея
float mAlpha;
float mRealAlpha;
bool mInheritsAlpha;
// имя виджета
std::string mName;
// курсор который будет показан при наведении
std::string mPointer;
std::string mTextureName;
ITexture* mTexture;
// наш отец в иерархии виджетов
Widget* mParent;
// это тот кто нас создал, и кто нас будет удалять
IWidgetCreator * mIWidgetCreator;
// нужен ли виджету ввод с клавы
bool mNeedKeyFocus;
// нужен ли виджету фокус мыши
bool mNeedMouseFocus;
bool mInheritsPick;
// клиентская зона окна
// если виджет имеет пользовательские окна не в себе
// то обязательно проинициализировать Client
Widget* mWidgetClient;
bool mNeedToolTip;
bool mEnableToolTip;
bool mToolTipVisible;
float mToolTipCurrentTime;
IntPoint mToolTipOldPoint;
size_t mToolTipOldIndex;
IntPoint m_oldMousePoint;
// поведение виджета, перекрывающийся дочерний или всплывающий
WidgetStyle mWidgetStyle;
FloatCoord mRelativeCoord;
bool mDisableUpdateRelative;
};
} // namespace MyGUI
#endif // __MYGUI_WIDGET_H__