summaryrefslogtreecommitdiff
authorllornkcor <llornkcor>2002-05-23 02:03:12 (UTC)
committer llornkcor <llornkcor>2002-05-23 02:03:12 (UTC)
commitd295491048567c8424643b983a21dc503857d91a (patch) (unidiff)
tree54cc32b49eef8518ffbeeacb99ffcbb35ec60769
parent7cec3bc3d3b8945e80c9171b9173d3d2dbdd2eaf (diff)
downloadopie-d295491048567c8424643b983a21dc503857d91a.zip
opie-d295491048567c8424643b983a21dc503857d91a.tar.gz
opie-d295491048567c8424643b983a21dc503857d91a.tar.bz2
new sound config
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/applets/vmemo/vmemo.cpp14
-rw-r--r--core/applets/volumeapplet/volume.cpp168
-rw-r--r--core/applets/volumeapplet/volume.h9
3 files changed, 130 insertions, 61 deletions
diff --git a/core/applets/vmemo/vmemo.cpp b/core/applets/vmemo/vmemo.cpp
index c27050d..7cc4062 100644
--- a/core/applets/vmemo/vmemo.cpp
+++ b/core/applets/vmemo/vmemo.cpp
@@ -256,110 +256,108 @@ void VMemo::paintEvent( QPaintEvent* )
256} 256}
257 257
258void VMemo::mousePressEvent( QMouseEvent * ) 258void VMemo::mousePressEvent( QMouseEvent * )
259{ 259{
260 startRecording(); 260 startRecording();
261} 261}
262 262
263void VMemo::mouseReleaseEvent( QMouseEvent * ) 263void VMemo::mouseReleaseEvent( QMouseEvent * )
264{ 264{
265 stopRecording(); 265 stopRecording();
266} 266}
267 267
268bool VMemo::startRecording() { 268bool VMemo::startRecording() {
269 269
270 if ( recording) 270 if ( recording)
271 return FALSE;; 271 return FALSE;;
272 Config config( "Sound" ); 272 Config config( "Vmemo" );
273 config.setGroup( "System" ); 273 config.setGroup( "System" );
274 useAlerts = config.readBoolEntry("Alert"); 274 useAlerts = config.readBoolEntry("Alert");
275 275
276// if(useAlerts) 276// if(useAlerts)
277// QMessageBox::message("VMemo","Really Record?");//) ==1) 277// QMessageBox::message("VMemo","Really Record?");//) ==1)
278// return; 278// return;
279// } else { 279// } else {
280 if (!systemZaurus ) 280 if (!systemZaurus )
281 QSound::play(Resource::findSound("vmemob")); 281 QSound::play(Resource::findSound("vmemob"));
282// } 282// }
283 qDebug("Start recording"); 283 qDebug("Start recording");
284 recording = TRUE; 284 recording = TRUE;
285 if (openDSP() == -1) { 285 if (openDSP() == -1) {
286 QMessageBox::critical(0, "VMemo", "Could not open dsp device.\n"+errorMsg, "Abort"); 286 QMessageBox::critical(0, "VMemo", "Could not open dsp device.\n"+errorMsg, "Abort");
287 recording = FALSE; 287 recording = FALSE;
288 return FALSE; 288 return FALSE;
289 } 289 }
290 290
291 Config vmCfg("VMemo"); 291 config.setGroup("Defaults");
292 vmCfg.setGroup("Defaults");
293 292
294 QDateTime dt = QDateTime::currentDateTime(); 293 QDateTime dt = QDateTime::currentDateTime();
295 294
296 QString fName; 295 QString fName;
297 Config cfg( "Sound" ); 296 config.setGroup( "System" );
298 cfg.setGroup( "System" );
299 fName = QPEApplication::documentDir() ; 297 fName = QPEApplication::documentDir() ;
300 fileName = cfg.readEntry("RecLocation", fName); 298 fileName = config.readEntry("RecLocation", fName);
301 299
302 int s; 300 int s;
303 s=fileName.find(':'); 301 s=fileName.find(':');
304 if(s) 302 if(s)
305 fileName=fileName.right(fileName.length()-s-2); 303 fileName=fileName.right(fileName.length()-s-2);
306 qDebug("filename will be "+fileName); 304 qDebug("filename will be "+fileName);
307 if( fileName.right(1).find('/') == -1) 305 if( fileName.right(1).find('/') == -1)
308 fileName+="/"; 306 fileName+="/";
309 fName = "vm_"+ dt.toString()+ ".wav"; 307 fName = "vm_"+ dt.toString()+ ".wav";
310 308
311 fileName+=fName; 309 fileName+=fName;
312 qDebug("filename is "+fileName); 310 qDebug("filename is "+fileName);
313 // No spaces in the filename 311 // No spaces in the filename
314 fileName.replace(QRegExp("'"),""); 312 fileName.replace(QRegExp("'"),"");
315 fileName.replace(QRegExp(" "),"_"); 313 fileName.replace(QRegExp(" "),"_");
316 fileName.replace(QRegExp(":"),"."); 314 fileName.replace(QRegExp(":"),".");
317 fileName.replace(QRegExp(","),""); 315 fileName.replace(QRegExp(","),"");
318 316
319 if(openWAV(fileName.latin1()) == -1) { 317 if(openWAV(fileName.latin1()) == -1) {
320 QString err("Could not open the output file\n"); 318 QString err("Could not open the output file\n");
321 err += fileName; 319 err += fileName;
322 QMessageBox::critical(0, "VMemo", err, "Abort"); 320 QMessageBox::critical(0, "VMemo", err, "Abort");
323 close(dsp); 321 close(dsp);
324 return FALSE; 322 return FALSE;
325 } 323 }
326 324
327 QArray<int> cats(1); 325 QArray<int> cats(1);
328 cats[0] = vmCfg.readNumEntry("Category", 0); 326 cats[0] = config.readNumEntry("Category", 0);
329 327
330 QString dlName("vm_"); 328 QString dlName("vm_");
331 dlName += dt.toString(); 329 dlName += dt.toString();
332 DocLnk l; 330 DocLnk l;
333 l.setFile(fileName); 331 l.setFile(fileName);
334 l.setName(dlName); 332 l.setName(dlName);
335 l.setType("audio/x-wav"); 333 l.setType("audio/x-wav");
336 l.setCategories(cats); 334 l.setCategories(cats);
337 l.writeLink(); 335 l.writeLink();
338 336
339 record(); 337 record();
340 return TRUE; 338 return TRUE;
341} 339}
342 340
343void VMemo::stopRecording() { 341void VMemo::stopRecording() {
344 recording = FALSE; 342 recording = FALSE;
345} 343}
346 344
347int VMemo::openDSP() 345int VMemo::openDSP()
348{ 346{
349 Config cfg("Sound"); 347 Config cfg("Vmemo");
350 cfg.setGroup("Record"); 348 cfg.setGroup("Record");
351 349
352 speed = cfg.readNumEntry("SampleRate", 22050); 350 speed = cfg.readNumEntry("SampleRate", 22050);
353 channels = cfg.readNumEntry("Stereo", 1) ? 2 : 1; // 1 = stereo(2), 0 = mono(1) 351 channels = cfg.readNumEntry("Stereo", 1) ? 2 : 1; // 1 = stereo(2), 0 = mono(1)
354 if (cfg.readNumEntry("SixteenBit", 1)==1) { 352 if (cfg.readNumEntry("SixteenBit", 1)==1) {
355 format = AFMT_S16_LE; 353 format = AFMT_S16_LE;
356 resolution = 16; 354 resolution = 16;
357 } else { 355 } else {
358 format = AFMT_U8; 356 format = AFMT_U8;
359 resolution = 8; 357 resolution = 8;
360 } 358 }
361 359
362 qDebug("samplerate: %d, channels %d, resolution %d", speed, channels, resolution); 360 qDebug("samplerate: %d, channels %d, resolution %d", speed, channels, resolution);
363 361
364 if(systemZaurus) { 362 if(systemZaurus) {
365 dsp = open("/dev/dsp1", O_RDWR); //Zaurus needs /dev/dsp1 363 dsp = open("/dev/dsp1", O_RDWR); //Zaurus needs /dev/dsp1
diff --git a/core/applets/volumeapplet/volume.cpp b/core/applets/volumeapplet/volume.cpp
index e393f0f..e8921f0 100644
--- a/core/applets/volumeapplet/volume.cpp
+++ b/core/applets/volumeapplet/volume.cpp
@@ -39,104 +39,135 @@
39#include <qpushbutton.h> 39#include <qpushbutton.h>
40#include <qtimer.h> 40#include <qtimer.h>
41 41
42#define RATE_TIMER_INTERVAL 100 42#define RATE_TIMER_INTERVAL 100
43// Ten times per second is fine (RATE_TIMER_INTERVAL 100). A shorter time 43// Ten times per second is fine (RATE_TIMER_INTERVAL 100). A shorter time
44// results in "hanging" buttons on the iPAQ due to quite high CPU consumption. 44// results in "hanging" buttons on the iPAQ due to quite high CPU consumption.
45 45
46VolumeControl::VolumeControl( bool showMic, QWidget *parent, const char *name ) 46VolumeControl::VolumeControl( bool showMic, QWidget *parent, const char *name )
47 : QFrame( parent, name, WDestructiveClose | WStyle_StaysOnTop | WType_Popup ) 47 : QFrame( parent, name, WDestructiveClose | WStyle_StaysOnTop | WType_Popup )
48{ 48{
49 setFrameStyle( QFrame::PopupPanel | QFrame::Raised ); 49 setFrameStyle( QFrame::PopupPanel | QFrame::Raised );
50 createView(showMic); 50 createView(showMic);
51} 51}
52 52
53void VolumeControl::createView(bool showMic) 53void VolumeControl::createView(bool showMic)
54{ 54{
55 Config cfg("Sound"); 55 Config cfg("qpe");
56 cfg.setGroup("System"); 56 cfg.setGroup("Volume");
57//showMic = TRUE; 57//showMic = TRUE;
58 QHBoxLayout *hboxLayout = new QHBoxLayout(this); 58 QHBoxLayout *hboxLayout = new QHBoxLayout(this);
59 hboxLayout->setMargin( 3 ); 59 hboxLayout->setMargin( 3 );
60 hboxLayout->setSpacing( 0); 60 hboxLayout->setSpacing( 0);
61 61
62 QVBoxLayout *vboxButtons = new QVBoxLayout(this); 62 QVBoxLayout *vboxButtons = new QVBoxLayout(this);
63 upButton = new QPushButton( this ); 63 upButton = new QPushButton( this );
64 upButton->setSizePolicy( QSizePolicy( QSizePolicy::Minimum, QSizePolicy::Expanding ) ); 64 upButton->setSizePolicy( QSizePolicy( QSizePolicy::Minimum, QSizePolicy::Expanding ) );
65 upButton->setPixmap( Resource::loadPixmap( "up" ) ); 65 upButton->setPixmap( Resource::loadPixmap( "up" ) );
66 downButton = new QPushButton( this ); 66 downButton = new QPushButton( this );
67 downButton->setSizePolicy( QSizePolicy( QSizePolicy::Minimum, QSizePolicy::Expanding ) ); 67 downButton->setSizePolicy( QSizePolicy( QSizePolicy::Minimum, QSizePolicy::Expanding ) );
68 downButton->setPixmap( Resource::loadPixmap( "down" ) ); 68 downButton->setPixmap( Resource::loadPixmap( "down" ) );
69 vboxButtons->setSpacing( 2 ); 69 vboxButtons->setSpacing( 2 );
70
71 upButton->setFixedHeight(26);
72 downButton->setFixedHeight(26);
70 73
71 vboxButtons->addWidget( upButton ); 74 vboxButtons->addWidget( upButton );
72 vboxButtons->addWidget( downButton ); 75 vboxButtons->addWidget( downButton );
73 76
74 QVBoxLayout *vbox = new QVBoxLayout( this ); 77 QVBoxLayout *vbox = new QVBoxLayout( this );
75 QHBoxLayout *hbox = NULL; 78 QHBoxLayout *hbox = NULL;
76 79
77 slider = new QSlider( this ); 80 slider = new QSlider( this );
78 slider->setRange( 0, 100 ); 81 slider->setRange( 0, 100 );
79 slider->setTickmarks( QSlider::Both ); 82 slider->setTickmarks( QSlider::Both );
80 slider->setTickInterval( 20 ); 83 slider->setTickInterval( 20 );
81 slider->setFocusPolicy( QWidget::NoFocus ); 84 slider->setFocusPolicy( QWidget::NoFocus );
82 slider->setValue(cfg.readNumEntry("Volume")); 85 slider->setValue(cfg.readNumEntry("VolumePercent"));
83 86
84 QVBoxLayout *sbox = new QVBoxLayout(this); 87 QVBoxLayout *sbox = new QVBoxLayout(this);
85 sbox->setMargin( 3 ); 88 sbox->setMargin( 3 );
86 sbox->setSpacing( 3 ); 89 sbox->setSpacing( 3 );
87 sbox->addWidget( new QLabel("Vol", this) , 0, Qt::AlignVCenter | Qt::AlignHCenter ); 90 sbox->addWidget( new QLabel("Vol", this) , 0, Qt::AlignVCenter | Qt::AlignHCenter );
88 sbox->addWidget( slider, 0, Qt::AlignVCenter | Qt::AlignHCenter ); 91 sbox->addWidget( slider, 0, Qt::AlignVCenter | Qt::AlignHCenter );
89 92
90 if (showMic == TRUE) { 93// if (showMic == TRUE) {
91 mic = new QSlider(this); 94 mic = new QSlider(this);
92 mic->setRange( 0, 100 ); 95 mic->setRange( 0, 100 );
93 mic->setTickmarks( QSlider::Both ); 96 mic->setTickmarks( QSlider::Both );
94 mic->setTickInterval( 20 ); 97 mic->setTickInterval( 20 );
95 mic->setFocusPolicy( QWidget::NoFocus ); 98 mic->setFocusPolicy( QWidget::NoFocus );
96 mic->setValue(cfg.readNumEntry("Mic")); 99 mic->setValue(cfg.readNumEntry("Mic"));
97 100
98 QVBoxLayout *mbox = new QVBoxLayout(this); 101 QVBoxLayout *mbox = new QVBoxLayout(this);
99 mbox->setMargin( 3 ); 102 mbox->setMargin( 3 );
100 mbox->setSpacing( 3 ); 103 mbox->setSpacing( 3 );
101 mbox->addWidget( new QLabel("Mic", this) , 0, Qt::AlignVCenter | Qt::AlignHCenter ); 104 mbox->addWidget( new QLabel("Mic", this) , 0, Qt::AlignVCenter | Qt::AlignHCenter );
102 mbox->addWidget( mic, 0, Qt::AlignVCenter | Qt::AlignHCenter ); 105 mbox->addWidget( mic, 0, Qt::AlignVCenter | Qt::AlignHCenter );
103 106
104 hbox = new QHBoxLayout( this ); 107 hbox = new QHBoxLayout( this );
105 hbox->setMargin( 3 ); 108 hbox->setMargin( 3 );
106 hbox->setSpacing( 3 ); 109 hbox->setSpacing( 3 );
107 hbox->addLayout( sbox, 1); 110 hbox->addLayout( sbox, 1);
108 hbox->addLayout( mbox, 1); 111 hbox->addLayout( mbox, 1);
109 } 112 // }
110 113
111 muteBox = new QCheckBox( tr("Mute"), this ); 114 muteBox = new QCheckBox( tr("Mute"), this );
112 muteBox->setFocusPolicy( QWidget::NoFocus ); 115 muteBox->setFocusPolicy( QWidget::NoFocus );
113 116
117 QVBoxLayout *klbox = new QVBoxLayout(this);
118
119 QLabel *Label1;
120 Label1 = new QLabel( this, "Label1" );
121 Label1->setText( tr( "Enable Sounds for:" ));
122
123 alarmSound = new QCheckBox( tr("Alarm Sound"), this );
124 alarmSound->setFocusPolicy( QWidget::NoFocus );
125
126 keyclicks = new QCheckBox( tr("Key Clicks"), this );
127 keyclicks->setFocusPolicy( QWidget::NoFocus );
128
129 screentaps = new QCheckBox( tr("Screen taps"), this );
130 screentaps->setFocusPolicy( QWidget::NoFocus );
131
132
133 keyclicks->setChecked( cfg.readBoolEntry("KeySound",0));
134 screentaps->setChecked( cfg.readBoolEntry("TouchSound",0));
135 alarmSound->setChecked( cfg.readBoolEntry("AlarmSound",1));
136
137 klbox->setMargin( 3 );
138 klbox->setSpacing( 0 );
139 klbox->addWidget( Label1, 1);
140 klbox->addWidget( alarmSound, 1);
141 klbox->addWidget( keyclicks, 1);
142 klbox->addWidget( screentaps, 1);
114 vbox->setMargin( 3 ); 143 vbox->setMargin( 3 );
115 vbox->setSpacing( 0 ); 144 vbox->setSpacing( 0 );
116 if (showMic == TRUE) 145// if (showMic == TRUE)
117 vbox->addLayout( hbox, 1 ); 146 vbox->addLayout( hbox, 1 );
118 else 147// else
119 vbox->addLayout( sbox, 1); 148// vbox->addLayout( sbox, 1);
120 vbox->addWidget( muteBox, 0, Qt::AlignVCenter | Qt::AlignHCenter ); 149 vbox->addWidget( muteBox, 0, Qt::AlignVCenter | Qt::AlignHCenter );
121 150
122 hboxLayout->addLayout( vboxButtons ); 151 hboxLayout->addLayout( vboxButtons );
123 hboxLayout->addLayout(vbox); 152 hboxLayout->addLayout( vbox);
153 hboxLayout->addLayout( klbox);
124 154
125 setFixedHeight( 120 ); 155
126 setFixedWidth( sizeHint().width() ); 156 setFixedHeight( 120);
157// setFixedWidth( sizeHint().width() );
127 setFocusPolicy(QWidget::NoFocus); 158 setFocusPolicy(QWidget::NoFocus);
128 connect( upButton, SIGNAL( pressed() ), this, SLOT( ButtonChanged() ) ); 159 connect( upButton, SIGNAL( pressed() ), this, SLOT( ButtonChanged() ) );
129 connect( upButton, SIGNAL( released() ), this, SLOT( ButtonChanged() ) ); 160 connect( upButton, SIGNAL( released() ), this, SLOT( ButtonChanged() ) );
130 connect( downButton, SIGNAL( pressed() ), this, SLOT( ButtonChanged() ) ); 161 connect( downButton, SIGNAL( pressed() ), this, SLOT( ButtonChanged() ) );
131 connect( downButton, SIGNAL( released() ), this, SLOT( ButtonChanged() ) ); 162 connect( downButton, SIGNAL( released() ), this, SLOT( ButtonChanged() ) );
132 163
133 rateTimer = new QTimer(this); 164 rateTimer = new QTimer(this);
134 connect( rateTimer, SIGNAL( timeout() ), this, SLOT( rateTimerDone() ) ); 165 connect( rateTimer, SIGNAL( timeout() ), this, SLOT( rateTimerDone() ) );
135} 166}
136 167
137void VolumeControl::keyPressEvent( QKeyEvent *e) 168void VolumeControl::keyPressEvent( QKeyEvent *e)
138{ 169{
139 switch(e->key()) 170 switch(e->key())
140 { 171 {
141 case Key_Up: 172 case Key_Up:
142 slider->subtractStep(); 173 slider->subtractStep();
@@ -166,41 +197,41 @@ void VolumeControl::ButtonChanged()
166 rateTimer->stop(); 197 rateTimer->stop();
167} 198}
168 199
169void VolumeControl::rateTimerDone() 200void VolumeControl::rateTimerDone()
170{ 201{
171 if ( upButton->isDown() ) 202 if ( upButton->isDown() )
172 slider->setValue( slider->value() - 2 ); 203 slider->setValue( slider->value() - 2 );
173 else // downButton->isDown() 204 else // downButton->isDown()
174 slider->setValue( slider->value() + 2 ); 205 slider->setValue( slider->value() + 2 );
175} 206}
176 207
177//=========================================================================== 208//===========================================================================
178 209
179VolumeApplet::VolumeApplet( QWidget *parent, const char *name ) 210VolumeApplet::VolumeApplet( QWidget *parent, const char *name )
180 : QWidget( parent, name ) 211 : QWidget( parent, name )
181{ 212{
182 Config cfg("Sound"); 213 Config cfg("qpe");
183 cfg.setGroup("System"); 214 cfg.setGroup("Volume");
184 215
185 setFixedHeight( 18 ); 216 setFixedHeight( 18 );
186 setFixedWidth( 14 ); 217 setFixedWidth( 14 );
187 218
188 volumePixmap = Resource::loadPixmap( "volume" ); 219 volumePixmap = Resource::loadPixmap( "volume" );
189 220
190 volumePercent = cfg.readNumEntry("Volume",50); 221 volumePercent = cfg.readNumEntry("VolumePercent",50);
191 micPercent = cfg.readNumEntry("Mic", 50); 222 micPercent = cfg.readNumEntry("Mic", 50);
192 muted = FALSE; // ### read from pref 223 muted = FALSE; // ### read from pref
193 micMuted = FALSE; // ### read from pref 224 micMuted = FALSE; // ### read from pref
194 225
195 advancedTimer = new QTimer(this); 226 advancedTimer = new QTimer(this);
196 227
197 connect( qApp, SIGNAL( volumeChanged(bool) ), this, SLOT( volumeChanged(bool) ) ); 228 connect( qApp, SIGNAL( volumeChanged(bool) ), this, SLOT( volumeChanged(bool) ) );
198 connect( qApp, SIGNAL( micChanged(bool) ), this, SLOT ( micChanged(bool) ) ); 229 connect( qApp, SIGNAL( micChanged(bool) ), this, SLOT ( micChanged(bool) ) );
199 connect( advancedTimer, SIGNAL( timeout() ),this, SLOT( advVolControl()) ); 230 connect( advancedTimer, SIGNAL( timeout() ),this, SLOT( advVolControl()) );
200 231
201 writeSystemVolume(); 232 writeSystemVolume();
202 writeSystemMic(); 233 writeSystemMic();
203} 234}
204 235
205VolumeApplet::~VolumeApplet() 236VolumeApplet::~VolumeApplet()
206{ 237{
@@ -216,52 +247,63 @@ void VolumeApplet::mousePressEvent( QMouseEvent * )
216{ 247{
217 advancedTimer->start( 750, TRUE ); 248 advancedTimer->start( 750, TRUE );
218} 249}
219 250
220void VolumeApplet::mouseReleaseEvent( QMouseEvent * ) 251void VolumeApplet::mouseReleaseEvent( QMouseEvent * )
221{ 252{
222 showVolControl(FALSE); 253 showVolControl(FALSE);
223} 254}
224 255
225void VolumeApplet::advVolControl() 256void VolumeApplet::advVolControl()
226{ 257{
227 showVolControl(TRUE); 258 showVolControl(TRUE);
228} 259}
229 260
230void VolumeApplet::showVolControl(bool showMic) 261void VolumeApplet::showVolControl(bool showMic)
231{ 262{
232 Config cfg("Sound"); 263 Config cfg("qpe");
233 cfg.setGroup("System"); 264 cfg.setGroup("Volume");
234 volumePercent = cfg.readNumEntry("Volume",50); 265 volumePercent = cfg.readNumEntry("VolumePercent",50);
235 micPercent = cfg.readNumEntry("Mic", 50); 266 micPercent = cfg.readNumEntry("Mic", 50);
236 QString show = cfg.readEntry("ShowMic", "FALSE"); 267
237 if(show == "TRUE") showMic = TRUE;
238 // Create a small volume control window to adjust the volume with 268 // Create a small volume control window to adjust the volume with
239 VolumeControl *vc = new VolumeControl(showMic); 269 VolumeControl *vc = new VolumeControl(showMic);
240 vc->slider->setValue( 100 - volumePercent ); 270 vc->slider->setValue( 100 - volumePercent );
241 if (showMic) 271// if (showMic)
242 { 272// {
243 vc->mic->setValue( 100 - micPercent ); 273 vc->mic->setValue( 100 - micPercent );
244 connect( vc->mic, SIGNAL( valueChanged( int ) ), this, SLOT( micMoved( int ) ) ); 274 connect( vc->mic, SIGNAL( valueChanged( int ) ), this, SLOT( micMoved( int ) ) );
245 } 275// }
246 276
247 vc->muteBox->setChecked( muted ); 277 vc->muteBox->setChecked( muted );
248 connect( vc->slider, SIGNAL( valueChanged( int ) ), this, SLOT( sliderMoved( int ) ) ); 278 connect( vc->slider, SIGNAL( valueChanged( int ) ), this, SLOT( sliderMoved( int ) ) );
249 connect( vc->muteBox, SIGNAL( toggled( bool ) ), this, SLOT( mute( bool ) ) ); 279 connect( vc->muteBox, SIGNAL( toggled( bool ) ), this, SLOT( mute( bool ) ) );
280
281 Config config("qpe");
282 config.setGroup("Volume");
283
284 vc->keyclicks->setChecked( config.readBoolEntry("KeySound",0));
285 vc->screentaps->setChecked( config.readBoolEntry("TouchSound",0));
286 vc->alarmSound->setChecked( config.readBoolEntry("AlarmSound",1));
287
288 connect( vc->alarmSound, SIGNAL(toggled(bool)), this, SLOT( alarmSoundCheckToggled(bool)));
289 connect( vc->keyclicks, SIGNAL(toggled(bool)), this, SLOT( keyclicksCheckToggled(bool)));
290 connect( vc->screentaps, SIGNAL(toggled(bool)), this, SLOT( screentapsCheckToggled(bool)));
291
250 QPoint curPos = mapToGlobal( rect().topLeft() ); 292 QPoint curPos = mapToGlobal( rect().topLeft() );
251 vc->move( curPos.x()-(vc->sizeHint().width()-width())/2, curPos.y() - 120 ); 293 vc->move( curPos.x()-(vc->sizeHint().width()/2+50), curPos.y() - 120 );
252 vc->show(); 294 vc->show();
253 295
254 advancedTimer->stop(); 296 advancedTimer->stop();
255} 297}
256 298
257void VolumeApplet::volumeChanged( bool nowMuted ) 299void VolumeApplet::volumeChanged( bool nowMuted )
258{ 300{
259 int previousVolume = volumePercent; 301 int previousVolume = volumePercent;
260 302
261 if ( !nowMuted ) 303 if ( !nowMuted )
262 readSystemVolume(); 304 readSystemVolume();
263 305
264 // Handle case where muting it toggled 306 // Handle case where muting it toggled
265 if ( muted != nowMuted ) { 307 if ( muted != nowMuted ) {
266 muted = nowMuted; 308 muted = nowMuted;
267 repaint( TRUE ); 309 repaint( TRUE );
@@ -289,92 +331,114 @@ void VolumeApplet::mute( bool toggled )
289 writeSystemVolume(); 331 writeSystemVolume();
290} 332}
291 333
292 334
293void VolumeApplet::sliderMoved( int percent ) 335void VolumeApplet::sliderMoved( int percent )
294{ 336{
295 setVolume( 100 - percent ); 337 setVolume( 100 - percent );
296} 338}
297 339
298void VolumeApplet::micMoved( int percent ) 340void VolumeApplet::micMoved( int percent )
299{ 341{
300 setMic( 100 - percent ); 342 setMic( 100 - percent );
301} 343}
302 344
303void VolumeApplet::readSystemVolume() 345void VolumeApplet::readSystemVolume()
304{ 346{
305 Config cfg("Sound"); 347 Config cfg("qpe");
306 cfg.setGroup("System"); 348 cfg.setGroup("Volume");
307 volumePercent = cfg.readNumEntry("Volume"); 349 volumePercent = cfg.readNumEntry("VolumePercent");
308} 350}
309 351
310void VolumeApplet::readSystemMic() 352void VolumeApplet::readSystemMic()
311{ 353{
312 Config cfg("Sound"); 354 Config cfg("qpe");
313 cfg.setGroup("System"); 355 cfg.setGroup("Volume");
314 micPercent = cfg.readNumEntry("Mic"); 356 micPercent = cfg.readNumEntry("Mic");
315} 357}
316 358
317void VolumeApplet::setVolume( int percent ) 359void VolumeApplet::setVolume( int percent )
318{ 360{
319 // clamp volume percent to be between 0 and 100 361 // clamp volume percent to be between 0 and 100
320 volumePercent = (percent < 0) ? 0 : ((percent > 100) ? 100 : percent); 362 volumePercent = (percent < 0) ? 0 : ((percent > 100) ? 100 : percent);
321 // repaint just the little volume rectangle 363 // repaint just the little volume rectangle
322 repaint( 2, height() - 3, width() - 4, 2, FALSE ); 364 repaint( 2, height() - 3, width() - 4, 2, FALSE );
323 writeSystemVolume(); 365 writeSystemVolume();
324} 366}
325 367
326void VolumeApplet::setMic( int percent ) 368void VolumeApplet::setMic( int percent )
327{ 369{
328 // clamp volume percent to be between 0 and 100 370 // clamp volume percent to be between 0 and 100
329 micPercent = (percent < 0) ? 0 : ((percent > 100) ? 100 : percent); 371 micPercent = (percent < 0) ? 0 : ((percent > 100) ? 100 : percent);
330 writeSystemMic(); 372 writeSystemMic();
331} 373}
332 374
333void VolumeApplet::writeSystemVolume() 375void VolumeApplet::writeSystemVolume()
334{ 376{
335 { 377 {
336 Config cfg("Sound"); 378 Config cfg("qpe");
337 cfg.setGroup("System"); 379 cfg.setGroup("Volume");
338 cfg.writeEntry("Volume",volumePercent); 380 cfg.writeEntry("VolumePercent",volumePercent);
339 } 381 }
340#if ( defined Q_WS_QWS || defined(_WS_QWS_) ) && !defined(QT_NO_COP) 382#if ( defined Q_WS_QWS || defined(_WS_QWS_) ) && !defined(QT_NO_COP)
341 // Send notification that the volume has changed 383 // Send notification that the volume has changed
342 QCopEnvelope( "QPE/System", "volumeChange(bool)" ) << muted; 384 QCopEnvelope( "QPE/System", "volumeChange(bool)" ) << muted;
343#endif 385#endif
344} 386}
345 387
346void VolumeApplet::writeSystemMic() 388void VolumeApplet::writeSystemMic()
347{ 389{
348 { 390 {
349 Config cfg("Sound"); 391 Config cfg("qpe");
350 cfg.setGroup("System"); 392 cfg.setGroup("Volume");
351 cfg.writeEntry("Mic",micPercent); 393 cfg.writeEntry("Mic",micPercent);
352 } 394 }
353#if ( defined Q_WS_QWS || defined(_WS_QWS_) ) && !defined(QT_NO_COP) 395#if ( defined Q_WS_QWS || defined(_WS_QWS_) ) && !defined(QT_NO_COP)
354 // Send notification that the volume has changed 396 // Send notification that the volume has changed
355 QCopEnvelope( "QPE/System", "micChange(bool)" ) << micMuted; 397 QCopEnvelope( "QPE/System", "micChange(bool)" ) << micMuted;
356#endif 398#endif
357} 399}
358 400
359void VolumeApplet::paintEvent( QPaintEvent* ) 401void VolumeApplet::paintEvent( QPaintEvent* )
360{ 402{
361 QPainter p(this); 403 QPainter p(this);
362 404
363 if (volumePixmap.isNull()) 405 if (volumePixmap.isNull())
364 volumePixmap = Resource::loadPixmap( "volume" ); 406 volumePixmap = Resource::loadPixmap( "volume" );
365 p.drawPixmap( 0, 1, volumePixmap ); 407 p.drawPixmap( 0, 1, volumePixmap );
366 p.setPen( darkGray ); 408 p.setPen( darkGray );
367 p.drawRect( 1, height() - 4, width() - 2, 4 ); 409 p.drawRect( 1, height() - 4, width() - 2, 4 );
368 410
369 int pixelsWide = volumePercent * (width() - 4) / 100; 411 int pixelsWide = volumePercent * (width() - 4) / 100;
370 p.fillRect( 2, height() - 3, pixelsWide, 2, red ); 412 p.fillRect( 2, height() - 3, pixelsWide, 2, red );
371 p.fillRect( pixelsWide + 2, height() - 3, width() - 4 - pixelsWide, 2, lightGray ); 413 p.fillRect( pixelsWide + 2, height() - 3, width() - 4 - pixelsWide, 2, lightGray );
372 414
373 if ( muted ) { 415 if ( muted ) {
374 p.setPen( red ); 416 p.setPen( red );
375 p.drawLine( 1, 2, width() - 2, height() - 5 ); 417 p.drawLine( 1, 2, width() - 2, height() - 5 );
376 p.drawLine( 1, 3, width() - 2, height() - 4 ); 418 p.drawLine( 1, 3, width() - 2, height() - 4 );
377 p.drawLine( width() - 2, 2, 1, height() - 5 ); 419 p.drawLine( width() - 2, 2, 1, height() - 5 );
378 p.drawLine( width() - 2, 3, 1, height() - 4 ); 420 p.drawLine( width() - 2, 3, 1, height() - 4 );
379 } 421 }
380} 422}
423
424void VolumeApplet::screentapsCheckToggled(bool b) {
425 Config cfg("qpe");
426 cfg.setGroup("Volume");
427 cfg.writeEntry("TouchSound",b );
428 cfg.write();
429}
430
431void VolumeApplet::keyclicksCheckToggled(bool b) {
432 Config cfg("qpe");
433 cfg.setGroup("Volume");
434 cfg.writeEntry("KeySound",b);
435 cfg.write();
436}
437
438void VolumeApplet::alarmSoundCheckToggled(bool b) {
439 Config cfg("qpe");
440 cfg.setGroup("Volume");
441 cfg.writeEntry("AlarmSound",b);
442 cfg.write();
443}
444
diff --git a/core/applets/volumeapplet/volume.h b/core/applets/volumeapplet/volume.h
index 3a2da43..6e631f2 100644
--- a/core/applets/volumeapplet/volume.h
+++ b/core/applets/volumeapplet/volume.h
@@ -10,51 +10,54 @@
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20 20
21#ifndef __VOLUME_APPLET_H__ 21#ifndef __VOLUME_APPLET_H__
22#define __VOLUME_APPLET_H__ 22#define __VOLUME_APPLET_H__
23 23
24 24
25#include <qwidget.h> 25#include <qwidget.h>
26#include <qpushbutton.h>
27#include <qframe.h> 26#include <qframe.h>
28#include <qpixmap.h> 27#include <qpixmap.h>
29#include <qguardedptr.h> 28#include <qguardedptr.h>
30#include <qtimer.h> 29#include <qtimer.h>
31 30
32class QSlider; 31class QSlider;
33class QCheckBox; 32class QCheckBox;
34 33
35class VolumeControl : public QFrame 34class VolumeControl : public QFrame
36{ 35{
37 Q_OBJECT 36 Q_OBJECT
38public: 37public:
39 VolumeControl( bool showMic=FALSE, QWidget *parent=0, const char *name=0 ); 38 VolumeControl( bool showMic=FALSE, QWidget *parent=0, const char *name=0 );
40 39
41public: 40public:
42 QSlider *slider; 41 QSlider *slider;
43 QSlider *mic; 42 QSlider *mic;
44 QCheckBox *muteBox; 43 QCheckBox *muteBox;
44 QCheckBox *alarmSound;
45 QCheckBox *screentaps;
46 QCheckBox *keyclicks;
47
45 48
46private: 49private:
47 QPushButton *upButton; 50 QPushButton *upButton;
48 QPushButton *downButton; 51 QPushButton *downButton;
49 QTimer *rateTimer; 52 QTimer *rateTimer;
50 53
51 void keyPressEvent( QKeyEvent * ); 54 void keyPressEvent( QKeyEvent * );
52 void createView(bool showMic = FALSE); 55 void createView(bool showMic = FALSE);
53private slots: 56private slots:
54 void ButtonChanged(); 57 void ButtonChanged();
55 void rateTimerDone(); 58 void rateTimerDone();
56 59
57}; 60};
58 61
59class VolumeApplet : public QWidget 62class VolumeApplet : public QWidget
60{ 63{
@@ -81,21 +84,25 @@ public slots:
81private: 84private:
82 int volumePercent, micPercent; 85 int volumePercent, micPercent;
83 bool muted, micMuted; 86 bool muted, micMuted;
84 QPixmap volumePixmap; 87 QPixmap volumePixmap;
85 QTimer *advancedTimer; 88 QTimer *advancedTimer;
86 89
87 void readSystemVolume(); 90 void readSystemVolume();
88 void writeSystemVolume(); 91 void writeSystemVolume();
89 void mousePressEvent( QMouseEvent * ); 92 void mousePressEvent( QMouseEvent * );
90 void paintEvent( QPaintEvent* ); 93 void paintEvent( QPaintEvent* );
91 94
92 void readSystemMic(); 95 void readSystemMic();
93 void keyPressEvent ( QKeyEvent * e ); 96 void keyPressEvent ( QKeyEvent * e );
94 void mouseReleaseEvent( QMouseEvent *); 97 void mouseReleaseEvent( QMouseEvent *);
95 void writeSystemMic(); 98 void writeSystemMic();
96 99
100protected slots:
101 void alarmSoundCheckToggled(bool);
102 void keyclicksCheckToggled(bool);
103 void screentapsCheckToggled(bool);
97}; 104};
98 105
99 106
100#endif // __VOLUME_APPLET_H__ 107#endif // __VOLUME_APPLET_H__
101 108