summaryrefslogtreecommitdiffstats
path: root/kmilo/generic/generic_monitor.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'kmilo/generic/generic_monitor.cpp')
-rw-r--r--kmilo/generic/generic_monitor.cpp366
1 files changed, 151 insertions, 215 deletions
diff --git a/kmilo/generic/generic_monitor.cpp b/kmilo/generic/generic_monitor.cpp
index 9017f70..2c15ad5 100644
--- a/kmilo/generic/generic_monitor.cpp
+++ b/kmilo/generic/generic_monitor.cpp
@@ -1,4 +1,3 @@
-// -*- Mode: C++; c-basic-offset: 2; indent-tabs-mode: t; tab-width: 2; -*-
/*
This file is part of the KDE project
@@ -25,7 +24,7 @@
#include <kgenericfactory.h>
#include <kdebug.h>
-#include <kprocess.h>
+#include <tdeprocess.h>
#include <tdeconfig.h>
#include <sys/types.h>
@@ -36,33 +35,63 @@
#include <tqmessagebox.h>
#include <tqfile.h>
#include <tqdir.h>
+#include <tqtimer.h>
#define CONFIG_FILE "kmilodrc"
using namespace KMilo;
+// now the key data (from kkeyserver_x11.h and $TQTDIR/include/tqnamespace.h)
+struct ShortcutInfo
+{
+ const char* name;
+ int symbol;
+ const char *slot;
+};
+
+static const ShortcutInfo shortcuts[] =
+{
+ { "Search", TDEShortcut("XF86Search"), TQ_SLOT(launchSearch()) },
+ { "Home Folder", TDEShortcut("XF86MyComputer"), TQ_SLOT(launchHomeFolder()) },
+ { "Mail", TDEShortcut("XF86Mail"), TQ_SLOT(launchMail()) },
+ { "Audio Media", TDEShortcut("XF86AudioMedia"), TQ_SLOT(launchMusic()) },
+ { "Music", TDEShortcut("XF86Music"), TQ_SLOT(launchMusic()) },
+ { "Browser", TDEShortcut("XF86WWW"), TQ_SLOT(launchBrowser()) },
+ { "Calculator", TDEShortcut("XF86Calculator"), TQ_SLOT(launchCalculator()) },
+ { "Terminal", TDEShortcut("XF86Terminal"), TQ_SLOT(launchTerminal()) },
+ { "Eject", TDEShortcut("XF86Eject"), TQ_SLOT(eject()) },
+ { "Help", TDEShortcut("XF86Launch0"), TQ_SLOT(launchHelp()) },
+ { "Light Bulb", TDEShortcut("XF86LightBulb"), TQ_SLOT(lightBulb()) },
+ { "Battery", TDEShortcut("XF86LaunchB"), TQ_SLOT(pmBattery()) },
+ { "FastVolumeUp", TQt::Key_VolumeUp, TQ_SLOT(fastVolumeUp()) },
+ { "FastVolumeDown", TQt::Key_VolumeDown, TQ_SLOT(fastVolumeDown()) },
+ { "SlowVolumeUp", TQt::CTRL+TQt::Key_VolumeUp, TQ_SLOT(slowVolumeUp()) },
+ { "SlowVolumeDown", TQt::CTRL+TQt::Key_VolumeDown, TQ_SLOT(slowVolumeDown()) },
+ { "Mute", TDEShortcut("XF86AudioMute"), TQ_SLOT(toggleMute()) },
+ { "BrightnessUp", TDEShortcut("XF86MonBrightnessUp"), TQ_SLOT(brightnessUp()) },
+ { "BrightnessDown", TDEShortcut("XF86MonBrightnessDown"), TQ_SLOT(brightnessDown()) },
+ { "BrightnessSlowUp", TDEShortcut("Ctrl+XF86MonBrightnessUp"), TQ_SLOT(brightnessSlowUp()) },
+ { "BrightnessSlowDown", TDEShortcut("Ctrl+XF86MonBrightnessDown"), TQ_SLOT(brightnessSlowDown()) }
+};
+
GenericMonitor::GenericMonitor(TQObject *parent, const char *name, const TQStringList& args)
-: Monitor(parent, name, args), kmixClient(NULL), kmixWindow(NULL), tdepowersave(NULL)
+: Monitor(parent, name, args), kmixClient(NULL), kmixWindow(NULL), tdepowersave(NULL),
+ m_progress(0), m_displayType(Monitor::None)
{
_poll = false;
- m_displayType = Monitor::None;
-
- m_mute = false;
- m_progress = 0;
- m_minVolume = 0;
- m_maxVolume = 100;
- m_volume = 50;
}
GenericMonitor::~GenericMonitor()
{
- if(ga) {
- ga->remove("FastVolumeUp");
- ga->remove("FastVolumeDown");
- ga->remove("SlowVolumeUp");
- ga->remove("SlowVolumeDown");
- ga->remove("Mute");
+ if (ga)
+ {
+ int len = (int)sizeof(shortcuts)/sizeof(ShortcutInfo);
+ for (int i = 0; i < len; i++)
+ {
+ ga->remove(shortcuts[i].name);
+ }
+ ga->updateConnections();
delete ga;
}
}
@@ -75,27 +104,6 @@ bool GenericMonitor::init()
if(!m_enabled)
return false; // exit early if we are not supposed to run
- static const ShortcutInfo shortcuts[] = {
- { "Search", TDEShortcut("XF86Search"), TQT_SLOT(launchSearch()) },
- { "Home Folder", TDEShortcut("XF86MyComputer"), TQT_SLOT(launchHomeFolder()) },
- { "Mail", TDEShortcut("XF86Mail"), TQT_SLOT(launchMail()) },
- { "Audio Media", TDEShortcut("XF86AudioMedia"), TQT_SLOT(launchMusic()) },
- { "Music", TDEShortcut("XF86Music"), TQT_SLOT(launchMusic()) },
- { "Browser", TDEShortcut("XF86WWW"), TQT_SLOT(launchBrowser()) },
- { "Calculator", TDEShortcut("XF86Calculator"), TQT_SLOT(launchCalculator()) },
- { "Terminal", TDEShortcut("XF86Terminal"), TQT_SLOT(launchTerminal()) },
- { "Eject", TDEShortcut("XF86Eject"), TQT_SLOT(eject()) },
- { "Help", TDEShortcut("XF86Launch0"), TQT_SLOT(launchHelp()) },
- { "Light Bulb", TDEShortcut("XF86LightBulb"), TQT_SLOT(lightBulb()) },
- { "Battery", TDEShortcut("XF86LaunchB"), TQT_SLOT(pmBattery()) },
- { "FastVolumeUp", TQt::Key_VolumeUp, TQT_SLOT(fastVolumeUp()) },
- { "FastVolumeDown", TQt::Key_VolumeDown, TQT_SLOT(fastVolumeDown()) },
- { "SlowVolumeUp", TQt::CTRL+TQt::Key_VolumeUp, TQT_SLOT(slowVolumeUp()) },
- { "SlowVolumeDown", TQt::CTRL+TQt::Key_VolumeDown, TQT_SLOT(slowVolumeDown()) },
- { "Mute", TDEShortcut("XF86AudioMute"), TQT_SLOT(mute()) },
- { "BrightnessUp", TDEShortcut("XF86MonBrightnessUp"), TQT_SLOT(brightnessUp()) },
- { "BrightnessDown", TDEShortcut("XF86MonBrightnessDown"), TQT_SLOT(brightnessDown()) }
- };
ga = new TDEGlobalAccel(this, "miloGenericAccel");
@@ -113,7 +121,7 @@ bool GenericMonitor::init()
ga->readSettings();
ga->updateConnections();
- kmixClient = new DCOPRef("kmix", "Mixer0");
+ kmixClient = new DCOPRef("kmix", "kmix");
kmixWindow = new DCOPRef("kmix", "kmix-mainwindow#1");
tdepowersave = new DCOPRef("tdepowersave", "tdepowersaveIface");
@@ -123,114 +131,72 @@ bool GenericMonitor::init()
void GenericMonitor::reconfigure(TDEConfig *config)
{
config->setGroup("generic monitor");
-
- m_volumeDeviceIdx = config->readNumEntry("volumeDeviceIdx", -1);
- m_muteDeviceIdx = config->readNumEntry("muteDeviceIdx", m_volumeDeviceIdx);
- m_extraDeviceIdx = config->readNumEntry("extraDeviceIdx", -1);
m_volumeStepFast = config->readNumEntry("volumeStepFast", 10);
m_volumeStepSlow = config->readNumEntry("volumeStepSlow", 1);
m_enabled = config->readBoolEntry("enabled", true);
}
-bool GenericMonitor::retrieveKmixDevices()
+bool GenericMonitor::retrieveVolume(int &volume)
{
- if(m_volumeDeviceIdx != -1 && m_muteDeviceIdx != -1)
- return true; // both indexes already set
-
- DCOPReply reply = kmixClient->call("masterDeviceIndex");
- if (!reply.isValid())
- { // maybe the error occurred because kmix wasn't running
- _interface->displayText(i18n("Starting KMix..."));
- if (kapp->startServiceByDesktopName("kmix")==0) // trying to start kmix
- {
- reply = kmixClient->call("masterDeviceIndex");
- if (reply.isValid())
- kmixWindow->send("hide");
- }
- }
-
- if (!reply.isValid())
+ DCOPReply reply = kmixClient->call("volume");
+ if (reply.isValid())
{
- kdDebug() << "KMilo: GenericMonitor could not access kmix/Mixer0 via dcop"
- << endl;
- _interface->displayText(i18n("It seems that KMix is not running."));
-
- return false;
- } else {
- if (m_volumeDeviceIdx == -1)
- m_volumeDeviceIdx = reply;
- if (m_muteDeviceIdx == -1)
- m_muteDeviceIdx = m_volumeDeviceIdx; // this is the behaviour documented in README
+ volume = reply;
return true;
}
+
+ // maybe the error occurred because kmix wasn't running. Try to start it
+ _interface->displayText(i18n("Starting KMix..."));
+ if (tdeApp->startServiceByDesktopName("kmix") == 0)
+ {
+ // trying again
+ reply = kmixClient->call("volume");
+ if (reply.isValid())
+ {
+ volume = reply;
+ kmixWindow->send("hide");
+ return true;
+ }
+ }
+ kdDebug() << "KMilo: GenericMonitor could not access kmix via dcop" << endl;
+ _interface->displayText(i18n("It seems that KMix is not running."));
+ return false;
}
-bool GenericMonitor::retrieveVolume()
+void GenericMonitor::volumeChange(int direction, int percentage)
{
- bool kmix_error = false;
-
- if(!retrieveKmixDevices())
- return false;
-
- DCOPReply reply = kmixClient->call("absoluteVolume", m_volumeDeviceIdx);
- if (reply.isValid())
- m_volume = reply;
- else
- kmix_error = true;
+ int volume;
+ if (!direction || !retrieveVolume(volume))
+ {
+ return;
+ }
- if (kmix_error) // maybe the error occurred because kmix wasn't running
+ if (direction > 0)
{
- _interface->displayText(i18n("Starting KMix..."));
- if (kapp->startServiceByDesktopName("kmix")==0) // trying to start kmix
+ volume += percentage;
+ if (volume > 100)
{
- // trying again
- reply = kmixClient->call("absoluteVolume", m_volumeDeviceIdx);
- if (reply.isValid())
- {
- m_volume = reply;
- kmix_error = false;
- kmixWindow->send("hide");
- }
+ volume = 100;
}
}
-
- if (kmix_error)
+ else
{
- kdDebug() << "KMilo: GenericMonitor could not access kmix/Mixer0 via dcop"
- << endl;
- _interface->displayText(i18n("It seems that KMix is not running."));
-
- return false;
- } else {
- reply = kmixClient->call("absoluteVolumeMax", m_volumeDeviceIdx);
- m_maxVolume = reply;
- reply = kmixClient->call("absoluteVolumeMin", m_volumeDeviceIdx);
- m_minVolume = reply;
- return true;
+ volume -= percentage;
+ if (volume < 0)
+ {
+ volume = 0;
+ }
}
-}
-void GenericMonitor::volumeChange(int direction, int step)
-{
- if (!retrieveVolume())
- return;
+ _interface->displayProgress(i18n("Volume"), volume);
+ kmixClient->send("setVolume", volume);
- /* Following snippet of code may seem to be overcomplicated, but it works for both devices with
- * volume grain < 100 (32 tested) and devices with volume grain > 100 (256 tested) while preserving
- * accuracy for devices with fine grain and preserving usability for devices with rough grain. */
- int userVisibleVolume = tqRound(m_volume * 100.0 / (m_maxVolume - m_minVolume));
- userVisibleVolume += direction * step; // add requested volume step
- long previousVolume = m_volume;
- m_volume = tqRound(m_minVolume + userVisibleVolume * (m_maxVolume - m_minVolume) / 100.0);
- if (m_volume == previousVolume) // if the change was rounded to zero
- m_volume += direction;
-
- if (m_volume > m_maxVolume)
- m_volume = m_maxVolume;
- if (m_volume < m_minVolume)
- m_volume = m_minVolume;
-
- displayVolume();
+ // if mute then unmute
+ bool muted = false;
+ if (retrieveMute(muted) && muted)
+ {
+ kmixClient->send("setMute", false);
+ }
}
void GenericMonitor::slowVolumeUp() { volumeChange( 1, m_volumeStepSlow); }
@@ -238,90 +204,53 @@ void GenericMonitor::slowVolumeDown() { volumeChange(-1, m_volumeStepSlow); }
void GenericMonitor::fastVolumeUp() { volumeChange( 1, m_volumeStepFast); }
void GenericMonitor::fastVolumeDown() { volumeChange(-1, m_volumeStepFast); }
-void GenericMonitor::displayVolume()
+bool GenericMonitor::retrieveMute(bool &muted)
{
- _interface->displayProgress(i18n("Volume"), tqRound(m_volume * 100.0 / (m_maxVolume - m_minVolume)));
-
- // If we got this far, the DCOP communication with kmix works,
- // so we don't have to test the result.
- // Also, device indexes are set to their proper values.
- kmixClient->send("setAbsoluteVolume", m_volumeDeviceIdx, m_volume);
- if(m_extraDeviceIdx != -1)
- // for simplicity, use relative volume rather that absolute (extra precision is not needed here)
- kmixClient->send("setVolume", m_extraDeviceIdx, tqRound(m_volume * 100.0 / (m_maxVolume - m_minVolume)));
-
- // if mute then unmute
- if (m_mute)
+ DCOPReply reply = kmixClient->call("mute");
+ if (reply.isValid())
{
- m_mute = false;
- kmixClient->send("setMute", m_muteDeviceIdx, m_mute);
+ muted = reply;
+ return true;
}
-}
-
-bool GenericMonitor::retrieveMute()
-{
- bool kmix_error = false;
-
- if(!retrieveKmixDevices())
- return false;
-
- DCOPReply reply = kmixClient->call("mute", m_muteDeviceIdx);
- if (reply.isValid())
- m_mute = reply;
- else
- kmix_error = true;
- if (kmix_error)
+ // maybe the error occurred because kmix wasn't running. Try to start it
+ _interface->displayText(i18n("Starting KMix..."));
+ if (tdeApp->startServiceByDesktopName("kmix") == 0)
{
- // maybe the error occurred because kmix wasn't running
- _interface->displayText(i18n("Starting KMix..."));
- if (kapp->startServiceByDesktopName("kmix")==0) // trying to start kmix
- {
- // trying again
- reply = kmixClient->call("mute", m_muteDeviceIdx);
- if (reply.isValid())
- {
- m_mute = reply;
- kmix_error = false;
- kmixWindow->send("hide");
- }
- } else
+ // trying again
+ reply = kmixClient->call("mute");
+ if (reply.isValid())
{
+ muted = reply;
kmixWindow->send("hide");
- kmix_error = true;
+ return true;
}
}
-
- if (kmix_error)
- {
- kdDebug() << "KMilo: GenericMonitor could not access kmix/Mixer0 via dcop"
- << endl;
- _interface->displayText(i18n("It seems that KMix is not running."));
-
- return false;
- } else {
- return true;
- }
+ kdDebug() << "KMilo: GenericMonitor could not access kmix via dcop" << endl;
+ _interface->displayText(i18n("It seems that KMix is not running."));
+ return false;
}
-void GenericMonitor::mute()
+void GenericMonitor::toggleMute()
{
- if (!retrieveMute())
+ bool muted = false;
+ if (!retrieveMute(muted))
+ {
return;
+ }
- m_mute = !m_mute;
+ muted = !muted;
TQString muteText;
- if (m_mute)
+ if (muted)
{
- muteText = i18n("Mute on");
- } else {
- muteText = i18n("Mute off");
+ muteText = i18n("System muted");
+ }
+ else
+ {
+ muteText = i18n("System unmuted");
}
- kmixClient->send("setMute", m_muteDeviceIdx, m_mute);
- if(m_extraDeviceIdx != -1)
- kmixClient->send("setMute", m_extraDeviceIdx, m_mute);
-
+ kmixClient->send("setMute", muted);
_interface->displayText(muteText);
}
@@ -335,44 +264,51 @@ void GenericMonitor::brightnessDown()
brightnessChange(-1, 10);
}
+void GenericMonitor::brightnessSlowUp()
+{
+ brightnessChange(1, 1);
+}
+
+void GenericMonitor::brightnessSlowDown()
+{
+ brightnessChange(-1, 1);
+}
+
void GenericMonitor::brightnessChange(int direction, int step)
{
- if (!tdepowersave)
+ if (!tdepowersave || direction == 0)
{
return;
}
+ if (direction > 0)
+ {
+ tdepowersave->call("do_brightnessUp", step);
+ }
+ else
+ {
+ tdepowersave->call("do_brightnessDown", step);
+ }
+ TQTimer::singleShot(250, this, TQ_SLOT(brightnessValueUpdate()));
+}
+
+void GenericMonitor::brightnessValueUpdate()
+{
DCOPReply reply = tdepowersave->call("brightnessGet");
if (reply.isValid())
{
- int brightnessLevel = 100 + (int)reply; // reply value is a negative number between 0 and -100.
- brightnessLevel += direction * step; // add requested brightness step
- if (brightnessLevel > 100)
- {
- brightnessLevel = 100;
- }
- if (brightnessLevel < 0)
- {
- brightnessLevel = 0;
- }
- if (direction > 0)
- {
- tdepowersave->send("do_brightnessUp", step);
- }
- else if (direction < 0)
- {
- tdepowersave->send("do_brightnessDown", step);
- }
- _interface->displayProgress(i18n("Brightness"), brightnessLevel);
+ // Display real brightness value. This may differ from the set value
+ // on machines with few brightness steps.
+ _interface->displayProgress(i18n("Brightness"), (int)reply);
}
}
-int GenericMonitor::progress() const
+int GenericMonitor::progress() const
{
return m_progress;
}
-Monitor::DisplayType GenericMonitor::poll()
+Monitor::DisplayType GenericMonitor::poll()
{
return m_displayType;
}
@@ -388,12 +324,12 @@ void GenericMonitor::launch(TQString configKey, TQString defaultApplication)
void GenericMonitor::launchMail()
{
kdDebug() << "launchMail" << endl;
- kapp->invokeMailer("", "", "", "", "", "", "", "");
+ tdeApp->invokeMailer("", "", "", "", "", "", "", "");
}
void GenericMonitor::launchBrowser()
{
- kapp->invokeBrowser("");
+ tdeApp->invokeBrowser("");
}
void GenericMonitor::launchSearch()