Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-2-2
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
videolan
vlc-2-2
Commits
16c71d33
Commit
16c71d33
authored
Jan 17, 2013
by
Francois Cartegnie
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Qt: PLSelector: add side icons
parent
92758bd8
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
74 additions
and
13 deletions
+74
-13
modules/gui/qt4/Modules.am
modules/gui/qt4/Modules.am
+4
-0
modules/gui/qt4/components/playlist/selector.cpp
modules/gui/qt4/components/playlist/selector.cpp
+62
-12
modules/gui/qt4/components/playlist/selector.hpp
modules/gui/qt4/components/playlist/selector.hpp
+1
-1
modules/gui/qt4/vlc.qrc
modules/gui/qt4/vlc.qrc
+7
-0
No files found.
modules/gui/qt4/Modules.am
View file @
16c71d33
...
@@ -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 \
...
...
modules/gui/qt4/components/playlist/selector.cpp
View file @
16c71d33
...
@@ -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"
)
);
...
...
modules/gui/qt4/components/playlist/selector.hpp
View file @
16c71d33
...
@@ -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
;
...
...
modules/gui/qt4/vlc.qrc
View file @
16c71d33
...
@@ -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>
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment