summaryrefslogtreecommitdiff
authorharlekin <harlekin>2002-08-16 15:42:44 (UTC)
committer harlekin <harlekin>2002-08-16 15:42:44 (UTC)
commitfec49e4f9f8d016e335eaca1630f4108801cc3ce (patch) (unidiff)
tree271c4dda3b4b634e0946528e4a4b2c9e6746d25c
parentaa9eba407a8236c72822d24643b58d4d48ae80c0 (diff)
downloadopie-fec49e4f9f8d016e335eaca1630f4108801cc3ce.zip
opie-fec49e4f9f8d016e335eaca1630f4108801cc3ce.tar.gz
opie-fec49e4f9f8d016e335eaca1630f4108801cc3ce.tar.bz2
hide slider when streaming videos
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/multimedia/opieplayer2/videowidget.cpp23
1 files changed, 6 insertions, 17 deletions
diff --git a/noncore/multimedia/opieplayer2/videowidget.cpp b/noncore/multimedia/opieplayer2/videowidget.cpp
index 5a69bf5..956789f 100644
--- a/noncore/multimedia/opieplayer2/videowidget.cpp
+++ b/noncore/multimedia/opieplayer2/videowidget.cpp
@@ -173,143 +173,128 @@ QPixmap *combineVImageWithBackground( QImage img, QPixmap bg, QPoint offset ) {
173QPixmap *maskVPixToMask( QPixmap pix, QBitmap mask ) { 173QPixmap *maskVPixToMask( QPixmap pix, QBitmap mask ) {
174 QPixmap *pixmap = new QPixmap( pix ); 174 QPixmap *pixmap = new QPixmap( pix );
175 pixmap->setMask( mask ); 175 pixmap->setMask( mask );
176 return pixmap; 176 return pixmap;
177} 177}
178 178
179void VideoWidget::resizeEvent( QResizeEvent * ) { 179void VideoWidget::resizeEvent( QResizeEvent * ) {
180 int h = height(); 180 int h = height();
181 int w = width(); 181 int w = width();
182 int Vh = 160; 182 int Vh = 160;
183 int Vw = 220; 183 int Vw = 220;
184 184
185 slider->setFixedWidth( w - 20 ); 185 slider->setFixedWidth( w - 20 );
186 slider->setGeometry( QRect( 15, h - 30, w - 90, 20 ) ); 186 slider->setGeometry( QRect( 15, h - 30, w - 90, 20 ) );
187 slider->setBackgroundOrigin( QWidget::ParentOrigin ); 187 slider->setBackgroundOrigin( QWidget::ParentOrigin );
188 slider->setFocusPolicy( QWidget::NoFocus ); 188 slider->setFocusPolicy( QWidget::NoFocus );
189 slider->setBackgroundPixmap( *pixBg ); 189 slider->setBackgroundPixmap( *pixBg );
190 190
191 xoff = 0;// ( imgUp->width() ) / 2; 191 xoff = 0;// ( imgUp->width() ) / 2;
192 yoff = 185;//(( Vh - imgUp->height() ) / 2) - 10; 192 yoff = 185;//(( Vh - imgUp->height() ) / 2) - 10;
193 QPoint p( xoff, yoff ); 193 QPoint p( xoff, yoff );
194 194
195 QPixmap *pixUp = combineVImageWithBackground( *imgUp, *pixBg, p ); 195 QPixmap *pixUp = combineVImageWithBackground( *imgUp, *pixBg, p );
196 QPixmap *pixDn = combineVImageWithBackground( *imgDn, *pixBg, p ); 196 QPixmap *pixDn = combineVImageWithBackground( *imgDn, *pixBg, p );
197 197
198 for ( int i = 0; i < 7; i++ ) { 198 for ( int i = 0; i < 7; i++ ) {
199 if ( !masks[i]->isNull() ) { 199 if ( !masks[i]->isNull() ) {
200 delete buttonPixUp[i]; 200 delete buttonPixUp[i];
201 delete buttonPixDown[i]; 201 delete buttonPixDown[i];
202 buttonPixUp[i] = maskVPixToMask( *pixUp, *masks[i] ); 202 buttonPixUp[i] = maskVPixToMask( *pixUp, *masks[i] );
203 buttonPixDown[i] = maskVPixToMask( *pixDn, *masks[i] ); 203 buttonPixDown[i] = maskVPixToMask( *pixDn, *masks[i] );
204 } 204 }
205 } 205 }
206 206
207 delete pixUp; 207 delete pixUp;
208 delete pixDn; 208 delete pixDn;
209} 209}
210 210
211static bool videoSliderBeingMoved = FALSE; 211static bool videoSliderBeingMoved = FALSE;
212 212
213void VideoWidget::sliderPressed() { 213void VideoWidget::sliderPressed() {
214 videoSliderBeingMoved = TRUE; 214 videoSliderBeingMoved = TRUE;
215} 215}
216 216
217void VideoWidget::sliderReleased() { 217void VideoWidget::sliderReleased() {
218 videoSliderBeingMoved = FALSE; 218 videoSliderBeingMoved = FALSE;
219 if ( slider->width() == 0 ) { 219 if ( slider->width() == 0 ) {
220 return; 220 return;
221 } 221 }
222 long val = long((double)slider->value() * mediaPlayerState->length() / slider->width()); 222 long val = long((double)slider->value() * mediaPlayerState->length() / slider->width());
223 mediaPlayerState->setPosition( val ); 223 mediaPlayerState->setPosition( val );
224} 224}
225 225
226void VideoWidget::setPosition( long i ) { 226void VideoWidget::setPosition( long i ) {
227 updateSlider( i, mediaPlayerState->length() ); 227 updateSlider( i, mediaPlayerState->length() );
228} 228}
229 229
230 230
231void VideoWidget::setLength( long max ) { 231void VideoWidget::setLength( long max ) {
232 updateSlider( mediaPlayerState->position(), max ); 232 updateSlider( mediaPlayerState->position(), max );
233} 233}
234 234
235void VideoWidget::setView( char view ) { 235void VideoWidget::setView( char view ) {
236 236
237 if ( mediaPlayerState->streaming() ) {
238 qDebug("<<<<<<<<<<<<<<file is STREAMING>>>>>>>>>>>>>>>>>>>");
239 if( !slider->isHidden()) {
240 slider->hide();
241 }
242 disconnect( mediaPlayerState, SIGNAL( positionChanged(long) ),this, SLOT( setPosition(long) ) );
243 disconnect( mediaPlayerState, SIGNAL( positionUpdated(long) ),this, SLOT( setPosition(long) ) );
244 } else {
245 // this stops the slider from being moved, thus
246 // does not stop stream when it reaches the end
247 slider->show();
248 connect( mediaPlayerState, SIGNAL( positionChanged(long) ),this, SLOT( setPosition(long) ) );
249 connect( mediaPlayerState, SIGNAL( positionUpdated(long) ),this, SLOT( setPosition(long) ) );
250 }
251
252 if ( view == 'v' ) { 237 if ( view == 'v' ) {
253 makeVisible(); 238 makeVisible();
254 } else { 239 } else {
255 // Effectively blank the view next time we show it so it looks nicer 240 // Effectively blank the view next time we show it so it looks nicer
256 scaledWidth = 0; 241 scaledWidth = 0;
257 scaledHeight = 0; 242 scaledHeight = 0;
258 hide(); 243 hide();
259 } 244 }
260} 245}
261 246
262void VideoWidget::updateSlider( long i, long max ) { 247void VideoWidget::updateSlider( long i, long max ) {
263 // Will flicker too much if we don't do this 248 // Will flicker too much if we don't do this
264 if ( max == 0 ) { 249 if ( max == 0 ) {
265 return; 250 return;
266 } 251 }
267 int width = slider->width(); 252 int width = slider->width();
268 int val = int((double)i * width / max); 253 int val = int((double)i * width / max);
269 if ( !mediaPlayerState->fullscreen() && !videoSliderBeingMoved ) { 254 if ( !mediaPlayerState->fullscreen() && !videoSliderBeingMoved ) {
270 if ( slider->value() != val ) { 255 if ( slider->value() != val ) {
271 slider->setValue( val ); 256 slider->setValue( val );
272 } 257 }
273 if ( slider->maxValue() != width ) { 258 if ( slider->maxValue() != width ) {
274 slider->setMaxValue( width ); 259 slider->setMaxValue( width );
275 } 260 }
276 } 261 }
277} 262}
278 263
279void VideoWidget::setToggleButton( int i, bool down ) { 264void VideoWidget::setToggleButton( int i, bool down ) {
280 if ( down != videoButtons[i].isDown ) { 265 if ( down != videoButtons[i].isDown ) {
281 toggleButton( i ); 266 toggleButton( i );
282 } 267 }
283} 268}
284 269
285void VideoWidget::toggleButton( int i ) { 270void VideoWidget::toggleButton( int i ) {
286 videoButtons[i].isDown = !videoButtons[i].isDown; 271 videoButtons[i].isDown = !videoButtons[i].isDown;
287 QPainter p(this); 272 QPainter p(this);
288 paintButton ( &p, i ); 273 paintButton ( &p, i );
289} 274}
290 275
291void VideoWidget::paintButton( QPainter *p, int i ) { 276void VideoWidget::paintButton( QPainter *p, int i ) {
292 277
293 if ( videoButtons[i].isDown ) { 278 if ( videoButtons[i].isDown ) {
294 p->drawPixmap( xoff, yoff, *buttonPixDown[i] ); 279 p->drawPixmap( xoff, yoff, *buttonPixDown[i] );
295 } else { 280 } else {
296 p->drawPixmap( xoff, yoff, *buttonPixUp[i] ); 281 p->drawPixmap( xoff, yoff, *buttonPixUp[i] );
297 } 282 }
298} 283}
299 284
300void VideoWidget::mouseMoveEvent( QMouseEvent *event ) { 285void VideoWidget::mouseMoveEvent( QMouseEvent *event ) {
301 for ( int i = 0; i < numVButtons; i++ ) { 286 for ( int i = 0; i < numVButtons; i++ ) {
302 if ( event->state() == QMouseEvent::LeftButton ) { 287 if ( event->state() == QMouseEvent::LeftButton ) {
303 // The test to see if the mouse click is inside the button or not 288 // The test to see if the mouse click is inside the button or not
304 int x = event->pos().x() - xoff; 289 int x = event->pos().x() - xoff;
305 int y = event->pos().y() - yoff; 290 int y = event->pos().y() - yoff;
306 291
307 bool isOnButton = ( x > 0 && y > 0 && x < imgButtonMask->width() 292 bool isOnButton = ( x > 0 && y > 0 && x < imgButtonMask->width()
308 && y < imgButtonMask->height() 293 && y < imgButtonMask->height()
309 && imgButtonMask->pixelIndex( x, y ) == i + 1 ); 294 && imgButtonMask->pixelIndex( x, y ) == i + 1 );
310 295
311 if ( isOnButton && !videoButtons[i].isHeld ) { 296 if ( isOnButton && !videoButtons[i].isHeld ) {
312 videoButtons[i].isHeld = TRUE; 297 videoButtons[i].isHeld = TRUE;
313 toggleButton(i); 298 toggleButton(i);
314 299
315 switch (i) { 300 switch (i) {
@@ -333,176 +318,180 @@ void VideoWidget::mouseMoveEvent( QMouseEvent *event ) {
333 } 318 }
334 319
335 switch(i) { 320 switch(i) {
336 321
337 case VideoPlay: { 322 case VideoPlay: {
338 if( mediaPlayerState->isPaused ) { 323 if( mediaPlayerState->isPaused ) {
339 setToggleButton( i, FALSE ); 324 setToggleButton( i, FALSE );
340 mediaPlayerState->setPaused( FALSE ); 325 mediaPlayerState->setPaused( FALSE );
341 return; 326 return;
342 } else if( !mediaPlayerState->isPaused ) { 327 } else if( !mediaPlayerState->isPaused ) {
343 setToggleButton( i, TRUE ); 328 setToggleButton( i, TRUE );
344 mediaPlayerState->setPaused( TRUE ); 329 mediaPlayerState->setPaused( TRUE );
345 return; 330 return;
346 } else { 331 } else {
347 return; 332 return;
348 } 333 }
349 } 334 }
350 335
351 case VideoStop: mediaPlayerState->setPlaying( FALSE ); return; 336 case VideoStop: mediaPlayerState->setPlaying( FALSE ); return;
352 case VideoNext: mediaPlayerState->setNext(); return; 337 case VideoNext: mediaPlayerState->setNext(); return;
353 case VideoPrevious: mediaPlayerState->setPrev(); return; 338 case VideoPrevious: mediaPlayerState->setPrev(); return;
354 case VideoVolUp: emit moreReleased(); return; 339 case VideoVolUp: emit moreReleased(); return;
355 case VideoVolDown: emit lessReleased(); return; 340 case VideoVolDown: emit lessReleased(); return;
356 case VideoFullscreen: mediaPlayerState->setFullscreen( TRUE ); makeVisible(); return; 341 case VideoFullscreen: mediaPlayerState->setFullscreen( TRUE ); makeVisible(); return;
357 } 342 }
358 } 343 }
359 } 344 }
360 } 345 }
361} 346}
362 347
363void VideoWidget::mousePressEvent( QMouseEvent *event ) { 348void VideoWidget::mousePressEvent( QMouseEvent *event ) {
364 mouseMoveEvent( event ); 349 mouseMoveEvent( event );
365} 350}
366 351
367void VideoWidget::mouseReleaseEvent( QMouseEvent *event ) { 352void VideoWidget::mouseReleaseEvent( QMouseEvent *event ) {
368 if ( mediaPlayerState->fullscreen() ) { 353 if ( mediaPlayerState->fullscreen() ) {
369 mediaPlayerState->setFullscreen( FALSE ); 354 mediaPlayerState->setFullscreen( FALSE );
370 makeVisible(); 355 makeVisible();
371 } 356 }
372 mouseMoveEvent( event ); 357 mouseMoveEvent( event );
373} 358}
374 359
375void VideoWidget::showEvent( QShowEvent* ) { 360void VideoWidget::showEvent( QShowEvent* ) {
376 QMouseEvent event( QEvent::MouseMove, QPoint( 0, 0 ), 0, 0 ); 361 QMouseEvent event( QEvent::MouseMove, QPoint( 0, 0 ), 0, 0 );
377 mouseMoveEvent( &event ); 362 mouseMoveEvent( &event );
378} 363}
379 364
380 365
381 void VideoWidget::backToNormal() { 366 void VideoWidget::backToNormal() {
382 mediaPlayerState->setFullscreen( FALSE ); 367 mediaPlayerState->setFullscreen( FALSE );
383 makeVisible(); 368 makeVisible();
384 } 369 }
385 370
386void VideoWidget::makeVisible() { 371void VideoWidget::makeVisible() {
387 if ( mediaPlayerState->fullscreen() ) { 372 if ( mediaPlayerState->fullscreen() ) {
388 setBackgroundMode( QWidget::NoBackground ); 373 setBackgroundMode( QWidget::NoBackground );
389 showFullScreen(); 374 showFullScreen();
390 resize( qApp->desktop()->size() ); 375 resize( qApp->desktop()->size() );
391 slider->hide(); 376 slider->hide();
392 videoFrame-> setGeometry ( 0, 0, width ( ), height ( )); 377 videoFrame-> setGeometry ( 0, 0, width ( ), height ( ));
393 378
394 } else { 379 } else {
395 showMaximized(); 380 showMaximized();
396 setBackgroundPixmap( *pixBg ); 381 setBackgroundPixmap( *pixBg );
397 slider->show(); 382 if ( mediaPlayerState->streaming() ) {
383 slider->hide();
384 } else {
385 slider->show();
386 }
398 videoFrame->setGeometry( QRect( 0, 30, 240, 170 ) ); 387 videoFrame->setGeometry( QRect( 0, 30, 240, 170 ) );
399 qApp->processEvents(); 388 qApp->processEvents();
400 } 389 }
401} 390}
402 391
403 392
404void VideoWidget::paintEvent( QPaintEvent * pe) { 393void VideoWidget::paintEvent( QPaintEvent * pe) {
405 QPainter p( this ); 394 QPainter p( this );
406 395
407 if ( mediaPlayerState->fullscreen() ) { 396 if ( mediaPlayerState->fullscreen() ) {
408 // Clear the background 397 // Clear the background
409 p.setBrush( QBrush( Qt::black ) ); 398 p.setBrush( QBrush( Qt::black ) );
410 } else { 399 } else {
411 if ( !pe->erased() ) { 400 if ( !pe->erased() ) {
412 // Combine with background and double buffer 401 // Combine with background and double buffer
413 QPixmap pix( pe->rect().size() ); 402 QPixmap pix( pe->rect().size() );
414 QPainter p( &pix ); 403 QPainter p( &pix );
415 p.translate( -pe->rect().topLeft().x(), -pe->rect().topLeft().y() ); 404 p.translate( -pe->rect().topLeft().x(), -pe->rect().topLeft().y() );
416 p.drawTiledPixmap( pe->rect(), *pixBg, pe->rect().topLeft() ); 405 p.drawTiledPixmap( pe->rect(), *pixBg, pe->rect().topLeft() );
417 for ( int i = 0; i < numVButtons; i++ ) { 406 for ( int i = 0; i < numVButtons; i++ ) {
418 paintButton( &p, i ); 407 paintButton( &p, i );
419 } 408 }
420 QPainter p2( this ); 409 QPainter p2( this );
421 p2.drawPixmap( pe->rect().topLeft(), pix ); 410 p2.drawPixmap( pe->rect().topLeft(), pix );
422 } else { 411 } else {
423 QPainter p( this ); 412 QPainter p( this );
424 for ( int i = 0; i < numVButtons; i++ ) 413 for ( int i = 0; i < numVButtons; i++ )
425 paintButton( &p, i ); 414 paintButton( &p, i );
426 } 415 }
427 slider->repaint( TRUE ); 416 slider->repaint( TRUE );
428 } 417 }
429} 418}
430 419
431 420
432void VideoWidget::closeEvent( QCloseEvent* ) { 421void VideoWidget::closeEvent( QCloseEvent* ) {
433 mediaPlayerState->setList(); 422 mediaPlayerState->setList();
434} 423}
435 424
436 425
437 426
438void VideoWidget::keyReleaseEvent( QKeyEvent *e) { 427void VideoWidget::keyReleaseEvent( QKeyEvent *e) {
439 switch ( e->key() ) { 428 switch ( e->key() ) {
440////////////////////////////// Zaurus keys 429////////////////////////////// Zaurus keys
441 case Key_Home: 430 case Key_Home:
442 break; 431 break;
443 case Key_F9: //activity 432 case Key_F9: //activity
444 break; 433 break;
445 case Key_F10: //contacts 434 case Key_F10: //contacts
446// hide(); 435// hide();
447 break; 436 break;
448 case Key_F11: //menu 437 case Key_F11: //menu
449 break; 438 break;
450 case Key_F12: //home 439 case Key_F12: //home
451 break; 440 break;
452 case Key_F13: //mail 441 case Key_F13: //mail
453 break; 442 break;
454 case Key_Space: { 443 case Key_Space: {
455 if(mediaPlayerState->playing()) { 444 if(mediaPlayerState->playing()) {
456 mediaPlayerState->setPlaying(FALSE); 445 mediaPlayerState->setPlaying(FALSE);
457 } else { 446 } else {
458 mediaPlayerState->setPlaying(TRUE); 447 mediaPlayerState->setPlaying(TRUE);
459 } 448 }
460 } 449 }
461 break; 450 break;
462 case Key_Down: 451 case Key_Down:
463// toggleButton(6); 452// toggleButton(6);
464 emit lessClicked(); 453 emit lessClicked();
465 emit lessReleased(); 454 emit lessReleased();
466// toggleButton(6); 455// toggleButton(6);
467 break; 456 break;
468 case Key_Up: 457 case Key_Up:
469// toggleButton(5); 458// toggleButton(5);
470 emit moreClicked(); 459 emit moreClicked();
471 emit moreReleased(); 460 emit moreReleased();
472// toggleButton(5); 461// toggleButton(5);
473 break; 462 break;
474 case Key_Right: 463 case Key_Right:
475 mediaPlayerState->setNext(); 464 mediaPlayerState->setNext();
476 break; 465 break;
477 case Key_Left: 466 case Key_Left:
478 mediaPlayerState->setPrev(); 467 mediaPlayerState->setPrev();
479 break; 468 break;
480 case Key_Escape: 469 case Key_Escape:
481#if defined(QT_QWS_IPAQ) 470#if defined(QT_QWS_IPAQ)
482 if( mediaPlayerState->isPaused ) { 471 if( mediaPlayerState->isPaused ) {
483 setToggleButton( i, FALSE ); 472 setToggleButton( i, FALSE );
484 mediaPlayerState->setPaused( FALSE ); 473 mediaPlayerState->setPaused( FALSE );
485 } else if( !mediaPlayerState->isPaused ) { 474 } else if( !mediaPlayerState->isPaused ) {
486 setToggleButton( i, TRUE ); 475 setToggleButton( i, TRUE );
487 mediaPlayerState->setPaused( TRUE ); 476 mediaPlayerState->setPaused( TRUE );
488 } 477 }
489#endif 478#endif
490 break; 479 break;
491 480
492 }; 481 };
493} 482}
494 483
495XineVideoWidget* VideoWidget::vidWidget() { 484XineVideoWidget* VideoWidget::vidWidget() {
496 return videoFrame; 485 return videoFrame;
497} 486}
498 487
499 488
500void VideoWidget::setFullscreen ( bool b ) { 489void VideoWidget::setFullscreen ( bool b ) {
501 setToggleButton( VideoFullscreen, b ); 490 setToggleButton( VideoFullscreen, b );
502} 491}
503 492
504 493
505void VideoWidget::setPlaying( bool b) { 494void VideoWidget::setPlaying( bool b) {
506 setToggleButton( VideoPlay, b ); 495 setToggleButton( VideoPlay, b );
507} 496}
508 497