MuseScore/libmscore/lasso.cpp
2019-12-24 14:16:06 +02:00

147 lines
4.6 KiB
C++

//=============================================================================
// MuseScore
// Music Composition & Notation
//
// Copyright (C) 2002-2011 Werner Schweer
//
// This program is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License version 2
// as published by the Free Software Foundation and appearing in
// the file LICENCE.GPL
//=============================================================================
#include "lasso.h"
#include "mscore.h"
#include "mscoreview.h"
#include "score.h"
namespace Ms {
//---------------------------------------------------------
// Lasso
//---------------------------------------------------------
Lasso::Lasso(Score* s)
: Element(s)
{
setVisible(false);
}
//---------------------------------------------------------
// draw
//---------------------------------------------------------
void Lasso::draw(QPainter* painter) const
{
painter->setBrush(QBrush(QColor(0, 0, 50, 50)));
// always 2 pixel width
qreal w = 2.0 / painter->transform().m11();
painter->setPen(QPen(MScore::selectColor[0], w));
painter->drawRect(bbox());
}
//---------------------------------------------------------
// editDrag
//---------------------------------------------------------
void Lasso::editDrag(EditData& ed)
{
Qt::CursorShape cursorShape = ed.view->cursor().shape();
switch (int(ed.curGrip)) {
case 0:
cursorShape = Qt::SizeFDiagCursor;
bbox().setTopLeft(bbox().topLeft() + ed.delta);
break;
case 1:
cursorShape = Qt::SizeBDiagCursor;
bbox().setTopRight(bbox().topRight() + ed.delta);
break;
case 2:
cursorShape = Qt::SizeFDiagCursor;
bbox().setBottomRight(bbox().bottomRight() + ed.delta);
break;
case 3:
cursorShape = Qt::SizeBDiagCursor;
bbox().setBottomLeft(bbox().bottomLeft() + ed.delta);
break;
case 4:
cursorShape = Qt::SizeVerCursor;
bbox().setTop(bbox().top() + ed.delta.y());
break;
case 5:
cursorShape = Qt::SizeHorCursor;
bbox().setRight(bbox().right() + ed.delta.x());
break;
case 6:
cursorShape = Qt::SizeVerCursor;
bbox().setBottom(bbox().bottom() + ed.delta.y());
break;
case 7:
cursorShape = Qt::SizeHorCursor;
bbox().setLeft(bbox().left() + ed.delta.x());
break;
}
ed.view->setCursor(QCursor(cursorShape));
}
//---------------------------------------------------------
// gripsPositions
//---------------------------------------------------------
std::vector<QPointF> Lasso::gripsPositions(const EditData&) const
{
const auto box(bbox());
return {
box.topLeft(),
box.topRight(),
box.bottomRight(),
box.bottomLeft(),
QPointF(box.x() + box.width() * .5, box.top()),
QPointF(box.right(), box.y() + box.height() * .5),
QPointF(box.x() + box.width()*.5, box.bottom()),
QPointF(box.left(), box.y() + box.height() * .5)
};
}
//---------------------------------------------------------
// setProperty
//---------------------------------------------------------
bool Lasso::setProperty(Pid propertyId, const QVariant& v)
{
switch (propertyId) {
case Pid::LASSO_POS:
bbox().moveTo(v.toPointF());
break;
case Pid::LASSO_SIZE:
bbox().setSize(v.toSizeF());
break;
default:
if (!Element::setProperty(propertyId, v))
return false;
break;
}
score()->setUpdateAll();
return true;
}
//---------------------------------------------------------
// getProperty
//---------------------------------------------------------
QVariant Lasso::getProperty(Pid propertyId) const
{
switch (propertyId) {
case Pid::LASSO_POS:
return bbox().topLeft();
case Pid::LASSO_SIZE:
return bbox().size();
default:
break;
}
return Element::getProperty(propertyId);
}
}