diff options
author | Michele Calgaro <michele.calgaro@yahoo.it> | 2020-05-20 01:19:55 +0900 |
---|---|---|
committer | Michele Calgaro <michele.calgaro@yahoo.it> | 2020-05-25 13:24:33 +0900 |
commit | b06d352d14d9d917ff23288dd6a9433e4e75f7df (patch) | |
tree | 5518cf17eab0c4d4f3d76e02c610deccbea63339 /kmix/kmix.cpp | |
parent | c0249fdb66a93f3fd3b413f8c05d455f05ae8cdb (diff) | |
download | tdemultimedia-b06d352d14d9d917ff23288dd6a9433e4e75f7df.tar.gz tdemultimedia-b06d352d14d9d917ff23288dd6a9433e4e75f7df.zip |
KMix: 1) added direct DCOP access to the user selected mixer/device channel used as master.
2) fixed bug with volume update
3) unlinked global keyboard shortcuts for volume control to avoid
clashing with kmilo. A user can still link them manually if needed.
Signed-off-by: Michele Calgaro <michele.calgaro@yahoo.it>
Diffstat (limited to 'kmix/kmix.cpp')
-rw-r--r-- | kmix/kmix.cpp | 172 |
1 files changed, 147 insertions, 25 deletions
diff --git a/kmix/kmix.cpp b/kmix/kmix.cpp index 5bee4585..69630f61 100644 --- a/kmix/kmix.cpp +++ b/kmix/kmix.cpp @@ -61,7 +61,7 @@ * Constructs a mixer window (KMix main window) */ KMixWindow::KMixWindow() - : TDEMainWindow(0, 0, 0, 0), m_showTicks( true ), + : DCOPObject("kmix"), TDEMainWindow(0, 0, 0, 0), m_showTicks( true ), m_dockWidget( 0L ) { m_visibilityUpdateAllowed = true; @@ -121,11 +121,11 @@ KMixWindow::initActions() m_globalAccel = new TDEGlobalAccel(this, "KMix"); m_globalAccel->insert( "Increase volume", i18n( "Increase Volume of Master Channel"), TQString(), - TDEShortcut(TQString("XF86AudioRaiseVolume")), TDEShortcut(TQString("XF86AudioRaiseVolume")), TQT_TQOBJECT(this), TQT_SLOT( increaseVolume() ) ); + TDEShortcut(), TDEShortcut(), TQT_TQOBJECT(this), TQT_SLOT( slotIncreaseVolume() ) ); m_globalAccel->insert( "Decrease volume", i18n( "Decrease Volume of Master Channel"), TQString(), - TDEShortcut(TQString("XF86AudioLowerVolume")), TDEShortcut(TQString("XF86AudioLowerVolume")), TQT_TQOBJECT(this), TQT_SLOT( decreaseVolume() ) ); + TDEShortcut(), TDEShortcut(), TQT_TQOBJECT(this), TQT_SLOT( slotDecreaseVolume() ) ); m_globalAccel->insert( "Toggle mute", i18n( "Toggle Mute of Master Channel"), TQString(), - TDEShortcut(TQString("XF86AudioMute")), TDEShortcut(TQString("XF86AudioMute")), TQT_TQOBJECT(this), TQT_SLOT( toggleMuted() ) ); + TDEShortcut(), TDEShortcut(), TQT_TQOBJECT(this), TQT_SLOT( slotToggleMuted() ) ); m_globalAccel->readSettings(); m_globalAccel->updateConnections(); @@ -619,40 +619,162 @@ KMixWindow::configureGlobalShortcuts() m_globalAccel->updateConnections(); } -void -KMixWindow::toggleMuted() +// KMixIface DCOP interface methods +void KMixWindow::setVolume(int percentage) +{ + Mixer *mixerMaster = Mixer::masterCard(); + if (mixerMaster) + { + mixerMaster->setMasterVolume(percentage); + } +} + +void KMixWindow::increaseVolume(int percentage) { - Mixer* mixerMaster = Mixer::masterCard(); - if ( mixerMaster != 0 ) { - MixDevice* md = mixerMaster->masterDevice(); - if ( md != 0 && md->hasMute() ) { - mixerMaster->toggleMute(md->num()); + Mixer *mixerMaster = Mixer::masterCard(); + if (mixerMaster) + { + MixDevice *md = mixerMaster->masterDevice(); + if (md) + { + mixerMaster->increaseVolume(md->num(), percentage); } } } -void -KMixWindow::increaseVolume() +void KMixWindow::decreaseVolume(int percentage) { - Mixer* mixerMaster = Mixer::masterCard(); - if ( mixerMaster != 0 ) { - MixDevice* md = mixerMaster->masterDevice(); - if ( md != 0 ) { - mixerMaster->increaseVolume(md->num()); + Mixer *mixerMaster = Mixer::masterCard(); + if (mixerMaster) + { + MixDevice *md = mixerMaster->masterDevice(); + if (md) + { + mixerMaster->decreaseVolume(md->num(), percentage); } } } -void -KMixWindow::decreaseVolume() +int KMixWindow::volume() +{ + Mixer *mixerMaster = Mixer::masterCard(); + if (mixerMaster) + { + return mixerMaster->masterVolume(); + } + return -1; +} + +void KMixWindow::setAbsoluteVolume(long absoluteVolume) +{ + Mixer *mixerMaster = Mixer::masterCard(); + if (mixerMaster) + { + MixDevice *md = mixerMaster->masterDevice(); + if (md) + { + return mixerMaster->setAbsoluteVolume(md->num(), absoluteVolume); + } + } +} + +long KMixWindow::absoluteVolume() +{ + Mixer *mixerMaster = Mixer::masterCard(); + if (mixerMaster) + { + MixDevice *md = mixerMaster->masterDevice(); + if (md) + { + return mixerMaster->absoluteVolume(md->num()); + } + } + return -1L; +} + +long KMixWindow::absoluteVolumeMin() +{ + Mixer *mixerMaster = Mixer::masterCard(); + if (mixerMaster) + { + MixDevice *md = mixerMaster->masterDevice(); + if (md) + { + return mixerMaster->absoluteVolumeMin(md->num()); + } + } + return -1L; +} + +long KMixWindow::absoluteVolumeMax() { - Mixer* mixerMaster = Mixer::masterCard(); - if ( mixerMaster != 0 ) { - MixDevice* md = mixerMaster->masterDevice(); - if ( md != 0 ) { - mixerMaster->decreaseVolume(md->num()); + Mixer *mixerMaster = Mixer::masterCard(); + if (mixerMaster) + { + MixDevice *md = mixerMaster->masterDevice(); + if (md) + { + return mixerMaster->absoluteVolumeMax(md->num()); } } + return -1L; +} + +void KMixWindow::setMute(bool on) +{ + Mixer *mixerMaster = Mixer::masterCard(); + if (mixerMaster) + { + mixerMaster->setMasterMute(on); + } +} + +void KMixWindow::toggleMute() +{ + Mixer *mixerMaster = Mixer::masterCard(); + if (mixerMaster) + { + mixerMaster->toggleMasterMute(); + } +} + +bool KMixWindow::mute() +{ + Mixer *mixerMaster = Mixer::masterCard(); + if (mixerMaster) + { + return mixerMaster->masterMute(); + } + return true; +} + +TQString KMixWindow::mixerName() +{ + Mixer *mixerMaster = Mixer::masterCard(); + if (mixerMaster) + { + return mixerMaster->mixerName(); + } + return TQString::null; +} + +int KMixWindow::deviceIndex() +{ + Mixer *mixerMaster = Mixer::masterCard(); + if (mixerMaster) + { + return mixerMaster->masterDeviceIndex(); + } + return -1; +} + +void KMixWindow::setBalance(int balance) +{ + Mixer *mixerMaster = Mixer::masterCard(); + if (mixerMaster) + { + mixerMaster->setBalance(balance); + } } #include "kmix.moc" |