Mercurial > hg > svgui
comparison layer/TimeValueLayer.cpp @ 944:78c152e4db95
Merge from branch tonioni
author | Chris Cannam |
---|---|
date | Mon, 20 Apr 2015 09:12:17 +0100 |
parents | 251dd0abc7b7 |
children | 94e4952a6774 6f97f5149cb3 |
comparison
equal
deleted
inserted
replaced
896:78e041e45ff0 | 944:78c152e4db95 |
---|---|
327 QPoint discard; | 327 QPoint discard; |
328 return !v->shouldIlluminateLocalFeatures(this, discard); | 328 return !v->shouldIlluminateLocalFeatures(this, discard); |
329 } | 329 } |
330 | 330 |
331 bool | 331 bool |
332 TimeValueLayer::getValueExtents(float &min, float &max, | 332 TimeValueLayer::getValueExtents(double &min, double &max, |
333 bool &logarithmic, QString &unit) const | 333 bool &logarithmic, QString &unit) const |
334 { | 334 { |
335 if (!m_model) return false; | 335 if (!m_model) return false; |
336 | 336 |
337 min = m_model->getValueMinimum(); | 337 min = m_model->getValueMinimum(); |
340 logarithmic = (m_verticalScale == LogScale); | 340 logarithmic = (m_verticalScale == LogScale); |
341 | 341 |
342 unit = getScaleUnits(); | 342 unit = getScaleUnits(); |
343 | 343 |
344 if (m_derivative) { | 344 if (m_derivative) { |
345 max = std::max(fabsf(min), fabsf(max)); | 345 max = std::max(fabs(min), fabs(max)); |
346 min = -max; | 346 min = -max; |
347 } | 347 } |
348 | 348 |
349 #ifdef DEBUG_TIME_VALUE_LAYER | 349 #ifdef DEBUG_TIME_VALUE_LAYER |
350 cerr << "TimeValueLayer::getValueExtents: min = " << min << ", max = " << max << endl; | 350 cerr << "TimeValueLayer::getValueExtents: min = " << min << ", max = " << max << endl; |
354 | 354 |
355 if (max == min) { | 355 if (max == min) { |
356 max = max + 0.5; | 356 max = max + 0.5; |
357 min = min - 0.5; | 357 min = min - 0.5; |
358 } else { | 358 } else { |
359 float margin = (max - min) / 10.0; | 359 double margin = (max - min) / 10.0; |
360 max = max + margin; | 360 max = max + margin; |
361 min = min - margin; | 361 min = min - margin; |
362 } | 362 } |
363 | 363 |
364 #ifdef DEBUG_TIME_VALUE_LAYER | 364 #ifdef DEBUG_TIME_VALUE_LAYER |
368 | 368 |
369 return true; | 369 return true; |
370 } | 370 } |
371 | 371 |
372 bool | 372 bool |
373 TimeValueLayer::getDisplayExtents(float &min, float &max) const | 373 TimeValueLayer::getDisplayExtents(double &min, double &max) const |
374 { | 374 { |
375 if (!m_model || shouldAutoAlign()) return false; | 375 if (!m_model || shouldAutoAlign()) return false; |
376 | 376 |
377 if (m_scaleMinimum == m_scaleMaximum) { | 377 if (m_scaleMinimum == m_scaleMaximum) { |
378 bool log; | 378 bool log; |
382 min = m_scaleMinimum; | 382 min = m_scaleMinimum; |
383 max = m_scaleMaximum; | 383 max = m_scaleMaximum; |
384 } | 384 } |
385 | 385 |
386 if (m_derivative) { | 386 if (m_derivative) { |
387 max = std::max(fabsf(min), fabsf(max)); | 387 max = std::max(fabs(min), fabs(max)); |
388 min = -max; | 388 min = -max; |
389 } | 389 } |
390 | 390 |
391 #ifdef DEBUG_TIME_VALUE_LAYER | 391 #ifdef DEBUG_TIME_VALUE_LAYER |
392 cerr << "TimeValueLayer::getDisplayExtents: min = " << min << ", max = " << max << endl; | 392 cerr << "TimeValueLayer::getDisplayExtents: min = " << min << ", max = " << max << endl; |
394 | 394 |
395 return true; | 395 return true; |
396 } | 396 } |
397 | 397 |
398 bool | 398 bool |
399 TimeValueLayer::setDisplayExtents(float min, float max) | 399 TimeValueLayer::setDisplayExtents(double min, double max) |
400 { | 400 { |
401 if (!m_model) return false; | 401 if (!m_model) return false; |
402 | 402 |
403 if (min == max) { | 403 if (min == max) { |
404 if (min == 0.f) { | 404 if (min == 0.f) { |
436 if (!m_model) return 0; | 436 if (!m_model) return 0; |
437 | 437 |
438 RangeMapper *mapper = getNewVerticalZoomRangeMapper(); | 438 RangeMapper *mapper = getNewVerticalZoomRangeMapper(); |
439 if (!mapper) return 0; | 439 if (!mapper) return 0; |
440 | 440 |
441 float dmin, dmax; | 441 double dmin, dmax; |
442 getDisplayExtents(dmin, dmax); | 442 getDisplayExtents(dmin, dmax); |
443 | 443 |
444 int nr = mapper->getPositionForValue(dmax - dmin); | 444 int nr = mapper->getPositionForValue(dmax - dmin); |
445 | 445 |
446 #ifdef DEBUG_TIME_VALUE_LAYER | 446 #ifdef DEBUG_TIME_VALUE_LAYER |
459 if (!m_model) return; | 459 if (!m_model) return; |
460 | 460 |
461 RangeMapper *mapper = getNewVerticalZoomRangeMapper(); | 461 RangeMapper *mapper = getNewVerticalZoomRangeMapper(); |
462 if (!mapper) return; | 462 if (!mapper) return; |
463 | 463 |
464 float min, max; | 464 double min, max; |
465 bool logarithmic; | 465 bool logarithmic; |
466 QString unit; | 466 QString unit; |
467 getValueExtents(min, max, logarithmic, unit); | 467 getValueExtents(min, max, logarithmic, unit); |
468 | 468 |
469 float dmin, dmax; | 469 double dmin, dmax; |
470 getDisplayExtents(dmin, dmax); | 470 getDisplayExtents(dmin, dmax); |
471 | 471 |
472 float newdist = mapper->getValueForPosition(100 - step); | 472 double newdist = mapper->getValueForPosition(100 - step); |
473 | 473 |
474 float newmin, newmax; | 474 double newmin, newmax; |
475 | 475 |
476 if (logarithmic) { | 476 if (logarithmic) { |
477 | 477 |
478 // see SpectrogramLayer::setVerticalZoomStep | 478 // see SpectrogramLayer::setVerticalZoomStep |
479 | 479 |
480 newmax = (newdist + sqrtf(newdist*newdist + 4*dmin*dmax)) / 2; | 480 newmax = (newdist + sqrt(newdist*newdist + 4*dmin*dmax)) / 2; |
481 newmin = newmax - newdist; | 481 newmin = newmax - newdist; |
482 | 482 |
483 #ifdef DEBUG_TIME_VALUE_LAYER | 483 #ifdef DEBUG_TIME_VALUE_LAYER |
484 cerr << "newmin = " << newmin << ", newmax = " << newmax << endl; | 484 cerr << "newmin = " << newmin << ", newmax = " << newmax << endl; |
485 #endif | 485 #endif |
486 | 486 |
487 } else { | 487 } else { |
488 float dmid = (dmax + dmin) / 2; | 488 double dmid = (dmax + dmin) / 2; |
489 newmin = dmid - newdist / 2; | 489 newmin = dmid - newdist / 2; |
490 newmax = dmid + newdist / 2; | 490 newmax = dmid + newdist / 2; |
491 } | 491 } |
492 | 492 |
493 if (newmin < min) { | 493 if (newmin < min) { |
510 { | 510 { |
511 if (!m_model) return 0; | 511 if (!m_model) return 0; |
512 | 512 |
513 RangeMapper *mapper; | 513 RangeMapper *mapper; |
514 | 514 |
515 float min, max; | 515 double min, max; |
516 bool logarithmic; | 516 bool logarithmic; |
517 QString unit; | 517 QString unit; |
518 getValueExtents(min, max, logarithmic, unit); | 518 getValueExtents(min, max, logarithmic, unit); |
519 | 519 |
520 if (min == max) return 0; | 520 if (min == max) return 0; |
531 SparseTimeValueModel::PointList | 531 SparseTimeValueModel::PointList |
532 TimeValueLayer::getLocalPoints(View *v, int x) const | 532 TimeValueLayer::getLocalPoints(View *v, int x) const |
533 { | 533 { |
534 if (!m_model) return SparseTimeValueModel::PointList(); | 534 if (!m_model) return SparseTimeValueModel::PointList(); |
535 | 535 |
536 long frame = v->getFrameForX(x); | 536 sv_frame_t frame = v->getFrameForX(x); |
537 | 537 |
538 SparseTimeValueModel::PointList onPoints = | 538 SparseTimeValueModel::PointList onPoints = |
539 m_model->getPoints(frame); | 539 m_model->getPoints(frame); |
540 | 540 |
541 if (!onPoints.empty()) { | 541 if (!onPoints.empty()) { |
551 | 551 |
552 if (prevPoints.empty()) { | 552 if (prevPoints.empty()) { |
553 usePoints = nextPoints; | 553 usePoints = nextPoints; |
554 } else if (nextPoints.empty()) { | 554 } else if (nextPoints.empty()) { |
555 // stick with prevPoints | 555 // stick with prevPoints |
556 } else if (long(prevPoints.begin()->frame) < v->getStartFrame() && | 556 } else if (prevPoints.begin()->frame < v->getStartFrame() && |
557 !(nextPoints.begin()->frame > v->getEndFrame())) { | 557 !(nextPoints.begin()->frame > v->getEndFrame())) { |
558 usePoints = nextPoints; | 558 usePoints = nextPoints; |
559 } else if (nextPoints.begin()->frame - frame < | 559 } else if (nextPoints.begin()->frame - frame < |
560 frame - prevPoints.begin()->frame) { | 560 frame - prevPoints.begin()->frame) { |
561 usePoints = nextPoints; | 561 usePoints = nextPoints; |
572 | 572 |
573 return usePoints; | 573 return usePoints; |
574 } | 574 } |
575 | 575 |
576 QString | 576 QString |
577 TimeValueLayer::getLabelPreceding(int frame) const | 577 TimeValueLayer::getLabelPreceding(sv_frame_t frame) const |
578 { | 578 { |
579 if (!m_model) return ""; | 579 if (!m_model) return ""; |
580 SparseTimeValueModel::PointList points = m_model->getPreviousPoints(frame); | 580 SparseTimeValueModel::PointList points = m_model->getPreviousPoints(frame); |
581 for (SparseTimeValueModel::PointList::const_iterator i = points.begin(); | 581 for (SparseTimeValueModel::PointList::const_iterator i = points.begin(); |
582 i != points.end(); ++i) { | 582 i != points.end(); ++i) { |
600 } else { | 600 } else { |
601 return tr("No local points"); | 601 return tr("No local points"); |
602 } | 602 } |
603 } | 603 } |
604 | 604 |
605 long useFrame = points.begin()->frame; | 605 sv_frame_t useFrame = points.begin()->frame; |
606 | 606 |
607 RealTime rt = RealTime::frame2RealTime(useFrame, m_model->getSampleRate()); | 607 RealTime rt = RealTime::frame2RealTime(useFrame, m_model->getSampleRate()); |
608 | 608 |
609 QString text; | 609 QString text; |
610 QString unit = getScaleUnits(); | 610 QString unit = getScaleUnits(); |
627 getYForValue(v, points.begin()->value)); | 627 getYForValue(v, points.begin()->value)); |
628 return text; | 628 return text; |
629 } | 629 } |
630 | 630 |
631 bool | 631 bool |
632 TimeValueLayer::snapToFeatureFrame(View *v, int &frame, | 632 TimeValueLayer::snapToFeatureFrame(View *v, sv_frame_t &frame, |
633 int &resolution, | 633 int &resolution, |
634 SnapType snap) const | 634 SnapType snap) const |
635 { | 635 { |
636 if (!m_model) { | 636 if (!m_model) { |
637 return Layer::snapToFeatureFrame(v, frame, resolution, snap); | 637 return Layer::snapToFeatureFrame(v, frame, resolution, snap); |
647 frame = points.begin()->frame; | 647 frame = points.begin()->frame; |
648 return true; | 648 return true; |
649 } | 649 } |
650 | 650 |
651 points = m_model->getPoints(frame, frame); | 651 points = m_model->getPoints(frame, frame); |
652 int snapped = frame; | 652 sv_frame_t snapped = frame; |
653 bool found = false; | 653 bool found = false; |
654 | 654 |
655 for (SparseTimeValueModel::PointList::const_iterator i = points.begin(); | 655 for (SparseTimeValueModel::PointList::const_iterator i = points.begin(); |
656 i != points.end(); ++i) { | 656 i != points.end(); ++i) { |
657 | 657 |
699 frame = snapped; | 699 frame = snapped; |
700 return found; | 700 return found; |
701 } | 701 } |
702 | 702 |
703 bool | 703 bool |
704 TimeValueLayer::snapToSimilarFeature(View *v, int &frame, | 704 TimeValueLayer::snapToSimilarFeature(View *v, sv_frame_t &frame, |
705 int &resolution, | 705 int &resolution, |
706 SnapType snap) const | 706 SnapType snap) const |
707 { | 707 { |
708 if (!m_model) { | 708 if (!m_model) { |
709 return Layer::snapToSimilarFeature(v, frame, resolution, snap); | 709 return Layer::snapToSimilarFeature(v, frame, resolution, snap); |
714 const SparseTimeValueModel::PointList &points = m_model->getPoints(); | 714 const SparseTimeValueModel::PointList &points = m_model->getPoints(); |
715 SparseTimeValueModel::PointList close = m_model->getPoints(frame, frame); | 715 SparseTimeValueModel::PointList close = m_model->getPoints(frame, frame); |
716 | 716 |
717 SparseTimeValueModel::PointList::const_iterator i; | 717 SparseTimeValueModel::PointList::const_iterator i; |
718 | 718 |
719 int matchframe = frame; | 719 sv_frame_t matchframe = frame; |
720 float matchvalue = 0.f; | 720 double matchvalue = 0.0; |
721 | 721 |
722 for (i = close.begin(); i != close.end(); ++i) { | 722 for (i = close.begin(); i != close.end(); ++i) { |
723 if (i->frame > frame) break; | 723 if (i->frame > frame) break; |
724 matchvalue = i->value; | 724 matchvalue = i->value; |
725 matchframe = i->frame; | 725 matchframe = i->frame; |
726 } | 726 } |
727 | 727 |
728 int snapped = frame; | 728 sv_frame_t snapped = frame; |
729 bool found = false; | 729 bool found = false; |
730 bool distant = false; | 730 bool distant = false; |
731 float epsilon = 0.0001; | 731 double epsilon = 0.0001; |
732 | 732 |
733 i = close.begin(); | 733 i = close.begin(); |
734 | 734 |
735 // Scan through the close points first, then the more distant ones | 735 // Scan through the close points first, then the more distant ones |
736 // if no suitable close one is found. So the while-termination | 736 // if no suitable close one is found. So the while-termination |
751 } | 751 } |
752 | 752 |
753 if (snap == SnapRight) { | 753 if (snap == SnapRight) { |
754 | 754 |
755 if (i->frame > matchframe && | 755 if (i->frame > matchframe && |
756 fabsf(i->value - matchvalue) < epsilon) { | 756 fabs(i->value - matchvalue) < epsilon) { |
757 snapped = i->frame; | 757 snapped = i->frame; |
758 found = true; | 758 found = true; |
759 break; | 759 break; |
760 } | 760 } |
761 | 761 |
762 } else if (snap == SnapLeft) { | 762 } else if (snap == SnapLeft) { |
763 | 763 |
764 if (i->frame < matchframe) { | 764 if (i->frame < matchframe) { |
765 if (fabsf(i->value - matchvalue) < epsilon) { | 765 if (fabs(i->value - matchvalue) < epsilon) { |
766 snapped = i->frame; | 766 snapped = i->frame; |
767 found = true; // don't break, as the next may be better | 767 found = true; // don't break, as the next may be better |
768 } | 768 } |
769 } else if (found || distant) { | 769 } else if (found || distant) { |
770 break; | 770 break; |
780 frame = snapped; | 780 frame = snapped; |
781 return found; | 781 return found; |
782 } | 782 } |
783 | 783 |
784 void | 784 void |
785 TimeValueLayer::getScaleExtents(View *v, float &min, float &max, bool &log) const | 785 TimeValueLayer::getScaleExtents(View *v, double &min, double &max, bool &log) const |
786 { | 786 { |
787 min = 0.0; | 787 min = 0.0; |
788 max = 0.0; | 788 max = 0.0; |
789 log = false; | 789 log = false; |
790 | 790 |
816 cerr << "TimeValueLayer::getScaleExtents: min = " << min << ", max = " << max << endl; | 816 cerr << "TimeValueLayer::getScaleExtents: min = " << min << ", max = " << max << endl; |
817 #endif | 817 #endif |
818 } | 818 } |
819 | 819 |
820 int | 820 int |
821 TimeValueLayer::getYForValue(View *v, float val) const | 821 TimeValueLayer::getYForValue(View *v, double val) const |
822 { | 822 { |
823 float min = 0.0, max = 0.0; | 823 double min = 0.0, max = 0.0; |
824 bool logarithmic = false; | 824 bool logarithmic = false; |
825 int h = v->height(); | 825 int h = v->height(); |
826 | 826 |
827 getScaleExtents(v, min, max, logarithmic); | 827 getScaleExtents(v, min, max, logarithmic); |
828 | 828 |
836 } | 836 } |
837 | 837 |
838 return int(h - ((val - min) * h) / (max - min)); | 838 return int(h - ((val - min) * h) / (max - min)); |
839 } | 839 } |
840 | 840 |
841 float | 841 double |
842 TimeValueLayer::getValueForY(View *v, int y) const | 842 TimeValueLayer::getValueForY(View *v, int y) const |
843 { | 843 { |
844 float min = 0.0, max = 0.0; | 844 double min = 0.0, max = 0.0; |
845 bool logarithmic = false; | 845 bool logarithmic = false; |
846 int h = v->height(); | 846 int h = v->height(); |
847 | 847 |
848 getScaleExtents(v, min, max, logarithmic); | 848 getScaleExtents(v, min, max, logarithmic); |
849 | 849 |
850 float val = min + (float(h - y) * float(max - min)) / h; | 850 double val = min + (double(h - y) * double(max - min)) / h; |
851 | 851 |
852 if (logarithmic) { | 852 if (logarithmic) { |
853 val = LogRange::map(val); | 853 val = LogRange::map(val); |
854 } | 854 } |
855 | 855 |
863 QString unit = getScaleUnits(); | 863 QString unit = getScaleUnits(); |
864 return (m_verticalScale == AutoAlignScale && unit != ""); | 864 return (m_verticalScale == AutoAlignScale && unit != ""); |
865 } | 865 } |
866 | 866 |
867 QColor | 867 QColor |
868 TimeValueLayer::getColourForValue(View *v, float val) const | 868 TimeValueLayer::getColourForValue(View *v, double val) const |
869 { | 869 { |
870 float min, max; | 870 double min, max; |
871 bool log; | 871 bool log; |
872 getScaleExtents(v, min, max, log); | 872 getScaleExtents(v, min, max, log); |
873 | 873 |
874 if (min > max) std::swap(min, max); | 874 if (min > max) std::swap(min, max); |
875 if (max == min) max = min + 1; | 875 if (max == min) max = min + 1; |
898 void | 898 void |
899 TimeValueLayer::paint(View *v, QPainter &paint, QRect rect) const | 899 TimeValueLayer::paint(View *v, QPainter &paint, QRect rect) const |
900 { | 900 { |
901 if (!m_model || !m_model->isOK()) return; | 901 if (!m_model || !m_model->isOK()) return; |
902 | 902 |
903 int sampleRate = m_model->getSampleRate(); | 903 sv_samplerate_t sampleRate = m_model->getSampleRate(); |
904 if (!sampleRate) return; | 904 if (!sampleRate) return; |
905 | 905 |
906 paint.setRenderHint(QPainter::Antialiasing, false); | 906 paint.setRenderHint(QPainter::Antialiasing, false); |
907 | 907 |
908 // Profiler profiler("TimeValueLayer::paint", true); | 908 // Profiler profiler("TimeValueLayer::paint", true); |
909 | 909 |
910 int x0 = rect.left(), x1 = rect.right(); | 910 int x0 = rect.left(), x1 = rect.right(); |
911 long frame0 = v->getFrameForX(x0); | 911 sv_frame_t frame0 = v->getFrameForX(x0); |
912 long frame1 = v->getFrameForX(x1); | 912 sv_frame_t frame1 = v->getFrameForX(x1); |
913 if (m_derivative) --frame0; | 913 if (m_derivative) --frame0; |
914 | 914 |
915 SparseTimeValueModel::PointList points(m_model->getPoints | 915 SparseTimeValueModel::PointList points(m_model->getPoints |
916 (frame0, frame1)); | 916 (frame0, frame1)); |
917 if (points.empty()) return; | 917 if (points.empty()) return; |
925 #ifdef DEBUG_TIME_VALUE_LAYER | 925 #ifdef DEBUG_TIME_VALUE_LAYER |
926 cerr << "TimeValueLayer::paint: resolution is " | 926 cerr << "TimeValueLayer::paint: resolution is " |
927 << m_model->getResolution() << " frames" << endl; | 927 << m_model->getResolution() << " frames" << endl; |
928 #endif | 928 #endif |
929 | 929 |
930 float min = m_model->getValueMinimum(); | 930 double min = m_model->getValueMinimum(); |
931 float max = m_model->getValueMaximum(); | 931 double max = m_model->getValueMaximum(); |
932 if (max == min) max = min + 1.0; | 932 if (max == min) max = min + 1.0; |
933 | 933 |
934 int origin = int(nearbyint(v->height() - | 934 int origin = int(nearbyint(v->height() - |
935 (-min * v->height()) / (max - min))); | 935 (-min * v->height()) / (max - min))); |
936 | 936 |
937 QPoint localPos; | 937 QPoint localPos; |
938 long illuminateFrame = -1; | 938 sv_frame_t illuminateFrame = -1; |
939 | 939 |
940 if (v->shouldIlluminateLocalFeatures(this, localPos)) { | 940 if (v->shouldIlluminateLocalFeatures(this, localPos)) { |
941 SparseTimeValueModel::PointList localPoints = | 941 SparseTimeValueModel::PointList localPoints = |
942 getLocalPoints(v, localPos.x()); | 942 getLocalPoints(v, localPos.x()); |
943 #ifdef DEBUG_TIME_VALUE_LAYER | 943 #ifdef DEBUG_TIME_VALUE_LAYER |
972 paint.drawLine(x0, originY, x1, originY); | 972 paint.drawLine(x0, originY, x1, originY); |
973 paint.restore(); | 973 paint.restore(); |
974 } | 974 } |
975 } | 975 } |
976 | 976 |
977 int prevFrame = 0; | 977 sv_frame_t prevFrame = 0; |
978 | 978 |
979 for (SparseTimeValueModel::PointList::const_iterator i = points.begin(); | 979 for (SparseTimeValueModel::PointList::const_iterator i = points.begin(); |
980 i != points.end(); ++i) { | 980 i != points.end(); ++i) { |
981 | 981 |
982 if (m_derivative && i == points.begin()) continue; | 982 if (m_derivative && i == points.begin()) continue; |
983 | 983 |
984 const SparseTimeValueModel::Point &p(*i); | 984 const SparseTimeValueModel::Point &p(*i); |
985 | 985 |
986 float value = p.value; | 986 double value = p.value; |
987 if (m_derivative) { | 987 if (m_derivative) { |
988 SparseTimeValueModel::PointList::const_iterator j = i; | 988 SparseTimeValueModel::PointList::const_iterator j = i; |
989 --j; | 989 --j; |
990 value -= j->value; | 990 value -= j->value; |
991 } | 991 } |
1010 textY = paint.fontMetrics().ascent() + 1; | 1010 textY = paint.fontMetrics().ascent() + 1; |
1011 } | 1011 } |
1012 } | 1012 } |
1013 | 1013 |
1014 bool haveNext = false; | 1014 bool haveNext = false; |
1015 float nvalue = 0.f; | 1015 double nvalue = 0.f; |
1016 int nf = v->getModelsEndFrame(); | 1016 sv_frame_t nf = v->getModelsEndFrame(); |
1017 int nx = v->getXForFrame(nf); | 1017 int nx = v->getXForFrame(nf); |
1018 int ny = y; | 1018 int ny = y; |
1019 | 1019 |
1020 SparseTimeValueModel::PointList::const_iterator j = i; | 1020 SparseTimeValueModel::PointList::const_iterator j = i; |
1021 ++j; | 1021 ++j; |
1120 // paint.drawLine(x + w/2, y, nx + w/2, ny); | 1120 // paint.drawLine(x + w/2, y, nx + w/2, ny); |
1121 path.lineTo(nx + w/2, ny); | 1121 path.lineTo(nx + w/2, ny); |
1122 | 1122 |
1123 } else { | 1123 } else { |
1124 | 1124 |
1125 float x0 = x + float(w)/2; | 1125 double x0 = x + double(w)/2; |
1126 float x1 = nx + float(w)/2; | 1126 double x1 = nx + double(w)/2; |
1127 | 1127 |
1128 float y0 = y; | 1128 double y0 = y; |
1129 float y1 = ny; | 1129 double y1 = ny; |
1130 | 1130 |
1131 if (m_plotStyle == PlotDiscreteCurves) { | 1131 if (m_plotStyle == PlotDiscreteCurves) { |
1132 bool nextGap = | 1132 bool nextGap = |
1133 (nvalue == 0.0) || | 1133 (nvalue == 0.0) || |
1134 (nf - p.frame >= m_model->getResolution() * 2); | 1134 (nf - p.frame >= m_model->getResolution() * 2); |
1253 TimeValueLayer::paintVerticalScale(View *v, bool, QPainter &paint, QRect) const | 1253 TimeValueLayer::paintVerticalScale(View *v, bool, QPainter &paint, QRect) const |
1254 { | 1254 { |
1255 if (!m_model || m_model->getPoints().empty()) return; | 1255 if (!m_model || m_model->getPoints().empty()) return; |
1256 | 1256 |
1257 QString unit; | 1257 QString unit; |
1258 float min, max; | 1258 double min, max; |
1259 bool logarithmic; | 1259 bool logarithmic; |
1260 | 1260 |
1261 int w = getVerticalScaleWidth(v, false, paint); | 1261 int w = getVerticalScaleWidth(v, false, paint); |
1262 int h = v->height(); | 1262 int h = v->height(); |
1263 | 1263 |
1308 cerr << "TimeValueLayer::drawStart(" << e->x() << "," << e->y() << ")" << endl; | 1308 cerr << "TimeValueLayer::drawStart(" << e->x() << "," << e->y() << ")" << endl; |
1309 #endif | 1309 #endif |
1310 | 1310 |
1311 if (!m_model) return; | 1311 if (!m_model) return; |
1312 | 1312 |
1313 long frame = v->getFrameForX(e->x()); | 1313 sv_frame_t frame = v->getFrameForX(e->x()); |
1314 long resolution = m_model->getResolution(); | 1314 int resolution = m_model->getResolution(); |
1315 if (frame < 0) frame = 0; | 1315 if (frame < 0) frame = 0; |
1316 frame = (frame / resolution) * resolution; | 1316 frame = (frame / resolution) * resolution; |
1317 | 1317 |
1318 float value = getValueForY(v, e->y()); | 1318 double value = getValueForY(v, e->y()); |
1319 | 1319 |
1320 bool havePoint = false; | 1320 bool havePoint = false; |
1321 | 1321 |
1322 SparseTimeValueModel::PointList points = getLocalPoints(v, e->x()); | 1322 SparseTimeValueModel::PointList points = getLocalPoints(v, e->x()); |
1323 if (!points.empty()) { | 1323 if (!points.empty()) { |
1334 } | 1334 } |
1335 } | 1335 } |
1336 | 1336 |
1337 if (!havePoint) { | 1337 if (!havePoint) { |
1338 m_editingPoint = SparseTimeValueModel::Point | 1338 m_editingPoint = SparseTimeValueModel::Point |
1339 (frame, value, tr("New Point")); | 1339 (frame, float(value), tr("New Point")); |
1340 } | 1340 } |
1341 | 1341 |
1342 m_originalPoint = m_editingPoint; | 1342 m_originalPoint = m_editingPoint; |
1343 | 1343 |
1344 if (m_editingCommand) finish(m_editingCommand); | 1344 if (m_editingCommand) finish(m_editingCommand); |
1358 cerr << "TimeValueLayer::drawDrag(" << e->x() << "," << e->y() << ")" << endl; | 1358 cerr << "TimeValueLayer::drawDrag(" << e->x() << "," << e->y() << ")" << endl; |
1359 #endif | 1359 #endif |
1360 | 1360 |
1361 if (!m_model || !m_editing) return; | 1361 if (!m_model || !m_editing) return; |
1362 | 1362 |
1363 long frame = v->getFrameForX(e->x()); | 1363 sv_frame_t frame = v->getFrameForX(e->x()); |
1364 long resolution = m_model->getResolution(); | 1364 int resolution = m_model->getResolution(); |
1365 if (frame < 0) frame = 0; | 1365 if (frame < 0) frame = 0; |
1366 frame = (frame / resolution) * resolution; | 1366 frame = (frame / resolution) * resolution; |
1367 | 1367 |
1368 float value = getValueForY(v, e->y()); | 1368 double value = getValueForY(v, e->y()); |
1369 | 1369 |
1370 SparseTimeValueModel::PointList points = getLocalPoints(v, e->x()); | 1370 SparseTimeValueModel::PointList points = getLocalPoints(v, e->x()); |
1371 | 1371 |
1372 #ifdef DEBUG_TIME_VALUE_LAYER | 1372 #ifdef DEBUG_TIME_VALUE_LAYER |
1373 cerr << points.size() << " points" << endl; | 1373 cerr << points.size() << " points" << endl; |
1407 } | 1407 } |
1408 } | 1408 } |
1409 | 1409 |
1410 // m_editingCommand->deletePoint(m_editingPoint); | 1410 // m_editingCommand->deletePoint(m_editingPoint); |
1411 m_editingPoint.frame = frame; | 1411 m_editingPoint.frame = frame; |
1412 m_editingPoint.value = value; | 1412 m_editingPoint.value = float(value); |
1413 m_editingCommand->addPoint(m_editingPoint); | 1413 m_editingCommand->addPoint(m_editingPoint); |
1414 } | 1414 } |
1415 | 1415 |
1416 void | 1416 void |
1417 TimeValueLayer::drawEnd(View *, QMouseEvent *) | 1417 TimeValueLayer::drawEnd(View *, QMouseEvent *) |
1500 cerr << "TimeValueLayer::editDrag(" << e->x() << "," << e->y() << ")" << endl; | 1500 cerr << "TimeValueLayer::editDrag(" << e->x() << "," << e->y() << ")" << endl; |
1501 #endif | 1501 #endif |
1502 | 1502 |
1503 if (!m_model || !m_editing) return; | 1503 if (!m_model || !m_editing) return; |
1504 | 1504 |
1505 long frame = v->getFrameForX(e->x()); | 1505 sv_frame_t frame = v->getFrameForX(e->x()); |
1506 if (frame < 0) frame = 0; | 1506 if (frame < 0) frame = 0; |
1507 frame = frame / m_model->getResolution() * m_model->getResolution(); | 1507 frame = frame / m_model->getResolution() * m_model->getResolution(); |
1508 | 1508 |
1509 float value = getValueForY(v, e->y()); | 1509 double value = getValueForY(v, e->y()); |
1510 | 1510 |
1511 if (!m_editingCommand) { | 1511 if (!m_editingCommand) { |
1512 m_editingCommand = new SparseTimeValueModel::EditCommand(m_model, | 1512 m_editingCommand = new SparseTimeValueModel::EditCommand(m_model, |
1513 tr("Drag Point")); | 1513 tr("Drag Point")); |
1514 } | 1514 } |
1515 | 1515 |
1516 m_editingCommand->deletePoint(m_editingPoint); | 1516 m_editingCommand->deletePoint(m_editingPoint); |
1517 m_editingPoint.frame = frame; | 1517 m_editingPoint.frame = frame; |
1518 m_editingPoint.value = value; | 1518 m_editingPoint.value = float(value); |
1519 m_editingCommand->addPoint(m_editingPoint); | 1519 m_editingCommand->addPoint(m_editingPoint); |
1520 } | 1520 } |
1521 | 1521 |
1522 void | 1522 void |
1523 TimeValueLayer::editEnd(View *, QMouseEvent *) | 1523 TimeValueLayer::editEnd(View *, QMouseEvent *) |
1587 delete dialog; | 1587 delete dialog; |
1588 return true; | 1588 return true; |
1589 } | 1589 } |
1590 | 1590 |
1591 void | 1591 void |
1592 TimeValueLayer::moveSelection(Selection s, int newStartFrame) | 1592 TimeValueLayer::moveSelection(Selection s, sv_frame_t newStartFrame) |
1593 { | 1593 { |
1594 if (!m_model) return; | 1594 if (!m_model) return; |
1595 | 1595 |
1596 SparseTimeValueModel::EditCommand *command = | 1596 SparseTimeValueModel::EditCommand *command = |
1597 new SparseTimeValueModel::EditCommand(m_model, | 1597 new SparseTimeValueModel::EditCommand(m_model, |
1633 for (SparseTimeValueModel::PointList::iterator i = points.begin(); | 1633 for (SparseTimeValueModel::PointList::iterator i = points.begin(); |
1634 i != points.end(); ++i) { | 1634 i != points.end(); ++i) { |
1635 | 1635 |
1636 if (s.contains(i->frame)) { | 1636 if (s.contains(i->frame)) { |
1637 | 1637 |
1638 double target = i->frame; | 1638 double target = double(i->frame); |
1639 target = newSize.getStartFrame() + | 1639 target = double(newSize.getStartFrame()) + |
1640 double(target - s.getStartFrame()) * ratio; | 1640 target - double(s.getStartFrame()) * ratio; |
1641 | 1641 |
1642 SparseTimeValueModel::Point newPoint(*i); | 1642 SparseTimeValueModel::Point newPoint(*i); |
1643 newPoint.frame = lrint(target); | 1643 newPoint.frame = lrint(target); |
1644 command->deletePoint(*i); | 1644 command->deletePoint(*i); |
1645 command->addPoint(newPoint); | 1645 command->addPoint(newPoint); |
1689 } | 1689 } |
1690 } | 1690 } |
1691 } | 1691 } |
1692 | 1692 |
1693 bool | 1693 bool |
1694 TimeValueLayer::paste(View *v, const Clipboard &from, int /* frameOffset */, | 1694 TimeValueLayer::paste(View *v, const Clipboard &from, sv_frame_t /* frameOffset */, |
1695 bool interactive) | 1695 bool interactive) |
1696 { | 1696 { |
1697 if (!m_model) return false; | 1697 if (!m_model) return false; |
1698 | 1698 |
1699 const Clipboard::PointList &points = from.getPoints(); | 1699 const Clipboard::PointList &points = from.getPoints(); |
1832 for (Clipboard::PointList::const_iterator i = points.begin(); | 1832 for (Clipboard::PointList::const_iterator i = points.begin(); |
1833 i != points.end(); ++i) { | 1833 i != points.end(); ++i) { |
1834 | 1834 |
1835 if (!i->haveFrame()) continue; | 1835 if (!i->haveFrame()) continue; |
1836 | 1836 |
1837 int frame = 0; | 1837 sv_frame_t frame = 0; |
1838 | 1838 |
1839 if (!realign) { | 1839 if (!realign) { |
1840 | 1840 |
1841 frame = i->getFrame(); | 1841 frame = i->getFrame(); |
1842 | 1842 |