Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-gpu
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-gpu
Commits
2c562b2a
Commit
2c562b2a
authored
Oct 30, 2009
by
Jakob Leben
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Qt4: media selector beautification
parent
a45e7b56
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
79 additions
and
15 deletions
+79
-15
modules/gui/qt4/components/playlist/selector.cpp
modules/gui/qt4/components/playlist/selector.cpp
+66
-15
modules/gui/qt4/components/playlist/selector.hpp
modules/gui/qt4/components/playlist/selector.hpp
+13
-0
No files found.
modules/gui/qt4/components/playlist/selector.cpp
View file @
2c562b2a
...
@@ -31,10 +31,13 @@
...
@@ -31,10 +31,13 @@
#include "components/playlist/selector.hpp"
#include "components/playlist/selector.hpp"
#include "playlist_item.hpp"
#include "playlist_item.hpp"
#include "qt4.hpp"
#include "qt4.hpp"
#include "../../dialogs_provider.hpp"
#include <QVBoxLayout>
#include <QVBoxLayout>
#include <QHeaderView>
#include <QHeaderView>
#include <QMimeData>
#include <QMimeData>
#include <QPushButton>
#include <QLabel>
#include <vlc_playlist.h>
#include <vlc_playlist.h>
#include <vlc_services_discovery.h>
#include <vlc_services_discovery.h>
...
@@ -42,13 +45,14 @@
...
@@ -42,13 +45,14 @@
PLSelector
::
PLSelector
(
QWidget
*
p
,
intf_thread_t
*
_p_intf
)
PLSelector
::
PLSelector
(
QWidget
*
p
,
intf_thread_t
*
_p_intf
)
:
QTreeWidget
(
p
),
p_intf
(
_p_intf
)
:
QTreeWidget
(
p
),
p_intf
(
_p_intf
)
{
{
setItemDelegate
(
new
PLSelectorDelegate
()
);
setFrameStyle
(
QFrame
::
StyledPanel
|
QFrame
::
Plain
);
setIconSize
(
QSize
(
24
,
24
)
);
setIconSize
(
QSize
(
24
,
24
)
);
// view->setAlternatingRowColors( true );
setIndentation
(
15
);
setIndentation
(
10
);
header
()
->
hide
();
header
()
->
hide
();
setRootIsDecorated
(
false
);
setRootIsDecorated
(
false
);
// model = new PLModel( THEPL, p_intf, THEPL->p_root_category, 1, this
);
setAlternatingRowColors
(
true
);
// view->setModel( model );
viewport
()
->
setAcceptDrops
(
true
);
viewport
()
->
setAcceptDrops
(
true
);
setDropIndicatorShown
(
true
);
setDropIndicatorShown
(
true
);
invisibleRootItem
()
->
setFlags
(
invisibleRootItem
()
->
flags
()
&
~
Qt
::
ItemIsDropEnabled
);
invisibleRootItem
()
->
setFlags
(
invisibleRootItem
()
->
flags
()
&
~
Qt
::
ItemIsDropEnabled
);
...
@@ -82,7 +86,6 @@ void PLSelector::setSource( QTreeWidgetItem *item )
...
@@ -82,7 +86,6 @@ void PLSelector::setSource( QTreeWidgetItem *item )
if
(
!
playlist_IsServicesDiscoveryLoaded
(
THEPL
,
qtu
(
qs
)
)
)
if
(
!
playlist_IsServicesDiscoveryLoaded
(
THEPL
,
qtu
(
qs
)
)
)
{
{
playlist_ServicesDiscoveryAdd
(
THEPL
,
qtu
(
qs
)
);
playlist_ServicesDiscoveryAdd
(
THEPL
,
qtu
(
qs
)
);
}
}
}
}
...
@@ -103,28 +106,36 @@ void PLSelector::setSource( QTreeWidgetItem *item )
...
@@ -103,28 +106,36 @@ void PLSelector::setSource( QTreeWidgetItem *item )
emit
activated
(
pl_item
);
emit
activated
(
pl_item
);
}
}
void
PLSelector
::
makeStandardItem
(
QTreeWidgetItem
*
item
,
const
QString
&
str
)
{
item
->
setText
(
0
,
str
);
}
void
PLSelector
::
createItems
()
void
PLSelector
::
createItems
()
{
{
QTreeWidgetItem
*
pl
=
new
QTreeWidgetItem
(
this
);
QTreeWidgetItem
*
pl
=
new
QTreeWidgetItem
(
this
);
pl
->
setText
(
0
,
qtr
(
"Playlist"
)
);
makeStandardItem
(
pl
,
qtr
(
"Playlist"
)
);
pl
->
setData
(
0
,
TYPE_ROLE
,
PL_TYPE
);
pl
->
setData
(
0
,
TYPE_ROLE
,
PL_TYPE
);
pl
->
setData
(
0
,
PPL_ITEM_ROLE
,
QVariant
::
fromValue
(
THEPL
->
p_local_category
)
);
pl
->
setData
(
0
,
PPL_ITEM_ROLE
,
QVariant
::
fromValue
(
THEPL
->
p_local_category
)
);
/* QTreeWidgetItem *empty = new QTreeWidgetItem( view );
empty->setFlags(Qt::NoItemFlags); */
QTreeWidgetItem
*
lib
=
new
QTreeWidgetItem
(
this
);
QTreeWidgetItem
*
lib
=
new
QTreeWidgetItem
(
this
);
lib
->
setText
(
0
,
qtr
(
"
Library"
)
);
makeStandardItem
(
lib
,
qtr
(
"Media
Library"
)
);
lib
->
setData
(
0
,
TYPE_ROLE
,
ML_TYPE
);
lib
->
setData
(
0
,
TYPE_ROLE
,
ML_TYPE
);
lib
->
setData
(
0
,
PPL_ITEM_ROLE
,
QVariant
::
fromValue
(
THEPL
->
p_ml_category
)
);
lib
->
setData
(
0
,
PPL_ITEM_ROLE
,
QVariant
::
fromValue
(
THEPL
->
p_ml_category
)
);
/* QTreeWidgetItem *empty2 = new QTreeWidgetItem( view );
empty2->setFlags(Qt::NoItemFlags);*/
QTreeWidgetItem
*
sds
=
new
QTreeWidgetItem
(
this
);
QTreeWidgetItem
*
sds
=
new
QTreeWidgetItem
(
this
);
makeStandardItem
(
sds
,
qtr
(
"Services"
)
);
sds
->
setExpanded
(
true
);
sds
->
setExpanded
(
true
);
sds
->
setText
(
0
,
qtr
(
"Libraries"
)
);
sds
->
setFlags
(
sds
->
flags
()
&
~
Qt
::
ItemIsDropEnabled
);
sds
->
setFlags
(
sds
->
flags
()
&
~
Qt
::
ItemIsDropEnabled
);
QTreeWidgetItem
*
mfldrs
=
new
QTreeWidgetItem
(
sds
);
makeStandardItem
(
mfldrs
,
qtr
(
"Media Folders"
)
);
mfldrs
->
setFlags
(
mfldrs
->
flags
()
&
~
Qt
::
ItemIsDropEnabled
);
QTreeWidgetItem
*
shouts
=
new
QTreeWidgetItem
(
sds
);
makeStandardItem
(
shouts
,
qtr
(
"Shoutcast"
)
);
shouts
->
setFlags
(
shouts
->
flags
()
&
~
Qt
::
ItemIsDropEnabled
);
char
**
ppsz_longnames
;
char
**
ppsz_longnames
;
char
**
ppsz_names
=
vlc_sd_GetNames
(
&
ppsz_longnames
);
char
**
ppsz_names
=
vlc_sd_GetNames
(
&
ppsz_longnames
);
if
(
!
ppsz_names
)
if
(
!
ppsz_names
)
...
@@ -134,12 +145,52 @@ void PLSelector::createItems()
...
@@ -134,12 +145,52 @@ void PLSelector::createItems()
QTreeWidgetItem
*
sd_item
;
QTreeWidgetItem
*
sd_item
;
for
(
;
*
ppsz_name
;
ppsz_name
++
,
ppsz_longname
++
)
for
(
;
*
ppsz_name
;
ppsz_name
++
,
ppsz_longname
++
)
{
{
sd_item
=
new
QTreeWidgetItem
(
QStringList
(
qfu
(
*
ppsz_longname
)
)
);
sd_item
=
new
QTreeWidgetItem
(
);
#define SD_IS( name ) ( !strcmp( *ppsz_name, name ) )
if
(
SD_IS
(
"shoutcast"
)
||
SD_IS
(
"shoutcasttv"
)
||
SD_IS
(
"frenchtv"
)
||
SD_IS
(
"freebox"
)
)
{
shouts
->
addChild
(
sd_item
);
makeStandardItem
(
sd_item
,
qfu
(
*
ppsz_longname
)
);
}
else
if
(
SD_IS
(
"video_dir"
)
||
SD_IS
(
"audio_dir"
)
||
SD_IS
(
"picture_dir"
)
)
{
mfldrs
->
addChild
(
sd_item
);
makeStandardItem
(
sd_item
,
qfu
(
*
ppsz_longname
)
);
}
else
if
(
SD_IS
(
"podcast"
)
)
{
sds
->
addChild
(
sd_item
);
QLabel
*
lbl
=
new
QLabel
(
"Podcasts"
);
lbl
->
setMargin
(
3
);
QPushButton
*
btn
=
new
QPushButton
();
btn
->
setMaximumWidth
(
30
);
btn
->
setIcon
(
QIcon
(
":/menu/preferences"
)
);
QHBoxLayout
*
hbox
=
new
QHBoxLayout
();
hbox
->
setContentsMargins
(
0
,
0
,
0
,
0
);
hbox
->
addWidget
(
lbl
);
hbox
->
addWidget
(
btn
);
QWidget
*
w
=
new
QWidget
();
w
->
setLayout
(
hbox
);
CONNECT
(
btn
,
clicked
(),
THEDP
,
podcastConfigureDialog
()
);
setItemWidget
(
sd_item
,
0
,
w
);
}
else
{
sds
->
addChild
(
sd_item
);
makeStandardItem
(
sd_item
,
qfu
(
*
ppsz_longname
)
);
}
#undef SD_IS
sd_item
->
setData
(
0
,
TYPE_ROLE
,
SD_TYPE
);
sd_item
->
setData
(
0
,
TYPE_ROLE
,
SD_TYPE
);
sd_item
->
setData
(
0
,
NAME_ROLE
,
qfu
(
*
ppsz_name
)
);
sd_item
->
setData
(
0
,
NAME_ROLE
,
qfu
(
*
ppsz_name
)
);
sd_item
->
setData
(
0
,
LONGNAME_ROLE
,
qfu
(
*
ppsz_longname
)
);
sd_item
->
setData
(
0
,
LONGNAME_ROLE
,
qfu
(
*
ppsz_longname
)
);
sd_item
->
setFlags
(
sd_item
->
flags
()
&
~
Qt
::
ItemIsDropEnabled
);
sd_item
->
setFlags
(
sd_item
->
flags
()
&
~
Qt
::
ItemIsDropEnabled
);
sds
->
addChild
(
sd_item
);
free
(
*
ppsz_name
);
free
(
*
ppsz_name
);
free
(
*
ppsz_longname
);
free
(
*
ppsz_longname
);
}
}
...
...
modules/gui/qt4/components/playlist/selector.hpp
View file @
2c562b2a
...
@@ -31,6 +31,7 @@
...
@@ -31,6 +31,7 @@
#include <QTreeWidget>
#include <QTreeWidget>
#include <QTreeWidgetItem>
#include <QTreeWidgetItem>
#include <QStyledItemDelegate>
#include <vlc_playlist.h>
#include <vlc_playlist.h>
...
@@ -51,6 +52,17 @@ enum {
...
@@ -51,6 +52,17 @@ enum {
LONGNAME_ROLE
,
LONGNAME_ROLE
,
};
};
class
PLSelectorDelegate
:
public
QStyledItemDelegate
{
private:
QSize
sizeHint
(
const
QStyleOptionViewItem
&
option
,
const
QModelIndex
&
index
)
const
{
QSize
sz
=
QStyledItemDelegate
::
sizeHint
(
option
,
index
);
if
(
sz
.
height
()
<
25
)
sz
.
setHeight
(
25
);
return
sz
;
}
};
Q_DECLARE_METATYPE
(
playlist_item_t
*
);
Q_DECLARE_METATYPE
(
playlist_item_t
*
);
class
PLSelector
:
public
QTreeWidget
class
PLSelector
:
public
QTreeWidget
{
{
...
@@ -62,6 +74,7 @@ protected:
...
@@ -62,6 +74,7 @@ protected:
friend
class
PlaylistWidget
;
friend
class
PlaylistWidget
;
private:
private:
QStringList
mimeTypes
()
const
;
QStringList
mimeTypes
()
const
;
void
makeStandardItem
(
QTreeWidgetItem
*
,
const
QString
&
);
bool
dropMimeData
(
QTreeWidgetItem
*
parent
,
int
index
,
const
QMimeData
*
data
,
Qt
::
DropAction
action
);
bool
dropMimeData
(
QTreeWidgetItem
*
parent
,
int
index
,
const
QMimeData
*
data
,
Qt
::
DropAction
action
);
void
createItems
();
void
createItems
();
intf_thread_t
*
p_intf
;
intf_thread_t
*
p_intf
;
...
...
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