comparison layer/Layer.cpp @ 946:36cddc3de023 alignment_view

Merge from default branch
author Chris Cannam
date Mon, 20 Apr 2015 09:19:52 +0100
parents 4a578a360011
children 4fe7a09be0fe
comparison
equal deleted inserted replaced
897:499b637f2a26 946:36cddc3de023
49 Layer::connectSignals(const Model *model) 49 Layer::connectSignals(const Model *model)
50 { 50 {
51 connect(model, SIGNAL(modelChanged()), 51 connect(model, SIGNAL(modelChanged()),
52 this, SIGNAL(modelChanged())); 52 this, SIGNAL(modelChanged()));
53 53
54 connect(model, SIGNAL(modelChangedWithin(int, int)), 54 connect(model, SIGNAL(modelChangedWithin(sv_frame_t, sv_frame_t)),
55 this, SIGNAL(modelChangedWithin(int, int))); 55 this, SIGNAL(modelChangedWithin(sv_frame_t, sv_frame_t)));
56 56
57 connect(model, SIGNAL(completionChanged()), 57 connect(model, SIGNAL(completionChanged()),
58 this, SIGNAL(modelCompletionChanged())); 58 this, SIGNAL(modelCompletionChanged()));
59 59
60 connect(model, SIGNAL(alignmentCompletionChanged()), 60 connect(model, SIGNAL(alignmentCompletionChanged()),
137 setLayerDormant(view, !show); 137 setLayerDormant(view, !show);
138 emit layerParametersChanged(); 138 emit layerParametersChanged();
139 } 139 }
140 140
141 bool 141 bool
142 Layer::getXScaleValue(const View *v, int x, float &value, QString &unit) const 142 Layer::getXScaleValue(const View *v, int x, double &value, QString &unit) const
143 { 143 {
144 if (!hasTimeXAxis()) return false; 144 if (!hasTimeXAxis()) return false;
145 145
146 const Model *m = getModel(); 146 const Model *m = getModel();
147 if (!m) return false; 147 if (!m) return false;
148 148
149 value = float(v->getFrameForX(x)) / m->getSampleRate(); 149 value = double(v->getFrameForX(x)) / m->getSampleRate();
150 unit = "s"; 150 unit = "s";
151 return true; 151 return true;
152 } 152 }
153 153
154 bool 154 bool
155 Layer::getYScaleDifference(const View *v, int y0, int y1, 155 Layer::getYScaleDifference(const View *v, int y0, int y1,
156 float &diff, QString &unit) const 156 double &diff, QString &unit) const
157 { 157 {
158 float v0, v1; 158 double v0, v1;
159 if (!getYScaleValue(v, y0, v0, unit) || 159 if (!getYScaleValue(v, y0, v0, unit) ||
160 !getYScaleValue(v, y1, v1, unit)) { 160 !getYScaleValue(v, y1, v1, unit)) {
161 diff = 0.f; 161 diff = 0.f;
162 return false; 162 return false;
163 } 163 }
164 diff = fabsf(v1 - v0); 164 diff = fabs(v1 - v0);
165 return true; 165 return true;
166 } 166 }
167 167
168 int 168 sv_frame_t
169 Layer::alignToReference(View *v, int frame) const 169 Layer::alignToReference(View *v, sv_frame_t frame) const
170 { 170 {
171 const Model *m = getModel(); 171 const Model *m = getModel();
172 SVDEBUG << "Layer::alignToReference(" << frame << "): model = " << m << ", alignment reference = " << (m ? m->getAlignmentReference() : 0) << endl; 172 SVDEBUG << "Layer::alignToReference(" << frame << "): model = " << m << ", alignment reference = " << (m ? m->getAlignmentReference() : 0) << endl;
173 if (m && m->getAlignmentReference()) { 173 if (m && m->getAlignmentReference()) {
174 return m->alignToReference(frame); 174 return m->alignToReference(frame);
175 } else { 175 } else {
176 return v->alignToReference(frame); 176 return v->alignToReference(frame);
177 } 177 }
178 } 178 }
179 179
180 int 180 sv_frame_t
181 Layer::alignFromReference(View *v, int frame) const 181 Layer::alignFromReference(View *v, sv_frame_t frame) const
182 { 182 {
183 const Model *m = getModel(); 183 const Model *m = getModel();
184 SVDEBUG << "Layer::alignFromReference(" << frame << "): model = " << m << ", alignment reference = " << (m ? m->getAlignmentReference() : 0) << endl; 184 SVDEBUG << "Layer::alignFromReference(" << frame << "): model = " << m << ", alignment reference = " << (m ? m->getAlignmentReference() : 0) << endl;
185 if (m && m->getAlignmentReference()) { 185 if (m && m->getAlignmentReference()) {
186 return m->alignFromReference(frame); 186 return m->alignFromReference(frame);
248 // What if the clipboard point has no reference frame? Then 248 // What if the clipboard point has no reference frame? Then
249 // we have to treat it as having its own frame as the 249 // we have to treat it as having its own frame as the
250 // reference (i.e. having been copied from the reference 250 // reference (i.e. having been copied from the reference
251 // model). 251 // model).
252 252
253 int sourceFrame = i->getFrame(); 253 sv_frame_t sourceFrame = i->getFrame();
254 int referenceFrame = sourceFrame; 254 sv_frame_t referenceFrame = sourceFrame;
255 if (i->haveReferenceFrame()) { 255 if (i->haveReferenceFrame()) {
256 referenceFrame = i->getReferenceFrame(); 256 referenceFrame = i->getReferenceFrame();
257 } 257 }
258 int myMappedFrame = alignToReference(v, sourceFrame); 258 sv_frame_t myMappedFrame = alignToReference(v, sourceFrame);
259 259
260 // cerr << "sourceFrame = " << sourceFrame << ", referenceFrame = " << referenceFrame << " (have = " << i->haveReferenceFrame() << "), myMappedFrame = " << myMappedFrame << endl; 260 // cerr << "sourceFrame = " << sourceFrame << ", referenceFrame = " << referenceFrame << " (have = " << i->haveReferenceFrame() << "), myMappedFrame = " << myMappedFrame << endl;
261 261
262 if (myMappedFrame != referenceFrame) return true; 262 if (myMappedFrame != referenceFrame) return true;
263 } 263 }
468 } 468 }
469 469
470 void 470 void
471 Layer::updateMeasurePixrects(View *v) const 471 Layer::updateMeasurePixrects(View *v) const
472 { 472 {
473 int sf = v->getStartFrame(); 473 sv_frame_t sf = v->getStartFrame();
474 int ef = v->getEndFrame(); 474 sv_frame_t ef = v->getEndFrame();
475 475
476 for (MeasureRectSet::const_iterator i = m_measureRects.begin(); 476 for (MeasureRectSet::const_iterator i = m_measureRects.begin();
477 i != m_measureRects.end(); ++i) { 477 i != m_measureRects.end(); ++i) {
478 478
479 // This logic depends on the fact that if one measure rect in 479 // This logic depends on the fact that if one measure rect in
507 } 507 }
508 508
509 void 509 void
510 Layer::updateMeasureRectYCoords(View *v, const MeasureRect &r) const 510 Layer::updateMeasureRectYCoords(View *v, const MeasureRect &r) const
511 { 511 {
512 int y0 = lrint(r.startY * v->height()); 512 int y0 = int(lrint(r.startY * v->height()));
513 int y1 = lrint(r.endY * v->height()); 513 int y1 = int(lrint(r.endY * v->height()));
514 r.pixrect = QRect(r.pixrect.x(), y0, r.pixrect.width(), y1 - y0); 514 r.pixrect = QRect(r.pixrect.x(), y0, r.pixrect.width(), y1 - y0);
515 } 515 }
516 516
517 void 517 void
518 Layer::setMeasureRectYCoord(View *v, MeasureRect &r, bool start, int y) const 518 Layer::setMeasureRectYCoord(View *v, MeasureRect &r, bool start, int y) const
539 } 539 }
540 540
541 Layer::MeasureRectSet::const_iterator 541 Layer::MeasureRectSet::const_iterator
542 Layer::findFocusedMeasureRect(QPoint focusPoint) const 542 Layer::findFocusedMeasureRect(QPoint focusPoint) const
543 { 543 {
544 float frDist = 0; 544 double frDist = 0;
545 MeasureRectSet::const_iterator focusRectItr = m_measureRects.end(); 545 MeasureRectSet::const_iterator focusRectItr = m_measureRects.end();
546 546
547 for (MeasureRectSet::const_iterator i = m_measureRects.begin(); 547 for (MeasureRectSet::const_iterator i = m_measureRects.begin();
548 i != m_measureRects.end(); ++i) { 548 i != m_measureRects.end(); ++i) {
549 549
552 int cx = i->pixrect.x() + i->pixrect.width()/2; 552 int cx = i->pixrect.x() + i->pixrect.width()/2;
553 int cy = i->pixrect.y() + i->pixrect.height()/2; 553 int cy = i->pixrect.y() + i->pixrect.height()/2;
554 int xd = focusPoint.x() - cx; 554 int xd = focusPoint.x() - cx;
555 int yd = focusPoint.y() - cy; 555 int yd = focusPoint.y() - cy;
556 556
557 float d = sqrt(float(xd * xd + yd * yd)); 557 double d = sqrt(double(xd * xd + yd * yd));
558 558
559 if (focusRectItr == m_measureRects.end() || d < frDist) { 559 if (focusRectItr == m_measureRects.end() || d < frDist) {
560 focusRectItr = i; 560 focusRectItr = i;
561 frDist = d; 561 frDist = d;
562 } 562 }