From 145364a8af6a1fec06556221e66d4b724a62fc9a Mon Sep 17 00:00:00 2001 From: tpearson Date: Mon, 1 Mar 2010 18:37:05 +0000 Subject: Added old abandoned KDE3 version of the RoseGarden MIDI tool git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/applications/rosegarden@1097595 283d02a7-25f6-0310-bc7c-ecb5cbfe19da --- src/commands/edit/TransposeCommand.cpp | 83 ++++++++++++++++++++++++++++++++++ 1 file changed, 83 insertions(+) create mode 100644 src/commands/edit/TransposeCommand.cpp (limited to 'src/commands/edit/TransposeCommand.cpp') diff --git a/src/commands/edit/TransposeCommand.cpp b/src/commands/edit/TransposeCommand.cpp new file mode 100644 index 0000000..4d08079 --- /dev/null +++ b/src/commands/edit/TransposeCommand.cpp @@ -0,0 +1,83 @@ +/* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */ + +/* + Rosegarden + A MIDI and audio sequencer and musical notation editor. + + This program is Copyright 2000-2008 + Guillaume Laurent , + Chris Cannam , + Richard Bown + + The moral rights of Guillaume Laurent, Chris Cannam, and Richard + Bown to claim authorship of this work have been asserted. + + Other copyrights also apply to some parts of this work. Please + see the AUTHORS file and individual file headers for details. + + 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 "TransposeCommand.h" + +#include +#include "base/NotationTypes.h" +#include "base/Selection.h" +#include "document/BasicSelectionCommand.h" +#include +#include "base/BaseProperties.h" + + +namespace Rosegarden +{ + +using namespace BaseProperties; +using namespace Accidentals; + +void +TransposeCommand::modifySegment() +{ + EventSelection::eventcontainer::iterator i; + + for (i = m_selection->getSegmentEvents().begin(); + i != m_selection->getSegmentEvents().end(); ++i) { + + if ((*i)->isa(Note::EventType)) { + + if (m_diatonic) + { + + Pitch oldPitch(**i); + + timeT noteTime = (*i)->getAbsoluteTime(); + Key key = m_selection->getSegment().getKeyAtTime(noteTime); + Pitch newPitch = oldPitch.transpose(key, m_semitones, m_steps); + Event * newNoteEvent = newPitch.getAsNoteEvent(0, 0); + Accidental newAccidental; + newNoteEvent->get(BaseProperties::ACCIDENTAL, newAccidental); + + (*i)->set(PITCH, newPitch.getPerformancePitch()); + (*i)->set(ACCIDENTAL, newAccidental); + } + else + { + try { + long pitch = (*i)->get(PITCH); + pitch += m_semitones; + (*i)->set(PITCH, pitch); + if ((m_semitones % 12) != 0) { + (*i)->unset(ACCIDENTAL); + } + } catch (...) { } + } + + } + } +} + +} -- cgit v1.2.3