Mercurial > hg > svgui
comparison layer/Layer.cpp @ 1436:c697186a8471 single-point
Fix tendency of start position of measure rect to wander as you drag out the rect (at certain zoom resolutions)
author | Chris Cannam |
---|---|
date | Thu, 21 Mar 2019 15:22:19 +0000 |
parents | 62e908518c71 |
children | b22a4df37095 |
comparison
equal
deleted
inserted
replaced
1433:9abddbd57667 | 1436:c697186a8471 |
---|---|
371 } | 371 } |
372 | 372 |
373 void | 373 void |
374 Layer::measureStart(LayerGeometryProvider *v, QMouseEvent *e) | 374 Layer::measureStart(LayerGeometryProvider *v, QMouseEvent *e) |
375 { | 375 { |
376 setMeasureRectFromPixrect(v, m_draggingRect, | 376 m_draggingRect.haveFrames = hasTimeXAxis(); |
377 QRect(e->x(), e->y(), 0, 0)); | 377 |
378 // NB if haveFrames, then pixrect x and width will be rewritten on | |
379 // every paint according to the current locations of the | |
380 // definitive frame values. So we should set the start frame value | |
381 // once on measureStart, and then not modify it on drag (to avoid | |
382 // drift from repeated conversion back and forth). | |
383 | |
384 m_draggingRect.pixrect = QRect(e->x(), e->y(), 0, 0); | |
385 | |
386 if (m_draggingRect.haveFrames) { | |
387 m_draggingRect.startFrame = v->getFrameForX(e->x()); | |
388 m_draggingRect.endFrame = v->getFrameForX(e->x()); | |
389 } | |
390 | |
391 setMeasureRectYCoord(v, m_draggingRect, true, e->y()); | |
392 setMeasureRectYCoord(v, m_draggingRect, false, e->y()); | |
393 | |
378 m_haveDraggingRect = true; | 394 m_haveDraggingRect = true; |
379 } | 395 } |
380 | 396 |
381 void | 397 void |
382 Layer::measureDrag(LayerGeometryProvider *v, QMouseEvent *e) | 398 Layer::measureDrag(LayerGeometryProvider *v, QMouseEvent *e) |
383 { | 399 { |
384 if (!m_haveDraggingRect) return; | 400 if (!m_haveDraggingRect) return; |
385 | 401 |
386 setMeasureRectFromPixrect(v, m_draggingRect, | 402 m_draggingRect.pixrect.setHeight(e->y() - m_draggingRect.pixrect.y()); |
387 QRect(m_draggingRect.pixrect.x(), | 403 |
388 m_draggingRect.pixrect.y(), | 404 if (m_draggingRect.haveFrames) { |
389 e->x() - m_draggingRect.pixrect.x(), | 405 m_draggingRect.endFrame = v->getFrameForX(e->x()); |
390 e->y() - m_draggingRect.pixrect.y())); | 406 } else { |
407 m_draggingRect.pixrect.setWidth(e->x() - m_draggingRect.pixrect.x()); | |
408 } | |
409 | |
410 setMeasureRectYCoord(v, m_draggingRect, false, e->y()); | |
391 } | 411 } |
392 | 412 |
393 void | 413 void |
394 Layer::measureEnd(LayerGeometryProvider *v, QMouseEvent *e) | 414 Layer::measureEnd(LayerGeometryProvider *v, QMouseEvent *e) |
395 { | 415 { |