1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138
|
// -*- c-basic-offset: 4 -*-
/*
Rosegarden-4
A sequencer and musical notation editor.
This program is Copyright 2000-2005
Guillaume Laurent <glaurent@telegraph-road.org>,
Chris Cannam <cannam@all-day-breakfast.com>,
Richard Bown <bownie@bownie.com>
The moral right of the authors to claim authorship of this work
has been asserted.
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License as
published by the Free Software Foundation; either version 2 of the
License, or (at your option) any later version. See the file
COPYING included with this distribution for more information.
*/
#include "matrixcommands.h"
#include "BaseProperties.h"
#include "SegmentMatrixHelper.h"
#include <klocale.h>
#include "rosestrings.h"
#include "rosedebug.h"
using Rosegarden::Event;
using Rosegarden::Note;
using Rosegarden::timeT;
MatrixInsertionCommand::MatrixInsertionCommand(Rosegarden::Segment &segment,
timeT time,
timeT endTime,
Event *event) :
BasicCommand(i18n("Insert Note"), segment, time, endTime),
m_event(new Event(*event,
std::min(time, endTime),
(time < endTime) ? endTime - time : time - endTime))
{
// nothing
}
MatrixInsertionCommand::~MatrixInsertionCommand()
{
delete m_event;
// don't want to delete m_lastInsertedEvent, it's just an alias
}
void MatrixInsertionCommand::modifySegment()
{
MATRIX_DEBUG << "MatrixInsertionCommand::modifySegment()\n";
if (!m_event->has(Rosegarden::BaseProperties::VELOCITY)) {
m_event->set<Rosegarden::Int>(Rosegarden::BaseProperties::VELOCITY, 100);
}
Rosegarden::SegmentMatrixHelper helper(getSegment());
m_lastInsertedEvent = new Event(*m_event);
helper.insertNote(m_lastInsertedEvent);
}
MatrixEraseCommand::MatrixEraseCommand(Rosegarden::Segment &segment,
Event *event) :
BasicCommand(i18n("Erase Note"),
segment,
event->getAbsoluteTime(),
event->getAbsoluteTime() + event->getDuration(),
true),
m_event(event),
m_relayoutEndTime(getEndTime())
{
// nothing
}
timeT MatrixEraseCommand::getRelayoutEndTime()
{
return m_relayoutEndTime;
}
void MatrixEraseCommand::modifySegment()
{
Rosegarden::SegmentMatrixHelper helper(getSegment());
std::string eventType = m_event->getType();
if (eventType == Note::EventType) {
helper.deleteNote(m_event, false);
}
}
MatrixModifyCommand::MatrixModifyCommand(Rosegarden::Segment &segment,
Rosegarden::Event *oldEvent,
Rosegarden::Event *newEvent,
bool isMove,
bool normalize):
BasicCommand((isMove ? i18n("Move Note") : i18n("Modify Note")),
segment,
std::min(newEvent->getAbsoluteTime(),
oldEvent->getAbsoluteTime()),
std::max(oldEvent->getAbsoluteTime() +
oldEvent->getDuration(),
newEvent->getAbsoluteTime() +
newEvent->getDuration()),
true),
m_normalize(normalize),
m_oldEvent(oldEvent),
m_newEvent(newEvent)
{
}
void MatrixModifyCommand::modifySegment()
{
std::string eventType = m_oldEvent->getType();
if (eventType == Note::EventType) {
timeT normalizeStart = std::min(m_newEvent->getAbsoluteTime(),
m_oldEvent->getAbsoluteTime());
timeT normalizeEnd = std::max(m_newEvent->getAbsoluteTime() +
m_newEvent->getDuration(),
m_oldEvent->getAbsoluteTime() +
m_oldEvent->getDuration());
Rosegarden::Segment &segment(getSegment());
segment.insert(m_newEvent);
segment.eraseSingle(m_oldEvent);
if (m_normalize) {
segment.normalizeRests(normalizeStart, normalizeEnd);
}
}
}
|