vlc | branch: master | Francois Cartegnie <[email protected]> | Thu Jan 17 20:02:24 2013 +0100| [16c71d3333158430139ee58286aa3306efcdf03b] | committer: Francois Cartegnie
Qt: PLSelector: add side icons > http://git.videolan.org/gitweb.cgi/vlc.git/?a=commit;h=16c71d3333158430139ee58286aa3306efcdf03b --- modules/gui/qt4/Modules.am | 4 ++ modules/gui/qt4/components/playlist/selector.cpp | 74 ++++++++++++++++++---- modules/gui/qt4/components/playlist/selector.hpp | 2 +- modules/gui/qt4/vlc.qrc | 7 ++ 4 files changed, 74 insertions(+), 13 deletions(-) diff --git a/modules/gui/qt4/Modules.am b/modules/gui/qt4/Modules.am index 575ba68..f90fb89 100644 --- a/modules/gui/qt4/Modules.am +++ b/modules/gui/qt4/Modules.am @@ -134,6 +134,10 @@ DEPS_res = \ pixmaps/playlist/shuffle_off.png \ pixmaps/playlist/shuffle_on.png \ pixmaps/playlist/dropzone.png \ + pixmaps/playlist/sidebar-icons/sidebar-movie.png \ + pixmaps/playlist/sidebar-icons/sidebar-pictures.png \ + pixmaps/playlist/sidebar-icons/sidebar-music.png \ + pixmaps/playlist/sidebar-icons/sidebar-podcast.png \ pixmaps/prefs/advprefs_audio.png \ pixmaps/prefs/advprefs_codec.png \ pixmaps/prefs/advprefs_extended.png \ diff --git a/modules/gui/qt4/components/playlist/selector.cpp b/modules/gui/qt4/components/playlist/selector.cpp index 5d9b209..e856c40 100644 --- a/modules/gui/qt4/components/playlist/selector.cpp +++ b/modules/gui/qt4/components/playlist/selector.cpp @@ -41,6 +41,7 @@ #include <QPainter> #include <QPalette> #include <QScrollBar> +#include <QResource> #include <assert.h> #include <vlc_playlist.h> @@ -224,29 +225,42 @@ void PLSelector::updateTotalDuration( PLSelItem* item, const char* prefix ) item->setText( qs_timeLabel ); } +/* Helper until we get proper icons */ +static QIcon orangify( QString resource ) +{ + QPixmap pix( resource ); + QPainter painter( &pix ); + painter.setCompositionMode( QPainter::CompositionMode_SourceAtop ); + painter.fillRect( pix.rect(), QColor( 255, 157, 62, 128 ) ); + return QIcon( pix ); +} + void PLSelector::createItems() { /* PL */ playlistItem = putPLData( addItem( PL_ITEM_TYPE, N_("Playlist"), true ), THEPL->p_playing ); playlistItem->treeItem()->setData( 0, SPECIAL_ROLE, QVariant( IS_PL ) ); + playlistItem->treeItem()->setData( 0, Qt::DecorationRole, orangify( ":/type/playlist" ) ); setCurrentItem( playlistItem->treeItem() ); /* ML */ PLSelItem *ml = putPLData( addItem( PL_ITEM_TYPE, N_("Media Library"), true ), THEPL->p_media_library ); ml->treeItem()->setData( 0, SPECIAL_ROLE, QVariant( IS_ML ) ); + ml->treeItem()->setData( 0, Qt::DecorationRole, orangify( ":/type/playlist" ) ); #ifdef MEDIA_LIBRARY /* SQL ML */ - addItem( SQL_ML_TYPE, "SQL Media Library" )->treeItem(); + ml = addItem( SQL_ML_TYPE, "SQL Media Library" )->treeItem(); + ml->treeItem()->setData( 0, Qt::DecorationRole, orangify( ":/type/playlist" ) ); #endif /* SD nodes */ - QTreeWidgetItem *mycomp = addItem( CATEGORY_TYPE, N_("My Computer") )->treeItem(); - QTreeWidgetItem *devices = addItem( CATEGORY_TYPE, N_("Devices") )->treeItem(); - QTreeWidgetItem *lan = addItem( CATEGORY_TYPE, N_("Local Network") )->treeItem(); - QTreeWidgetItem *internet = addItem( CATEGORY_TYPE, N_("Internet") )->treeItem(); + QTreeWidgetItem *mycomp = addItem( CATEGORY_TYPE, N_("My Computer"), false, true )->treeItem(); + QTreeWidgetItem *devices = addItem( CATEGORY_TYPE, N_("Devices"), false, true )->treeItem(); + QTreeWidgetItem *lan = addItem( CATEGORY_TYPE, N_("Local Network"), false, true )->treeItem(); + QTreeWidgetItem *internet = addItem( CATEGORY_TYPE, N_("Internet"), false, true )->treeItem(); #define NOT_SELECTABLE(w) w->setFlags( w->flags() ^ Qt::ItemIsSelectable ); NOT_SELECTABLE( mycomp ); @@ -269,34 +283,69 @@ void PLSelector::createItems() //msg_Dbg( p_intf, "Adding a SD item: %s", *ppsz_longname ); PLSelItem *selItem; + QIcon icon; + QString name( *ppsz_name ); switch( *p_category ) { case SD_CAT_INTERNET: { - selItem = addItem( SD_TYPE, *ppsz_longname, false, internet ); - if( !strncmp( *ppsz_name, "podcast", 7 ) ) + selItem = addItem( SD_TYPE, *ppsz_longname, false, false, internet ); + if( name.startsWith( "podcast" ) ) { selItem->treeItem()->setData( 0, SPECIAL_ROLE, QVariant( IS_PODCAST ) ); selItem->addAction( ADD_ACTION, qtr( "Subscribe to a podcast" ) ); CONNECT( selItem, action( PLSelItem* ), this, podcastAdd( PLSelItem* ) ); podcastsParent = selItem->treeItem(); + icon = QIcon( ":/sidebar/podcast" ); + } + else if ( name.startsWith( "lua{" ) ) + { + int i_head = name.indexOf( "sd='" ) + 4; + int i_tail = name.indexOf( '\'', i_head ); + name.mid( i_head, i_tail - i_head ); + QString iconname = QString( ":/sidebar/sd/%1" ).arg( name.mid( i_head, i_tail - i_head + 1 ) ); + QResource resource( iconname ); + if ( !resource.isValid() ) + icon = orangify( ":/type/net" ); + else + icon = QIcon( iconname ); } } break; case SD_CAT_DEVICES: - selItem = addItem( SD_TYPE, *ppsz_longname, false, devices ); + name = name.mid( 0, name.indexOf( '{' ) ); + selItem = addItem( SD_TYPE, *ppsz_longname, false, false, devices ); + if ( name == "xcb_app" ) + icon = QIcon( ":/sidebar/pictures" ); + else if ( name == "disc" ) + icon = orangify( ":/type/disc" ); + else + icon = orangify( ":/type/capture-card" ); break; case SD_CAT_LAN: - selItem = addItem( SD_TYPE, *ppsz_longname, false, lan ); + selItem = addItem( SD_TYPE, *ppsz_longname, false, false, lan ); + icon = orangify( ":/type/network" ); break; case SD_CAT_MYCOMPUTER: - selItem = addItem( SD_TYPE, *ppsz_longname, false, mycomp ); + name = name.mid( 0, name.indexOf( '{' ) ); + selItem = addItem( SD_TYPE, *ppsz_longname, false, false, mycomp ); + if ( name == "video_dir" ) + icon = QIcon( ":/sidebar/movie" ); + else if ( name == "audio_dir" ) + icon = QIcon( ":/sidebar/music" ); + else if ( name == "picture_dir" ) + icon = QIcon( ":/sidebar/pictures" ); + else + icon = orangify( ":/type/folder-grey" ); break; default: selItem = addItem( SD_TYPE, *ppsz_longname ); } putSDData( selItem, *ppsz_name, *ppsz_longname ); + if ( ! icon.isNull() ) + selItem->treeItem()->setData( 0, Qt::DecorationRole, icon ); + free( *ppsz_name ); free( *ppsz_longname ); } @@ -382,13 +431,14 @@ void PLSelector::setSource( QTreeWidgetItem *item ) } PLSelItem * PLSelector::addItem ( - SelectorItemType type, const char* str, bool drop, + SelectorItemType type, const char* str, bool drop, bool bold, QTreeWidgetItem* parentItem ) { QTreeWidgetItem *item = parentItem ? new QTreeWidgetItem( parentItem ) : new QTreeWidgetItem( this ); PLSelItem *selItem = new PLSelItem( item, qtr( str ) ); + if ( bold ) selItem->setStyleSheet( "font-weight: bold;" ); setItemWidget( item, 0, selItem ); item->setData( 0, TYPE_ROLE, (int)type ); if( !drop ) item->setFlags( item->flags() & ~Qt::ItemIsDropEnabled ); @@ -401,7 +451,7 @@ PLSelItem *PLSelector::addPodcastItem( playlist_item_t *p_item ) vlc_gc_incref( p_item->p_input ); char *psz_name = input_item_GetName( p_item->p_input ); - PLSelItem *item = addItem( PL_ITEM_TYPE, psz_name, false, podcastsParent ); + PLSelItem *item = addItem( PL_ITEM_TYPE, psz_name, false, false, podcastsParent ); free( psz_name ); item->addAction( RM_ACTION, qtr( "Remove this podcast subscription" ) ); diff --git a/modules/gui/qt4/components/playlist/selector.hpp b/modules/gui/qt4/components/playlist/selector.hpp index 7ec7639..b1755b9 100644 --- a/modules/gui/qt4/components/playlist/selector.hpp +++ b/modules/gui/qt4/components/playlist/selector.hpp @@ -130,7 +130,7 @@ protected: private: void createItems(); PLSelItem * addItem ( SelectorItemType type, const char* str, - bool drop = false, QTreeWidgetItem* parentItem = 0 ); + bool drop = false, bool bold = false, QTreeWidgetItem* parentItem = 0 ); PLSelItem * addPodcastItem( playlist_item_t *p_item ); PLSelItem* playlistItem; diff --git a/modules/gui/qt4/vlc.qrc b/modules/gui/qt4/vlc.qrc index 23e7944..7f84963 100644 --- a/modules/gui/qt4/vlc.qrc +++ b/modules/gui/qt4/vlc.qrc @@ -127,4 +127,11 @@ <file alias="play">pixmaps/win7/win7thumbnail_play.png</file> <file alias="next">pixmaps/win7/win7thumbnail_next.png</file> </qresource> + <qresource prefix="/sidebar"> + <file alias="podcast">pixmaps/playlist/sidebar-icons/sidebar-podcast.png</file> + <file alias="movie">pixmaps/playlist/sidebar-icons/sidebar-movie.png</file> + <file alias="music">pixmaps/playlist/sidebar-icons/sidebar-music.png</file> + <file alias="pictures">pixmaps/playlist/sidebar-icons/sidebar-pictures.png</file> + </qresource> + <qresource prefix="/sidebar/sd"/> </RCC> _______________________________________________ vlc-commits mailing list [email protected] http://mailman.videolan.org/listinfo/vlc-commits
