author | llornkcor <llornkcor> | 2002-07-29 23:43:21 (UTC) |
---|---|---|
committer | llornkcor <llornkcor> | 2002-07-29 23:43:21 (UTC) |
commit | 121002ebe4cdebd99fcba5ec833c1c7b05bb8892 (patch) (unidiff) | |
tree | dcf68d4f74388a1b01052ed2e6eb9fe1ee0ede86 | |
parent | 6c41e8a4fd35f8e1689caa2e62981d1df2432223 (diff) | |
download | opie-121002ebe4cdebd99fcba5ec833c1c7b05bb8892.zip opie-121002ebe4cdebd99fcba5ec833c1c7b05bb8892.tar.gz opie-121002ebe4cdebd99fcba5ec833c1c7b05bb8892.tar.bz2 |
fixed slider
-rw-r--r-- | noncore/multimedia/opieplayer2/audiowidget.cpp | 12 |
1 files changed, 6 insertions, 6 deletions
diff --git a/noncore/multimedia/opieplayer2/audiowidget.cpp b/noncore/multimedia/opieplayer2/audiowidget.cpp index b82171e..1fae689 100644 --- a/noncore/multimedia/opieplayer2/audiowidget.cpp +++ b/noncore/multimedia/opieplayer2/audiowidget.cpp | |||
@@ -176,230 +176,230 @@ AudioWidget::~AudioWidget() { | |||
176 | for ( int i = 0; i < 11; i++ ) { | 176 | for ( int i = 0; i < 11; i++ ) { |
177 | delete buttonPixUp[i]; | 177 | delete buttonPixUp[i]; |
178 | delete buttonPixDown[i]; | 178 | delete buttonPixDown[i]; |
179 | } | 179 | } |
180 | delete pixBg; | 180 | delete pixBg; |
181 | delete imgUp; | 181 | delete imgUp; |
182 | delete imgDn; | 182 | delete imgDn; |
183 | delete imgButtonMask; | 183 | delete imgButtonMask; |
184 | for ( int i = 0; i < 11; i++ ) { | 184 | for ( int i = 0; i < 11; i++ ) { |
185 | delete masks[i]; | 185 | delete masks[i]; |
186 | } | 186 | } |
187 | } | 187 | } |
188 | 188 | ||
189 | QPixmap *combineImageWithBackground( QImage img, QPixmap bg, QPoint offset ) { | 189 | QPixmap *combineImageWithBackground( QImage img, QPixmap bg, QPoint offset ) { |
190 | QPixmap pix( img.width(), img.height() ); | 190 | QPixmap pix( img.width(), img.height() ); |
191 | QPainter p( &pix ); | 191 | QPainter p( &pix ); |
192 | p.drawTiledPixmap( pix.rect(), bg, offset ); | 192 | p.drawTiledPixmap( pix.rect(), bg, offset ); |
193 | p.drawImage( 0, 0, img ); | 193 | p.drawImage( 0, 0, img ); |
194 | return new QPixmap( pix ); | 194 | return new QPixmap( pix ); |
195 | } | 195 | } |
196 | 196 | ||
197 | 197 | ||
198 | QPixmap *maskPixToMask( QPixmap pix, QBitmap mask ) | 198 | QPixmap *maskPixToMask( QPixmap pix, QBitmap mask ) |
199 | { | 199 | { |
200 | QPixmap *pixmap = new QPixmap( pix ); | 200 | QPixmap *pixmap = new QPixmap( pix ); |
201 | pixmap->setMask( mask ); | 201 | pixmap->setMask( mask ); |
202 | return pixmap; | 202 | return pixmap; |
203 | } | 203 | } |
204 | 204 | ||
205 | 205 | ||
206 | 206 | ||
207 | void AudioWidget::resizeEvent( QResizeEvent * ) { | 207 | void AudioWidget::resizeEvent( QResizeEvent * ) { |
208 | int h = height(); | 208 | int h = height(); |
209 | int w = width(); | 209 | int w = width(); |
210 | 210 | ||
211 | songInfo.setGeometry( QRect( 2, 10, w - 4, 20 ) ); | 211 | songInfo.setGeometry( QRect( 2, 10, w - 4, 20 ) ); |
212 | slider.setFixedWidth( w - 110 ); | 212 | slider.setFixedWidth( w - 110 ); |
213 | slider.setGeometry( QRect( 15, h - 30, w - 90, 20 ) ); | 213 | slider.setGeometry( QRect( 15, h - 30, w - 90, 20 ) ); |
214 | slider.setBackgroundOrigin( QWidget::ParentOrigin ); | 214 | slider.setBackgroundOrigin( QWidget::ParentOrigin ); |
215 | time.setGeometry( QRect( w - 85, h - 30, 70, 20 ) ); | 215 | time.setGeometry( QRect( w - 85, h - 30, 70, 20 ) ); |
216 | 216 | ||
217 | xoff = ( w - imgUp->width() ) / 2; | 217 | xoff = ( w - imgUp->width() ) / 2; |
218 | yoff = (( h - imgUp->height() ) / 2) - 10; | 218 | yoff = (( h - imgUp->height() ) / 2) - 10; |
219 | QPoint p( xoff, yoff ); | 219 | QPoint p( xoff, yoff ); |
220 | 220 | ||
221 | QPixmap *pixUp = combineImageWithBackground( *imgUp, *pixBg, p ); | 221 | QPixmap *pixUp = combineImageWithBackground( *imgUp, *pixBg, p ); |
222 | QPixmap *pixDn = combineImageWithBackground( *imgDn, *pixBg, p ); | 222 | QPixmap *pixDn = combineImageWithBackground( *imgDn, *pixBg, p ); |
223 | 223 | ||
224 | for ( int i = 0; i < 11; i++ ) { | 224 | for ( int i = 0; i < 11; i++ ) { |
225 | if ( !masks[i]->isNull() ) { | 225 | if ( !masks[i]->isNull() ) { |
226 | delete buttonPixUp[i]; | 226 | delete buttonPixUp[i]; |
227 | delete buttonPixDown[i]; | 227 | delete buttonPixDown[i]; |
228 | buttonPixUp[i] = maskPixToMask( *pixUp, *masks[i] ); | 228 | buttonPixUp[i] = maskPixToMask( *pixUp, *masks[i] ); |
229 | buttonPixDown[i] = maskPixToMask( *pixDn, *masks[i] ); | 229 | buttonPixDown[i] = maskPixToMask( *pixDn, *masks[i] ); |
230 | } | 230 | } |
231 | } | 231 | } |
232 | 232 | ||
233 | delete pixUp; | 233 | delete pixUp; |
234 | delete pixDn; | 234 | delete pixDn; |
235 | } | 235 | } |
236 | 236 | ||
237 | static bool audioSliderBeingMoved = FALSE; | 237 | static bool audioSliderBeingMoved = FALSE; |
238 | 238 | ||
239 | 239 | ||
240 | void AudioWidget::sliderPressed() { | 240 | void AudioWidget::sliderPressed() { |
241 | audioSliderBeingMoved = TRUE; | 241 | audioSliderBeingMoved = TRUE; |
242 | } | 242 | } |
243 | 243 | ||
244 | 244 | ||
245 | void AudioWidget::sliderReleased() { | 245 | void AudioWidget::sliderReleased() { |
246 | audioSliderBeingMoved = FALSE; | 246 | audioSliderBeingMoved = FALSE; |
247 | if ( slider.width() == 0 ) | 247 | if ( slider.width() == 0 ) |
248 | return; | 248 | return; |
249 | long val = long((double)slider.value() * mediaPlayerState->length() / slider.width()); | 249 | long val = long((double)slider.value() * mediaPlayerState->length() / slider.width()); |
250 | mediaPlayerState->setPosition( val ); | 250 | mediaPlayerState->setPosition( val ); |
251 | } | 251 | } |
252 | 252 | ||
253 | void AudioWidget::setPosition( long i ) { | 253 | void AudioWidget::setPosition( long i ) { |
254 | // qDebug("set position %d",i); | 254 | // qDebug("set position %d",i); |
255 | updateSlider( i, mediaPlayerState->length() ); | 255 | updateSlider( i, mediaPlayerState->length() ); |
256 | } | 256 | } |
257 | 257 | ||
258 | 258 | ||
259 | void AudioWidget::setLength( long max ) { | 259 | void AudioWidget::setLength( long max ) { |
260 | updateSlider( mediaPlayerState->position(), max ); | 260 | updateSlider( mediaPlayerState->position(), max ); |
261 | } | 261 | } |
262 | 262 | ||
263 | 263 | ||
264 | void AudioWidget::setView( char view ) { | 264 | void AudioWidget::setView( char view ) { |
265 | if (mediaPlayerState->streaming() ) { | 265 | if (mediaPlayerState->streaming() ) { |
266 | if( !slider.isHidden()) slider.hide(); | 266 | if( !slider.isHidden()) slider.hide(); |
267 | disconnect( mediaPlayerState, SIGNAL( positionChanged(long) ),this, SLOT( setPosition(long) ) ); | 267 | disconnect( mediaPlayerState, SIGNAL( positionChanged(long) ),this, SLOT( setPosition(long) ) ); |
268 | disconnect( mediaPlayerState, SIGNAL( positionUpdated(long) ),this, SLOT( setPosition(long) ) ); | 268 | disconnect( mediaPlayerState, SIGNAL( positionUpdated(long) ),this, SLOT( setPosition(long) ) ); |
269 | } else { | 269 | } else { |
270 | // this stops the slider from being moved, thus | 270 | // this stops the slider from being moved, thus |
271 | // does not stop stream when it reaches the end | 271 | // does not stop stream when it reaches the end |
272 | slider->show(); | 272 | slider.show(); |
273 | connect( mediaPlayerState, SIGNAL( positionChanged(long) ),this, SLOT( setPosition(long) ) ); | 273 | connect( mediaPlayerState, SIGNAL( positionChanged(long) ),this, SLOT( setPosition(long) ) ); |
274 | connect( mediaPlayerState, SIGNAL( positionUpdated(long) ),this, SLOT( setPosition(long) ) ); | 274 | connect( mediaPlayerState, SIGNAL( positionUpdated(long) ),this, SLOT( setPosition(long) ) ); |
275 | } | 275 | } |
276 | 276 | ||
277 | if ( view == 'a' ) { | 277 | if ( view == 'a' ) { |
278 | startTimer( 150 ); | 278 | startTimer( 150 ); |
279 | showMaximized(); | 279 | showMaximized(); |
280 | } else { | 280 | } else { |
281 | killTimers(); | 281 | killTimers(); |
282 | hide(); | 282 | hide(); |
283 | } | 283 | } |
284 | } | 284 | } |
285 | 285 | ||
286 | 286 | ||
287 | static QString timeAsString( long length ) { | 287 | static QString timeAsString( long length ) { |
288 | length /= 44100; | 288 | length /= 44100; |
289 | int minutes = length / 60; | 289 | int minutes = length / 60; |
290 | int seconds = length % 60; | 290 | int seconds = length % 60; |
291 | return QString("%1:%2%3").arg( minutes ).arg( seconds / 10 ).arg( seconds % 10 ); | 291 | return QString("%1:%2%3").arg( minutes ).arg( seconds / 10 ).arg( seconds % 10 ); |
292 | } | 292 | } |
293 | 293 | ||
294 | void AudioWidget::updateSlider( long i, long max ) { | 294 | void AudioWidget::updateSlider( long i, long max ) { |
295 | time.setText( timeAsString( i ) + " / " + timeAsString( max ) ); | 295 | time.setText( timeAsString( i ) + " / " + timeAsString( max ) ); |
296 | if ( max == 0 ) { | 296 | if ( max == 0 ) { |
297 | return; | 297 | return; |
298 | } | 298 | } |
299 | // Will flicker too much if we don't do this | 299 | // Will flicker too much if we don't do this |
300 | // Scale to something reasonable | 300 | // Scale to something reasonable |
301 | int width = slider->width(); | 301 | int width = slider.width(); |
302 | int val = int((double)i * width / max); | 302 | int val = int((double)i * width / max); |
303 | if ( !audioSliderBeingMoved ) { | 303 | if ( !audioSliderBeingMoved ) { |
304 | if ( slider->value() != val ) { | 304 | if ( slider.value() != val ) { |
305 | slider->setValue( val ); | 305 | slider.setValue( val ); |
306 | } | 306 | } |
307 | 307 | ||
308 | if ( slider->maxValue() != width ) { | 308 | if ( slider.maxValue() != width ) { |
309 | slider->setMaxValue( width ); | 309 | slider.setMaxValue( width ); |
310 | } | 310 | } |
311 | } | 311 | } |
312 | } | 312 | } |
313 | 313 | ||
314 | 314 | ||
315 | void AudioWidget::setToggleButton( int i, bool down ) { | 315 | void AudioWidget::setToggleButton( int i, bool down ) { |
316 | if ( down != audioButtons[i].isDown ) { | 316 | if ( down != audioButtons[i].isDown ) { |
317 | toggleButton( i ); | 317 | toggleButton( i ); |
318 | } | 318 | } |
319 | } | 319 | } |
320 | 320 | ||
321 | 321 | ||
322 | void AudioWidget::toggleButton( int i ) { | 322 | void AudioWidget::toggleButton( int i ) { |
323 | audioButtons[i].isDown = !audioButtons[i].isDown; | 323 | audioButtons[i].isDown = !audioButtons[i].isDown; |
324 | QPainter p(this); | 324 | QPainter p(this); |
325 | paintButton ( &p, i ); | 325 | paintButton ( &p, i ); |
326 | } | 326 | } |
327 | 327 | ||
328 | 328 | ||
329 | void AudioWidget::paintButton( QPainter *p, int i ) { | 329 | void AudioWidget::paintButton( QPainter *p, int i ) { |
330 | if ( audioButtons[i].isDown ) | 330 | if ( audioButtons[i].isDown ) |
331 | p->drawPixmap( xoff, yoff, *buttonPixDown[i] ); | 331 | p->drawPixmap( xoff, yoff, *buttonPixDown[i] ); |
332 | else | 332 | else |
333 | p->drawPixmap( xoff, yoff, *buttonPixUp[i] ); | 333 | p->drawPixmap( xoff, yoff, *buttonPixUp[i] ); |
334 | } | 334 | } |
335 | 335 | ||
336 | 336 | ||
337 | void AudioWidget::timerEvent( QTimerEvent * ) { | 337 | void AudioWidget::timerEvent( QTimerEvent * ) { |
338 | // static int frame = 0; | 338 | // static int frame = 0; |
339 | // if ( !mediaPlayerState->paused() && audioButtons[ AudioPlay ].isDown ) { | 339 | // if ( !mediaPlayerState->paused() && audioButtons[ AudioPlay ].isDown ) { |
340 | // frame = frame >= 7 ? 0 : frame + 1; | 340 | // frame = frame >= 7 ? 0 : frame + 1; |
341 | // } | 341 | // } |
342 | } | 342 | } |
343 | 343 | ||
344 | 344 | ||
345 | void AudioWidget::mouseMoveEvent( QMouseEvent *event ) { | 345 | void AudioWidget::mouseMoveEvent( QMouseEvent *event ) { |
346 | for ( int i = 0; i < numButtons; i++ ) { | 346 | for ( int i = 0; i < numButtons; i++ ) { |
347 | if ( event->state() == QMouseEvent::LeftButton ) { | 347 | if ( event->state() == QMouseEvent::LeftButton ) { |
348 | 348 | ||
349 | // The test to see if the mouse click is inside the button or not | 349 | // The test to see if the mouse click is inside the button or not |
350 | int x = event->pos().x() - xoff; | 350 | int x = event->pos().x() - xoff; |
351 | int y = event->pos().y() - yoff; | 351 | int y = event->pos().y() - yoff; |
352 | 352 | ||
353 | bool isOnButton = ( x > 0 && y > 0 && x < imgButtonMask->width() | 353 | bool isOnButton = ( x > 0 && y > 0 && x < imgButtonMask->width() |
354 | && y < imgButtonMask->height() && imgButtonMask->pixelIndex( x, y ) == i + 1 ); | 354 | && y < imgButtonMask->height() && imgButtonMask->pixelIndex( x, y ) == i + 1 ); |
355 | 355 | ||
356 | if ( isOnButton && i == AudioVolumeUp ) | 356 | if ( isOnButton && i == AudioVolumeUp ) |
357 | qDebug("on up"); | 357 | qDebug("on up"); |
358 | 358 | ||
359 | if ( isOnButton && !audioButtons[i].isHeld ) { | 359 | if ( isOnButton && !audioButtons[i].isHeld ) { |
360 | audioButtons[i].isHeld = TRUE; | 360 | audioButtons[i].isHeld = TRUE; |
361 | toggleButton(i); | 361 | toggleButton(i); |
362 | switch (i) { | 362 | switch (i) { |
363 | case AudioVolumeUp: | 363 | case AudioVolumeUp: |
364 | qDebug("more clicked"); | 364 | qDebug("more clicked"); |
365 | emit moreClicked(); | 365 | emit moreClicked(); |
366 | return; | 366 | return; |
367 | case AudioVolumeDown: emit lessClicked(); return; | 367 | case AudioVolumeDown: emit lessClicked(); return; |
368 | } | 368 | } |
369 | } else if ( !isOnButton && audioButtons[i].isHeld ) { | 369 | } else if ( !isOnButton && audioButtons[i].isHeld ) { |
370 | audioButtons[i].isHeld = FALSE; | 370 | audioButtons[i].isHeld = FALSE; |
371 | toggleButton(i); | 371 | toggleButton(i); |
372 | } | 372 | } |
373 | } else { | 373 | } else { |
374 | if ( audioButtons[i].isHeld ) { | 374 | if ( audioButtons[i].isHeld ) { |
375 | audioButtons[i].isHeld = FALSE; | 375 | audioButtons[i].isHeld = FALSE; |
376 | if ( !audioButtons[i].isToggle ) | 376 | if ( !audioButtons[i].isToggle ) |
377 | setToggleButton( i, FALSE ); | 377 | setToggleButton( i, FALSE ); |
378 | switch (i) { | 378 | switch (i) { |
379 | case AudioPlay: mediaPlayerState->setPlaying(audioButtons[i].isDown); return; | 379 | case AudioPlay: mediaPlayerState->setPlaying(audioButtons[i].isDown); return; |
380 | case AudioStop: mediaPlayerState->setPlaying(FALSE); return; | 380 | case AudioStop: mediaPlayerState->setPlaying(FALSE); return; |
381 | case AudioPause: mediaPlayerState->setPaused(audioButtons[i].isDown); return; | 381 | case AudioPause: mediaPlayerState->setPaused(audioButtons[i].isDown); return; |
382 | case AudioNext: mediaPlayerState->setNext(); return; | 382 | case AudioNext: mediaPlayerState->setNext(); return; |
383 | case AudioPrevious: mediaPlayerState->setPrev(); return; | 383 | case AudioPrevious: mediaPlayerState->setPrev(); return; |
384 | case AudioLoop: mediaPlayerState->setLooping(audioButtons[i].isDown); return; | 384 | case AudioLoop: mediaPlayerState->setLooping(audioButtons[i].isDown); return; |
385 | case AudioVolumeUp: emit moreReleased(); return; | 385 | case AudioVolumeUp: emit moreReleased(); return; |
386 | case AudioVolumeDown: emit lessReleased(); return; | 386 | case AudioVolumeDown: emit lessReleased(); return; |
387 | case AudioPlayList: mediaPlayerState->setList(); return; | 387 | case AudioPlayList: mediaPlayerState->setList(); return; |
388 | } | 388 | } |
389 | } | 389 | } |
390 | } | 390 | } |
391 | } | 391 | } |
392 | } | 392 | } |
393 | 393 | ||
394 | 394 | ||
395 | void AudioWidget::mousePressEvent( QMouseEvent *event ) { | 395 | void AudioWidget::mousePressEvent( QMouseEvent *event ) { |
396 | mouseMoveEvent( event ); | 396 | mouseMoveEvent( event ); |
397 | } | 397 | } |
398 | 398 | ||
399 | 399 | ||
400 | void AudioWidget::mouseReleaseEvent( QMouseEvent *event ) { | 400 | void AudioWidget::mouseReleaseEvent( QMouseEvent *event ) { |
401 | mouseMoveEvent( event ); | 401 | mouseMoveEvent( event ); |
402 | } | 402 | } |
403 | 403 | ||
404 | 404 | ||
405 | void AudioWidget::showEvent( QShowEvent* ) { | 405 | void AudioWidget::showEvent( QShowEvent* ) { |