1
0
mirror of https://github.com/cookiengineer/audacity synced 2025-08-10 00:51:13 +02:00

Add Tracks->Pan->Left/Right/Center

This commit is contained in:
James Crook 2017-04-03 22:35:19 +01:00
parent c9b03b51a2
commit 52f0f750d9
4 changed files with 60 additions and 5 deletions

View File

@ -954,6 +954,13 @@ void AudacityProject::CreateMenusAndCommands()
c->AddItem(wxT("UnMuteAllTracks"), _("&Unmute All Tracks"), FN(OnUnMuteAllTracks), wxT("Ctrl+Shift+U"));
c->EndSubMenu();
c->BeginSubMenu("Pan");
c->AddItem(wxT("PanLeft"), _("&Left"), FN(OnPanLeft));
c->AddItem(wxT("PanRight"), _("&Right"), FN(OnPanRight));
c->AddItem(wxT("PanCenter"), _("&Center"), FN(OnPanCenter));
c->EndSubMenu();
c->AddSeparator();
wxArrayString alignLabelsNoSync;
@ -7363,6 +7370,41 @@ void AudacityProject::OnExpandAllTracks()
RedrawProject();
}
void AudacityProject::OnPanTracks(float PanValue)
{
TrackListIterator iter(GetTracks());
Track *t = iter.First();
// count selected wave tracks
int count =0;
while (t)
{
if( t->GetKind() == Track::Wave && t->GetSelected() )
count++;
t = iter.Next();
}
// iter through them, all if none selected.
t = iter.First();
while (t)
{
if( t->GetKind() == Track::Wave && ((count==0) || t->GetSelected()) ){
WaveTrack *left = (WaveTrack *)t;
left->SetPan( PanValue );
}
t = iter.Next();
}
ModifyState(true);
RedrawProject();
if (mMixerBoard)
mMixerBoard->UpdatePan();
}
void AudacityProject::OnPanLeft(){ OnPanTracks( -1.0);}
void AudacityProject::OnPanRight(){ OnPanTracks( 1.0);}
void AudacityProject::OnPanCenter(){ OnPanTracks( 0.0);}
void AudacityProject::OnMuteAllTracks()
{

View File

@ -311,6 +311,11 @@ void OnGoSelEnd();
void OnExpandAllTracks();
void OnCollapseAllTracks();
void OnPanTracks(float PanValue);
void OnPanLeft();
void OnPanRight();
void OnPanCenter();
void OnMuteAllTracks();
void OnUnMuteAllTracks();

View File

@ -1227,10 +1227,18 @@ void MixerBoard::UpdateSolo(const PlayableTrack* pTrack /*= NULL*/) // NULL mean
void MixerBoard::UpdatePan(const PlayableTrack* pTrack)
{
MixerTrackCluster* pMixerTrackCluster;
FindMixerTrackCluster(pTrack, &pMixerTrackCluster);
if (pMixerTrackCluster)
pMixerTrackCluster->UpdatePan();
if (pTrack == NULL)
{
for (unsigned int i = 0; i < mMixerTrackClusters.GetCount(); i++)
mMixerTrackClusters[i]->UpdatePan();
}
else
{
MixerTrackCluster* pMixerTrackCluster;
FindMixerTrackCluster(pTrack, &pMixerTrackCluster);
if (pMixerTrackCluster)
pMixerTrackCluster->UpdatePan();
}
}
void MixerBoard::UpdateGain(const PlayableTrack* pTrack)

View File

@ -236,7 +236,7 @@ public:
void UpdateName(const PlayableTrack* pTrack);
void UpdateMute(const PlayableTrack* pTrack = NULL); // NULL means update for all tracks.
void UpdateSolo(const PlayableTrack* pTrack = NULL); // NULL means update for all tracks.
void UpdatePan(const PlayableTrack* pTrack);
void UpdatePan(const PlayableTrack* pTrack = NULL); // NULL means update for all tracks.
void UpdateGain(const PlayableTrack* pTrack);
#ifdef EXPERIMENTAL_MIDI_OUT
void UpdateVelocity(const PlayableTrack* pTrack);