forked from aseprite/aseprite
-
Notifications
You must be signed in to change notification settings - Fork 0
/
size_hint_event.cpp
77 lines (62 loc) · 1.33 KB
/
size_hint_event.cpp
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
// Aseprite UI Library
// Copyright (C) 2001-2013, 2015 David Capello
//
// This file is released under the terms of the MIT license.
// Read LICENSE.txt for more information.
#ifdef HAVE_CONFIG_H
#include "config.h"
#endif
#include "ui/size_hint_event.h"
#include "ui/widget.h"
namespace ui {
using namespace gfx;
/**
Event generated to calculate the preferred size of a widget.
@param source
The widget that want to know its preferred size.
@param fitIn
This could be Size(0, 0) that means calculate the preferred size
without restrictions. If its width or height is greater than 0,
you could try to fit your widget to that width or height.
*/
SizeHintEvent::SizeHintEvent(Widget* source, const Size& fitIn)
: Event(source)
, m_fitIn(fitIn)
, m_sizeHint(0, 0)
{
}
/**
Destroys the SizeHintEvent.
*/
SizeHintEvent::~SizeHintEvent()
{
}
Size SizeHintEvent::fitInSize() const
{
return m_fitIn;
}
int SizeHintEvent::fitInWidth() const
{
return m_fitIn.w;
}
int SizeHintEvent::fitInHeight() const
{
return m_fitIn.h;
}
Size SizeHintEvent::sizeHint() const
{
return m_sizeHint;
}
void SizeHintEvent::setSizeHint(const Size& sz)
{
m_sizeHint = sz;
}
/**
Sets the preferred size for the widget.
*/
void SizeHintEvent::setSizeHint(int w, int h)
{
m_sizeHint.w = w;
m_sizeHint.h = h;
}
} // namespace ui