From 7a04855af4e042152a47e90192dc4c2c20858e8c Mon Sep 17 00:00:00 2001 From: harlekin Date: Tue, 24 Sep 2002 20:26:17 +0000 Subject: adapted to the new api --- (limited to 'noncore/multimedia/opieplayer2/lib.cpp') diff --git a/noncore/multimedia/opieplayer2/lib.cpp b/noncore/multimedia/opieplayer2/lib.cpp index d8a0694..4021d4a 100644 --- a/noncore/multimedia/opieplayer2/lib.cpp +++ b/noncore/multimedia/opieplayer2/lib.cpp @@ -1,4 +1,4 @@ -/* + /*                 This file is part of the Opie Project               Copyright (c) 2002 Max Reiss @@ -50,23 +50,23 @@ typedef void (*display_xine_frame_t) (void *user_data, uint8_t* frame, int width, int height,int bytes ); extern "C" { - vo_driver_t* init_video_out_plugin( config_values_t* conf, void* video); - int null_is_showing_video( vo_driver_t* self ); - void null_set_show_video( vo_driver_t* self, int show ); - int null_is_fullscreen( vo_driver_t* self ); - void null_set_fullscreen( vo_driver_t* self, int screen ); - int null_is_scaling( vo_driver_t* self ); - void null_set_scaling( vo_driver_t* self, int scale ); - void null_set_gui_width( vo_driver_t* self, int width ); - void null_set_gui_height( vo_driver_t* self, int height ); - void null_set_mode( vo_driver_t* self, int depth, int rgb ); - void null_set_videoGamma( vo_driver_t* self , int value ); - void null_display_handler(vo_driver_t* self, display_xine_frame_t t, void* user_data); + xine_vo_driver_t* init_video_out_plugin( xine_cfg_entry_t* conf, void* video); + int null_is_showing_video( const xine_vo_driver_t* self ); + void null_set_show_video( const xine_vo_driver_t* self, int show ); + int null_is_fullscreen( const xine_vo_driver_t* self ); + void null_set_fullscreen( const xine_vo_driver_t* self, int screen ); + int null_is_scaling( const xine_vo_driver_t* self ); + void null_set_scaling( const xine_vo_driver_t* self, int scale ); + void null_set_gui_width( const xine_vo_driver_t* self, int width ); + void null_set_gui_height( const xine_vo_driver_t* self, int height ); + void null_set_mode( const xine_vo_driver_t* self, int depth, int rgb ); + void null_set_videoGamma( const xine_vo_driver_t* self , int value ); + void null_display_handler( const xine_vo_driver_t* self, display_xine_frame_t t, void* user_data ); } using namespace XINE; -Lib::Lib(XineVideoWidget* widget) { +Lib::Lib( XineVideoWidget* widget ) { m_video = false; m_wid = widget; printf("Lib"); @@ -83,124 +83,154 @@ Lib::Lib(XineVideoWidget* widget) { f.close(); } - m_config = xine_config_file_init( str.data() ); + m_xine = xine_new( ); + + xine_config_load( m_xine, str.data() ); + // allocate oss for sound // and fb for framebuffer - m_audioOutput= xine_load_audio_output_plugin( m_config, "oss") ; + m_audioOutput = xine_open_audio_driver( m_xine, "oss", NULL ); m_videoOutput = ::init_video_out_plugin( m_config, NULL ); + + +//xine_open_video_driver( m_xine, NULL, XINE_VISUAL_TYPE_FB, NULL); + + + null_display_handler( m_videoOutput, xine_display_frame, this ); + xine_init( m_xine, m_audioOutput, m_videoOutput ); + if (m_wid != 0 ) { - printf("!0\n" ); - resize ( m_wid-> size ( )); + printf( "!0\n" ); + resize ( m_wid-> size ( ) ); ::null_set_mode( m_videoOutput, qt_screen->depth(), qt_screen->pixelType() ); - m_wid-> setLogo ( new QImage ( Resource::loadImage(""))); + m_wid->repaint(); } - null_display_handler( m_videoOutput, - xine_display_frame, - this ); - m_xine = xine_init( m_videoOutput, - m_audioOutput, m_config ); - // install the event handler xine_register_event_listener( m_xine, xine_event_handler, this ); } Lib::~Lib() { - free( m_config ); +// free( m_config ); xine_remove_event_listener( m_xine, xine_event_handler ); xine_exit( m_xine ); /* FIXME either free or delete but valgrind bitches against both */ //free( m_videoOutput ); //delete m_audioOutput; - } -void Lib::resize ( const QSize &s ) -{ - if ( s. width ( ) && s. height ( )) { - ::null_set_gui_width( m_videoOutput, s. width() ); - ::null_set_gui_height(m_videoOutput, s. height() ); - } +void Lib::resize ( const QSize &s ) { + if ( s. width ( ) && s. height ( ) ) { + ::null_set_gui_width( m_videoOutput, s. width() ); + ::null_set_gui_height( m_videoOutput, s. height() ); + } } QCString Lib::version() { - QCString str( xine_get_str_version() ); - return str; -}; + // QCString str( xine_get_str_version() ); + // return str; + return "test"; +} int Lib::majorVersion() { - return xine_get_major_version(); + xine_get_version ( &m_major_version, &m_minor_version, &m_sub_version ); + return m_major_version; } + int Lib::minorVersion() { - return xine_get_minor_version(); -}; + xine_get_version ( &m_major_version, &m_minor_version, &m_sub_version ); + return m_minor_version; +} int Lib::subVersion() { - return xine_get_sub_version(); + xine_get_version ( &m_major_version, &m_minor_version, &m_sub_version ); + return m_sub_version; } -int Lib::play( const QString& fileName, - int startPos, - int start_time ) { + +int Lib::play( const QString& fileName, int startPos, int start_time ) { QString str = fileName.stripWhiteSpace(); - //workaround OpiePlayer bug - //f (str.right(1) == QString::fromLatin1("/") ) - // str = str.mid( str.length() -1 ); - return xine_play( m_xine, QFile::encodeName(str.utf8() ).data(), - startPos, start_time); + xine_open( m_xine, QFile::encodeName(str.utf8() ).data() ); + return xine_play( m_xine, startPos, start_time); } + void Lib::stop() { qDebug("<<<<<<<< STOP IN LIB TRIGGERED >>>>>>>"); - xine_stop(m_xine ); + xine_stop( m_xine ); } -void Lib::pause(){ - xine_set_speed( m_xine, SPEED_PAUSE ); + +void Lib::pause() { + xine_set_param( m_xine, XINE_PARAM_SPEED, XINE_SPEED_PAUSE ); } + int Lib::speed() { - return xine_get_speed( m_xine ); + return xine_get_param ( m_xine, XINE_PARAM_SPEED ); } + void Lib::setSpeed( int speed ) { - xine_set_speed( m_xine, speed ); + xine_set_param ( m_xine, XINE_PARAM_SPEED, speed ); } -int Lib::status(){ + +int Lib::status() { return xine_get_status( m_xine ); } -int Lib::currentPosition(){ - return xine_get_current_position( m_xine ); + +int Lib::currentPosition() { + xine_get_pos_length( m_xine, &m_pos, &m_time, &m_length ); + return m_pos; +} + +int Lib::currentTime() { + xine_get_pos_length( m_xine, &m_pos, &m_time, &m_length ); + return m_time/1000; } -int Lib::currentTime() { - return xine_get_current_time( m_xine ); -}; + int Lib::length() { - return xine_get_stream_length( m_xine ); + xine_get_pos_length( m_xine, &m_pos, &m_time, &m_length ); + return m_length/1000; } + bool Lib::isSeekable() { - return xine_is_stream_seekable(m_xine); + return xine_get_stream_info ( m_xine, XINE_STREAM_INFO_SEEKABLE ); } + Frame Lib::currentFrame() { Frame frame; return frame; }; + +QString Lib::metaInfo() { + xine_get_meta_info( m_xine, 0 ); +} + int Lib::error() { return xine_get_error( m_xine ); }; + void Lib::handleXineEvent( xine_event_t* t ) { - if ( t->type == XINE_EVENT_PLAYBACK_FINISHED ) + if ( t->type == XINE_EVENT_PLAYBACK_FINISHED ) { emit stopped(); + } } + + void Lib::setShowVideo( bool video ) { m_video = video; ::null_set_show_video( m_videoOutput, video ); } + bool Lib::isShowingVideo() { return ::null_is_showing_video( m_videoOutput ); } + void Lib::showVideoFullScreen( bool fullScreen ) { ::null_set_fullscreen( m_videoOutput, fullScreen ); } + bool Lib::isVideoFullScreen() { return ::null_is_fullscreen( m_videoOutput ); } + void Lib::setScaling( bool scale ) { ::null_set_scaling( m_videoOutput, scale ); } @@ -213,19 +243,22 @@ void Lib::setGamma( int value ) { bool Lib::isScaling() { return ::null_is_scaling( m_videoOutput ); } + void Lib::xine_event_handler( void* user_data, xine_event_t* t ) { - ((Lib*)user_data)->handleXineEvent( t ); + ( (Lib*)user_data)->handleXineEvent( t ); } + void Lib::xine_display_frame( void* user_data, uint8_t *frame, int width, int height, int bytes ) { - - ((Lib*)user_data)->drawFrame( frame, width, height, bytes ); + ( (Lib*)user_data)->drawFrame( frame, width, height, bytes ); } + void Lib::drawFrame( uint8_t* frame, int width, int height, int bytes ) { - if (!m_video ) { + if ( !m_video ) { qWarning("not showing video now"); return; } + // qWarning( "called draw frame %d %d", width, height ); m_wid-> setVideoFrame ( frame, width, height, bytes ); -- cgit v0.9.0.2