diff options
Diffstat (limited to 'qt-ui/profilegraphics.cpp')
-rw-r--r-- | qt-ui/profilegraphics.cpp | 128 |
1 files changed, 64 insertions, 64 deletions
diff --git a/qt-ui/profilegraphics.cpp b/qt-ui/profilegraphics.cpp index 264e02d96..ad412e4b0 100644 --- a/qt-ui/profilegraphics.cpp +++ b/qt-ui/profilegraphics.cpp @@ -1,7 +1,6 @@ #include "profilegraphics.h" #include "mainwindow.h" #include "divelistview.h" -#include "graphicsview-common.h" #include <QGraphicsScene> #include <QResizeEvent> @@ -46,11 +45,12 @@ extern int evn_used; ProfileGraphicsView::ProfileGraphicsView(QWidget* parent) : QGraphicsView(parent), toolTip(0) , dive(0), diveDC(0) { + printMode = false; + isGrayscale = false; gc.printer = false; fill_profile_color(); setScene(new QGraphicsScene()); - setBackgroundBrush(profile_color[BACKGROUND].at(0)); scene()->installEventFilter(this); setRenderHint(QPainter::Antialiasing); @@ -189,6 +189,17 @@ void ProfileGraphicsView::refresh() plot(current_dive, TRUE); } +void ProfileGraphicsView::setPrintMode(bool mode, bool grayscale) +{ + printMode = mode; + isGrayscale = grayscale; +} + +QColor ProfileGraphicsView::getColor(const color_indice_t i) +{ + return profile_color[i].at((isGrayscale) ? 1 : 0); +} + void ProfileGraphicsView::plot(struct dive *d, bool forceRedraw) { struct divecomputer *dc; @@ -206,6 +217,7 @@ void ProfileGraphicsView::plot(struct dive *d, bool forceRedraw) if (!isVisible() || !dive) { return; } + setBackgroundBrush(getColor(BACKGROUND)); // best place to put the focus stealer code. setFocusProxy(mainWindow()->dive_list()); @@ -214,6 +226,8 @@ void ProfileGraphicsView::plot(struct dive *d, bool forceRedraw) toolTip = new ToolTipItem(); installEventFilter(toolTip); scene()->addItem(toolTip); + if (printMode) + toolTip->setVisible(false); // Fix this for printing / screen later. // plot_set_scale(scale_mode_t); @@ -250,7 +264,7 @@ void ProfileGraphicsView::plot(struct dive *d, bool forceRedraw) /* Bounding box */ QPen pen = defaultPen; - pen.setColor(profile_color[TIME_GRID].at(0)); + pen.setColor(getColor(TIME_GRID)); QGraphicsRectItem *rect = new QGraphicsRectItem(profile_grid_area); rect->setPen(pen); scene()->addItem(rect); @@ -338,7 +352,7 @@ void ProfileGraphicsView::plot_depth_scale() case units::FEET: marker = 9144; break; /* 30 ft */ } - QColor c(profile_color[DEPTH_GRID].first()); + QColor c(getColor(DEPTH_GRID)); /* don't write depth labels all the way to the bottom as * there may be other graphs below the depth plot (like @@ -364,7 +378,7 @@ void ProfileGraphicsView::plot_pp_text() pp = floor(gc.pi.maxpp * 10.0) / 10.0 + 0.2; dpp = pp > 4 ? 1.0 : 0.5; hpos = gc.pi.entry[gc.pi.nr - 1].sec; - QColor c = profile_color[PP_LINES].first(); + QColor c = getColor(PP_LINES); for (m = 0.0; m <= pp; m += dpp) { QGraphicsLineItem *item = new QGraphicsLineItem(SCALEGC(0, m), SCALEGC(hpos, m)); @@ -397,7 +411,7 @@ void ProfileGraphicsView::plot_pp_gas_profile() QColor c; QPointF from, to; if (prefs.pp_graphs.pn2) { - c = profile_color[PN2].first(); + c = getColor(PN2); entry = pi->entry; from = QPointF(SCALEGC(entry->sec, entry->pn2)); for (i = 1; i < pi->nr; i++) { @@ -408,7 +422,7 @@ void ProfileGraphicsView::plot_pp_gas_profile() from = QPointF(SCALEGC(entry->sec, entry->pn2)); } - c = profile_color[PN2_ALERT].first(); + c = getColor(PN2_ALERT); entry = pi->entry; from = QPointF(SCALEGC(entry->sec, entry->pn2)); for (i = 1; i < pi->nr; i++) { @@ -421,7 +435,7 @@ void ProfileGraphicsView::plot_pp_gas_profile() } if (prefs.pp_graphs.phe) { - c = profile_color[PHE].first(); + c = getColor(PHE); entry = pi->entry; from = QPointF(SCALEGC(entry->sec, entry->phe)); @@ -433,7 +447,7 @@ void ProfileGraphicsView::plot_pp_gas_profile() from = QPointF(SCALEGC(entry->sec, entry->phe)); } - c = profile_color[PHE_ALERT].first(); + c = getColor(PHE_ALERT); entry = pi->entry; from = QPointF(SCALEGC(entry->sec, entry->phe)); for (i = 1; i < pi->nr; i++) { @@ -445,7 +459,7 @@ void ProfileGraphicsView::plot_pp_gas_profile() } } if (prefs.pp_graphs.po2) { - c = profile_color[PO2].first(); + c = getColor(PO2); entry = pi->entry; from = QPointF(SCALEGC(entry->sec, entry->po2)); for (i = 1; i < pi->nr; i++) { @@ -456,7 +470,7 @@ void ProfileGraphicsView::plot_pp_gas_profile() from = QPointF(SCALEGC(entry->sec, entry->po2)); } - c = profile_color[PO2_ALERT].first(); + c = getColor(PO2_ALERT); entry = pi->entry; from = QPointF(SCALEGC(entry->sec, entry->po2)); for (i = 1; i < pi->nr; i++) { @@ -739,9 +753,9 @@ QColor ProfileGraphicsView::get_sac_color(int sac, int avg_sac) sac_index = 0; if (sac_index > SAC_COLORS - 1) sac_index = SAC_COLORS - 1; - return profile_color[ (color_indice_t) (SAC_COLORS_START_IDX + sac_index)].first(); + return getColor((color_indice_t)(SAC_COLORS_START_IDX + sac_index)); } - return profile_color[SAC_DEFAULT].first(); + return getColor(SAC_DEFAULT); } void ProfileGraphicsView::plot_events(struct divecomputer *dc) @@ -792,7 +806,7 @@ void ProfileGraphicsView::plot_one_event(struct event *ev) int x = SCALEXGC(ev->time.seconds); int y = SCALEYGC(depth); - EventItem *item = new EventItem(); + EventItem *item = new EventItem(0, isGrayscale); item->setPos(x, y); scene()->addItem(item); @@ -816,8 +830,8 @@ void ProfileGraphicsView::plot_one_event(struct event *ev) } else if (ev->name && name == "SP change") { name += tr("Bailing out to OC"); } else { - name += ev->flags == SAMPLE_FLAGS_BEGIN ? tr("Starts with space!"," begin") : - ev->flags == SAMPLE_FLAGS_END ? tr("Starts with space!", " end") : ""; + name += ev->flags == SAMPLE_FLAGS_BEGIN ? tr(" begin", "Starts with space!") : + ev->flags == SAMPLE_FLAGS_END ? tr(" end", "Starts with space!") : ""; } //item->setToolTipController(toolTip); @@ -858,7 +872,7 @@ void ProfileGraphicsView::plot_depth_profile() last_gc = gc; - QColor c = profile_color[TIME_GRID].at(0); + QColor c = getColor(TIME_GRID); for (i = incr; i < maxtime; i += incr) { QGraphicsLineItem *item = new QGraphicsLineItem(SCALEGC(i, 0), SCALEGC(i, 1)); QPen pen(defaultPen); @@ -895,7 +909,7 @@ void ProfileGraphicsView::plot_depth_profile() } maxline = MAX(gc.pi.maxdepth + marker, maxdepth * 2 / 3); - c = profile_color[DEPTH_GRID].at(0); + c = getColor(DEPTH_GRID); for (i = marker; i < maxline; i += marker) { QGraphicsLineItem *item = new QGraphicsLineItem(SCALEGC(0, i), SCALEGC(1, i)); @@ -906,7 +920,7 @@ void ProfileGraphicsView::plot_depth_profile() } gc.leftx = 0; gc.rightx = maxtime; - c = profile_color[MEAN_DEPTH].at(0); + c = getColor(MEAN_DEPTH); /* Show mean depth */ if (! gc.printer) { @@ -955,8 +969,8 @@ void ProfileGraphicsView::plot_depth_profile() } } } - pat.setColorAt(1, profile_color[DEPTH_BOTTOM].first()); - pat.setColorAt(0, profile_color[DEPTH_TOP].first()); + pat.setColorAt(1, getColor(DEPTH_BOTTOM)); + pat.setColorAt(0, getColor(DEPTH_TOP)); neatFill = new QGraphicsPolygonItem(); neatFill->setPolygon(p); @@ -970,8 +984,8 @@ void ProfileGraphicsView::plot_depth_profile() * through so far) */ if (prefs.profile_dc_ceiling && prefs.profile_red_ceiling) { p.clear(); - pat.setColorAt(0, profile_color[CEILING_SHALLOW].first()); - pat.setColorAt(1, profile_color[CEILING_DEEP].first()); + pat.setColorAt(0, getColor(CEILING_SHALLOW)); + pat.setColorAt(1, getColor(CEILING_DEEP)); entry = gc.pi.entry; p.append(QPointF(SCALEGC(0, 0))); @@ -996,8 +1010,8 @@ void ProfileGraphicsView::plot_depth_profile() /* finally, plot the calculated ceiling over all this */ if (prefs.profile_calc_ceiling) { - pat.setColorAt(0, profile_color[CALC_CEILING_SHALLOW].first()); - pat.setColorAt(1, profile_color[CALC_CEILING_DEEP].first()); + pat.setColorAt(0, getColor(CALC_CEILING_SHALLOW)); + pat.setColorAt(1, getColor(CALC_CEILING_DEEP)); entry = gc.pi.entry; p.clear(); @@ -1020,7 +1034,7 @@ void ProfileGraphicsView::plot_depth_profile() if (prefs.profile_calc_ceiling && prefs.calc_all_tissues){ int k; for (k=0; k<16; k++){ - pat.setColorAt(0, profile_color[CALC_CEILING_SHALLOW].first()); + pat.setColorAt(0, getColor(CALC_CEILING_SHALLOW)); pat.setColorAt(1, QColor(100, 100, 100, 50)); entry = gc.pi.entry; @@ -1041,8 +1055,8 @@ void ProfileGraphicsView::plot_depth_profile() } /* next show where we have been bad and crossed the dc's ceiling */ if (prefs.profile_dc_ceiling) { - pat.setColorAt(0, profile_color[CEILING_SHALLOW].first()); - pat.setColorAt(1, profile_color[CEILING_DEEP].first()); + pat.setColorAt(0, getColor(CEILING_SHALLOW)); + pat.setColorAt(1, getColor(CEILING_DEEP)); entry = gc.pi.entry; p.clear(); @@ -1075,7 +1089,7 @@ void ProfileGraphicsView::plot_depth_profile() depth = entry->depth; QGraphicsLineItem *item = new QGraphicsLineItem(SCALEGC(entry[-1].sec, entry[-1].depth), SCALEGC(sec, depth)); QPen pen(defaultPen); - pen.setColor(profile_color[ (color_indice_t) (VELOCITY_COLORS_START_IDX + entry->velocity)].first()); + pen.setColor(getColor((color_indice_t)(VELOCITY_COLORS_START_IDX + entry->velocity))); item->setPen(pen); scene()->addItem(item); } @@ -1098,15 +1112,16 @@ QGraphicsItemGroup *ProfileGraphicsView::plot_text(text_render_options_t *tro,co QPainterPathStroker stroker; stroker.setWidth(3); QGraphicsPathItem *strokedItem = new QGraphicsPathItem(stroker.createStroke(textPath), group); - strokedItem->setBrush(QBrush(profile_color[TEXT_BACKGROUND].first())); + strokedItem->setBrush(QBrush(getColor(TEXT_BACKGROUND))); strokedItem->setPen(Qt::NoPen); QGraphicsPathItem *textItem = new QGraphicsPathItem(textPath, group); - textItem->setBrush(QBrush(profile_color[tro->color].first())); + textItem->setBrush(QBrush(getColor(tro->color))); textItem->setPen(Qt::NoPen); group->setPos(point.x() + dx, point.y() + dy); - group->setFlag(QGraphicsItem::ItemIgnoresTransformations); + if (!printMode) + group->setFlag(QGraphicsItem::ItemIgnoresTransformations); if (!parent) scene()->addItem(group); @@ -1127,7 +1142,7 @@ void ProfileGraphicsView::plot_temperature_profile() QPointF from; QPointF to; - QColor color = profile_color[TEMP_PLOT].first(); + QColor color = getColor(TEMP_PLOT); for (int i = 0; i < gc.pi.nr; i++) { struct plot_data *entry = gc.pi.entry + i; @@ -1175,36 +1190,14 @@ void ToolTipItem::addToolTip(const QString& toolTip, const QIcon& icon) textItem->setPos(SPACING + ICON_SMALL + SPACING, yValue); textItem->setBrush(QBrush(Qt::white)); textItem->setFlag(ItemIgnoresTransformations); - toolTips[toolTip] = qMakePair(iconItem, textItem); + toolTips.push_back(qMakePair(iconItem, textItem)); expand(); } -void ToolTipItem::removeToolTip(const QString& toolTip) -{ - ToolTip toBeRemoved = toolTips[toolTip]; - delete toBeRemoved.first; - delete toBeRemoved.second; - toolTips.remove(toolTip); - - int toolTipIndex = 0; - - // We removed a toolTip, let's move the others to the correct location - Q_FOREACH(ToolTip t, toolTips) { - double yValue = title->boundingRect().height() + SPACING + toolTipIndex * ICON_SMALL + SPACING; - - // Icons can be null. - if (t.first) - t.first->setPos(SPACING, yValue); - - t.second->setPos(SPACING + ICON_SMALL + SPACING, yValue); - toolTipIndex++; - } -} - void ToolTipItem::refresh(struct graphics_context *gc, QPointF pos) { clear(); - int time = (pos.x() * gc->maxtime) / scene()->sceneRect().width(); + int time = (pos.x() * gc->maxtime) / gc->maxx; char buffer[500]; get_plot_details(gc, time, buffer, 500); addToolTip(QString(buffer)); @@ -1397,8 +1390,14 @@ bool ToolTipItem::eventFilter(QObject* view, QEvent* event) return false; } -EventItem::EventItem(QGraphicsItem* parent): QGraphicsPolygonItem(parent) +QColor EventItem::getColor(const color_indice_t i) +{ + return profile_color[i].at((isGrayscale) ? 1 : 0); +} + +EventItem::EventItem(QGraphicsItem* parent, bool grayscale): QGraphicsPolygonItem(parent) { + isGrayscale = grayscale; setFlag(ItemIgnoresTransformations); setFlag(ItemIsFocusable); setAcceptHoverEvents(true); @@ -1416,17 +1415,18 @@ EventItem::EventItem(QGraphicsItem* parent): QGraphicsPolygonItem(parent) defaultPen.setCosmetic(true); QPen pen = defaultPen; - pen.setBrush(QBrush(profile_color[ALERT_BG].first())); + pen.setBrush(QBrush(getColor(ALERT_BG))); setPolygon(poly); - setBrush(QBrush(profile_color[ALERT_BG].first())); + setBrush(QBrush(getColor(ALERT_BG))); setPen(pen); - QGraphicsLineItem *line = new QGraphicsLineItem(0,5,0,10, this); - line->setPen(QPen(Qt::black, 2)); + QGraphicsLineItem *line = new QGraphicsLineItem(0, 5, 0, 10, this); + line->setPen(QPen(getColor(ALERT_FG), 2)); - QGraphicsEllipseItem *ball = new QGraphicsEllipseItem(-1, 12, 2,2, this); - ball->setBrush(QBrush(Qt::black)); + QGraphicsEllipseItem *ball = new QGraphicsEllipseItem(-1, 12, 2, 2, this); + ball->setBrush(QBrush(getColor(ALERT_FG))); + ball->setPen(QPen(getColor(ALERT_FG))); } GraphicsTextEditor::GraphicsTextEditor(QGraphicsItem* parent): QGraphicsTextItem(parent) |