]> git.sesse.net Git - vlc/commitdiff
Qt: cleaning of the MediaInfo Dialog mess.
authorJean-Baptiste Kempf <jb@videolan.org>
Wed, 31 Dec 2008 11:27:52 +0000 (12:27 +0100)
committerJean-Baptiste Kempf <jb@videolan.org>
Wed, 31 Dec 2008 12:43:07 +0000 (13:43 +0100)
First, assume that the core is correct now (not sure)
Then, rename a few functions and simplify the cases.

NOTA BENE, any commit on MediaInfo or Art needs to be reviewed before commiting.
NB2: any function named update() is forbidden in new commits in Qt code, thanks.

modules/gui/qt4/components/playlist/playlist.hpp
modules/gui/qt4/dialogs/mediainfo.cpp
modules/gui/qt4/dialogs/mediainfo.hpp
modules/gui/qt4/input_manager.cpp
modules/gui/qt4/input_manager.hpp

index 673f3f2b50135f55c7397969eb7a239297b0f675..7b284bc67b72516891b9cd0470ca41bc034df1b1 100644 (file)
@@ -71,7 +71,6 @@ class ArtLabel : public CoverArtLabel
 public:
     ArtLabel( QWidget *parent, intf_thread_t *intf )
             : CoverArtLabel( parent, VLC_OBJECT( intf ) ) {};
-    virtual ~ArtLabel() {};
     void mouseDoubleClickEvent( QMouseEvent *event )
     {
         THEDP->mediaInfoDialog();
index d36ba2b6266a32ef2a459734907c0e8b60b29c1a..6994a03c825eb2ee0eda95b30ebabeae9a3a9ddc 100644 (file)
@@ -41,30 +41,26 @@ MediaInfoDialog *MediaInfoDialog::instance = NULL;
    Please be Careful of not breaking one the modes behaviour... */
 
 MediaInfoDialog::MediaInfoDialog( intf_thread_t *_p_intf,
-                                  input_item_t *_p_item,
-                                  bool _mainInput,
-                                  bool _stats ) :
-                                  QVLCFrame( _p_intf ), mainInput(_mainInput),
-                                  stats( _stats )
+                                  input_item_t *p_item ) :
+                                  QVLCFrame( _p_intf )
 {
-    p_item = _p_item;
-    b_cleaned = true;
-    i_runs = 0;
+    isMainInputInfo = ( p_item == NULL );
 
     setWindowTitle( qtr( "Media Information" ) );
 
     /* TabWidgets and Tabs creation */
-    IT = new QTabWidget;
-    MP = new MetaPanel( IT, p_intf );
-    IT->addTab( MP, qtr( "&General" ) );
-    EMP = new ExtraMetaPanel( IT, p_intf );
-    IT->addTab( EMP, qtr( "&Extra Metadata" ) );
-    IP = new InfoPanel( IT, p_intf );
-    IT->addTab( IP, qtr( "&Codec Details" ) );
-    if( stats )
+    infoTabW = new QTabWidget;
+
+    MP = new MetaPanel( infoTabW, p_intf );
+    infoTabW->addTab( MP, qtr( "&General" ) );
+    EMP = new ExtraMetaPanel( infoTabW, p_intf );
+    infoTabW->addTab( EMP, qtr( "&Extra Metadata" ) );
+    IP = new InfoPanel( infoTabW, p_intf );
+    infoTabW->addTab( IP, qtr( "&Codec Details" ) );
+    if( isMainInputInfo )
     {
-        ISP = new InputStatsPanel( IT, p_intf );
-        IT->addTab( ISP, qtr( "&Statistics" ) );
+        ISP = new InputStatsPanel( infoTabW, p_intf );
+        infoTabW->addTab( ISP, qtr( "&Statistics" ) );
     }
 
     QGridLayout *layout = new QGridLayout( this );
@@ -75,10 +71,10 @@ MediaInfoDialog::MediaInfoDialog( intf_thread_t *_p_intf,
     QPushButton *closeButton = new QPushButton( qtr( "&Close" ) );
     closeButton->setDefault( true );
 
-    uriLine = new QLineEdit;
     QLabel *uriLabel = new QLabel( qtr( "Location:" ) );
+    QLineEdit *uriLine = new QLineEdit;
 
-    layout->addWidget( IT, 0, 0, 1, 8 );
+    layout->addWidget( infoTabW, 0, 0, 1, 8 );
     layout->addWidget( uriLabel, 1, 0, 1, 1 );
     layout->addWidget( uriLine, 1, 1, 1, 7 );
     layout->addWidget( saveMetaButton, 2, 6 );
@@ -91,24 +87,23 @@ MediaInfoDialog::MediaInfoDialog( intf_thread_t *_p_intf,
 
     /* Let the MetaData Panel update the URI */
     CONNECT( MP, uriSet( QString ), uriLine, setText( QString ) );
-    CONNECT( MP, editing(), this, showMetaSaveButton() );
+    CONNECT( MP, editing(), saveMetaButton, show() );
 
-    CONNECT( IT, currentChanged( int ), this, updateButtons( int ) );
+    CONNECT( infoTabW, currentChanged( int ), this, updateButtons( int ) );
 
     /* If using the General Mode */
-    if( !p_item )
+    if( isMainInputInfo )
     {
-        msg_Dbg( p_intf, "Using a general windows" );
-        CONNECT( THEMIM, inputChanged( input_thread_t * ),
-                 this, update( input_thread_t * ) );
-
+        msg_Dbg( p_intf, "Using a general info windows" );
         if( THEMIM->getInput() )
             p_item = input_GetItem( THEMIM->getInput() );
     }
+    else
+        msg_Dbg( p_intf, "Using an item specific info windows" );
 
-    /* Call update by hand, so info is shown from current item too */
+    /* Call update at start, so info is shown for a running input */
     if( p_item )
-        update( p_item, true, true );
+        updateAllTabs( p_item );
 
     readSettings( "Mediainfo", QSize( 600 , 480 ) );
 }
@@ -120,69 +115,37 @@ MediaInfoDialog::~MediaInfoDialog()
 
 void MediaInfoDialog::showTab( int i_tab = 0 )
 {
-    IT->setCurrentIndex( i_tab );
+    infoTabW->setCurrentIndex( i_tab );
     show();
 }
 
-void MediaInfoDialog::showMetaSaveButton()
-{
-    saveMetaButton->show();
-}
-
 void MediaInfoDialog::saveMeta()
 {
     MP->saveMeta();
     saveMetaButton->hide();
 }
 
-/* Function called on inputChanged-update*/
-void MediaInfoDialog::update( input_thread_t *p_input )
+void MediaInfoDialog::updateAllTabs( input_item_t *p_item )
 {
-    if( !p_input || p_input->b_dead )
-    {
-        if( !b_cleaned )
-        {
-            clear();
-            b_cleaned = true;
-        }
-        return;
-    }
-
-    /* Launch the update in all the panels */
-    vlc_object_hold( p_input );
-
-    update( input_GetItem(p_input), true, true);
+    IP->update( p_item );
+    MP->update( p_item );
+    EMP->update( p_item );
 
-    vlc_object_release( p_input );
-}
-
-void MediaInfoDialog::update( input_item_t *p_item,
-                              bool update_info,
-                              bool update_meta )
-{
-    if( update_info )
-        IP->update( p_item );
-    if( update_meta )
-    {
-        MP->update( p_item );
-        EMP->update( p_item );
-    }
-    if( stats )
+    if( isMainInputInfo )
         ISP->update( p_item );
 }
 
-void MediaInfoDialog::clear()
+void MediaInfoDialog::clearAllTabs()
 {
     IP->clear();
     MP->clear();
     EMP->clear();
-    if( stats ) ISP->clear();
-    b_cleaned = true;
+    if( isMainInputInfo ) ISP->clear();
 }
 
 void MediaInfoDialog::close()
 {
-    toggleVisible();
+    hide();
 
     /* if dialog is closed, revert editing if not saved */
     if( MP->isInEditMode() )
@@ -190,9 +153,9 @@ void MediaInfoDialog::close()
         MP->setEditMode( false );
         updateButtons( 0 );
     }
-    if( mainInput == false ) {
+
+    if( !isMainInputInfo )
         deleteLater();
-    }
 }
 
 void MediaInfoDialog::updateButtons( int i_tab )
@@ -202,3 +165,4 @@ void MediaInfoDialog::updateButtons( int i_tab )
     else
         saveMetaButton->hide();
 }
+
index b6a4a0b3d86ec0a454fbf9ce9c9a3e84b5d487dc..bdfdd811178ed94808787b4e8f0feb37fcf0719b 100644 (file)
 #include "components/info_panels.hpp"
 
 class QTabWidget;
-class InfoTab;
-class QLineEdit;
 
 class MediaInfoDialog : public QVLCFrame
 {
     Q_OBJECT;
 public:
     MediaInfoDialog( intf_thread_t *,
-                     input_item_t *,
-                     bool stats = true,
-                     bool mainInput = false );
+                     input_item_t * );
 
     static MediaInfoDialog * getInstance( intf_thread_t *p_intf )
     {
-        if( !instance) instance = new MediaInfoDialog( p_intf,
-                                                       NULL,
-                                                       true,
-                                                       true );
+        if( !instance) instance = new MediaInfoDialog( p_intf, NULL );
         return instance;
     }
 
     static void killInstance()
     {
         if( instance ) delete instance;
-        instance= NULL;
+        instance = NULL;
     }
 
     virtual ~MediaInfoDialog();
@@ -64,32 +57,25 @@ public:
 #endif
 
 private:
-    input_item_t *p_item;
     static MediaInfoDialog *instance;
+    bool isMainInputInfo;
 
-    bool mainInput;
-    bool stats;
-    bool b_cleaned;
-    int i_runs;
+    QTabWidget *infoTabW;
 
-    QTabWidget *IT;
     InputStatsPanel *ISP;
     MetaPanel *MP;
     InfoPanel *IP;
     ExtraMetaPanel *EMP;
 
     QPushButton *saveMetaButton;
-    QLineEdit *uriLine;
-
-public slots:
-    void update( input_thread_t * );
-    void update( input_item_t *, bool, bool );
 
 private slots:
-    void close();
-    void clear();
+    void updateAllTabs( input_item_t * );
+    void clearAllTabs();
+
+    virtual void close();
+
     void saveMeta();
-    void showMetaSaveButton();
     void updateButtons( int i_tab );
 };
 
index 77783b800f5d490534764a1928e82a94384bbf6a..88d9424ff13f422fb8e676748016ae259c1663b8 100644 (file)
@@ -202,16 +202,16 @@ void InputManager::customEvent( QEvent *event )
         UpdateName();
         break;
     case MetaChanged_Type:
+        UpdateMeta();
         UpdateName(); /* Needed for NowPlaying */
-//        UpdateMeta();
-        UpdateArt();
+        UpdateArt(); /* Art is part of meta in the core */
         break;
     case InfoChanged_Type:
-//        UpdateInfo();
+        UpdateInfo();
         break;
     case ItemTitleChanged_Type:
         UpdateNavigation();
-        UpdateName(); /* Display the name of the Chapter */
+        UpdateName(); /* Display the name of the Chapter, if exists */
         break;
     case ItemRateChanged_Type:
         UpdateRate();
@@ -230,11 +230,6 @@ void InputManager::customEvent( QEvent *event )
     }
 }
 
-void InputManager::UpdateStats()
-{
-    emit statisticsUpdated( input_GetItem( p_input ) );
-}
-
 void InputManager::UpdatePosition()
 {
     /* Update position */
@@ -376,12 +371,27 @@ void InputManager::UpdateVout()
     }
 }
 
-void InputManager::UpdateArt()
+inline void InputManager::UpdateArt()
 {
     /* Update Art meta */
     emit artChanged( input_GetItem( p_input ) );
 }
 
+inline void InputManager::UpdateStats()
+{
+    emit statisticsUpdated( input_GetItem( p_input ) );
+}
+
+inline void InputManager::UpdateMeta()
+{
+    emit metaChanged( input_GetItem( p_input ) );
+}
+
+inline void InputManager::UpdateInfo()
+{
+    emit infoChanged( input_GetItem( p_input ) );
+}
+
 /* User update of the slider */
 void InputManager::sliderUpdate( float new_pos )
 {
index a616d7836d4fb0814dd08e29f55be64a94b2a8fb..cfb020f167a4b8b4e7439021ddac1f0523386115 100644 (file)
@@ -115,6 +115,8 @@ private:
     void UpdatePosition();
     void UpdateTeletext();
     void UpdateArt();
+    void UpdateInfo();
+    void UpdateMeta();
     void UpdateVout();
     void UpdateStats();
 
@@ -154,9 +156,11 @@ signals:
     void chapterChanged( bool );
     /// Statistics are updated
     void statisticsUpdated( input_item_t* );
+    void infoChanged( input_item_t* );
+    void metaChanged( input_item_t* );
+    void artChanged( input_item_t* );
     /// Play/pause status
     void statusChanged( int );
-    void artChanged( input_item_t* );
     /// Teletext
     void teletextPossible( bool );
     void teletextActivated( bool );