mirror of
https://github.com/subsurface/subsurface.git
synced 2024-12-01 06:30:26 +00:00
6dec4b0556
The ruler is a weird beast - it has two child objects that access the parent to call another function, that call the child functions. When I updated the plot_info I didn't take that into consideration, what happened is that when I set the parent's plot_info, the children's plot_info are still invalid, but the update method is called anyhow. This patch updates all plot_info's before calling anything else. Signed-off-by: Tomaz Canabrava <tomaz.canabrava@intel.com> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
180 lines
4 KiB
C++
180 lines
4 KiB
C++
#include "ruleritem.h"
|
|
#include "divetextitem.h"
|
|
|
|
#include <QFont>
|
|
#include <QFontMetrics>
|
|
#include <QPainter>
|
|
#include <QGraphicsScene>
|
|
#include <QGraphicsView>
|
|
#include <QDebug>
|
|
|
|
#include <stdint.h>
|
|
|
|
#include "profile.h"
|
|
#include "display.h"
|
|
|
|
RulerNodeItem2::RulerNodeItem2() : entry(NULL), ruler(NULL)
|
|
{
|
|
memset(&pInfo, 0, sizeof(pInfo));
|
|
setRect(QRect(QPoint(-8, 8), QPoint(8, -8)));
|
|
setBrush(QColor(0xff, 0, 0, 127));
|
|
setPen(QColor("#FF0000"));
|
|
setFlag(QGraphicsItem::ItemIsMovable);
|
|
setFlag(ItemSendsGeometryChanges);
|
|
setFlag(ItemIgnoresTransformations);
|
|
}
|
|
|
|
void RulerNodeItem2::setPlotInfo(plot_info& info)
|
|
{
|
|
pInfo = info;
|
|
entry = pInfo.entry;
|
|
}
|
|
|
|
void RulerNodeItem2::setRuler(RulerItem2 *r)
|
|
{
|
|
ruler = r;
|
|
}
|
|
|
|
void RulerNodeItem2::recalculate()
|
|
{
|
|
struct plot_data *data = pInfo.entry + (pInfo.nr - 1);
|
|
uint16_t count = 0;
|
|
if (x() < 0) {
|
|
setPos(0, y());
|
|
} else if (x() > timeAxis->posAtValue(data->sec)) {
|
|
setPos(timeAxis->posAtValue(data->sec), y());
|
|
} else {
|
|
data = pInfo.entry;
|
|
count = 0;
|
|
while (timeAxis->posAtValue(data->sec) < x() && count < pInfo.nr) {
|
|
data = pInfo.entry + count;
|
|
count++;
|
|
}
|
|
setPos(timeAxis->posAtValue(data->sec), depthAxis->posAtValue(data->depth));
|
|
entry = data;
|
|
}
|
|
}
|
|
|
|
QVariant RulerNodeItem2::itemChange(GraphicsItemChange change, const QVariant &value)
|
|
{
|
|
if (change == ItemPositionHasChanged) {
|
|
recalculate();
|
|
if (ruler != NULL)
|
|
ruler->recalculate();
|
|
}
|
|
return QGraphicsEllipseItem::itemChange(change, value);
|
|
}
|
|
|
|
RulerItem2::RulerItem2() : timeAxis(NULL),
|
|
depthAxis(NULL),
|
|
source(new RulerNodeItem2()),
|
|
dest(new RulerNodeItem2()),
|
|
textItem(new QGraphicsSimpleTextItem(this))
|
|
{
|
|
memset(&pInfo, 0, sizeof(pInfo));
|
|
source->setRuler(this);
|
|
dest->setRuler(this);
|
|
textItem->setFlag(QGraphicsItem::ItemIgnoresTransformations);
|
|
}
|
|
|
|
void RulerItem2::recalculate()
|
|
{
|
|
char buffer[500];
|
|
QPointF tmp;
|
|
QFont font;
|
|
QFontMetrics fm(font);
|
|
|
|
if (timeAxis == NULL || depthAxis == NULL || pInfo.nr == 0)
|
|
return;
|
|
|
|
prepareGeometryChange();
|
|
startPoint = mapFromItem(source, 0, 0);
|
|
endPoint = mapFromItem(dest, 0, 0);
|
|
|
|
if (startPoint.x() > endPoint.x()) {
|
|
tmp = endPoint;
|
|
endPoint = startPoint;
|
|
startPoint = tmp;
|
|
}
|
|
QLineF line(startPoint, endPoint);
|
|
|
|
compare_samples(source->entry, dest->entry, buffer, 500, 1);
|
|
text = QString(buffer);
|
|
|
|
//Draw Text
|
|
// This text item ignores transformations, so we cant use
|
|
// the line.angle(), we need to calculate the angle based
|
|
// on the view.
|
|
|
|
QGraphicsView *view = scene()->views().first();
|
|
QPoint begin = view->mapFromScene(mapToScene(startPoint));
|
|
QPoint end = view->mapFromScene(mapToScene(endPoint));
|
|
QLineF globalLine(begin, end);
|
|
textItem->setText(text);
|
|
textItem->resetMatrix();
|
|
textItem->resetTransform();
|
|
textItem->setPos(startPoint);
|
|
textItem->rotate(globalLine.angle() * -1);
|
|
}
|
|
|
|
RulerNodeItem2 *RulerItem2::sourceNode() const
|
|
{
|
|
return source;
|
|
}
|
|
|
|
RulerNodeItem2 *RulerItem2::destNode() const
|
|
{
|
|
return dest;
|
|
}
|
|
|
|
void RulerItem2::paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget)
|
|
{
|
|
Q_UNUSED(option);
|
|
Q_UNUSED(widget);
|
|
QLineF line(startPoint, endPoint);
|
|
painter->setPen(QColor(Qt::black));
|
|
painter->setBrush(Qt::NoBrush);
|
|
painter->drawLine(line);
|
|
}
|
|
|
|
QRectF RulerItem2::boundingRect() const
|
|
{
|
|
return shape().controlPointRect();
|
|
}
|
|
|
|
QPainterPath RulerItem2::shape() const
|
|
{
|
|
QPainterPath path;
|
|
QLineF line(startPoint, endPoint);
|
|
QLineF line_n = line.normalVector();
|
|
line_n.setLength(height);
|
|
if (paint_direction == 1)
|
|
line_n.setAngle(line_n.angle() + 180);
|
|
path.moveTo(startPoint);
|
|
path.lineTo(line_n.p2());
|
|
path.lineTo(line_n.p2() + QPointF(line.dx(), line.dy()));
|
|
path.lineTo(endPoint);
|
|
path.lineTo(startPoint);
|
|
return path;
|
|
}
|
|
|
|
void RulerItem2::setPlotInfo(plot_info info)
|
|
{
|
|
pInfo = info;
|
|
dest->setPlotInfo(info);
|
|
source->setPlotInfo(info);
|
|
dest->recalculate();
|
|
source->recalculate();
|
|
recalculate();
|
|
}
|
|
|
|
void RulerItem2::setAxis(DiveCartesianAxis *time, DiveCartesianAxis *depth)
|
|
{
|
|
timeAxis = time;
|
|
depthAxis = depth;
|
|
dest->depthAxis = depth;
|
|
dest->timeAxis = time;
|
|
source->depthAxis = depth;
|
|
source->timeAxis = time;
|
|
recalculate();
|
|
}
|