[vlc-commits] Qt: PLSelector: add side icons
Francois Cartegnie
git at videolan.org
Fri Jan 18 23:12:45 CET 2013
vlc | branch: master | Francois Cartegnie <fcvlcdev at free.fr> | 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>
More information about the vlc-commits
mailing list