Mercurial > hg > svgui
comparison layer/RegionLayer.cpp @ 1324:13d9b422f7fe zoom
Merge from default branch
author | Chris Cannam |
---|---|
date | Mon, 17 Sep 2018 13:51:31 +0100 |
parents | a34a2a25907c |
children | d79e21855aef |
comparison
equal
deleted
inserted
replaced
1183:57d192e26331 | 1324:13d9b422f7fe |
---|---|
136 if (deflt) *deflt = 0; | 136 if (deflt) *deflt = 0; |
137 | 137 |
138 val = m_colourMap; | 138 val = m_colourMap; |
139 | 139 |
140 } else if (name == "Plot Type") { | 140 } else if (name == "Plot Type") { |
141 | 141 |
142 if (min) *min = 0; | 142 if (min) *min = 0; |
143 if (max) *max = 1; | 143 if (max) *max = 1; |
144 if (deflt) *deflt = 0; | 144 if (deflt) *deflt = 0; |
145 | 145 |
146 val = int(m_plotStyle); | 146 val = int(m_plotStyle); |
147 | 147 |
148 } else if (name == "Vertical Scale") { | 148 } else if (name == "Vertical Scale") { |
149 | 149 |
150 if (min) *min = 0; | 150 if (min) *min = 0; |
151 if (max) *max = 3; | 151 if (max) *max = 3; |
152 if (deflt) *deflt = int(EqualSpaced); | 152 if (deflt) *deflt = int(EqualSpaced); |
153 | 153 |
154 val = int(m_verticalScale); | 154 val = int(m_verticalScale); |
155 | 155 |
156 } else if (name == "Scale Units") { | 156 } else if (name == "Scale Units") { |
157 | 157 |
158 if (deflt) *deflt = 0; | 158 if (deflt) *deflt = 0; |
159 if (m_model) { | 159 if (m_model) { |
161 (getScaleUnits()); | 161 (getScaleUnits()); |
162 } | 162 } |
163 | 163 |
164 } else { | 164 } else { |
165 | 165 |
166 val = SingleColourLayer::getPropertyRangeAndValue(name, min, max, deflt); | 166 val = SingleColourLayer::getPropertyRangeAndValue(name, min, max, deflt); |
167 } | 167 } |
168 | 168 |
169 return val; | 169 return val; |
170 } | 170 } |
171 | 171 |
175 { | 175 { |
176 if (name == "Colour" && m_plotStyle == PlotSegmentation) { | 176 if (name == "Colour" && m_plotStyle == PlotSegmentation) { |
177 return ColourMapper::getColourMapName(value); | 177 return ColourMapper::getColourMapName(value); |
178 } else if (name == "Plot Type") { | 178 } else if (name == "Plot Type") { |
179 | 179 |
180 switch (value) { | 180 switch (value) { |
181 default: | 181 default: |
182 case 0: return tr("Bars"); | 182 case 0: return tr("Bars"); |
183 case 1: return tr("Segmentation"); | 183 case 1: return tr("Segmentation"); |
184 } | 184 } |
185 | 185 |
186 } else if (name == "Vertical Scale") { | 186 } else if (name == "Vertical Scale") { |
187 switch (value) { | 187 switch (value) { |
188 default: | 188 default: |
189 case 0: return tr("Auto-Align"); | 189 case 0: return tr("Auto-Align"); |
190 case 1: return tr("Equal Spaced"); | 190 case 1: return tr("Equal Spaced"); |
191 case 2: return tr("Linear"); | 191 case 2: return tr("Linear"); |
192 case 3: return tr("Log"); | 192 case 3: return tr("Log"); |
193 } | 193 } |
194 } | 194 } |
195 return SingleColourLayer::getPropertyValueLabel(name, value); | 195 return SingleColourLayer::getPropertyValueLabel(name, value); |
196 } | 196 } |
197 | 197 |
198 void | 198 void |
199 RegionLayer::setProperty(const PropertyName &name, int value) | 199 RegionLayer::setProperty(const PropertyName &name, int value) |
200 { | 200 { |
201 if (name == "Colour" && m_plotStyle == PlotSegmentation) { | 201 if (name == "Colour" && m_plotStyle == PlotSegmentation) { |
202 setFillColourMap(value); | 202 setFillColourMap(value); |
203 } else if (name == "Plot Type") { | 203 } else if (name == "Plot Type") { |
204 setPlotStyle(PlotStyle(value)); | 204 setPlotStyle(PlotStyle(value)); |
205 } else if (name == "Vertical Scale") { | 205 } else if (name == "Vertical Scale") { |
206 setVerticalScale(VerticalScale(value)); | 206 setVerticalScale(VerticalScale(value)); |
207 } else if (name == "Scale Units") { | 207 } else if (name == "Scale Units") { |
208 if (m_model) { | 208 if (m_model) { |
209 m_model->setScaleUnits | 209 m_model->setScaleUnits |
210 (UnitDatabase::getInstance()->getUnitById(value)); | 210 (UnitDatabase::getInstance()->getUnitById(value)); |
211 emit modelChanged(); | 211 emit modelChanged(); |
308 if (!m_model) return RegionModel::PointList(); | 308 if (!m_model) return RegionModel::PointList(); |
309 | 309 |
310 sv_frame_t frame = v->getFrameForX(x); | 310 sv_frame_t frame = v->getFrameForX(x); |
311 | 311 |
312 RegionModel::PointList onPoints = | 312 RegionModel::PointList onPoints = |
313 m_model->getPoints(frame); | 313 m_model->getPoints(frame); |
314 | 314 |
315 if (!onPoints.empty()) { | 315 if (!onPoints.empty()) { |
316 return onPoints; | 316 return onPoints; |
317 } | 317 } |
318 | 318 |
319 RegionModel::PointList prevPoints = | 319 RegionModel::PointList prevPoints = |
320 m_model->getPreviousPoints(frame); | 320 m_model->getPreviousPoints(frame); |
321 RegionModel::PointList nextPoints = | 321 RegionModel::PointList nextPoints = |
322 m_model->getNextPoints(frame); | 322 m_model->getNextPoints(frame); |
323 | 323 |
324 RegionModel::PointList usePoints = prevPoints; | 324 RegionModel::PointList usePoints = prevPoints; |
325 | 325 |
326 if (prevPoints.empty()) { | 326 if (prevPoints.empty()) { |
327 usePoints = nextPoints; | 327 usePoints = nextPoints; |
328 } else if (long(prevPoints.begin()->frame) < v->getStartFrame() && | 328 } else if (long(prevPoints.begin()->frame) < v->getStartFrame() && |
329 !(nextPoints.begin()->frame > v->getEndFrame())) { | 329 !(nextPoints.begin()->frame > v->getEndFrame())) { |
330 usePoints = nextPoints; | 330 usePoints = nextPoints; |
331 } else if (long(nextPoints.begin()->frame) - frame < | 331 } else if (long(nextPoints.begin()->frame) - frame < |
332 frame - long(prevPoints.begin()->frame)) { | 332 frame - long(prevPoints.begin()->frame)) { |
333 usePoints = nextPoints; | 333 usePoints = nextPoints; |
334 } | 334 } |
335 | 335 |
336 if (!usePoints.empty()) { | 336 if (!usePoints.empty()) { |
337 int fuzz = 2; | 337 int fuzz = 2; |
338 int px = v->getXForFrame(usePoints.begin()->frame); | 338 int px = v->getXForFrame(usePoints.begin()->frame); |
339 if ((px > x && px - x > fuzz) || | 339 if ((px > x && px - x > fuzz) || |
340 (px < x && x - px > fuzz + 1)) { | 340 (px < x && x - px > fuzz + 1)) { |
341 usePoints.clear(); | 341 usePoints.clear(); |
342 } | 342 } |
343 } | 343 } |
344 | 344 |
345 return usePoints; | 345 return usePoints; |
346 } | 346 } |
347 | 347 |
391 if (!m_model || !m_model->getSampleRate()) return ""; | 391 if (!m_model || !m_model->getSampleRate()) return ""; |
392 | 392 |
393 RegionModel::PointList points = getLocalPoints(v, x); | 393 RegionModel::PointList points = getLocalPoints(v, x); |
394 | 394 |
395 if (points.empty()) { | 395 if (points.empty()) { |
396 if (!m_model->isReady()) { | 396 if (!m_model->isReady()) { |
397 return tr("In progress"); | 397 return tr("In progress"); |
398 } else { | 398 } else { |
399 return tr("No local points"); | 399 return tr("No local points"); |
400 } | 400 } |
401 } | 401 } |
402 | 402 |
403 RegionRec region(0); | 403 RegionRec region(0); |
404 RegionModel::PointList::iterator i; | 404 RegionModel::PointList::iterator i; |
405 | 405 |
406 //!!! harmonise with whatever decision is made about point y | 406 //!!! harmonise with whatever decision is made about point y |
407 //!!! coords in paint method | 407 //!!! coords in paint method |
408 | 408 |
409 for (i = points.begin(); i != points.end(); ++i) { | 409 for (i = points.begin(); i != points.end(); ++i) { |
410 | 410 |
411 int y = getYForValue(v, i->value); | 411 int y = getYForValue(v, i->value); |
412 int h = 3; | 412 int h = 3; |
413 | 413 |
414 if (m_model->getValueQuantization() != 0.0) { | 414 if (m_model->getValueQuantization() != 0.0) { |
415 h = y - getYForValue(v, i->value + m_model->getValueQuantization()); | 415 h = y - getYForValue(v, i->value + m_model->getValueQuantization()); |
416 if (h < 3) h = 3; | 416 if (h < 3) h = 3; |
417 } | 417 } |
418 | 418 |
419 if (pos.y() >= y - h && pos.y() <= y) { | 419 if (pos.y() >= y - h && pos.y() <= y) { |
420 region = *i; | 420 region = *i; |
421 break; | 421 break; |
422 } | 422 } |
423 } | 423 } |
424 | 424 |
425 if (i == points.end()) return tr("No local points"); | 425 if (i == points.end()) return tr("No local points"); |
426 | 426 |
427 RealTime rt = RealTime::frame2RealTime(region.frame, | 427 RealTime rt = RealTime::frame2RealTime(region.frame, |
428 m_model->getSampleRate()); | 428 m_model->getSampleRate()); |
429 RealTime rd = RealTime::frame2RealTime(region.duration, | 429 RealTime rd = RealTime::frame2RealTime(region.duration, |
430 m_model->getSampleRate()); | 430 m_model->getSampleRate()); |
431 | 431 |
432 QString valueText; | 432 QString valueText; |
433 | 433 |
434 valueText = tr("%1 %2").arg(region.value).arg(getScaleUnits()); | 434 valueText = tr("%1 %2").arg(region.value).arg(getScaleUnits()); |
435 | 435 |
436 QString text; | 436 QString text; |
437 | 437 |
438 if (region.label == "") { | 438 if (region.label == "") { |
439 text = QString(tr("Time:\t%1\nValue:\t%2\nDuration:\t%3\nNo label")) | 439 text = QString(tr("Time:\t%1\nValue:\t%2\nDuration:\t%3\nNo label")) |
440 .arg(rt.toText(true).c_str()) | 440 .arg(rt.toText(true).c_str()) |
441 .arg(valueText) | 441 .arg(valueText) |
442 .arg(rd.toText(true).c_str()); | 442 .arg(rd.toText(true).c_str()); |
443 } else { | 443 } else { |
444 text = QString(tr("Time:\t%1\nValue:\t%2\nDuration:\t%3\nLabel:\t%4")) | 444 text = QString(tr("Time:\t%1\nValue:\t%2\nDuration:\t%3\nLabel:\t%4")) |
445 .arg(rt.toText(true).c_str()) | 445 .arg(rt.toText(true).c_str()) |
446 .arg(valueText) | 446 .arg(valueText) |
447 .arg(rd.toText(true).c_str()) | 447 .arg(rd.toText(true).c_str()) |
448 .arg(region.label); | 448 .arg(region.label); |
449 } | 449 } |
450 | 450 |
451 pos = QPoint(v->getXForFrame(region.frame), | 451 pos = QPoint(v->getXForFrame(region.frame), |
452 getYForValue(v, region.value)); | 452 getYForValue(v, region.value)); |
453 return text; | 453 return text; |
454 } | 454 } |
455 | 455 |
456 bool | 456 bool |
457 RegionLayer::snapToFeatureFrame(LayerGeometryProvider *v, sv_frame_t &frame, | 457 RegionLayer::snapToFeatureFrame(LayerGeometryProvider *v, sv_frame_t &frame, |
458 int &resolution, | 458 int &resolution, |
459 SnapType snap) const | 459 SnapType snap) const |
460 { | 460 { |
461 if (!m_model) { | 461 if (!m_model) { |
462 return Layer::snapToFeatureFrame(v, frame, resolution, snap); | 462 return Layer::snapToFeatureFrame(v, frame, resolution, snap); |
463 } | 463 } |
464 | 464 |
465 resolution = m_model->getResolution(); | 465 resolution = m_model->getResolution(); |
466 RegionModel::PointList points; | 466 RegionModel::PointList points; |
467 | 467 |
468 if (snap == SnapNeighbouring) { | 468 if (snap == SnapNeighbouring) { |
469 | 469 |
470 points = getLocalPoints(v, v->getXForFrame(frame)); | 470 points = getLocalPoints(v, v->getXForFrame(frame)); |
471 if (points.empty()) return false; | 471 if (points.empty()) return false; |
472 frame = points.begin()->frame; | 472 frame = points.begin()->frame; |
473 return true; | 473 return true; |
474 } | 474 } |
475 | 475 |
476 points = m_model->getPoints(frame, frame); | 476 points = m_model->getPoints(frame, frame); |
477 sv_frame_t snapped = frame; | 477 sv_frame_t snapped = frame; |
478 bool found = false; | 478 bool found = false; |
479 | 479 |
480 for (RegionModel::PointList::const_iterator i = points.begin(); | 480 for (RegionModel::PointList::const_iterator i = points.begin(); |
481 i != points.end(); ++i) { | 481 i != points.end(); ++i) { |
482 | 482 |
483 if (snap == SnapRight) { | 483 if (snap == SnapRight) { |
484 | 484 |
485 // The best frame to snap to is the end frame of whichever | 485 // The best frame to snap to is the end frame of whichever |
486 // feature we would have snapped to the start frame of if | 486 // feature we would have snapped to the start frame of if |
487 // we had been snapping left. | 487 // we had been snapping left. |
488 | 488 |
489 if (i->frame <= frame) { | 489 if (i->frame <= frame) { |
490 if (i->frame + i->duration > frame) { | 490 if (i->frame + i->duration > frame) { |
491 snapped = i->frame + i->duration; | 491 snapped = i->frame + i->duration; |
492 found = true; // don't break, as the next may be better | 492 found = true; // don't break, as the next may be better |
493 } | 493 } |
494 } else { | 494 } else { |
497 found = true; | 497 found = true; |
498 } | 498 } |
499 break; | 499 break; |
500 } | 500 } |
501 | 501 |
502 } else if (snap == SnapLeft) { | 502 } else if (snap == SnapLeft) { |
503 | 503 |
504 if (i->frame <= frame) { | 504 if (i->frame <= frame) { |
505 snapped = i->frame; | 505 snapped = i->frame; |
506 found = true; // don't break, as the next may be better | 506 found = true; // don't break, as the next may be better |
507 } else { | 507 } else { |
508 break; | 508 break; |
509 } | 509 } |
510 | 510 |
511 } else { // nearest | 511 } else { // nearest |
512 | 512 |
513 RegionModel::PointList::const_iterator j = i; | 513 RegionModel::PointList::const_iterator j = i; |
514 ++j; | 514 ++j; |
515 | 515 |
516 if (j == points.end()) { | 516 if (j == points.end()) { |
517 | 517 |
518 snapped = i->frame; | 518 snapped = i->frame; |
519 found = true; | 519 found = true; |
520 break; | 520 break; |
521 | 521 |
522 } else if (j->frame >= frame) { | 522 } else if (j->frame >= frame) { |
523 | 523 |
524 if (j->frame - frame < frame - i->frame) { | 524 if (j->frame - frame < frame - i->frame) { |
525 snapped = j->frame; | 525 snapped = j->frame; |
526 } else { | 526 } else { |
527 snapped = i->frame; | 527 snapped = i->frame; |
528 } | 528 } |
529 found = true; | 529 found = true; |
530 break; | 530 break; |
531 } | 531 } |
532 } | 532 } |
533 } | 533 } |
534 | 534 |
535 frame = snapped; | 535 frame = snapped; |
536 return found; | 536 return found; |
537 } | 537 } |
540 RegionLayer::snapToSimilarFeature(LayerGeometryProvider *v, sv_frame_t &frame, | 540 RegionLayer::snapToSimilarFeature(LayerGeometryProvider *v, sv_frame_t &frame, |
541 int &resolution, | 541 int &resolution, |
542 SnapType snap) const | 542 SnapType snap) const |
543 { | 543 { |
544 if (!m_model) { | 544 if (!m_model) { |
545 return Layer::snapToSimilarFeature(v, frame, resolution, snap); | 545 return Layer::snapToSimilarFeature(v, frame, resolution, snap); |
546 } | 546 } |
547 | 547 |
548 resolution = m_model->getResolution(); | 548 resolution = m_model->getResolution(); |
549 | 549 |
550 const RegionModel::PointList &points = m_model->getPoints(); | 550 const RegionModel::PointList &points = m_model->getPoints(); |
584 i = points.begin(); | 584 i = points.begin(); |
585 distant = true; | 585 distant = true; |
586 } | 586 } |
587 } | 587 } |
588 | 588 |
589 if (snap == SnapRight) { | 589 if (snap == SnapRight) { |
590 | 590 |
591 if (i->frame > matchframe && | 591 if (i->frame > matchframe && |
592 fabs(i->value - matchvalue) < epsilon) { | 592 fabs(i->value - matchvalue) < epsilon) { |
593 snapped = i->frame; | 593 snapped = i->frame; |
594 found = true; | 594 found = true; |
595 break; | 595 break; |
596 } | 596 } |
597 | 597 |
598 } else if (snap == SnapLeft) { | 598 } else if (snap == SnapLeft) { |
599 | 599 |
600 if (i->frame < matchframe) { | 600 if (i->frame < matchframe) { |
601 if (fabs(i->value - matchvalue) < epsilon) { | 601 if (fabs(i->value - matchvalue) < epsilon) { |
602 snapped = i->frame; | 602 snapped = i->frame; |
603 found = true; // don't break, as the next may be better | 603 found = true; // don't break, as the next may be better |
604 } | 604 } |
605 } else if (found || distant) { | 605 } else if (found || distant) { |
606 break; | 606 break; |
607 } | 607 } |
608 | 608 |
609 } else { | 609 } else { |
610 // no other snap types supported | 610 // no other snap types supported |
611 } | 611 } |
612 | 612 |
613 ++i; | 613 ++i; |
614 } | 614 } |
615 | 615 |
616 frame = snapped; | 616 frame = snapped; |
887 | 887 |
888 QColor brushColour(getBaseQColor()); | 888 QColor brushColour(getBaseQColor()); |
889 brushColour.setAlpha(80); | 889 brushColour.setAlpha(80); |
890 | 890 |
891 // SVDEBUG << "RegionLayer::paint: resolution is " | 891 // SVDEBUG << "RegionLayer::paint: resolution is " |
892 // << m_model->getResolution() << " frames" << endl; | 892 // << m_model->getResolution() << " frames" << endl; |
893 | 893 |
894 double min = m_model->getValueMinimum(); | 894 double min = m_model->getValueMinimum(); |
895 double max = m_model->getValueMaximum(); | 895 double max = m_model->getValueMaximum(); |
896 if (max == min) max = min + 1.0; | 896 if (max == min) max = min + 1.0; |
897 | 897 |
914 //!!! coord is never completely flat on the top or bottom | 914 //!!! coord is never completely flat on the top or bottom |
915 | 915 |
916 int fontHeight = paint.fontMetrics().height(); | 916 int fontHeight = paint.fontMetrics().height(); |
917 | 917 |
918 for (RegionModel::PointList::const_iterator i = points.begin(); | 918 for (RegionModel::PointList::const_iterator i = points.begin(); |
919 i != points.end(); ++i) { | 919 i != points.end(); ++i) { |
920 | 920 |
921 const RegionModel::Point &p(*i); | 921 const RegionModel::Point &p(*i); |
922 | 922 |
923 int x = v->getXForFrame(p.frame); | 923 int x = v->getXForFrame(p.frame); |
924 int y = getYForValue(v, p.value); | 924 int y = getYForValue(v, p.value); |
925 int w = v->getXForFrame(p.frame + p.duration) - x; | 925 int w = v->getXForFrame(p.frame + p.duration) - x; |
926 int h = 9; | 926 int h = 9; |
927 int ex = x + w; | 927 int ex = x + w; |
928 | 928 |
929 RegionModel::PointList::const_iterator j = i; | 929 RegionModel::PointList::const_iterator j = i; |
930 ++j; | 930 ++j; |
931 | 931 |
932 if (j != points.end()) { | 932 if (j != points.end()) { |
933 const RegionModel::Point &q(*j); | 933 const RegionModel::Point &q(*j); |
934 int nx = v->getXForFrame(q.frame); | 934 int nx = v->getXForFrame(q.frame); |
935 if (nx < ex) ex = nx; | 935 if (nx < ex) ex = nx; |
936 } | 936 } |
937 | 937 |
938 if (m_model->getValueQuantization() != 0.0) { | 938 if (m_model->getValueQuantization() != 0.0) { |
939 h = y - getYForValue(v, p.value + m_model->getValueQuantization()); | 939 h = y - getYForValue(v, p.value + m_model->getValueQuantization()); |
940 if (h < 3) h = 3; | 940 if (h < 3) h = 3; |
941 } | 941 } |
942 | 942 |
943 if (w < 1) w = 1; | 943 if (w < 1) w = 1; |
944 | 944 |
945 if (m_plotStyle == PlotSegmentation) { | 945 if (m_plotStyle == PlotSegmentation) { |
946 paint.setPen(getForegroundQColor(v->getView())); | 946 paint.setPen(getForegroundQColor(v->getView())); |
947 paint.setBrush(getColourForValue(v, p.value)); | 947 paint.setBrush(getColourForValue(v, p.value)); |
948 } else { | 948 } else { |
949 paint.setPen(getBaseQColor()); | 949 paint.setPen(getBaseQColor()); |
950 paint.setBrush(brushColour); | 950 paint.setBrush(brushColour); |
951 } | 951 } |
952 | 952 |
953 if (m_plotStyle == PlotSegmentation) { | 953 if (m_plotStyle == PlotSegmentation) { |
954 | 954 |
955 if (ex <= x) continue; | 955 if (ex <= x) continue; |
956 | 956 |
957 if (!shouldIlluminate || | 957 if (!shouldIlluminate || |
958 // "illuminatePoint != p" | 958 // "illuminatePoint != p" |
959 RegionModel::Point::Comparator()(illuminatePoint, p) || | 959 RegionModel::Point::Comparator()(illuminatePoint, p) || |
960 RegionModel::Point::Comparator()(p, illuminatePoint)) { | 960 RegionModel::Point::Comparator()(p, illuminatePoint)) { |
965 | 965 |
966 } else { | 966 } else { |
967 paint.setPen(QPen(getForegroundQColor(v->getView()), 2)); | 967 paint.setPen(QPen(getForegroundQColor(v->getView()), 2)); |
968 } | 968 } |
969 | 969 |
970 paint.drawRect(x, -1, ex - x, v->getPaintHeight() + 2); | 970 paint.drawRect(x, -1, ex - x, v->getPaintHeight() + 2); |
971 | 971 |
972 } else { | 972 } else { |
973 | 973 |
974 if (shouldIlluminate && | 974 if (shouldIlluminate && |
975 // "illuminatePoint == p" | 975 // "illuminatePoint == p" |
976 !RegionModel::Point::Comparator()(illuminatePoint, p) && | 976 !RegionModel::Point::Comparator()(illuminatePoint, p) && |
977 !RegionModel::Point::Comparator()(p, illuminatePoint)) { | 977 !RegionModel::Point::Comparator()(p, illuminatePoint)) { |
1003 | 1003 |
1004 int nextLabelMinX = -100; | 1004 int nextLabelMinX = -100; |
1005 int lastLabelY = 0; | 1005 int lastLabelY = 0; |
1006 | 1006 |
1007 for (RegionModel::PointList::const_iterator i = points.begin(); | 1007 for (RegionModel::PointList::const_iterator i = points.begin(); |
1008 i != points.end(); ++i) { | 1008 i != points.end(); ++i) { |
1009 | 1009 |
1010 const RegionModel::Point &p(*i); | 1010 const RegionModel::Point &p(*i); |
1011 | 1011 |
1012 int x = v->getXForFrame(p.frame); | 1012 int x = v->getXForFrame(p.frame); |
1013 int y = getYForValue(v, p.value); | 1013 int y = getYForValue(v, p.value); |
1014 | 1014 |
1015 bool illuminated = false; | 1015 bool illuminated = false; |
1016 | 1016 |
1017 if (m_plotStyle != PlotSegmentation) { | 1017 if (m_plotStyle != PlotSegmentation) { |
1018 | 1018 |
1019 if (shouldIlluminate && | 1019 if (shouldIlluminate && |
1020 // "illuminatePoint == p" | 1020 // "illuminatePoint == p" |
1021 !RegionModel::Point::Comparator()(illuminatePoint, p) && | 1021 !RegionModel::Point::Comparator()(illuminatePoint, p) && |
1022 !RegionModel::Point::Comparator()(p, illuminatePoint)) { | 1022 !RegionModel::Point::Comparator()(p, illuminatePoint)) { |
1192 if (!m_model) return; | 1192 if (!m_model) return; |
1193 | 1193 |
1194 if (!getPointToDrag(v, e->x(), e->y(), m_editingPoint)) return; | 1194 if (!getPointToDrag(v, e->x(), e->y(), m_editingPoint)) return; |
1195 | 1195 |
1196 if (m_editingCommand) { | 1196 if (m_editingCommand) { |
1197 finish(m_editingCommand); | 1197 finish(m_editingCommand); |
1198 m_editingCommand = 0; | 1198 m_editingCommand = 0; |
1199 } | 1199 } |
1200 | 1200 |
1201 m_editing = true; | 1201 m_editing = true; |
1202 recalcSpacing(); | 1202 recalcSpacing(); |
1203 } | 1203 } |
1242 m_dragPointY = getYForValue(v, m_editingPoint.value); | 1242 m_dragPointY = getYForValue(v, m_editingPoint.value); |
1243 | 1243 |
1244 m_originalPoint = m_editingPoint; | 1244 m_originalPoint = m_editingPoint; |
1245 | 1245 |
1246 if (m_editingCommand) { | 1246 if (m_editingCommand) { |
1247 finish(m_editingCommand); | 1247 finish(m_editingCommand); |
1248 m_editingCommand = 0; | 1248 m_editingCommand = 0; |
1249 } | 1249 } |
1250 | 1250 |
1251 m_editing = true; | 1251 m_editing = true; |
1252 m_dragStartX = e->x(); | 1252 m_dragStartX = e->x(); |
1253 m_dragStartY = e->y(); | 1253 m_dragStartY = e->y(); |
1276 if (m_distributionMap[m_editingPoint.value] > 1) avoid = -1; | 1276 if (m_distributionMap[m_editingPoint.value] > 1) avoid = -1; |
1277 | 1277 |
1278 double value = getValueForY(v, newy, avoid); | 1278 double value = getValueForY(v, newy, avoid); |
1279 | 1279 |
1280 if (!m_editingCommand) { | 1280 if (!m_editingCommand) { |
1281 m_editingCommand = new RegionModel::EditCommand(m_model, | 1281 m_editingCommand = new RegionModel::EditCommand(m_model, |
1282 tr("Drag Region")); | 1282 tr("Drag Region")); |
1283 } | 1283 } |
1284 | 1284 |
1285 m_editingCommand->deletePoint(m_editingPoint); | 1285 m_editingCommand->deletePoint(m_editingPoint); |
1286 m_editingPoint.frame = frame; | 1286 m_editingPoint.frame = frame; |
1287 m_editingPoint.value = float(value); | 1287 m_editingPoint.value = float(value); |
1294 { | 1294 { |
1295 if (!m_model || !m_editing) return; | 1295 if (!m_model || !m_editing) return; |
1296 | 1296 |
1297 if (m_editingCommand) { | 1297 if (m_editingCommand) { |
1298 | 1298 |
1299 QString newName = m_editingCommand->getName(); | 1299 QString newName = m_editingCommand->getName(); |
1300 | 1300 |
1301 if (m_editingPoint.frame != m_originalPoint.frame) { | 1301 if (m_editingPoint.frame != m_originalPoint.frame) { |
1302 if (m_editingPoint.value != m_originalPoint.value) { | 1302 if (m_editingPoint.value != m_originalPoint.value) { |
1303 newName = tr("Edit Region"); | 1303 newName = tr("Edit Region"); |
1304 } else { | 1304 } else { |
1305 newName = tr("Relocate Region"); | 1305 newName = tr("Relocate Region"); |
1306 } | 1306 } |
1307 } else { | 1307 } else { |
1308 newName = tr("Change Point Value"); | 1308 newName = tr("Change Point Value"); |
1309 } | 1309 } |
1310 | 1310 |
1311 m_editingCommand->setName(newName); | 1311 m_editingCommand->setName(newName); |
1312 finish(m_editingCommand); | 1312 finish(m_editingCommand); |
1313 } | 1313 } |
1314 | 1314 |
1315 m_editingCommand = 0; | 1315 m_editingCommand = 0; |
1316 m_editing = false; | 1316 m_editing = false; |
1317 recalcSpacing(); | 1317 recalcSpacing(); |
1362 RegionLayer::moveSelection(Selection s, sv_frame_t newStartFrame) | 1362 RegionLayer::moveSelection(Selection s, sv_frame_t newStartFrame) |
1363 { | 1363 { |
1364 if (!m_model) return; | 1364 if (!m_model) return; |
1365 | 1365 |
1366 RegionModel::EditCommand *command = | 1366 RegionModel::EditCommand *command = |
1367 new RegionModel::EditCommand(m_model, tr("Drag Selection")); | 1367 new RegionModel::EditCommand(m_model, tr("Drag Selection")); |
1368 | 1368 |
1369 RegionModel::PointList points = | 1369 RegionModel::PointList points = |
1370 m_model->getPoints(s.getStartFrame(), s.getEndFrame()); | 1370 m_model->getPoints(s.getStartFrame(), s.getEndFrame()); |
1371 | 1371 |
1372 for (RegionModel::PointList::iterator i = points.begin(); | 1372 for (RegionModel::PointList::iterator i = points.begin(); |
1373 i != points.end(); ++i) { | 1373 i != points.end(); ++i) { |
1374 | 1374 |
1375 if (s.contains(i->frame)) { | 1375 if (s.contains(i->frame)) { |
1376 RegionModel::Point newPoint(*i); | 1376 RegionModel::Point newPoint(*i); |
1377 newPoint.frame = i->frame + newStartFrame - s.getStartFrame(); | 1377 newPoint.frame = i->frame + newStartFrame - s.getStartFrame(); |
1378 command->deletePoint(*i); | 1378 command->deletePoint(*i); |
1379 command->addPoint(newPoint); | 1379 command->addPoint(newPoint); |
1380 } | 1380 } |
1381 } | 1381 } |
1382 | 1382 |
1383 finish(command); | 1383 finish(command); |
1384 recalcSpacing(); | 1384 recalcSpacing(); |
1385 } | 1385 } |
1388 RegionLayer::resizeSelection(Selection s, Selection newSize) | 1388 RegionLayer::resizeSelection(Selection s, Selection newSize) |
1389 { | 1389 { |
1390 if (!m_model) return; | 1390 if (!m_model) return; |
1391 | 1391 |
1392 RegionModel::EditCommand *command = | 1392 RegionModel::EditCommand *command = |
1393 new RegionModel::EditCommand(m_model, tr("Resize Selection")); | 1393 new RegionModel::EditCommand(m_model, tr("Resize Selection")); |
1394 | 1394 |
1395 RegionModel::PointList points = | 1395 RegionModel::PointList points = |
1396 m_model->getPoints(s.getStartFrame(), s.getEndFrame()); | 1396 m_model->getPoints(s.getStartFrame(), s.getEndFrame()); |
1397 | 1397 |
1398 double ratio = | 1398 double ratio = |
1399 double(newSize.getEndFrame() - newSize.getStartFrame()) / | 1399 double(newSize.getEndFrame() - newSize.getStartFrame()) / |
1400 double(s.getEndFrame() - s.getStartFrame()); | 1400 double(s.getEndFrame() - s.getStartFrame()); |
1401 | 1401 |
1402 for (RegionModel::PointList::iterator i = points.begin(); | 1402 for (RegionModel::PointList::iterator i = points.begin(); |
1403 i != points.end(); ++i) { | 1403 i != points.end(); ++i) { |
1404 | 1404 |
1405 if (s.contains(i->frame)) { | 1405 if (s.contains(i->frame)) { |
1406 | 1406 |
1407 double targetStart = double(i->frame); | 1407 double targetStart = double(i->frame); |
1408 targetStart = double(newSize.getStartFrame()) + | 1408 targetStart = double(newSize.getStartFrame()) + |
1409 targetStart - double(s.getStartFrame()) * ratio; | 1409 targetStart - double(s.getStartFrame()) * ratio; |
1410 | 1410 |
1411 double targetEnd = double(i->frame + i->duration); | 1411 double targetEnd = double(i->frame + i->duration); |
1412 targetEnd = double(newSize.getStartFrame()) + | 1412 targetEnd = double(newSize.getStartFrame()) + |
1413 targetEnd - double(s.getStartFrame()) * ratio; | 1413 targetEnd - double(s.getStartFrame()) * ratio; |
1414 | 1414 |
1415 RegionModel::Point newPoint(*i); | 1415 RegionModel::Point newPoint(*i); |
1416 newPoint.frame = lrint(targetStart); | 1416 newPoint.frame = lrint(targetStart); |
1417 newPoint.duration = lrint(targetEnd - targetStart); | 1417 newPoint.duration = lrint(targetEnd - targetStart); |
1418 command->deletePoint(*i); | 1418 command->deletePoint(*i); |
1419 command->addPoint(newPoint); | 1419 command->addPoint(newPoint); |
1420 } | 1420 } |
1421 } | 1421 } |
1422 | 1422 |
1423 finish(command); | 1423 finish(command); |
1424 recalcSpacing(); | 1424 recalcSpacing(); |
1425 } | 1425 } |
1428 RegionLayer::deleteSelection(Selection s) | 1428 RegionLayer::deleteSelection(Selection s) |
1429 { | 1429 { |
1430 if (!m_model) return; | 1430 if (!m_model) return; |
1431 | 1431 |
1432 RegionModel::EditCommand *command = | 1432 RegionModel::EditCommand *command = |
1433 new RegionModel::EditCommand(m_model, tr("Delete Selected Points")); | 1433 new RegionModel::EditCommand(m_model, tr("Delete Selected Points")); |
1434 | 1434 |
1435 RegionModel::PointList points = | 1435 RegionModel::PointList points = |
1436 m_model->getPoints(s.getStartFrame(), s.getEndFrame()); | 1436 m_model->getPoints(s.getStartFrame(), s.getEndFrame()); |
1437 | 1437 |
1438 for (RegionModel::PointList::iterator i = points.begin(); | 1438 for (RegionModel::PointList::iterator i = points.begin(); |
1439 i != points.end(); ++i) { | 1439 i != points.end(); ++i) { |
1440 | 1440 |
1441 if (s.contains(i->frame)) { | 1441 if (s.contains(i->frame)) { |
1442 command->deletePoint(*i); | 1442 command->deletePoint(*i); |
1443 } | 1443 } |
1444 } | 1444 } |
1451 RegionLayer::copy(LayerGeometryProvider *v, Selection s, Clipboard &to) | 1451 RegionLayer::copy(LayerGeometryProvider *v, Selection s, Clipboard &to) |
1452 { | 1452 { |
1453 if (!m_model) return; | 1453 if (!m_model) return; |
1454 | 1454 |
1455 RegionModel::PointList points = | 1455 RegionModel::PointList points = |
1456 m_model->getPoints(s.getStartFrame(), s.getEndFrame()); | 1456 m_model->getPoints(s.getStartFrame(), s.getEndFrame()); |
1457 | 1457 |
1458 for (RegionModel::PointList::iterator i = points.begin(); | 1458 for (RegionModel::PointList::iterator i = points.begin(); |
1459 i != points.end(); ++i) { | 1459 i != points.end(); ++i) { |
1460 if (s.contains(i->frame)) { | 1460 if (s.contains(i->frame)) { |
1461 Clipboard::Point point(i->frame, i->value, i->duration, i->label); | 1461 Clipboard::Point point(i->frame, i->value, i->duration, i->label); |
1462 point.setReferenceFrame(alignToReference(v, i->frame)); | 1462 point.setReferenceFrame(alignToReference(v, i->frame)); |
1463 to.addPoint(point); | 1463 to.addPoint(point); |
1464 } | 1464 } |
1465 } | 1465 } |
1490 realign = true; | 1490 realign = true; |
1491 } | 1491 } |
1492 } | 1492 } |
1493 | 1493 |
1494 RegionModel::EditCommand *command = | 1494 RegionModel::EditCommand *command = |
1495 new RegionModel::EditCommand(m_model, tr("Paste")); | 1495 new RegionModel::EditCommand(m_model, tr("Paste")); |
1496 | 1496 |
1497 for (Clipboard::PointList::const_iterator i = points.begin(); | 1497 for (Clipboard::PointList::const_iterator i = points.begin(); |
1498 i != points.end(); ++i) { | 1498 i != points.end(); ++i) { |
1499 | 1499 |
1500 if (!i->haveFrame()) continue; | 1500 if (!i->haveFrame()) continue; |
1561 { | 1561 { |
1562 SingleColourLayer::setProperties(attributes); | 1562 SingleColourLayer::setProperties(attributes); |
1563 | 1563 |
1564 bool ok; | 1564 bool ok; |
1565 VerticalScale scale = (VerticalScale) | 1565 VerticalScale scale = (VerticalScale) |
1566 attributes.value("verticalScale").toInt(&ok); | 1566 attributes.value("verticalScale").toInt(&ok); |
1567 if (ok) setVerticalScale(scale); | 1567 if (ok) setVerticalScale(scale); |
1568 PlotStyle style = (PlotStyle) | 1568 PlotStyle style = (PlotStyle) |
1569 attributes.value("plotStyle").toInt(&ok); | 1569 attributes.value("plotStyle").toInt(&ok); |
1570 if (ok) setPlotStyle(style); | 1570 if (ok) setPlotStyle(style); |
1571 } | 1571 } |
1572 | 1572 |
1573 | 1573 |