Mercurial > hg > svgui
comparison layer/RegionLayer.cpp @ 1409:24234307c9b2
Fix erasing of Region layer labels as the playhead moves over them
author | Chris Cannam |
---|---|
date | Thu, 29 Nov 2018 11:57:30 +0000 |
parents | c39f2d439d59 |
children | d057dcc827e7 89d124ac9bfa |
comparison
equal
deleted
inserted
replaced
1404:a33d38247631 | 1409:24234307c9b2 |
---|---|
879 | 879 |
880 int x0 = rect.left() - 40, x1 = rect.right(); | 880 int x0 = rect.left() - 40, x1 = rect.right(); |
881 sv_frame_t frame0 = v->getFrameForX(x0); | 881 sv_frame_t frame0 = v->getFrameForX(x0); |
882 sv_frame_t frame1 = v->getFrameForX(x1); | 882 sv_frame_t frame1 = v->getFrameForX(x1); |
883 | 883 |
884 RegionModel::PointList points(m_model->getPoints(frame0, frame1)); | 884 sv_frame_t wholeFrame0 = v->getFrameForX(0); |
885 sv_frame_t wholeFrame1 = v->getFrameForX(v->getPaintWidth()); | |
886 | |
887 RegionModel::PointList points(m_model->getPoints(wholeFrame0, wholeFrame1)); | |
885 if (points.empty()) return; | 888 if (points.empty()) return; |
886 | 889 |
887 paint.setPen(getBaseQColor()); | 890 paint.setPen(getBaseQColor()); |
888 | 891 |
889 QColor brushColour(getBaseQColor()); | 892 QColor brushColour(getBaseQColor()); |
920 i != points.end(); ++i) { | 923 i != points.end(); ++i) { |
921 | 924 |
922 const RegionModel::Point &p(*i); | 925 const RegionModel::Point &p(*i); |
923 | 926 |
924 int x = v->getXForFrame(p.frame); | 927 int x = v->getXForFrame(p.frame); |
928 int w = v->getXForFrame(p.frame + p.duration) - x; | |
925 int y = getYForValue(v, p.value); | 929 int y = getYForValue(v, p.value); |
926 int w = v->getXForFrame(p.frame + p.duration) - x; | |
927 int h = 9; | 930 int h = 9; |
928 int ex = x + w; | 931 int ex = x + w; |
929 | 932 |
933 int gap = v->scalePixelSize(2); | |
934 | |
930 RegionModel::PointList::const_iterator j = i; | 935 RegionModel::PointList::const_iterator j = i; |
931 ++j; | 936 ++j; |
932 | 937 |
933 if (j != points.end()) { | 938 if (j != points.end()) { |
934 const RegionModel::Point &q(*j); | 939 const RegionModel::Point &q(*j); |
966 | 971 |
967 } else { | 972 } else { |
968 paint.setPen(QPen(getForegroundQColor(v->getView()), 2)); | 973 paint.setPen(QPen(getForegroundQColor(v->getView()), 2)); |
969 } | 974 } |
970 | 975 |
971 paint.drawRect(x, -1, ex - x, v->getPaintHeight() + 2); | 976 paint.drawRect(x, -1, ex - x, v->getPaintHeight() + gap); |
972 | 977 |
973 } else { | 978 } else { |
974 | 979 |
975 if (shouldIlluminate && | 980 if (shouldIlluminate && |
976 // "illuminatePoint == p" | 981 // "illuminatePoint == p" |
980 paint.setPen(v->getForeground()); | 985 paint.setPen(v->getForeground()); |
981 paint.setBrush(v->getForeground()); | 986 paint.setBrush(v->getForeground()); |
982 | 987 |
983 QString vlabel = QString("%1%2").arg(p.value).arg(getScaleUnits()); | 988 QString vlabel = QString("%1%2").arg(p.value).arg(getScaleUnits()); |
984 PaintAssistant::drawVisibleText(v, paint, | 989 PaintAssistant::drawVisibleText(v, paint, |
985 x - paint.fontMetrics().width(vlabel) - 2, | 990 x - paint.fontMetrics().width(vlabel) - gap, |
986 y + paint.fontMetrics().height()/2 | 991 y + paint.fontMetrics().height()/2 |
987 - paint.fontMetrics().descent(), | 992 - paint.fontMetrics().descent(), |
988 vlabel, PaintAssistant::OutlinedText); | 993 vlabel, PaintAssistant::OutlinedText); |
989 | 994 |
990 QString hlabel = RealTime::frame2RealTime | 995 QString hlabel = RealTime::frame2RealTime |
991 (p.frame, m_model->getSampleRate()).toText(true).c_str(); | 996 (p.frame, m_model->getSampleRate()).toText(true).c_str(); |
992 PaintAssistant::drawVisibleText(v, paint, | 997 PaintAssistant::drawVisibleText(v, paint, |
993 x, | 998 x, |
994 y - h/2 - paint.fontMetrics().descent() - 2, | 999 y - h/2 - paint.fontMetrics().descent() - gap, |
995 hlabel, PaintAssistant::OutlinedText); | 1000 hlabel, PaintAssistant::OutlinedText); |
996 } | 1001 } |
997 | 1002 |
998 paint.drawLine(x, y-1, x + w, y-1); | 1003 paint.drawLine(x, y-1, x + w, y-1); |
999 paint.drawLine(x, y+1, x + w, y+1); | 1004 paint.drawLine(x, y+1, x + w, y+1); |
1009 i != points.end(); ++i) { | 1014 i != points.end(); ++i) { |
1010 | 1015 |
1011 const RegionModel::Point &p(*i); | 1016 const RegionModel::Point &p(*i); |
1012 | 1017 |
1013 int x = v->getXForFrame(p.frame); | 1018 int x = v->getXForFrame(p.frame); |
1019 int w = v->getXForFrame(p.frame + p.duration) - x; | |
1014 int y = getYForValue(v, p.value); | 1020 int y = getYForValue(v, p.value); |
1015 | 1021 |
1022 QString label = p.label; | |
1023 if (label == "") { | |
1024 label = QString("%1%2").arg(p.value).arg(getScaleUnits()); | |
1025 } | |
1026 int labelWidth = paint.fontMetrics().width(label); | |
1027 | |
1028 int gap = v->scalePixelSize(2); | |
1029 | |
1030 if (m_plotStyle == PlotSegmentation) { | |
1031 if ((x + w < x0 && x + labelWidth + gap < x0) || x > x1) { | |
1032 continue; | |
1033 } | |
1034 } else { | |
1035 if (x + w < x0 || x - labelWidth - gap > x1) { | |
1036 continue; | |
1037 } | |
1038 } | |
1039 | |
1016 bool illuminated = false; | 1040 bool illuminated = false; |
1017 | 1041 |
1018 if (m_plotStyle != PlotSegmentation) { | 1042 if (m_plotStyle != PlotSegmentation) { |
1019 | 1043 |
1020 if (shouldIlluminate && | 1044 if (shouldIlluminate && |
1025 illuminated = true; | 1049 illuminated = true; |
1026 } | 1050 } |
1027 } | 1051 } |
1028 | 1052 |
1029 if (!illuminated) { | 1053 if (!illuminated) { |
1030 QString label = p.label; | |
1031 if (label == "") { | |
1032 label = QString("%1%2").arg(p.value).arg(getScaleUnits()); | |
1033 } | |
1034 | 1054 |
1035 int labelX, labelY; | 1055 int labelX, labelY; |
1036 | 1056 |
1037 if (m_plotStyle != PlotSegmentation) { | 1057 if (m_plotStyle != PlotSegmentation) { |
1038 labelX = x - paint.fontMetrics().width(label) - 2; | 1058 labelX = x - labelWidth - gap; |
1039 labelY = y + paint.fontMetrics().height()/2 | 1059 labelY = y + paint.fontMetrics().height()/2 |
1040 - paint.fontMetrics().descent(); | 1060 - paint.fontMetrics().descent(); |
1041 } else { | 1061 } else { |
1042 labelX = x + 5; | 1062 labelX = x + 5; |
1043 labelY = v->getTextLabelHeight(this, paint); | 1063 labelY = v->getTextLabelHeight(this, paint); |
1045 if (lastLabelY < v->getPaintHeight()/2) { | 1065 if (lastLabelY < v->getPaintHeight()/2) { |
1046 labelY = lastLabelY + fontHeight; | 1066 labelY = lastLabelY + fontHeight; |
1047 } | 1067 } |
1048 } | 1068 } |
1049 lastLabelY = labelY; | 1069 lastLabelY = labelY; |
1050 nextLabelMinX = labelX + paint.fontMetrics().width(label); | 1070 nextLabelMinX = labelX + labelWidth; |
1051 } | 1071 } |
1052 | 1072 |
1053 PaintAssistant::drawVisibleText(v, paint, labelX, labelY, label, PaintAssistant::OutlinedText); | 1073 PaintAssistant::drawVisibleText(v, paint, labelX, labelY, label, |
1074 PaintAssistant::OutlinedText); | |
1054 } | 1075 } |
1055 } | 1076 } |
1056 | 1077 |
1057 paint.restore(); | 1078 paint.restore(); |
1058 } | 1079 } |