Mercurial > hg > svgui
changeset 784:3a52b458fcd5 tonioni
fixed note delete bug (now deletes when any overlap with the selection occurs)
author | matthiasm |
---|---|
date | Wed, 11 Jun 2014 19:41:29 +0100 (2014-06-11) |
parents | c1fc074971ed |
children | 488add397d34 |
files | layer/FlexiNoteLayer.cpp layer/FlexiNoteLayer.h view/View.cpp |
diffstat | 3 files changed, 58 insertions(+), 24 deletions(-) [+] |
line wrap: on
line diff
--- a/layer/FlexiNoteLayer.cpp Tue Jun 03 11:14:34 2014 +0100 +++ b/layer/FlexiNoteLayer.cpp Wed Jun 11 19:41:29 2014 +0100 @@ -820,6 +820,7 @@ FlexiNoteModel::Point illuminatePoint(0); bool shouldIlluminate = false; + if (v->shouldIlluminateLocalFeatures(this, localPos)) { shouldIlluminate = getPointToDrag(v, localPos.x(), localPos.y(), illuminatePoint); @@ -847,28 +848,31 @@ paint.setPen(getBaseQColor()); paint.setBrush(brushColour); - // if (shouldIlluminate && - // // "illuminatePoint == p" - // !FlexiNoteModel::Point::Comparator()(illuminatePoint, p) && - // !FlexiNoteModel::Point::Comparator()(p, illuminatePoint)) { - // - // paint.setPen(v->getForeground()); - // paint.setBrush(v->getForeground()); - // - // QString vlabel = QString("%1%2").arg(p.value).arg(m_model->getScaleUnits()); - // v->drawVisibleText(paint, - // x - paint.fontMetrics().width(vlabel) - 2, - // y + paint.fontMetrics().height()/2 - // - paint.fontMetrics().descent(), - // vlabel, View::OutlinedText); - // - // QString hlabel = RealTime::frame2RealTime - // (p.frame, m_model->getSampleRate()).toText(true).c_str(); - // v->drawVisibleText(paint, - // x, - // y - h/2 - paint.fontMetrics().descent() - 2, - // hlabel, View::OutlinedText); - // } + if (shouldIlluminate && + // "illuminatePoint == p" + !FlexiNoteModel::Point::Comparator()(illuminatePoint, p) && + !FlexiNoteModel::Point::Comparator()(p, illuminatePoint)) { + + paint.drawLine(x, -1, x, v->height() + 1); + paint.drawLine(x+w, -1, x+w, v->height() + 1); + + paint.setPen(v->getForeground()); + // paint.setBrush(v->getForeground()); + + QString vlabel = QString("%1%2").arg(p.value).arg(m_model->getScaleUnits()); + v->drawVisibleText(paint, + x - paint.fontMetrics().width(vlabel) - 2, + y + paint.fontMetrics().height()/2 + - paint.fontMetrics().descent(), + vlabel, View::OutlinedText); + + QString hlabel = RealTime::frame2RealTime + (p.duration, m_model->getSampleRate()).toText(true).c_str(); + v->drawVisibleText(paint, + x, + y - h/2 - paint.fontMetrics().descent() - 2, + hlabel, View::OutlinedText); + } paint.drawRect(x, y - h/2, w, h); } @@ -1472,7 +1476,13 @@ v->setCursor(Qt::ArrowCursor); - // std::cerr << "Mouse moved in edit mode over FlexiNoteLayer" << std::endl; + // QPainter paint; + // paint.begin(m_pan); + // QRect r(rect()); + // paint(v, paint, r); + // paint.end(this); + + std::cerr << "Mouse moved in edit mode over FlexiNoteLayer" << std::endl; // v->setCursor(Qt::SizeHorCursor); } @@ -1636,6 +1646,29 @@ } void +FlexiNoteLayer::deleteSelectionInclusive(Selection s) +{ + if (!m_model) return; + + FlexiNoteModel::EditCommand *command = + new FlexiNoteModel::EditCommand(m_model, tr("Delete Selected Points")); + + FlexiNoteModel::PointList points = + m_model->getPoints(s.getStartFrame(), s.getEndFrame()); + + for (FlexiNoteModel::PointList::iterator i = points.begin(); + i != points.end(); ++i) { + bool overlap = !(((s.getStartFrame() < i->frame) && (s.getEndFrame() < i->frame)) + || ((s.getStartFrame() > i->frame+i->duration) && (s.getEndFrame() > i->frame+i->duration))); + if (overlap) { + command->deletePoint(*i); + } + } + + finish(command); +} + +void FlexiNoteLayer::copy(View *v, Selection s, Clipboard &to) { if (!m_model) return;
--- a/layer/FlexiNoteLayer.h Tue Jun 03 11:14:34 2014 +0100 +++ b/layer/FlexiNoteLayer.h Wed Jun 11 19:41:29 2014 +0100 @@ -73,6 +73,7 @@ virtual void moveSelection(Selection s, size_t newStartFrame); virtual void resizeSelection(Selection s, Selection newSize); virtual void deleteSelection(Selection s); + virtual void deleteSelectionInclusive(Selection s); virtual void copy(View *v, Selection s, Clipboard &to); virtual bool paste(View *v, const Clipboard &from, int frameOffset,
--- a/view/View.cpp Tue Jun 03 11:14:34 2014 +0100 +++ b/view/View.cpp Wed Jun 11 19:41:29 2014 +0100 @@ -1563,7 +1563,7 @@ { // Profiler prof("View::paintEvent", false); // SVDEBUG << "View::paintEvent: centre frame is " << m_centreFrame << endl; - + // cerr << "View::paintEvent: centre frame is " << m_centreFrame << endl; if (m_layers.empty()) { QFrame::paintEvent(e); return;