summaryrefslogtreecommitdiffstats
path: root/sigmodr/WarpItem.cpp
blob: bf1f23850fe5d91f700c92894902c66bb25109e1 (plain)
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();
}