File: preferred_size_event.cpp

package info (click to toggle)
aseprite 1.0.5+ds-2
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 9,504 kB
  • ctags: 18,296
  • sloc: cpp: 84,144; ansic: 49,119; xml: 1,971; objc: 1,211; asm: 117; makefile: 45
file content (77 lines) | stat: -rw-r--r-- 1,486 bytes parent folder | download
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  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/preferred_size_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.
*/
PreferredSizeEvent::PreferredSizeEvent(Widget* source, const Size& fitIn)
  : Event(source)
  , m_fitIn(fitIn)
  , m_preferredSize(0, 0)
{
}

/**
   Destroys the PreferredSizeEvent.
*/
PreferredSizeEvent::~PreferredSizeEvent()
{
}

Size PreferredSizeEvent::fitInSize() const
{
  return m_fitIn;
}

int PreferredSizeEvent::fitInWidth() const
{
  return m_fitIn.w;
}

int PreferredSizeEvent::fitInHeight() const
{
  return m_fitIn.h;
}

Size PreferredSizeEvent::getPreferredSize() const
{
  return m_preferredSize;
}

void PreferredSizeEvent::setPreferredSize(const Size& preferredSize)
{
  m_preferredSize = preferredSize;
}

/**
   Sets the preferred size for the widget.
*/
void PreferredSizeEvent::setPreferredSize(int w, int h)
{
  m_preferredSize.w = w;
  m_preferredSize.h = h;
}

} // namespace ui