1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82
|
/*!
@file
@author Albert Semenov
@date 03/2011
*/
#ifndef PANEL_H_
#define PANEL_H_
#include "MyGUI_Prerequest.h"
#include "MyGUI_Widget.h"
namespace MyGUI
{
class Panel :
public Widget
{
MYGUI_RTTI_DERIVED( Panel )
public:
Panel();
/** Set widget position (position of left top corner) */
void setPosition(const IntPoint& _value) override;
/** Set widget size */
void setSize(const IntSize& _value) override;
/** Set widget position and size */
void setCoord(const IntCoord& _value) override;
using Widget::setPosition;
using Widget::setSize;
using Widget::setCoord;
//static void invalidateMeasure(Widget* _widget);
/*
Обновление размеров содержимого.
Метод updateMeasure вызывается для обновления mDesiredSize по нашему содержимому.
В этот размер входят наши внешние отступы Margin, внутрение отступы Padding, размер наших рамок и размер самого содержимого.
При расчете mDesiredSize учитывается MinSize и MaxSize, но только для виджета, без учета внешних отступов Margin.
В метод передается размер доступной зоны _sizeAvailable в который мы должны себя уместить.
Размер mDesiredSize не может быть больше чем размер доступной зоны _sizeAvailable.
*/
static void updateMeasure(Widget* _widget, const IntSize& _sizeAvailable);
/*
вызывается отцом для того чтобы виджет себя физически разместил
передается _coordPlace это координаты места где виджет будет находиться
виджет не имеет права заходить за эти координаты,
в эти координаты не входит внутрение отступы отца Padding, так как они принадлежат отцу
эти отступы отец уже учел
*/
static void updateArrange(Widget* _widget, const IntCoord& _coordPlace);
static IntSize getDesiredSize(Widget* _widget);
protected:
/*
Запрос размера.
Метод overrideMeasure вызывается для обновления размера mDesiredSize.
Метод является перекрываемым, для того чтобы виджеты могли учесть свою внутренюю структуру для размещения содержимого.
В метод передается доступный размер _sizeAvailable. В этот размер не входят внешние отступы Margin, т.е. это размер для самого виджета.
В этом методе виджет должен сам учесть свои внутренние отступы Padding, размеры свой рамки и размер содержимого.
Если размер mDesiredSize будет больше _sizeAvailable то он усечется.
*/
virtual IntSize overrideMeasure(const IntSize& _sizeAvailable) = 0;
/*
Метод overrideArrange для раставления дочерних виджетов.
Можно использовать размер mDesiredSize дочерних виджетов.
*/
virtual void overrideArrange() = 0;
void onWidgetCreated(Widget* _widget) override;
void onWidgetDestroy(Widget* _widget) override;
private:
IntSize mDesiredSize;
};
} // namespace MyGUI
#endif // PANEL_H_
|