Commit 16c71d33 authored by Francois Cartegnie's avatar Francois Cartegnie

Qt: PLSelector: add side icons

parent 92758bd8
...@@ -134,6 +134,10 @@ DEPS_res = \ ...@@ -134,6 +134,10 @@ DEPS_res = \
pixmaps/playlist/shuffle_off.png \ pixmaps/playlist/shuffle_off.png \
pixmaps/playlist/shuffle_on.png \ pixmaps/playlist/shuffle_on.png \
pixmaps/playlist/dropzone.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_audio.png \
pixmaps/prefs/advprefs_codec.png \ pixmaps/prefs/advprefs_codec.png \
pixmaps/prefs/advprefs_extended.png \ pixmaps/prefs/advprefs_extended.png \
......
...@@ -41,6 +41,7 @@ ...@@ -41,6 +41,7 @@
#include <QPainter> #include <QPainter>
#include <QPalette> #include <QPalette>
#include <QScrollBar> #include <QScrollBar>
#include <QResource>
#include <assert.h> #include <assert.h>
#include <vlc_playlist.h> #include <vlc_playlist.h>
...@@ -224,29 +225,42 @@ void PLSelector::updateTotalDuration( PLSelItem* item, const char* prefix ) ...@@ -224,29 +225,42 @@ void PLSelector::updateTotalDuration( PLSelItem* item, const char* prefix )
item->setText( qs_timeLabel ); 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() void PLSelector::createItems()
{ {
/* PL */ /* PL */
playlistItem = putPLData( addItem( PL_ITEM_TYPE, N_("Playlist"), true ), playlistItem = putPLData( addItem( PL_ITEM_TYPE, N_("Playlist"), true ),
THEPL->p_playing ); THEPL->p_playing );
playlistItem->treeItem()->setData( 0, SPECIAL_ROLE, QVariant( IS_PL ) ); playlistItem->treeItem()->setData( 0, SPECIAL_ROLE, QVariant( IS_PL ) );
playlistItem->treeItem()->setData( 0, Qt::DecorationRole, orangify( ":/type/playlist" ) );
setCurrentItem( playlistItem->treeItem() ); setCurrentItem( playlistItem->treeItem() );
/* ML */ /* ML */
PLSelItem *ml = putPLData( addItem( PL_ITEM_TYPE, N_("Media Library"), true ), PLSelItem *ml = putPLData( addItem( PL_ITEM_TYPE, N_("Media Library"), true ),
THEPL->p_media_library ); THEPL->p_media_library );
ml->treeItem()->setData( 0, SPECIAL_ROLE, QVariant( IS_ML ) ); ml->treeItem()->setData( 0, SPECIAL_ROLE, QVariant( IS_ML ) );
ml->treeItem()->setData( 0, Qt::DecorationRole, orangify( ":/type/playlist" ) );
#ifdef MEDIA_LIBRARY #ifdef MEDIA_LIBRARY
/* SQL ML */ /* 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 #endif
/* SD nodes */ /* SD nodes */
QTreeWidgetItem *mycomp = addItem( CATEGORY_TYPE, N_("My Computer") )->treeItem(); QTreeWidgetItem *mycomp = addItem( CATEGORY_TYPE, N_("My Computer"), false, true )->treeItem();
QTreeWidgetItem *devices = addItem( CATEGORY_TYPE, N_("Devices") )->treeItem(); QTreeWidgetItem *devices = addItem( CATEGORY_TYPE, N_("Devices"), false, true )->treeItem();
QTreeWidgetItem *lan = addItem( CATEGORY_TYPE, N_("Local Network") )->treeItem(); QTreeWidgetItem *lan = addItem( CATEGORY_TYPE, N_("Local Network"), false, true )->treeItem();
QTreeWidgetItem *internet = addItem( CATEGORY_TYPE, N_("Internet") )->treeItem(); QTreeWidgetItem *internet = addItem( CATEGORY_TYPE, N_("Internet"), false, true )->treeItem();
#define NOT_SELECTABLE(w) w->setFlags( w->flags() ^ Qt::ItemIsSelectable ); #define NOT_SELECTABLE(w) w->setFlags( w->flags() ^ Qt::ItemIsSelectable );
NOT_SELECTABLE( mycomp ); NOT_SELECTABLE( mycomp );
...@@ -269,34 +283,69 @@ void PLSelector::createItems() ...@@ -269,34 +283,69 @@ void PLSelector::createItems()
//msg_Dbg( p_intf, "Adding a SD item: %s", *ppsz_longname ); //msg_Dbg( p_intf, "Adding a SD item: %s", *ppsz_longname );
PLSelItem *selItem; PLSelItem *selItem;
QIcon icon;
QString name( *ppsz_name );
switch( *p_category ) switch( *p_category )
{ {
case SD_CAT_INTERNET: case SD_CAT_INTERNET:
{ {
selItem = addItem( SD_TYPE, *ppsz_longname, false, internet ); selItem = addItem( SD_TYPE, *ppsz_longname, false, false, internet );
if( !strncmp( *ppsz_name, "podcast", 7 ) ) if( name.startsWith( "podcast" ) )
{ {
selItem->treeItem()->setData( 0, SPECIAL_ROLE, QVariant( IS_PODCAST ) ); selItem->treeItem()->setData( 0, SPECIAL_ROLE, QVariant( IS_PODCAST ) );
selItem->addAction( ADD_ACTION, qtr( "Subscribe to a podcast" ) ); selItem->addAction( ADD_ACTION, qtr( "Subscribe to a podcast" ) );
CONNECT( selItem, action( PLSelItem* ), this, podcastAdd( PLSelItem* ) ); CONNECT( selItem, action( PLSelItem* ), this, podcastAdd( PLSelItem* ) );
podcastsParent = selItem->treeItem(); 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; break;
case SD_CAT_DEVICES: 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; break;
case SD_CAT_LAN: 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; break;
case SD_CAT_MYCOMPUTER: 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; break;
default: default:
selItem = addItem( SD_TYPE, *ppsz_longname ); selItem = addItem( SD_TYPE, *ppsz_longname );
} }
putSDData( selItem, *ppsz_name, *ppsz_longname ); putSDData( selItem, *ppsz_name, *ppsz_longname );
if ( ! icon.isNull() )
selItem->treeItem()->setData( 0, Qt::DecorationRole, icon );
free( *ppsz_name ); free( *ppsz_name );
free( *ppsz_longname ); free( *ppsz_longname );
} }
...@@ -382,13 +431,14 @@ void PLSelector::setSource( QTreeWidgetItem *item ) ...@@ -382,13 +431,14 @@ void PLSelector::setSource( QTreeWidgetItem *item )
} }
PLSelItem * PLSelector::addItem ( PLSelItem * PLSelector::addItem (
SelectorItemType type, const char* str, bool drop, SelectorItemType type, const char* str, bool drop, bool bold,
QTreeWidgetItem* parentItem ) QTreeWidgetItem* parentItem )
{ {
QTreeWidgetItem *item = parentItem ? QTreeWidgetItem *item = parentItem ?
new QTreeWidgetItem( parentItem ) : new QTreeWidgetItem( this ); new QTreeWidgetItem( parentItem ) : new QTreeWidgetItem( this );
PLSelItem *selItem = new PLSelItem( item, qtr( str ) ); PLSelItem *selItem = new PLSelItem( item, qtr( str ) );
if ( bold ) selItem->setStyleSheet( "font-weight: bold;" );
setItemWidget( item, 0, selItem ); setItemWidget( item, 0, selItem );
item->setData( 0, TYPE_ROLE, (int)type ); item->setData( 0, TYPE_ROLE, (int)type );
if( !drop ) item->setFlags( item->flags() & ~Qt::ItemIsDropEnabled ); if( !drop ) item->setFlags( item->flags() & ~Qt::ItemIsDropEnabled );
...@@ -401,7 +451,7 @@ PLSelItem *PLSelector::addPodcastItem( playlist_item_t *p_item ) ...@@ -401,7 +451,7 @@ PLSelItem *PLSelector::addPodcastItem( playlist_item_t *p_item )
vlc_gc_incref( p_item->p_input ); vlc_gc_incref( p_item->p_input );
char *psz_name = input_item_GetName( 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 ); free( psz_name );
item->addAction( RM_ACTION, qtr( "Remove this podcast subscription" ) ); item->addAction( RM_ACTION, qtr( "Remove this podcast subscription" ) );
......
...@@ -130,7 +130,7 @@ protected: ...@@ -130,7 +130,7 @@ protected:
private: private:
void createItems(); void createItems();
PLSelItem * addItem ( SelectorItemType type, const char* str, 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 * addPodcastItem( playlist_item_t *p_item );
PLSelItem* playlistItem; PLSelItem* playlistItem;
......
...@@ -127,4 +127,11 @@ ...@@ -127,4 +127,11 @@
<file alias="play">pixmaps/win7/win7thumbnail_play.png</file> <file alias="play">pixmaps/win7/win7thumbnail_play.png</file>
<file alias="next">pixmaps/win7/win7thumbnail_next.png</file> <file alias="next">pixmaps/win7/win7thumbnail_next.png</file>
</qresource> </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> </RCC>
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment