/* * TempoSyncKnobModel.cpp - adds bpm to ms conversion for knob class * * Copyright (c) 2005-2007 Danny McRae * Copyright (c) 2005-2009 Tobias Doerffel * * This file is part of Linux MultiMedia Studio - http://lmms.sourceforge.net * * 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. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * General Public License for more details. * * You should have received a copy of the GNU General Public * License along with this program (see COPYING); if not, write to the * Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, * Boston, MA 02110-1301 USA. * */ #include #include #include "TempoSyncKnobModel.h" #include "engine.h" #include "song.h" TempoSyncKnobModel::TempoSyncKnobModel( const float _val, const float _min, const float _max, const float _step, const float _scale, Model * _parent, const QString & _display_name ) : FloatModel( _val, _min, _max, _step, _parent, _display_name ), m_tempoSyncMode( SyncNone ), m_tempoLastSyncMode( SyncNone ), m_scale( _scale ), m_custom( _parent ) { connect( engine::getSong(), SIGNAL( tempoChanged( bpm_t ) ), this, SLOT( calculateTempoSyncTime( bpm_t ) ) ); } TempoSyncKnobModel::~TempoSyncKnobModel() { } void TempoSyncKnobModel::setTempoSync( QAction * _item ) { setTempoSync( _item->data().toInt() ); } void TempoSyncKnobModel::setTempoSync( int _note_type ) { setSyncMode( ( TempoSyncMode ) _note_type ); engine::getSong()->setModified(); } void TempoSyncKnobModel::calculateTempoSyncTime( bpm_t _bpm ) { float conversionFactor = 1.0; if( m_tempoSyncMode ) { switch( m_tempoSyncMode ) { case SyncCustom: conversionFactor = static_cast( m_custom.getDenominator() ) / static_cast( m_custom.getNumerator() ); break; case SyncDoubleWholeNote: conversionFactor = 0.125; break; case SyncWholeNote: conversionFactor = 0.25; break; case SyncHalfNote: conversionFactor = 0.5; break; case SyncQuarterNote: conversionFactor = 1.0; break; case SyncEighthNote: conversionFactor = 2.0; break; case SyncSixteenthNote: conversionFactor = 4.0; break; case SyncThirtysecondNote: conversionFactor = 8.0; break; default: ; } bool journalling = testAndSetJournalling( false ); float oneUnit = 60000.0 / ( _bpm * conversionFactor * m_scale ); setValue( oneUnit * maxValue() ); setJournalling( journalling ); } if( m_tempoSyncMode != m_tempoLastSyncMode ) { emit syncModeChanged( m_tempoSyncMode ); m_tempoLastSyncMode = m_tempoSyncMode; } } void TempoSyncKnobModel::saveSettings( QDomDocument & _doc, QDomElement & _this, const QString & _name ) { _this.setAttribute( "syncmode", (int) syncMode() ); m_custom.saveSettings( _doc, _this, _name ); FloatModel::saveSettings( _doc, _this, _name ); } void TempoSyncKnobModel::loadSettings( const QDomElement & _this, const QString & _name ) { setSyncMode( ( TempoSyncMode ) _this.attribute( "syncmode" ).toInt() ); m_custom.loadSettings( _this, _name ); FloatModel::loadSettings( _this, _name ); } void TempoSyncKnobModel::setSyncMode( TempoSyncMode _new_mode ) { if( m_tempoSyncMode != _new_mode ) { m_tempoSyncMode = _new_mode; if( _new_mode == SyncCustom ) { connect( &m_custom, SIGNAL( dataChanged() ), this, SLOT( updateCustom() ) ); } } calculateTempoSyncTime( engine::getSong()->getTempo() ); } void TempoSyncKnobModel::setScale( float _new_scale ) { m_scale = _new_scale; calculateTempoSyncTime( engine::getSong()->getTempo() ); emit scaleChanged( _new_scale ); } void TempoSyncKnobModel::updateCustom() { setSyncMode( SyncCustom ); } #include "moc_TempoSyncKnobModel.cxx"