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
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
|
/*
* Copyright 2008 Ben Boeckel <MathStuf@gmail.com>
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program. If not, see <http://www.gnu.org/licenses/>.
*/
// Header include
#include "WarpItem.h"
// Sigmod includes
#include "../sigmod/MapWarp.h"
#include "../sigmod/Sigmod.h"
// KDE includes
#include <KColorScheme>
// Qt includes
#include <QtGui/QGraphicsSceneMouseEvent>
#include <QtGui/QPainter>
#include <QtGui/QStyle>
#include <QtGui/QStyleOptionGraphicsItem>
Sigmodr::WarpItem::WarpItem(Sigmod::MapWarp* warp, QObject* parent) :
QObject(parent),
m_warp(warp)
{
connect(m_warp, SIGNAL(changed()), this, SLOT(warpChanged()));
warpChanged();
setZValue(INT_MAX);
setAcceptHoverEvents(true);
}
QRectF Sigmodr::WarpItem::boundingRect() const
{
return m_warp->area();
}
void Sigmodr::WarpItem::paint(QPainter* painter, const QStyleOptionGraphicsItem* option, QWidget* widget)
{
Q_UNUSED(widget)
if (m_warp->area().size().isValid())
return;
if (!(flags() & QGraphicsItem::ItemIsSelectable))
{
QPixmap temp(m_warp->area().size());
temp.fill(Qt::transparent);
QPainter p;
p.begin(&temp);
p.setCompositionMode(QPainter::CompositionMode_DestinationIn);
p.fillRect(temp.rect(), QColor(0, 0, 0, 127));
p.end();
painter->drawPixmap(0, 0, temp);
}
painter->setBrush(KStatefulBrush(KColorScheme::View, KColorScheme::ActiveBackground).brush(QPalette::Active));
painter->drawRect(m_warp->area());
if (option->state & QStyle::State_MouseOver)
{
painter->setPen(QPen(KStatefulBrush(KColorScheme::View, (flags() & QGraphicsItem::ItemIsSelectable) ? KColorScheme::ActiveText : KColorScheme::InactiveText).brush((flags() & QGraphicsItem::ItemIsSelectable) ? QPalette::Active : QPalette::Inactive), 1));
painter->drawText(m_warp->area(), Qt::AlignHCenter | Qt::AlignVCenter, m_warp->name());
}
if (option->state & QStyle::State_HasFocus)
{
painter->setPen(QPen(KStatefulBrush(KColorScheme::Selection, KColorScheme::FocusColor).brush(QPalette::Active), 6));
painter->drawRect(m_warp->area());
}
else if (option->state & QStyle::State_Selected)
{
painter->setPen(QPen(KStatefulBrush(KColorScheme::Selection, KColorScheme::ActiveBackground).brush(QPalette::Active), 6));
painter->drawRect(m_warp->area());
}
else if ((option->state & QStyle::State_MouseOver) && (flags() & QGraphicsItem::ItemIsSelectable))
{
painter->setPen(QPen(KStatefulBrush(KColorScheme::Selection, KColorScheme::HoverColor).brush(QPalette::Active), 6));
painter->drawRect(m_warp->area());
}
}
void Sigmodr::WarpItem::mousePressEvent(QGraphicsSceneMouseEvent* event)
{
QGraphicsItem::mousePressEvent(event);
update();
}
void Sigmodr::WarpItem::mouseMoveEvent(QGraphicsSceneMouseEvent* event)
{
if (event->modifiers() & Qt::ShiftModifier)
{
QRect rect = m_warp->area();
QPointF diff = event->scenePos() - event->lastScenePos();
rect.setSize(rect.size() + QSize(diff.x(), diff.y()));
m_warp->setArea(rect);
}
else
{
QGraphicsItem::mouseMoveEvent(event);
QRect rect = m_warp->area();
rect.setTopLeft(scenePos().toPoint());
m_warp->setArea(rect);
}
}
void Sigmodr::WarpItem::mouseReleaseEvent(QGraphicsSceneMouseEvent* event)
{
QGraphicsItem::mouseReleaseEvent(event);
update();
}
void Sigmodr::WarpItem::warpChanged()
{
setPos(m_warp->area().topLeft());
update();
}
|