comparison layer/TimeValueLayer.cpp @ 1045:f535f6e5dbb0 alignment-simple

Merge in from SV 3.0-integration branches
author Chris Cannam
date Wed, 02 Mar 2016 17:25:27 +0000
parents fa96108d552d
children ee01a4062747
comparison
equal deleted inserted replaced
976:f2c63ec85901 1045:f535f6e5dbb0
314 m_derivative = show; 314 m_derivative = show;
315 emit layerParametersChanged(); 315 emit layerParametersChanged();
316 } 316 }
317 317
318 bool 318 bool
319 TimeValueLayer::isLayerScrollable(const View *v) const 319 TimeValueLayer::isLayerScrollable(const LayerGeometryProvider *v) const
320 { 320 {
321 // We don't illuminate sections in the line or curve modes, so 321 // We don't illuminate sections in the line or curve modes, so
322 // they're always scrollable 322 // they're always scrollable
323 323
324 if (m_plotStyle == PlotLines || 324 if (m_plotStyle == PlotLines ||
528 528
529 return mapper; 529 return mapper;
530 } 530 }
531 531
532 SparseTimeValueModel::PointList 532 SparseTimeValueModel::PointList
533 TimeValueLayer::getLocalPoints(View *v, int x) const 533 TimeValueLayer::getLocalPoints(LayerGeometryProvider *v, int x) const
534 { 534 {
535 if (!m_model) return SparseTimeValueModel::PointList(); 535 if (!m_model) return SparseTimeValueModel::PointList();
536 536
537 sv_frame_t frame = v->getFrameForX(x); 537 sv_frame_t frame = v->getFrameForX(x);
538 538
585 } 585 }
586 return ""; 586 return "";
587 } 587 }
588 588
589 QString 589 QString
590 TimeValueLayer::getFeatureDescription(View *v, QPoint &pos) const 590 TimeValueLayer::getFeatureDescription(LayerGeometryProvider *v, QPoint &pos) const
591 { 591 {
592 int x = pos.x(); 592 int x = pos.x();
593 593
594 if (!m_model || !m_model->getSampleRate()) return ""; 594 if (!m_model || !m_model->getSampleRate()) return "";
595 595
639 getYForValue(v, points.begin()->value)); 639 getYForValue(v, points.begin()->value));
640 return text; 640 return text;
641 } 641 }
642 642
643 bool 643 bool
644 TimeValueLayer::snapToFeatureFrame(View *v, sv_frame_t &frame, 644 TimeValueLayer::snapToFeatureFrame(LayerGeometryProvider *v, sv_frame_t &frame,
645 int &resolution, 645 int &resolution,
646 SnapType snap) const 646 SnapType snap) const
647 { 647 {
648 if (!m_model) { 648 if (!m_model) {
649 return Layer::snapToFeatureFrame(v, frame, resolution, snap); 649 return Layer::snapToFeatureFrame(v, frame, resolution, snap);
711 frame = snapped; 711 frame = snapped;
712 return found; 712 return found;
713 } 713 }
714 714
715 bool 715 bool
716 TimeValueLayer::snapToSimilarFeature(View *v, sv_frame_t &frame, 716 TimeValueLayer::snapToSimilarFeature(LayerGeometryProvider *v, sv_frame_t &frame,
717 int &resolution, 717 int &resolution,
718 SnapType snap) const 718 SnapType snap) const
719 { 719 {
720 if (!m_model) { 720 if (!m_model) {
721 return Layer::snapToSimilarFeature(v, frame, resolution, snap); 721 return Layer::snapToSimilarFeature(v, frame, resolution, snap);
792 frame = snapped; 792 frame = snapped;
793 return found; 793 return found;
794 } 794 }
795 795
796 void 796 void
797 TimeValueLayer::getScaleExtents(View *v, double &min, double &max, bool &log) const 797 TimeValueLayer::getScaleExtents(LayerGeometryProvider *v, double &min, double &max, bool &log) const
798 { 798 {
799 min = 0.0; 799 min = 0.0;
800 max = 0.0; 800 max = 0.0;
801 log = false; 801 log = false;
802 802
828 cerr << "TimeValueLayer::getScaleExtents: min = " << min << ", max = " << max << endl; 828 cerr << "TimeValueLayer::getScaleExtents: min = " << min << ", max = " << max << endl;
829 #endif 829 #endif
830 } 830 }
831 831
832 int 832 int
833 TimeValueLayer::getYForValue(View *v, double val) const 833 TimeValueLayer::getYForValue(LayerGeometryProvider *v, double val) const
834 { 834 {
835 double min = 0.0, max = 0.0; 835 double min = 0.0, max = 0.0;
836 bool logarithmic = false; 836 bool logarithmic = false;
837 int h = v->height(); 837 int h = v->getPaintHeight();
838 838
839 getScaleExtents(v, min, max, logarithmic); 839 getScaleExtents(v, min, max, logarithmic);
840 840
841 #ifdef DEBUG_TIME_VALUE_LAYER 841 #ifdef DEBUG_TIME_VALUE_LAYER
842 cerr << "getYForValue(" << val << "): min " << min << ", max " 842 cerr << "getYForValue(" << val << "): min " << min << ", max "
849 849
850 return int(h - ((val - min) * h) / (max - min)); 850 return int(h - ((val - min) * h) / (max - min));
851 } 851 }
852 852
853 double 853 double
854 TimeValueLayer::getValueForY(View *v, int y) const 854 TimeValueLayer::getValueForY(LayerGeometryProvider *v, int y) const
855 { 855 {
856 double min = 0.0, max = 0.0; 856 double min = 0.0, max = 0.0;
857 bool logarithmic = false; 857 bool logarithmic = false;
858 int h = v->height(); 858 int h = v->getPaintHeight();
859 859
860 getScaleExtents(v, min, max, logarithmic); 860 getScaleExtents(v, min, max, logarithmic);
861 861
862 double val = min + (double(h - y) * double(max - min)) / h; 862 double val = min + (double(h - y) * double(max - min)) / h;
863 863
875 QString unit = getScaleUnits(); 875 QString unit = getScaleUnits();
876 return (m_verticalScale == AutoAlignScale && unit != ""); 876 return (m_verticalScale == AutoAlignScale && unit != "");
877 } 877 }
878 878
879 QColor 879 QColor
880 TimeValueLayer::getColourForValue(View *v, double val) const 880 TimeValueLayer::getColourForValue(LayerGeometryProvider *v, double val) const
881 { 881 {
882 double min, max; 882 double min, max;
883 bool log; 883 bool log;
884 getScaleExtents(v, min, max, log); 884 getScaleExtents(v, min, max, log);
885 885
906 return ColourDatabase::getInstance()->getColourIndex 906 return ColourDatabase::getInstance()->getColourIndex
907 (QString(darkbg ? "Bright Green" : "Green")); 907 (QString(darkbg ? "Bright Green" : "Green"));
908 } 908 }
909 909
910 void 910 void
911 TimeValueLayer::paint(View *v, QPainter &paint, QRect rect) const 911 TimeValueLayer::paint(LayerGeometryProvider *v, QPainter &paint, QRect rect) const
912 { 912 {
913 if (!m_model || !m_model->isOK()) return; 913 if (!m_model || !m_model->isOK()) return;
914 914
915 sv_samplerate_t sampleRate = m_model->getSampleRate(); 915 sv_samplerate_t sampleRate = m_model->getSampleRate();
916 if (!sampleRate) return; 916 if (!sampleRate) return;
941 941
942 double min = m_model->getValueMinimum(); 942 double min = m_model->getValueMinimum();
943 double max = m_model->getValueMaximum(); 943 double max = m_model->getValueMaximum();
944 if (max == min) max = min + 1.0; 944 if (max == min) max = min + 1.0;
945 945
946 int origin = int(nearbyint(v->height() - 946 int origin = int(nearbyint(v->getPaintHeight() -
947 (-min * v->height()) / (max - min))); 947 (-min * v->getPaintHeight()) / (max - min)));
948 948
949 QPoint localPos; 949 QPoint localPos;
950 sv_frame_t illuminateFrame = -1; 950 sv_frame_t illuminateFrame = -1;
951 951
952 if (v->shouldIlluminateLocalFeatures(this, localPos)) { 952 if (v->shouldIlluminateLocalFeatures(this, localPos)) {
976 int textY = 0; 976 int textY = 0;
977 if (m_plotStyle == PlotSegmentation) { 977 if (m_plotStyle == PlotSegmentation) {
978 textY = v->getTextLabelHeight(this, paint); 978 textY = v->getTextLabelHeight(this, paint);
979 } else { 979 } else {
980 int originY = getYForValue(v, 0.f); 980 int originY = getYForValue(v, 0.f);
981 if (originY > 0 && originY < v->height()) { 981 if (originY > 0 && originY < v->getPaintHeight()) {
982 paint.save(); 982 paint.save();
983 paint.setPen(getPartialShades(v)[1]); 983 paint.setPen(getPartialShades(v)[1]);
984 paint.drawLine(x0, originY, x1, originY); 984 paint.drawLine(x0, originY, x1, originY);
985 paint.restore(); 985 paint.restore();
986 } 986 }
1181 paint.setPen(QPen(getForegroundQColor(v), 2)); 1181 paint.setPen(QPen(getForegroundQColor(v), 2));
1182 1182
1183 if (!illuminate) { 1183 if (!illuminate) {
1184 if (!m_drawSegmentDivisions || 1184 if (!m_drawSegmentDivisions ||
1185 nx < x + 5 || 1185 nx < x + 5 ||
1186 x >= v->width() - 1) { 1186 x >= v->getPaintWidth() - 1) {
1187 paint.setPen(Qt::NoPen); 1187 paint.setPen(Qt::NoPen);
1188 } 1188 }
1189 } 1189 }
1190 1190
1191 paint.drawRect(x, -1, nx - x, v->height() + 1); 1191 paint.drawRect(x, -1, nx - x, v->getPaintHeight() + 1);
1192 } 1192 }
1193 1193
1194 if (v->shouldShowFeatureLabels()) { 1194 if (v->shouldShowFeatureLabels()) {
1195 1195
1196 QString label = p.label; 1196 QString label = p.label;
1229 if (m_plotStyle == PlotDiscreteCurves) { 1229 if (m_plotStyle == PlotDiscreteCurves) {
1230 paint.setRenderHint(QPainter::Antialiasing, true); 1230 paint.setRenderHint(QPainter::Antialiasing, true);
1231 paint.drawPath(path); 1231 paint.drawPath(path);
1232 } else if ((m_plotStyle == PlotCurve || m_plotStyle == PlotLines) 1232 } else if ((m_plotStyle == PlotCurve || m_plotStyle == PlotLines)
1233 && !path.isEmpty()) { 1233 && !path.isEmpty()) {
1234 paint.setRenderHint(QPainter::Antialiasing, pointCount <= v->width()); 1234 paint.setRenderHint(QPainter::Antialiasing, pointCount <= v->getPaintWidth());
1235 paint.drawPath(path); 1235 paint.drawPath(path);
1236 } 1236 }
1237 1237
1238 paint.restore(); 1238 paint.restore();
1239 1239
1240 // looks like save/restore doesn't deal with this: 1240 // looks like save/restore doesn't deal with this:
1241 paint.setRenderHint(QPainter::Antialiasing, false); 1241 paint.setRenderHint(QPainter::Antialiasing, false);
1242 } 1242 }
1243 1243
1244 int 1244 int
1245 TimeValueLayer::getVerticalScaleWidth(View *v, bool, QPainter &paint) const 1245 TimeValueLayer::getVerticalScaleWidth(LayerGeometryProvider *v, bool, QPainter &paint) const
1246 { 1246 {
1247 if (!m_model || shouldAutoAlign()) { 1247 if (!m_model || shouldAutoAlign()) {
1248 return 0; 1248 return 0;
1249 } else if (m_plotStyle == PlotSegmentation) { 1249 } else if (m_plotStyle == PlotSegmentation) {
1250 if (m_verticalScale == LogScale) { 1250 if (m_verticalScale == LogScale) {
1260 } 1260 }
1261 } 1261 }
1262 } 1262 }
1263 1263
1264 void 1264 void
1265 TimeValueLayer::paintVerticalScale(View *v, bool, QPainter &paint, QRect) const 1265 TimeValueLayer::paintVerticalScale(LayerGeometryProvider *v, bool, QPainter &paint, QRect) const
1266 { 1266 {
1267 if (!m_model || m_model->getPoints().empty()) return; 1267 if (!m_model || m_model->getPoints().empty()) return;
1268 1268
1269 QString unit; 1269 QString unit;
1270 double min, max; 1270 double min, max;
1271 bool logarithmic; 1271 bool logarithmic;
1272 1272
1273 int w = getVerticalScaleWidth(v, false, paint); 1273 int w = getVerticalScaleWidth(v, false, paint);
1274 int h = v->height(); 1274 int h = v->getPaintHeight();
1275 1275
1276 if (m_plotStyle == PlotSegmentation) { 1276 if (m_plotStyle == PlotSegmentation) {
1277 1277
1278 getValueExtents(min, max, logarithmic, unit); 1278 getValueExtents(min, max, logarithmic, unit);
1279 1279
1312 mw)); 1312 mw));
1313 } 1313 }
1314 } 1314 }
1315 1315
1316 void 1316 void
1317 TimeValueLayer::drawStart(View *v, QMouseEvent *e) 1317 TimeValueLayer::drawStart(LayerGeometryProvider *v, QMouseEvent *e)
1318 { 1318 {
1319 #ifdef DEBUG_TIME_VALUE_LAYER 1319 #ifdef DEBUG_TIME_VALUE_LAYER
1320 cerr << "TimeValueLayer::drawStart(" << e->x() << "," << e->y() << ")" << endl; 1320 cerr << "TimeValueLayer::drawStart(" << e->x() << "," << e->y() << ")" << endl;
1321 #endif 1321 #endif
1322 1322
1362 1362
1363 m_editing = true; 1363 m_editing = true;
1364 } 1364 }
1365 1365
1366 void 1366 void
1367 TimeValueLayer::drawDrag(View *v, QMouseEvent *e) 1367 TimeValueLayer::drawDrag(LayerGeometryProvider *v, QMouseEvent *e)
1368 { 1368 {
1369 #ifdef DEBUG_TIME_VALUE_LAYER 1369 #ifdef DEBUG_TIME_VALUE_LAYER
1370 cerr << "TimeValueLayer::drawDrag(" << e->x() << "," << e->y() << ")" << endl; 1370 cerr << "TimeValueLayer::drawDrag(" << e->x() << "," << e->y() << ")" << endl;
1371 #endif 1371 #endif
1372 1372
1424 m_editingPoint.value = float(value); 1424 m_editingPoint.value = float(value);
1425 m_editingCommand->addPoint(m_editingPoint); 1425 m_editingCommand->addPoint(m_editingPoint);
1426 } 1426 }
1427 1427
1428 void 1428 void
1429 TimeValueLayer::drawEnd(View *, QMouseEvent *) 1429 TimeValueLayer::drawEnd(LayerGeometryProvider *, QMouseEvent *)
1430 { 1430 {
1431 #ifdef DEBUG_TIME_VALUE_LAYER 1431 #ifdef DEBUG_TIME_VALUE_LAYER
1432 cerr << "TimeValueLayer::drawEnd" << endl; 1432 cerr << "TimeValueLayer::drawEnd" << endl;
1433 #endif 1433 #endif
1434 if (!m_model || !m_editing) return; 1434 if (!m_model || !m_editing) return;
1436 m_editingCommand = 0; 1436 m_editingCommand = 0;
1437 m_editing = false; 1437 m_editing = false;
1438 } 1438 }
1439 1439
1440 void 1440 void
1441 TimeValueLayer::eraseStart(View *v, QMouseEvent *e) 1441 TimeValueLayer::eraseStart(LayerGeometryProvider *v, QMouseEvent *e)
1442 { 1442 {
1443 if (!m_model) return; 1443 if (!m_model) return;
1444 1444
1445 SparseTimeValueModel::PointList points = getLocalPoints(v, e->x()); 1445 SparseTimeValueModel::PointList points = getLocalPoints(v, e->x());
1446 if (points.empty()) return; 1446 if (points.empty()) return;
1454 1454
1455 m_editing = true; 1455 m_editing = true;
1456 } 1456 }
1457 1457
1458 void 1458 void
1459 TimeValueLayer::eraseDrag(View *, QMouseEvent *) 1459 TimeValueLayer::eraseDrag(LayerGeometryProvider *, QMouseEvent *)
1460 { 1460 {
1461 } 1461 }
1462 1462
1463 void 1463 void
1464 TimeValueLayer::eraseEnd(View *v, QMouseEvent *e) 1464 TimeValueLayer::eraseEnd(LayerGeometryProvider *v, QMouseEvent *e)
1465 { 1465 {
1466 if (!m_model || !m_editing) return; 1466 if (!m_model || !m_editing) return;
1467 1467
1468 m_editing = false; 1468 m_editing = false;
1469 1469
1481 m_editingCommand = 0; 1481 m_editingCommand = 0;
1482 m_editing = false; 1482 m_editing = false;
1483 } 1483 }
1484 1484
1485 void 1485 void
1486 TimeValueLayer::editStart(View *v, QMouseEvent *e) 1486 TimeValueLayer::editStart(LayerGeometryProvider *v, QMouseEvent *e)
1487 { 1487 {
1488 #ifdef DEBUG_TIME_VALUE_LAYER 1488 #ifdef DEBUG_TIME_VALUE_LAYER
1489 cerr << "TimeValueLayer::editStart(" << e->x() << "," << e->y() << ")" << endl; 1489 cerr << "TimeValueLayer::editStart(" << e->x() << "," << e->y() << ")" << endl;
1490 #endif 1490 #endif
1491 1491
1504 1504
1505 m_editing = true; 1505 m_editing = true;
1506 } 1506 }
1507 1507
1508 void 1508 void
1509 TimeValueLayer::editDrag(View *v, QMouseEvent *e) 1509 TimeValueLayer::editDrag(LayerGeometryProvider *v, QMouseEvent *e)
1510 { 1510 {
1511 #ifdef DEBUG_TIME_VALUE_LAYER 1511 #ifdef DEBUG_TIME_VALUE_LAYER
1512 cerr << "TimeValueLayer::editDrag(" << e->x() << "," << e->y() << ")" << endl; 1512 cerr << "TimeValueLayer::editDrag(" << e->x() << "," << e->y() << ")" << endl;
1513 #endif 1513 #endif
1514 1514
1530 m_editingPoint.value = float(value); 1530 m_editingPoint.value = float(value);
1531 m_editingCommand->addPoint(m_editingPoint); 1531 m_editingCommand->addPoint(m_editingPoint);
1532 } 1532 }
1533 1533
1534 void 1534 void
1535 TimeValueLayer::editEnd(View *, QMouseEvent *) 1535 TimeValueLayer::editEnd(LayerGeometryProvider *, QMouseEvent *)
1536 { 1536 {
1537 #ifdef DEBUG_TIME_VALUE_LAYER 1537 #ifdef DEBUG_TIME_VALUE_LAYER
1538 cerr << "TimeValueLayer::editEnd" << endl; 1538 cerr << "TimeValueLayer::editEnd" << endl;
1539 #endif 1539 #endif
1540 if (!m_model || !m_editing) return; 1540 if (!m_model || !m_editing) return;
1560 m_editingCommand = 0; 1560 m_editingCommand = 0;
1561 m_editing = false; 1561 m_editing = false;
1562 } 1562 }
1563 1563
1564 bool 1564 bool
1565 TimeValueLayer::editOpen(View *v, QMouseEvent *e) 1565 TimeValueLayer::editOpen(LayerGeometryProvider *v, QMouseEvent *e)
1566 { 1566 {
1567 if (!m_model) return false; 1567 if (!m_model) return false;
1568 1568
1569 SparseTimeValueModel::PointList points = getLocalPoints(v, e->x()); 1569 SparseTimeValueModel::PointList points = getLocalPoints(v, e->x());
1570 if (points.empty()) return false; 1570 if (points.empty()) return false;
1683 1683
1684 finish(command); 1684 finish(command);
1685 } 1685 }
1686 1686
1687 void 1687 void
1688 TimeValueLayer::copy(View *v, Selection s, Clipboard &to) 1688 TimeValueLayer::copy(LayerGeometryProvider *v, Selection s, Clipboard &to)
1689 { 1689 {
1690 if (!m_model) return; 1690 if (!m_model) return;
1691 1691
1692 SparseTimeValueModel::PointList points = 1692 SparseTimeValueModel::PointList points =
1693 m_model->getPoints(s.getStartFrame(), s.getEndFrame()); 1693 m_model->getPoints(s.getStartFrame(), s.getEndFrame());
1701 } 1701 }
1702 } 1702 }
1703 } 1703 }
1704 1704
1705 bool 1705 bool
1706 TimeValueLayer::paste(View *v, const Clipboard &from, sv_frame_t /* frameOffset */, 1706 TimeValueLayer::paste(LayerGeometryProvider *v, const Clipboard &from, sv_frame_t /* frameOffset */,
1707 bool interactive) 1707 bool interactive)
1708 { 1708 {
1709 if (!m_model) return false; 1709 if (!m_model) return false;
1710 1710
1711 const Clipboard::PointList &points = from.getPoints(); 1711 const Clipboard::PointList &points = from.getPoints();
1713 bool realign = false; 1713 bool realign = false;
1714 1714
1715 if (clipboardHasDifferentAlignment(v, from)) { 1715 if (clipboardHasDifferentAlignment(v, from)) {
1716 1716
1717 QMessageBox::StandardButton button = 1717 QMessageBox::StandardButton button =
1718 QMessageBox::question(v, tr("Re-align pasted items?"), 1718 QMessageBox::question(v->getView(), tr("Re-align pasted items?"),
1719 tr("The items you are pasting came from a layer with different source material from this one. Do you want to re-align them in time, to match the source material for this layer?"), 1719 tr("The items you are pasting came from a layer with different source material from this one. Do you want to re-align them in time, to match the source material for this layer?"),
1720 QMessageBox::Yes | QMessageBox::No | QMessageBox::Cancel, 1720 QMessageBox::Yes | QMessageBox::No | QMessageBox::Cancel,
1721 QMessageBox::Yes); 1721 QMessageBox::Yes);
1722 1722
1723 if (button == QMessageBox::Cancel) { 1723 if (button == QMessageBox::Cancel) {