mirror of
https://github.com/subsurface/subsurface.git
synced 2024-11-28 05:00:20 +00:00
1d6683f3e0
The reason for that is, even if profile widget is made with qpainter and for that reason it should be a desktop widget, it's being used on the mobile version because of a lack of QML plotting library that is fast and reliable. We discovered that it was faster just to encapsulate our Profile in a QML class and call it directly. Signed-off-by: Tomaz Canabrava <tomaz.canabrava@intel.com> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
130 lines
3.1 KiB
C++
130 lines
3.1 KiB
C++
#include "divepixmapitem.h"
|
|
#include "animationfunctions.h"
|
|
#include "divepicturemodel.h"
|
|
#include <preferences.h>
|
|
|
|
#include <QDesktopServices>
|
|
#include <QGraphicsView>
|
|
#include <QUrl>
|
|
|
|
DivePixmapItem::DivePixmapItem(QObject *parent) : QObject(parent), QGraphicsPixmapItem()
|
|
{
|
|
}
|
|
|
|
DiveButtonItem::DiveButtonItem(QObject *parent): DivePixmapItem(parent)
|
|
{
|
|
}
|
|
|
|
void DiveButtonItem::mousePressEvent(QGraphicsSceneMouseEvent *event)
|
|
{
|
|
QGraphicsItem::mousePressEvent(event);
|
|
emit clicked();
|
|
}
|
|
|
|
// If we have many many pictures on screen, maybe a shared-pixmap would be better to
|
|
// paint on screen, but for now, this.
|
|
CloseButtonItem::CloseButtonItem(QObject *parent): DiveButtonItem(parent)
|
|
{
|
|
static QPixmap p = QPixmap(":trash");
|
|
setPixmap(p);
|
|
setFlag(ItemIgnoresTransformations);
|
|
}
|
|
|
|
void CloseButtonItem::hide()
|
|
{
|
|
DiveButtonItem::hide();
|
|
}
|
|
|
|
void CloseButtonItem::show()
|
|
{
|
|
DiveButtonItem::show();
|
|
}
|
|
|
|
DivePictureItem::DivePictureItem(QObject *parent): DivePixmapItem(parent),
|
|
canvas(new QGraphicsRectItem(this)),
|
|
shadow(new QGraphicsRectItem(this))
|
|
{
|
|
setFlag(ItemIgnoresTransformations);
|
|
setAcceptHoverEvents(true);
|
|
setScale(0.2);
|
|
connect(PreferencesDialog::instance(), SIGNAL(settingsChanged()), this, SLOT(settingsChanged()));
|
|
setVisible(prefs.show_pictures_in_profile);
|
|
|
|
canvas->setPen(Qt::NoPen);
|
|
canvas->setBrush(QColor(Qt::white));
|
|
canvas->setFlag(ItemStacksBehindParent);
|
|
canvas->setZValue(-1);
|
|
|
|
shadow->setPos(5,5);
|
|
shadow->setPen(Qt::NoPen);
|
|
shadow->setBrush(QColor(Qt::lightGray));
|
|
shadow->setFlag(ItemStacksBehindParent);
|
|
shadow->setZValue(-2);
|
|
}
|
|
|
|
void DivePictureItem::settingsChanged()
|
|
{
|
|
setVisible(prefs.show_pictures_in_profile);
|
|
}
|
|
|
|
void DivePictureItem::setPixmap(const QPixmap &pix)
|
|
{
|
|
DivePixmapItem::setPixmap(pix);
|
|
QRectF r = boundingRect();
|
|
canvas->setRect(0 - 10, 0 -10, r.width() + 20, r.height() + 20);
|
|
shadow->setRect(canvas->rect());
|
|
}
|
|
|
|
CloseButtonItem *button = NULL;
|
|
void DivePictureItem::hoverEnterEvent(QGraphicsSceneHoverEvent *event)
|
|
{
|
|
Animations::scaleTo(this, 1.0);
|
|
setZValue(5);
|
|
|
|
if(!button) {
|
|
button = new CloseButtonItem();
|
|
button->setScale(0.2);
|
|
button->setZValue(7);
|
|
scene()->addItem(button);
|
|
}
|
|
button->setParentItem(this);
|
|
button->setPos(boundingRect().width() - button->boundingRect().width() * 0.2,
|
|
boundingRect().height() - button->boundingRect().height() * 0.2);
|
|
button->setOpacity(0);
|
|
button->show();
|
|
Animations::show(button);
|
|
button->disconnect();
|
|
connect(button, SIGNAL(clicked()), this, SLOT(removePicture()));
|
|
}
|
|
|
|
void DivePictureItem::setFileUrl(const QString &s)
|
|
{
|
|
fileUrl = s;
|
|
}
|
|
|
|
void DivePictureItem::hoverLeaveEvent(QGraphicsSceneHoverEvent *event)
|
|
{
|
|
Animations::scaleTo(this, 0.2);
|
|
setZValue(0);
|
|
if(button){
|
|
button->setParentItem(NULL);
|
|
Animations::hide(button);
|
|
}
|
|
}
|
|
|
|
DivePictureItem::~DivePictureItem(){
|
|
if(button){
|
|
button->setParentItem(NULL);
|
|
Animations::hide(button);
|
|
}
|
|
}
|
|
|
|
void DivePictureItem::mousePressEvent(QGraphicsSceneMouseEvent *event)
|
|
{
|
|
QDesktopServices::openUrl(QUrl::fromLocalFile(fileUrl));
|
|
}
|
|
|
|
void DivePictureItem::removePicture()
|
|
{
|
|
DivePictureModel::instance()->removePicture(fileUrl);
|
|
}
|