File: EllipseOverlay.cpp

package info (click to toggle)
bornagain 23.0-4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 103,936 kB
  • sloc: cpp: 423,131; python: 40,997; javascript: 11,167; awk: 630; sh: 318; ruby: 173; xml: 130; makefile: 51; ansic: 24
file content (98 lines) | stat: -rw-r--r-- 2,680 bytes parent folder | download | duplicates (2)
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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
//  ************************************************************************************************
//
//  BornAgain: simulate and fit reflection and scattering
//
//! @file      GUI/View/Overlay/EllipseOverlay.cpp
//! @brief     Implements class EllipseOverlay.
//!
//! @homepage  http://www.bornagainproject.org
//! @license   GNU General Public License v3 or higher (see COPYING)
//! @copyright Forschungszentrum Jülich GmbH 2018
//! @authors   Scientific Computing Group at MLZ (see CITATION, AUTHORS)
//
//  ************************************************************************************************

#include "GUI/View/Overlay/EllipseOverlay.h"
#include "GUI/Model/Mask/MaskItems.h"
#include "GUI/View/Plotter/ColorMap.h"

EllipseOverlay::EllipseOverlay(EllipseItem* item, ColorMap* plot)
    : IRectangularOverlay(plot)
    , m_item(item)
{
    m_item->maskVisibilityChanged();
}

OverlayItem* EllipseOverlay::parameterizedItem() const
{
    return m_item;
}

void EllipseOverlay::onChangedX()
{
    setBlockOnProperty(true);
    m_item->setXCenter(x2coo(this->x()));
    setBlockOnProperty(false);
}

void EllipseOverlay::onChangedY()
{
    setBlockOnProperty(true);
    m_item->setYCenter(y2coo(this->y()));
    setBlockOnProperty(false);
}

void EllipseOverlay::onPropertyChange()
{
    update_view();
    setX(x2pix(m_item->xCenter().dVal()));
    setY(y2pix(m_item->yCenter().dVal()));
    setTransform(QTransform().rotate(-1.0 * m_item->angle().dVal()));
}

QPainterPath EllipseOverlay::shape() const
{
    QPainterPath path;
    path.addEllipse(m_mask_rect);
    return path;
}

void EllipseOverlay::resizeX(double xl, double xh)
{
    m_item->setXCenter(x2coo((xl + xh) / 2));
    m_item->setXRadius((x2coo(xh) - x2coo(xl)) / 2);
}

void EllipseOverlay::resizeY(double yl, double yh)
{
    m_item->setYCenter(y2coo((yl + yh) / 2));
    m_item->setYRadius((y2coo(yl) - y2coo(yh)) / 2);
}

//! updates position of view using item properties

void EllipseOverlay::updatePosition()
{
    setX(x2pix(m_item->xCenter().dVal()));
    setY(y2pix(m_item->yCenter().dVal()));

    if (m_item->angle().dVal() != 0)
        setTransform(QTransform().rotate(-1 * m_item->angle().dVal()));
}

QRectF EllipseOverlay::maskRectangle()
{
    return QRectF(-width() / 2, -height() / 2, width(), height());
}

qreal EllipseOverlay::width() const
{
    return x2pix(m_item->xCenter().dVal() + m_item->xRadius().dVal())
           - x2pix(m_item->xCenter().dVal() - m_item->xRadius().dVal());
}

qreal EllipseOverlay::height() const
{
    return y2pix(m_item->yCenter().dVal() - m_item->yRadius().dVal())
           - y2pix(m_item->yCenter().dVal() + m_item->yRadius().dVal());
}