summaryrefslogtreecommitdiffstats
path: root/kmix/kmix.cpp
diff options
context:
space:
mode:
authorMichele Calgaro <michele.calgaro@yahoo.it>2020-05-20 01:19:55 +0900
committerMichele Calgaro <michele.calgaro@yahoo.it>2020-05-25 13:24:33 +0900
commitb06d352d14d9d917ff23288dd6a9433e4e75f7df (patch)
tree5518cf17eab0c4d4f3d76e02c610deccbea63339 /kmix/kmix.cpp
parentc0249fdb66a93f3fd3b413f8c05d455f05ae8cdb (diff)
downloadtdemultimedia-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.cpp172
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"