mirror of
https://gitlab.com/pholy/OSCAR-code.git
synced 2025-04-06 11:10:44 +00:00
Some Mouse handling and By Pressure cleanups
This commit is contained in:
parent
67203a8c49
commit
8fae3b4a6e
@ -108,6 +108,7 @@ bool MinutesAtPressure::isEmpty()
|
|||||||
return m_empty;
|
return m_empty;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void MinutesAtPressure::paint(QPainter &painter, gGraph &graph, const QRegion ®ion)
|
void MinutesAtPressure::paint(QPainter &painter, gGraph &graph, const QRegion ®ion)
|
||||||
{
|
{
|
||||||
QRect rect = region.boundingRect();
|
QRect rect = region.boundingRect();
|
||||||
@ -116,8 +117,8 @@ void MinutesAtPressure::paint(QPainter &painter, gGraph &graph, const QRegion &r
|
|||||||
float cells = m_maxpressure-m_minpressure+1;
|
float cells = m_maxpressure-m_minpressure+1;
|
||||||
|
|
||||||
|
|
||||||
float width = rect.width() - gYAxis::Margin;
|
float width = rect.width();
|
||||||
float left = rect.left() + gYAxis::Margin;
|
float left = rect.left();
|
||||||
float pix = width / cells;
|
float pix = width / cells;
|
||||||
|
|
||||||
m_minx = graph.min_x;
|
m_minx = graph.min_x;
|
||||||
@ -140,21 +141,31 @@ void MinutesAtPressure::paint(QPainter &painter, gGraph &graph, const QRegion &r
|
|||||||
QMap<EventStoreType, int>::iterator times_end = times.end();
|
QMap<EventStoreType, int>::iterator times_end = times.end();
|
||||||
QPoint mouse = graph.graphView()->currentMousePos();
|
QPoint mouse = graph.graphView()->currentMousePos();
|
||||||
|
|
||||||
|
|
||||||
|
float ypos = top;
|
||||||
|
|
||||||
QString text = schema::channel[m_presChannel].label();
|
QString text = schema::channel[m_presChannel].label();
|
||||||
QRectF rec(left,top, pix * 3,0);
|
QRectF rec(left - gYAxis::Margin, top, gYAxis::Margin,0);
|
||||||
rec = painter.boundingRect(rec, Qt::AlignTop | Qt::AlignRight, text);
|
rec = painter.boundingRect(rec, Qt::AlignTop | Qt::AlignRight, text);
|
||||||
rec.moveRight(left-4);
|
rec.moveRight(left-4);
|
||||||
painter.drawText(rec, Qt::AlignRight | Qt::AlignVCenter, text);
|
graph.renderText(text, rec, Qt::AlignRight | Qt::AlignVCenter);
|
||||||
|
|
||||||
|
//painter.drawText(rec, Qt::AlignRight | Qt::AlignVCenter, text);
|
||||||
if (rec.contains(mouse)) {
|
if (rec.contains(mouse)) {
|
||||||
QString text = schema::channel[m_presChannel].description();
|
QString text = schema::channel[m_presChannel].description();
|
||||||
graph.ToolTip(text, mouse.x() + 10, mouse.y(), TT_AlignLeft);
|
graph.ToolTip(text, mouse.x() + 10, mouse.y(), TT_AlignLeft);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
double tmph = rec.height();
|
||||||
|
|
||||||
text = STR_UNIT_Minutes;
|
text = STR_UNIT_Minutes;
|
||||||
QRectF rec2(left, top + rec.height(),pix * 3, 0);
|
QRectF rec2(left - gYAxis::Margin, top + rec.height(), gYAxis::Margin, 0);
|
||||||
rec2 = painter.boundingRect(rec2, Qt::AlignTop | Qt::AlignRight, text);
|
rec2 = painter.boundingRect(rec2, Qt::AlignTop | Qt::AlignRight, text);
|
||||||
rec2.moveRight(left-4);
|
rec2.moveRight(left-4);
|
||||||
painter.drawText(rec2, Qt::AlignRight | Qt::AlignVCenter, text);
|
//painter.drawText(rec2, Qt::AlignRight | Qt::AlignVCenter, text);
|
||||||
|
graph.renderText(text, rec2, Qt::AlignRight | Qt::AlignVCenter);
|
||||||
|
|
||||||
|
tmph += rec2.height();
|
||||||
|
|
||||||
float xpos = left;
|
float xpos = left;
|
||||||
for (it = times.begin(); it != times_end; ++it) {
|
for (it = times.begin(); it != times_end; ++it) {
|
||||||
@ -166,16 +177,19 @@ void MinutesAtPressure::paint(QPainter &painter, gGraph &graph, const QRegion &r
|
|||||||
rec.setWidth(pix - 1);
|
rec.setWidth(pix - 1);
|
||||||
|
|
||||||
painter.fillRect(rec, QColor("orange"));
|
painter.fillRect(rec, QColor("orange"));
|
||||||
painter.drawText(rec, Qt::AlignCenter, text);
|
graph.renderText(text, rec, Qt::AlignCenter);
|
||||||
|
//painter.drawText(rec, Qt::AlignCenter, text);
|
||||||
rec.moveTop(top + rec.height());
|
rec.moveTop(top + rec.height());
|
||||||
painter.drawText(rec, Qt::AlignCenter, value);
|
graph.renderText(value, rec, Qt::AlignCenter);
|
||||||
|
//painter.drawText(rec, Qt::AlignCenter, value);
|
||||||
|
|
||||||
xpos += pix;
|
xpos += pix;
|
||||||
}
|
}
|
||||||
|
|
||||||
float hh = rec.height();
|
ypos = top + tmph;
|
||||||
|
left = rect.left();
|
||||||
|
|
||||||
float ypos = top + hh * 2;
|
float hh = rec.height();
|
||||||
|
|
||||||
QHash<ChannelID, QMap<EventStoreType, EventDataType> >::iterator eit;
|
QHash<ChannelID, QMap<EventStoreType, EventDataType> >::iterator eit;
|
||||||
QHash<ChannelID, QMap<EventStoreType, EventDataType> >::iterator ev_end = events.end();
|
QHash<ChannelID, QMap<EventStoreType, EventDataType> >::iterator ev_end = events.end();
|
||||||
@ -196,8 +210,8 @@ void MinutesAtPressure::paint(QPainter &painter, gGraph &graph, const QRegion &r
|
|||||||
QMap<EventStoreType, EventDataType>::iterator eit_end = eit.value().end();
|
QMap<EventStoreType, EventDataType>::iterator eit_end = eit.value().end();
|
||||||
|
|
||||||
QString text = chan.label();
|
QString text = chan.label();
|
||||||
QRectF rec2(xpos, ypos, pix * 3, hh);
|
QRectF rec2(xpos - gYAxis::Margin, ypos, gYAxis::Margin, hh);
|
||||||
rec2 = painter.boundingRect(rec2, Qt::AlignTop | Qt::AlignRight, text);
|
rec2 = painter.boundingRect(rec2, Qt::AlignRight | Qt::AlignVCenter, text);
|
||||||
rec2.moveRight(left-4);
|
rec2.moveRight(left-4);
|
||||||
|
|
||||||
if (rec2.contains(mouse)) {
|
if (rec2.contains(mouse)) {
|
||||||
@ -207,7 +221,8 @@ void MinutesAtPressure::paint(QPainter &painter, gGraph &graph, const QRegion &r
|
|||||||
}
|
}
|
||||||
graph.ToolTip(text, mouse.x() + 10, mouse.y(), TT_AlignLeft);
|
graph.ToolTip(text, mouse.x() + 10, mouse.y(), TT_AlignLeft);
|
||||||
}
|
}
|
||||||
painter.drawText(rec2, Qt::AlignRight | Qt::AlignVCenter, text);
|
graph.renderText(text, rec2, Qt::AlignRight | Qt::AlignVCenter);
|
||||||
|
//painter.drawText(rec2, Qt::AlignRight | Qt::AlignVCenter, text);
|
||||||
|
|
||||||
for (it = times.begin(), vit = eit.value().begin(); vit != eit_end; ++vit, ++it) {
|
for (it = times.begin(), vit = eit.value().begin(); vit != eit_end; ++vit, ++it) {
|
||||||
float minutes = float(it.value()) / 60.0;
|
float minutes = float(it.value()) / 60.0;
|
||||||
@ -228,7 +243,8 @@ void MinutesAtPressure::paint(QPainter &painter, gGraph &graph, const QRegion &r
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
painter.drawText(rec, Qt::AlignCenter, QString(fmt).arg(value,5,'f',2));
|
graph.renderText(QString(fmt).arg(value,5,'f',2), rec, Qt::AlignCenter);
|
||||||
|
// painter.drawText(rec, Qt::AlignCenter, QString(fmt).arg(value,5,'f',2));
|
||||||
xpos += pix;
|
xpos += pix;
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -456,21 +472,36 @@ void MinutesAtPressure::recalcFinished()
|
|||||||
|
|
||||||
bool MinutesAtPressure::mouseMoveEvent(QMouseEvent *event, gGraph *graph)
|
bool MinutesAtPressure::mouseMoveEvent(QMouseEvent *event, gGraph *graph)
|
||||||
{
|
{
|
||||||
Q_UNUSED(event);
|
// int y = event->y() - m_rect.top();
|
||||||
Q_UNUSED(graph);
|
// int x = event->x() - graph->graphView()->titleWidth;
|
||||||
return true;
|
|
||||||
|
// double w = m_rect.width() - gYAxis::Margin;
|
||||||
|
|
||||||
|
// double xmult = (graph->blockZoom() ? double(graph->rmax_x - graph->rmin_x) : double(graph->max_x - graph->min_x)) / w;
|
||||||
|
|
||||||
|
// double a = x - gYAxis::Margin;
|
||||||
|
// if (a < 0) a = 0;
|
||||||
|
// if (a > w) a = w;
|
||||||
|
|
||||||
|
// double b = a * xmult;
|
||||||
|
// double c= b + (graph->blockZoom() ? graph->rmin_x : graph->min_x);
|
||||||
|
|
||||||
|
// graph->graphView()->setCurrentTime(c);
|
||||||
|
|
||||||
|
graph->timedRedraw(0);
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool MinutesAtPressure::mousePressEvent(QMouseEvent *event, gGraph *graph)
|
bool MinutesAtPressure::mousePressEvent(QMouseEvent *event, gGraph *graph)
|
||||||
{
|
{
|
||||||
Q_UNUSED(event);
|
Q_UNUSED(event);
|
||||||
Q_UNUSED(graph);
|
Q_UNUSED(graph);
|
||||||
return true;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool MinutesAtPressure::mouseReleaseEvent(QMouseEvent *event, gGraph *graph)
|
bool MinutesAtPressure::mouseReleaseEvent(QMouseEvent *event, gGraph *graph)
|
||||||
{
|
{
|
||||||
Q_UNUSED(event);
|
Q_UNUSED(event);
|
||||||
Q_UNUSED(graph);
|
Q_UNUSED(graph);
|
||||||
return true;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -15,15 +15,15 @@
|
|||||||
#include "gFlagsLine.h"
|
#include "gFlagsLine.h"
|
||||||
#include "gYAxis.h"
|
#include "gYAxis.h"
|
||||||
|
|
||||||
gFlagsLabelArea::gFlagsLabelArea(gFlagsGroup *group)
|
gLabelArea::gLabelArea(Layer * layer)
|
||||||
: gSpacer(20)
|
: gSpacer(20)
|
||||||
{
|
{
|
||||||
m_group = group;
|
m_mainlayer = layer;
|
||||||
}
|
}
|
||||||
bool gFlagsLabelArea::mouseMoveEvent(QMouseEvent *event, gGraph *graph)
|
bool gLabelArea::mouseMoveEvent(QMouseEvent *event, gGraph *graph)
|
||||||
{
|
{
|
||||||
if (m_group) {
|
if (m_mainlayer) {
|
||||||
return m_group->mouseMoveEvent(event, graph);
|
return m_mainlayer->mouseMoveEvent(event, graph);
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
@ -221,7 +221,7 @@ bool gFlagsGroup::mouseMoveEvent(QMouseEvent *event, gGraph *graph)
|
|||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return true;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -405,5 +405,5 @@ bool gFlagsLine::mouseMoveEvent(QMouseEvent *event, gGraph *graph)
|
|||||||
Q_UNUSED(graph)
|
Q_UNUSED(graph)
|
||||||
// qDebug() << code() << event->x() << event->y() << graph->rect();
|
// qDebug() << code() << event->x() << event->y() << graph->rect();
|
||||||
|
|
||||||
return true;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -20,17 +20,17 @@ class gFlagsGroup;
|
|||||||
/*! \class gYSpacer
|
/*! \class gYSpacer
|
||||||
\brief A dummy vertical spacer object
|
\brief A dummy vertical spacer object
|
||||||
*/
|
*/
|
||||||
class gFlagsLabelArea: public gSpacer
|
class gLabelArea: public gSpacer
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
gFlagsLabelArea(gFlagsGroup *group);
|
gLabelArea(Layer * layer);
|
||||||
virtual void paint(QPainter &painter, gGraph &w, const QRegion ®ion) {
|
virtual void paint(QPainter &painter, gGraph &w, const QRegion ®ion) {
|
||||||
Q_UNUSED(w);
|
Q_UNUSED(w);
|
||||||
Q_UNUSED(painter);
|
Q_UNUSED(painter);
|
||||||
Q_UNUSED(region);
|
Q_UNUSED(region);
|
||||||
}
|
}
|
||||||
protected:
|
protected:
|
||||||
gFlagsGroup *m_group;
|
Layer *m_mainlayer;
|
||||||
virtual bool mouseMoveEvent(QMouseEvent *event, gGraph *graph);
|
virtual bool mouseMoveEvent(QMouseEvent *event, gGraph *graph);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -265,6 +265,12 @@ void gGraph::renderText(QString text, int x, int y, float angle, QColor color, Q
|
|||||||
m_graphview->AddTextQue(text, x, y, angle, color, font, antialias);
|
m_graphview->AddTextQue(text, x, y, angle, color, font, antialias);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void gGraph::renderText(QString text, QRectF rect, int flags, float angle, QColor color, QFont *font, bool antialias)
|
||||||
|
{
|
||||||
|
m_graphview->AddTextQue(text, rect, flags, angle, color, font, antialias);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void gGraph::paint(QPainter &painter, const QRegion ®ion)
|
void gGraph::paint(QPainter &painter, const QRegion ®ion)
|
||||||
{
|
{
|
||||||
m_rect = region.boundingRect();
|
m_rect = region.boundingRect();
|
||||||
@ -702,7 +708,8 @@ void gGraph::mouseMoveEvent(QMouseEvent *event)
|
|||||||
for (int i = 0; i < m_layers.size(); i++) {
|
for (int i = 0; i < m_layers.size(); i++) {
|
||||||
if (m_layers[i]->m_rect.contains(x, y))
|
if (m_layers[i]->m_rect.contains(x, y))
|
||||||
if (m_layers[i]->mouseMoveEvent(event, this)) {
|
if (m_layers[i]->mouseMoveEvent(event, this)) {
|
||||||
doredraw = true;
|
return;
|
||||||
|
// doredraw = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -113,6 +113,7 @@ class gGraph : public QObject
|
|||||||
bool selectingArea();
|
bool selectingArea();
|
||||||
|
|
||||||
double currentTime() const;
|
double currentTime() const;
|
||||||
|
void setCurrentTime(double value) { m_currentTime = value; }
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -123,8 +124,10 @@ class gGraph : public QObject
|
|||||||
bool movable = false, short x = 0, short y = 0);
|
bool movable = false, short x = 0, short y = 0);
|
||||||
|
|
||||||
//! \brief Queues text for gGraphView object to draw it.
|
//! \brief Queues text for gGraphView object to draw it.
|
||||||
void renderText(QString text, int x, int y, float angle = 0.0,
|
void renderText(QString text, int x, int y, float angle = 0.0, QColor color = Qt::black, QFont *font = defaultfont, bool antialias = true);
|
||||||
QColor color = Qt::black, QFont *font = defaultfont, bool antialias = true);
|
|
||||||
|
//! \brief Queues text for gGraphView object to draw it, using given rect.
|
||||||
|
void renderText(QString text, QRectF rect, int flags = Qt::AlignCenter, float angle = 0.0, QColor color = Qt::black, QFont *font = defaultfont, bool antialias = true);
|
||||||
|
|
||||||
//! \brief Rounds Y scale values to make them look nice..
|
//! \brief Rounds Y scale values to make them look nice..
|
||||||
// Applies the Graph Preference min/max settings.
|
// Applies the Graph Preference min/max settings.
|
||||||
|
@ -440,8 +440,8 @@ void gGraphView::DrawTextQue(QPainter &painter)
|
|||||||
|
|
||||||
// not sure if global antialiasing would be better..
|
// not sure if global antialiasing would be better..
|
||||||
//painter.setRenderHint(QPainter::TextAntialiasing, p_profile->appearance->antiAliasing());
|
//painter.setRenderHint(QPainter::TextAntialiasing, p_profile->appearance->antiAliasing());
|
||||||
int m_textque_items = m_textque.size();
|
int items = m_textque.size();
|
||||||
for (int i = 0; i < m_textque_items; ++i) {
|
for (int i = 0; i < items; ++i) {
|
||||||
TextQue &q = m_textque[i];
|
TextQue &q = m_textque[i];
|
||||||
painter.setPen(q.color);
|
painter.setPen(q.color);
|
||||||
painter.setRenderHint(QPainter::TextAntialiasing, q.antialias);
|
painter.setRenderHint(QPainter::TextAntialiasing, q.antialias);
|
||||||
@ -466,6 +466,37 @@ void gGraphView::DrawTextQue(QPainter &painter)
|
|||||||
}
|
}
|
||||||
|
|
||||||
m_textque.clear();
|
m_textque.clear();
|
||||||
|
|
||||||
|
items = m_textqueRect.size();
|
||||||
|
for (int i=0; i< items; ++i) {
|
||||||
|
TextQueRect &q = m_textqueRect[i];
|
||||||
|
painter.setPen(q.color);
|
||||||
|
painter.setRenderHint(QPainter::TextAntialiasing, q.antialias);
|
||||||
|
QFont font = *q.font;
|
||||||
|
painter.setFont(font);
|
||||||
|
|
||||||
|
if (q.angle == 0) { // normal text
|
||||||
|
|
||||||
|
painter.drawText(q.rect, q.flags, q.text);
|
||||||
|
} else { // rotated text
|
||||||
|
|
||||||
|
int x = q.rect.x();
|
||||||
|
int y = q.rect.y();
|
||||||
|
w = painter.fontMetrics().width(q.text);
|
||||||
|
h = painter.fontMetrics().xHeight() + 2;
|
||||||
|
|
||||||
|
painter.translate(x, y);
|
||||||
|
painter.rotate(-q.angle);
|
||||||
|
painter.drawText(floor(-w / 2.0), floor(-h / 2.0), q.text);
|
||||||
|
painter.rotate(+q.angle);
|
||||||
|
painter.translate(-x, -y);
|
||||||
|
}
|
||||||
|
strings_drawn_this_frame++;
|
||||||
|
q.text.clear();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
m_textqueRect.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
#else
|
#else
|
||||||
@ -477,7 +508,6 @@ void gGraphView::DrawTextQue(QPainter &painter)
|
|||||||
|
|
||||||
int h,w;
|
int h,w;
|
||||||
|
|
||||||
|
|
||||||
for (int i = 0; i < m_textque_items; ++i) {
|
for (int i = 0; i < m_textque_items; ++i) {
|
||||||
TextQue &q = m_textque[i];
|
TextQue &q = m_textque[i];
|
||||||
|
|
||||||
@ -563,11 +593,114 @@ void gGraphView::DrawTextQue(QPainter &painter)
|
|||||||
}
|
}
|
||||||
|
|
||||||
m_textque.clear();
|
m_textque.clear();
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////////
|
||||||
|
// Text Rectangle Queues..
|
||||||
|
////////////////////////////////////////////////////////////////////////
|
||||||
|
int items = m_textqueRect.size();
|
||||||
|
|
||||||
|
float ww, hh;
|
||||||
|
for (int i = 0; i < items; ++i) {
|
||||||
|
TextQueRect &q = m_textqueRect[i];
|
||||||
|
|
||||||
|
// can do antialiased text via texture cache fine on mac
|
||||||
|
if (usePixmapCache()) {
|
||||||
|
// Generate the pixmap cache "key"
|
||||||
|
QString hstr = QString("%1:%2:%3").
|
||||||
|
arg(q.text).
|
||||||
|
arg(q.color.name()).
|
||||||
|
arg(q.font->pointSize());
|
||||||
|
|
||||||
|
QPixmap pm;
|
||||||
|
const int buf = 8;
|
||||||
|
if (!QPixmapCache::find(hstr, &pm)) {
|
||||||
|
|
||||||
|
ww = q.rect.width();
|
||||||
|
hh = q.rect.height();
|
||||||
|
|
||||||
|
pm=QPixmap(ww, hh);
|
||||||
|
pm.fill(Qt::transparent);
|
||||||
|
|
||||||
|
QPainter imgpainter(&pm);
|
||||||
|
|
||||||
|
imgpainter.setPen(q.color);
|
||||||
|
|
||||||
|
imgpainter.setFont(*q.font);
|
||||||
|
|
||||||
|
imgpainter.setRenderHint(QPainter::Antialiasing, true);
|
||||||
|
imgpainter.setRenderHint(QPainter::TextAntialiasing, true);
|
||||||
|
QRectF rect(0,0, ww, hh);
|
||||||
|
imgpainter.drawText(rect, q.flags, q.text);
|
||||||
|
imgpainter.end();
|
||||||
|
|
||||||
|
QPixmapCache::insert(hstr, pm);
|
||||||
|
strings_drawn_this_frame++;
|
||||||
|
} else {
|
||||||
|
//cached
|
||||||
|
strings_cached_this_frame++;
|
||||||
|
}
|
||||||
|
|
||||||
|
hh = pm.height();
|
||||||
|
ww = pm.width();
|
||||||
|
if (q.angle != 0) {
|
||||||
|
float xxx = q.rect.x() - hh - (hh / 2);
|
||||||
|
float yyy = q.rect.y() + ww / 2; // + buf / 2;
|
||||||
|
|
||||||
|
xxx+=4;
|
||||||
|
yyy+=4;
|
||||||
|
|
||||||
|
painter.translate(xxx, yyy);
|
||||||
|
painter.rotate(-q.angle);
|
||||||
|
painter.drawPixmap(QRect(0, hh / 2, ww, hh), pm);
|
||||||
|
painter.rotate(+q.angle);
|
||||||
|
painter.translate(-xxx, -yyy);
|
||||||
|
} else {
|
||||||
|
painter.drawPixmap(QRect(q.rect.x(), q.rect.y(), ww, hh), pm);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// Just draw the fonts..
|
||||||
|
painter.setPen(QColor(q.color));
|
||||||
|
painter.setFont(*q.font);
|
||||||
|
|
||||||
|
if (q.angle == 0) {
|
||||||
|
painter.drawText(q.rect, q.flags, q.text);
|
||||||
|
} else {
|
||||||
|
painter.setFont(*q.font);
|
||||||
|
|
||||||
|
w = painter.fontMetrics().width(q.text);
|
||||||
|
h = painter.fontMetrics().xHeight() + 2;
|
||||||
|
|
||||||
|
painter.translate(q.rect.x(), q.rect.y());
|
||||||
|
painter.rotate(-q.angle);
|
||||||
|
painter.drawText(floor(-ww / 2.0), floor(-hh / 2.0), q.text);
|
||||||
|
painter.rotate(+q.angle);
|
||||||
|
painter.translate(-q.rect.x(), -q.rect.y());
|
||||||
|
}
|
||||||
|
strings_drawn_this_frame++;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
//q.text.clear();
|
||||||
|
//q.text.squeeze();
|
||||||
|
}
|
||||||
|
|
||||||
|
m_textqueRect.clear();
|
||||||
|
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void gGraphView::AddTextQue(const QString &text, short x, short y, float angle, QColor color,
|
void gGraphView::AddTextQue(const QString &text, QRectF rect, int flags, float angle, QColor color, QFont *font, bool antialias)
|
||||||
QFont *font, bool antialias)
|
{
|
||||||
|
#ifdef ENABLED_THREADED_DRAWING
|
||||||
|
text_mutex.lock();
|
||||||
|
#endif
|
||||||
|
m_textqueRect.append(TextQueRect(rect,flags,text,angle,color,font,antialias));
|
||||||
|
#ifdef ENABLED_THREADED_DRAWING
|
||||||
|
text_mutex.unlock();
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void gGraphView::AddTextQue(const QString &text, short x, short y, float angle, QColor color, QFont *font, bool antialias)
|
||||||
{
|
{
|
||||||
#ifdef ENABLED_THREADED_DRAWING
|
#ifdef ENABLED_THREADED_DRAWING
|
||||||
text_mutex.lock();
|
text_mutex.lock();
|
||||||
@ -576,13 +709,6 @@ void gGraphView::AddTextQue(const QString &text, short x, short y, float angle,
|
|||||||
#ifdef ENABLED_THREADED_DRAWING
|
#ifdef ENABLED_THREADED_DRAWING
|
||||||
text_mutex.unlock();
|
text_mutex.unlock();
|
||||||
#endif
|
#endif
|
||||||
// q.text = text;
|
|
||||||
// q.x = x;
|
|
||||||
// q.y = y;
|
|
||||||
// q.angle = angle;
|
|
||||||
// q.color = color;
|
|
||||||
// q.font = font;
|
|
||||||
// q.antialias = antialias;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void gGraphView::addGraph(gGraph *g, short group)
|
void gGraphView::addGraph(gGraph *g, short group)
|
||||||
|
@ -72,6 +72,39 @@ struct TextQue {
|
|||||||
bool antialias;
|
bool antialias;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct TextQueRect {
|
||||||
|
TextQueRect() {
|
||||||
|
}
|
||||||
|
TextQueRect(QRectF rect, int flags, QString text, float angle, QColor color, QFont * font, bool antialias):
|
||||||
|
rect(rect), flags(flags), text(text), angle(angle), color(color), font(font), antialias(antialias)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
TextQueRect(const TextQueRect & copy) {
|
||||||
|
rect = copy.rect;
|
||||||
|
flags = copy.flags;
|
||||||
|
text = copy.text;
|
||||||
|
angle = copy.angle;
|
||||||
|
color = copy.color;
|
||||||
|
font = copy.font;
|
||||||
|
antialias = copy.antialias;
|
||||||
|
}
|
||||||
|
|
||||||
|
//! \variable contains the QRect containing the text object
|
||||||
|
QRectF rect;
|
||||||
|
//! \variable Qt alignment flags..
|
||||||
|
int flags;
|
||||||
|
//! \variable the actual text to draw
|
||||||
|
QString text;
|
||||||
|
//! \variable the angle in degrees for drawing rotated text
|
||||||
|
float angle;
|
||||||
|
//! \variable the color the text will be drawn in
|
||||||
|
QColor color;
|
||||||
|
//! \variable a pointer to the QFont to use to draw this text
|
||||||
|
QFont *font;
|
||||||
|
//! \variable whether to use antialiasing to draw this text
|
||||||
|
bool antialias;
|
||||||
|
};
|
||||||
|
|
||||||
/*! \class MyScrollBar
|
/*! \class MyScrollBar
|
||||||
\brief An custom scrollbar to interface with gGraphWindow
|
\brief An custom scrollbar to interface with gGraphWindow
|
||||||
*/
|
*/
|
||||||
@ -295,6 +328,10 @@ class gGraphView
|
|||||||
//! \brief Updates the current selection time in the statusbar area
|
//! \brief Updates the current selection time in the statusbar area
|
||||||
void updateSelectionTime();
|
void updateSelectionTime();
|
||||||
|
|
||||||
|
//! \brief Add the Text information to the Text Drawing Queue (called by gGraphs renderText method)
|
||||||
|
void AddTextQue(const QString &text, QRectF rect, int flags, float angle = 0.0,
|
||||||
|
QColor color = Qt::black, QFont *font = defaultfont, bool antialias = true);
|
||||||
|
|
||||||
//! \brief Add the Text information to the Text Drawing Queue (called by gGraphs renderText method)
|
//! \brief Add the Text information to the Text Drawing Queue (called by gGraphs renderText method)
|
||||||
void AddTextQue(const QString &text, short x, short y, float angle = 0.0,
|
void AddTextQue(const QString &text, short x, short y, float angle = 0.0,
|
||||||
QColor color = Qt::black, QFont *font = defaultfont, bool antialias = true);
|
QColor color = Qt::black, QFont *font = defaultfont, bool antialias = true);
|
||||||
@ -486,6 +523,9 @@ class gGraphView
|
|||||||
//! \brief List of all queue text to draw.. not sure why I didn't use a vector here.. Might of been a leak issue
|
//! \brief List of all queue text to draw.. not sure why I didn't use a vector here.. Might of been a leak issue
|
||||||
QVector<TextQue> m_textque;
|
QVector<TextQue> m_textque;
|
||||||
|
|
||||||
|
//! \brief ANother text que with rect alignment capabilities...
|
||||||
|
QVector<TextQueRect> m_textqueRect;
|
||||||
|
|
||||||
int m_lastxpos, m_lastypos;
|
int m_lastxpos, m_lastypos;
|
||||||
|
|
||||||
QString m_emptytext;
|
QString m_emptytext;
|
||||||
|
@ -288,7 +288,9 @@ bool gLineChart::mouseMoveEvent(QMouseEvent *event, gGraph *graph)
|
|||||||
{
|
{
|
||||||
Q_UNUSED(event)
|
Q_UNUSED(event)
|
||||||
Q_UNUSED(graph)
|
Q_UNUSED(graph)
|
||||||
return true;
|
graph->timedRedraw(0);
|
||||||
|
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
QString gLineChart::getMetaString(qint64 time)
|
QString gLineChart::getMetaString(qint64 time)
|
||||||
|
@ -319,7 +319,7 @@ bool gLineOverlayBar::mouseMoveEvent(QMouseEvent *event, gGraph *graph)
|
|||||||
{
|
{
|
||||||
Q_UNUSED(event)
|
Q_UNUSED(event)
|
||||||
Q_UNUSED(graph)
|
Q_UNUSED(graph)
|
||||||
return true;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -447,11 +447,23 @@ void SummaryChart::paint(QPainter &painter, gGraph &w, const QRegion ®ion)
|
|||||||
|
|
||||||
int days = ceil(double(maxx-minx) / 86400000.0);
|
int days = ceil(double(maxx-minx) / 86400000.0);
|
||||||
|
|
||||||
|
double lcursor = w.graphView()->currentTime();
|
||||||
if (days >= 1) {
|
if (days >= 1) {
|
||||||
|
|
||||||
|
double b = w.max_x - w.min_x;
|
||||||
|
double a = lcursor - w.min_x;
|
||||||
|
double c = a / b;
|
||||||
|
|
||||||
minx = floor(double(minx)/86400000.0);
|
minx = floor(double(minx)/86400000.0);
|
||||||
minx *= 86400000L;
|
minx *= 86400000L;
|
||||||
|
|
||||||
maxx = minx + 86400000L * qint64(days)-1;
|
maxx = minx + 86400000L * qint64(days)-1;
|
||||||
|
|
||||||
|
b = maxx - minx;
|
||||||
|
double d = c * b;
|
||||||
|
lcursor = d + minx;
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -511,8 +523,9 @@ void SummaryChart::paint(QPainter &painter, gGraph &w, const QRegion ®ion)
|
|||||||
|
|
||||||
lastdaygood = true;
|
lastdaygood = true;
|
||||||
|
|
||||||
|
// Display Line Cursor
|
||||||
if (p_profile->appearance->lineCursorMode()) {
|
if (p_profile->appearance->lineCursorMode()) {
|
||||||
qint64 time = w.currentTime();
|
qint64 time = lcursor;
|
||||||
double xmult = double(width) / xx;
|
double xmult = double(width) / xx;
|
||||||
|
|
||||||
if ((time > minx) && (time < maxx)) {
|
if ((time > minx) && (time < maxx)) {
|
||||||
@ -1063,6 +1076,7 @@ QString formatTime(EventDataType v, bool show_seconds = false, bool duration = f
|
|||||||
|
|
||||||
bool SummaryChart::mouseMoveEvent(QMouseEvent *event, gGraph *graph)
|
bool SummaryChart::mouseMoveEvent(QMouseEvent *event, gGraph *graph)
|
||||||
{
|
{
|
||||||
|
graph->timedRedraw(0);
|
||||||
int x = event->x();
|
int x = event->x();
|
||||||
int y = event->y();
|
int y = event->y();
|
||||||
|
|
||||||
@ -1253,11 +1267,11 @@ bool SummaryChart::mouseMoveEvent(QMouseEvent *event, gGraph *graph)
|
|||||||
}
|
}
|
||||||
|
|
||||||
graph->ToolTip(z, x, y - 15);
|
graph->ToolTip(z, x, y - 15);
|
||||||
return true;
|
return false;
|
||||||
} else {
|
} else {
|
||||||
QString z = dt.toString(Qt::SystemLocaleShortDate) + "\r\nNo Data";
|
QString z = dt.toString(Qt::SystemLocaleShortDate) + "\r\nNo Data";
|
||||||
graph->ToolTip(z, x, y - 15);
|
graph->ToolTip(z, x, y - 15);
|
||||||
return true;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -405,7 +405,7 @@ bool gYAxis::mouseMoveEvent(QMouseEvent *event, gGraph *graph)
|
|||||||
// graph->redraw();
|
// graph->redraw();
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool gYAxis::mouseDoubleClickEvent(QMouseEvent *event, gGraph *graph)
|
bool gYAxis::mouseDoubleClickEvent(QMouseEvent *event, gGraph *graph)
|
||||||
|
@ -174,7 +174,7 @@ class Layer
|
|||||||
QRect m_rect;
|
QRect m_rect;
|
||||||
bool m_mouseover;
|
bool m_mouseover;
|
||||||
volatile bool m_recalculating;
|
volatile bool m_recalculating;
|
||||||
|
public:
|
||||||
|
|
||||||
// //! \brief A vector containing all this layers custom drawing buffers
|
// //! \brief A vector containing all this layers custom drawing buffers
|
||||||
// QVector<GLBuffer *> mgl_buffers;
|
// QVector<GLBuffer *> mgl_buffers;
|
||||||
|
@ -261,7 +261,7 @@ Daily::Daily(QWidget *parent,gGraphView * shared)
|
|||||||
SF->setBlockZoom(true);
|
SF->setBlockZoom(true);
|
||||||
SF->AddLayer(new gShadowArea());
|
SF->AddLayer(new gShadowArea());
|
||||||
|
|
||||||
SF->AddLayer(new gFlagsLabelArea(fg),LayerLeft,gYAxis::Margin);
|
SF->AddLayer(new gLabelArea(fg),LayerLeft,gYAxis::Margin);
|
||||||
//SF->AddLayer(new gFooBar(),LayerBottom,0,1);
|
//SF->AddLayer(new gFooBar(),LayerBottom,0,1);
|
||||||
SF->AddLayer(new gXAxis(COLOR_Text,false),LayerBottom,0,20); //gXAxis::Margin);
|
SF->AddLayer(new gXAxis(COLOR_Text,false),LayerBottom,0,20); //gXAxis::Margin);
|
||||||
|
|
||||||
@ -340,8 +340,9 @@ Daily::Daily(QWidget *parent,gGraphView * shared)
|
|||||||
|
|
||||||
gGraph * TAP2;
|
gGraph * TAP2;
|
||||||
graphlist[STR_GRAPH_TAP] = TAP2 = new gGraph(STR_GRAPH_TAP, GraphView, QObject::tr("By Pressure"), QObject::tr("Statistics at Pressure"), default_height);
|
graphlist[STR_GRAPH_TAP] = TAP2 = new gGraph(STR_GRAPH_TAP, GraphView, QObject::tr("By Pressure"), QObject::tr("Statistics at Pressure"), default_height);
|
||||||
// TAP2->AddLayer(new gFlagsLabelArea(nullptr),LayerLeft,gYAxis::Margin);
|
MinutesAtPressure * map;
|
||||||
TAP2->AddLayer(AddCPAP(new MinutesAtPressure()));
|
TAP2->AddLayer(AddCPAP(map = new MinutesAtPressure()));
|
||||||
|
TAP2->AddLayer(new gLabelArea(map),LayerLeft,gYAxis::Margin);
|
||||||
TAP2->setBlockSelect(true);
|
TAP2->setBlockSelect(true);
|
||||||
|
|
||||||
if (p_profile->general->calculateRDI()) {
|
if (p_profile->general->calculateRDI()) {
|
||||||
|
Loading…
Reference in New Issue
Block a user