Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc
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
Commits
c7e38315
Commit
c7e38315
authored
Aug 20, 2005
by
Antoine Cellerier
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
* Playtree start. Basic functionalities work. Still needs a lot of
work, cleaning and fixing. I'll continue this weekend.
parent
4d282645
Changes
24
Hide whitespace changes
Inline
Side-by-side
Showing
24 changed files
with
1580 additions
and
5 deletions
+1580
-5
modules/gui/skins2/Modules.am
modules/gui/skins2/Modules.am
+8
-0
modules/gui/skins2/commands/cmd_dialogs.hpp
modules/gui/skins2/commands/cmd_dialogs.hpp
+2
-0
modules/gui/skins2/commands/cmd_playtree.cpp
modules/gui/skins2/commands/cmd_playtree.cpp
+71
-0
modules/gui/skins2/commands/cmd_playtree.hpp
modules/gui/skins2/commands/cmd_playtree.hpp
+155
-0
modules/gui/skins2/commands/cmd_vars.cpp
modules/gui/skins2/commands/cmd_vars.cpp
+8
-0
modules/gui/skins2/commands/cmd_vars.hpp
modules/gui/skins2/commands/cmd_vars.hpp
+2
-0
modules/gui/skins2/controls/ctrl_list.cpp
modules/gui/skins2/controls/ctrl_list.cpp
+2
-2
modules/gui/skins2/controls/ctrl_tree.cpp
modules/gui/skins2/controls/ctrl_tree.cpp
+509
-0
modules/gui/skins2/controls/ctrl_tree.hpp
modules/gui/skins2/controls/ctrl_tree.hpp
+126
-0
modules/gui/skins2/parser/builder.cpp
modules/gui/skins2/parser/builder.cpp
+58
-0
modules/gui/skins2/parser/builder.hpp
modules/gui/skins2/parser/builder.hpp
+1
-0
modules/gui/skins2/parser/builder_data.def
modules/gui/skins2/parser/builder_data.def
+1
-0
modules/gui/skins2/parser/builder_data.hpp
modules/gui/skins2/parser/builder_data.hpp
+34
-1
modules/gui/skins2/parser/gen_builder.py
modules/gui/skins2/parser/gen_builder.py
+1
-1
modules/gui/skins2/parser/interpreter.cpp
modules/gui/skins2/parser/interpreter.cpp
+29
-0
modules/gui/skins2/parser/interpreter.hpp
modules/gui/skins2/parser/interpreter.hpp
+4
-0
modules/gui/skins2/parser/skin_parser.cpp
modules/gui/skins2/parser/skin_parser.cpp
+43
-1
modules/gui/skins2/src/dialogs.cpp
modules/gui/skins2/src/dialogs.cpp
+3
-0
modules/gui/skins2/src/vlcproc.cpp
modules/gui/skins2/src/vlcproc.cpp
+18
-0
modules/gui/skins2/src/vlcproc.hpp
modules/gui/skins2/src/vlcproc.hpp
+6
-0
modules/gui/skins2/utils/var_tree.cpp
modules/gui/skins2/utils/var_tree.cpp
+183
-0
modules/gui/skins2/utils/var_tree.hpp
modules/gui/skins2/utils/var_tree.hpp
+125
-0
modules/gui/skins2/vars/playtree.cpp
modules/gui/skins2/vars/playtree.cpp
+133
-0
modules/gui/skins2/vars/playtree.hpp
modules/gui/skins2/vars/playtree.hpp
+58
-0
No files found.
modules/gui/skins2/Modules.am
View file @
c7e38315
...
@@ -20,6 +20,8 @@ SOURCES_skins2 = \
...
@@ -20,6 +20,8 @@ SOURCES_skins2 = \
commands/cmd_on_top.hpp \
commands/cmd_on_top.hpp \
commands/cmd_playlist.cpp \
commands/cmd_playlist.cpp \
commands/cmd_playlist.hpp \
commands/cmd_playlist.hpp \
commands/cmd_playtree.cpp \
commands/cmd_playtree.hpp \
commands/cmd_minimize.cpp \
commands/cmd_minimize.cpp \
commands/cmd_minimize.hpp \
commands/cmd_minimize.hpp \
commands/cmd_quit.cpp \
commands/cmd_quit.cpp \
...
@@ -41,6 +43,8 @@ SOURCES_skins2 = \
...
@@ -41,6 +43,8 @@ SOURCES_skins2 = \
controls/ctrl_image.hpp \
controls/ctrl_image.hpp \
controls/ctrl_list.cpp \
controls/ctrl_list.cpp \
controls/ctrl_list.hpp \
controls/ctrl_list.hpp \
controls/ctrl_tree.cpp \
controls/ctrl_tree.hpp \
controls/ctrl_move.cpp \
controls/ctrl_move.cpp \
controls/ctrl_move.hpp \
controls/ctrl_move.hpp \
controls/ctrl_resize.cpp \
controls/ctrl_resize.cpp \
...
@@ -153,9 +157,13 @@ SOURCES_skins2 = \
...
@@ -153,9 +157,13 @@ SOURCES_skins2 = \
utils/var_percent.hpp \
utils/var_percent.hpp \
utils/var_text.cpp \
utils/var_text.cpp \
utils/var_text.hpp \
utils/var_text.hpp \
utils/var_tree.cpp \
utils/var_tree.hpp \
\
\
vars/playlist.cpp \
vars/playlist.cpp \
vars/playlist.hpp \
vars/playlist.hpp \
vars/playtree.cpp \
vars/playtree.hpp \
vars/time.cpp \
vars/time.cpp \
vars/time.hpp \
vars/time.hpp \
vars/volume.cpp \
vars/volume.cpp \
...
...
modules/gui/skins2/commands/cmd_dialogs.hpp
View file @
c7e38315
...
@@ -48,6 +48,8 @@ typedef CmdDialogs<12> CmdDlgPlaylistLoad;
...
@@ -48,6 +48,8 @@ typedef CmdDialogs<12> CmdDlgPlaylistLoad;
typedef
CmdDialogs
<
13
>
CmdDlgPlaylistSave
;
typedef
CmdDialogs
<
13
>
CmdDlgPlaylistSave
;
typedef
CmdDialogs
<
14
>
CmdDlgDirectory
;
typedef
CmdDialogs
<
14
>
CmdDlgDirectory
;
typedef
CmdDialogs
<
15
>
CmdDlgStreamingWizard
;
typedef
CmdDialogs
<
15
>
CmdDlgStreamingWizard
;
typedef
CmdDialogs
<
16
>
CmdDlgPlaytreeLoad
;
typedef
CmdDialogs
<
17
>
CmdDlgPlaytreeSave
;
/// Generic "Open dialog" command
/// Generic "Open dialog" command
...
...
modules/gui/skins2/commands/cmd_playtree.cpp
0 → 100644
View file @
c7e38315
/*****************************************************************************
* cmd_playtree.cpp
*****************************************************************************
* Copyright (C) 2005 VideoLAN
* $Id: cmd_playlist.cpp 10101 2005-03-02 16:47:31Z robux4 $
*
* Authors: Antoine Cellerier <dionoea@videolan.org>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111, USA.
*****************************************************************************/
#include "cmd_playtree.hpp"
#include "../src/vlcproc.hpp"
#include "../utils/var_bool.hpp"
void
CmdPlaytreeDel
::
execute
()
{
m_rTree
.
delSelected
();
}
void
CmdPlaytreeSort
::
execute
()
{
// TODO
}
void
CmdPlaytreeNext
::
execute
()
{
// TODO
}
void
CmdPlaytreePrevious
::
execute
()
{
// TODO
}
void
CmdPlaytreeRandom
::
execute
()
{
// TODO
}
void
CmdPlaytreeLoop
::
execute
()
{
// TODO
}
void
CmdPlaytreeRepeat
::
execute
()
{
// TODO
}
void
CmdPlaytreeLoad
::
execute
()
{
// TODO
}
void
CmdPlaytreeSave
::
execute
()
{
// TODO
}
modules/gui/skins2/commands/cmd_playtree.hpp
0 → 100644
View file @
c7e38315
/*****************************************************************************
* cmd_playtree.hpp
*****************************************************************************
* Copyright (C) 2005 VideoLAN
* $Id: cmd_playlist.hpp 9934 2005-02-15 13:55:08Z courmisch $
*
* Authors: Antoine Cellerier <dionoea@videolan.org>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111, USA.
*****************************************************************************/
#ifndef CMD_PLAYTREE_HPP
#define CMD_PLAYTREE_HPP
#include "cmd_generic.hpp"
#include "../utils/var_tree.hpp"
// TODO : implement branch specific stuff
/// Command to delete the selected items from a tree
class
CmdPlaytreeDel
:
public
CmdGeneric
{
public:
CmdPlaytreeDel
(
intf_thread_t
*
pIntf
,
VarTree
&
rTree
)
:
CmdGeneric
(
pIntf
),
m_rTree
(
rTree
)
{}
virtual
~
CmdPlaytreeDel
()
{}
/// This method does the real job of the command
virtual
void
execute
();
/// Return the type of the command
virtual
string
getType
()
const
{
return
"playtree del"
;
}
private:
/// Tree
VarTree
&
m_rTree
;
};
/// Command to sort the playtree
DEFINE_COMMAND
(
PlaytreeSort
,
"playtree sort"
)
/// Command to jump to the next item
DEFINE_COMMAND
(
PlaytreeNext
,
"playtree next"
)
/// Command to jump to the previous item
DEFINE_COMMAND
(
PlaytreePrevious
,
"playtree previous"
)
/// Command to set the random state
class
CmdPlaytreeRandom
:
public
CmdGeneric
{
public:
CmdPlaytreeRandom
(
intf_thread_t
*
pIntf
,
bool
value
)
:
CmdGeneric
(
pIntf
),
m_value
(
value
)
{}
virtual
~
CmdPlaytreeRandom
()
{}
/// This method does the real job of the command
virtual
void
execute
();
/// Return the type of the command
virtual
string
getType
()
const
{
return
"playtree random"
;
}
private:
/// Random state
bool
m_value
;
};
/// Command to set the loop state
class
CmdPlaytreeLoop
:
public
CmdGeneric
{
public:
CmdPlaytreeLoop
(
intf_thread_t
*
pIntf
,
bool
value
)
:
CmdGeneric
(
pIntf
),
m_value
(
value
)
{}
virtual
~
CmdPlaytreeLoop
()
{}
/// This method does the real job of the command
virtual
void
execute
();
/// Return the type of the command
virtual
string
getType
()
const
{
return
"playtree loop"
;
}
private:
/// Loop state
bool
m_value
;
};
/// Command to set the repeat state
class
CmdPlaytreeRepeat
:
public
CmdGeneric
{
public:
CmdPlaytreeRepeat
(
intf_thread_t
*
pIntf
,
bool
value
)
:
CmdGeneric
(
pIntf
),
m_value
(
value
)
{}
virtual
~
CmdPlaytreeRepeat
()
{}
/// This method does the real job of the command
virtual
void
execute
();
/// Return the type of the command
virtual
string
getType
()
const
{
return
"playtree repeat"
;
}
private:
/// Loop state
bool
m_value
;
};
/// Command to load a playlist
class
CmdPlaytreeLoad
:
public
CmdGeneric
{
public:
CmdPlaytreeLoad
(
intf_thread_t
*
pIntf
,
bool
value
)
:
CmdGeneric
(
pIntf
),
m_value
(
value
)
{}
virtual
~
CmdPlaytreeLoad
()
{}
/// This method does the real job of the command
virtual
void
execute
();
/// Return the type of the command
virtual
string
getType
()
const
{
return
"playtree load"
;
}
private:
/// Loop state
bool
m_value
;
};
/// Command to save a playlist
class
CmdPlaytreeSave
:
public
CmdGeneric
{
public:
CmdPlaytreeSave
(
intf_thread_t
*
pIntf
,
bool
value
)
:
CmdGeneric
(
pIntf
),
m_value
(
value
)
{}
virtual
~
CmdPlaytreeSave
()
{}
/// This method does the real job of the command
virtual
void
execute
();
/// Return the type of the command
virtual
string
getType
()
const
{
return
"playtree save"
;
}
private:
/// Loop state
bool
m_value
;
};
#endif
modules/gui/skins2/commands/cmd_vars.cpp
View file @
c7e38315
...
@@ -25,6 +25,7 @@
...
@@ -25,6 +25,7 @@
#include "../src/vlcproc.hpp"
#include "../src/vlcproc.hpp"
#include "../utils/var_text.hpp"
#include "../utils/var_text.hpp"
#include "../vars/playlist.hpp"
#include "../vars/playlist.hpp"
#include "../vars/playtree.hpp"
void
CmdNotifyPlaylist
::
execute
()
void
CmdNotifyPlaylist
::
execute
()
...
@@ -34,6 +35,13 @@ void CmdNotifyPlaylist::execute()
...
@@ -34,6 +35,13 @@ void CmdNotifyPlaylist::execute()
rVar
.
onChange
();
rVar
.
onChange
();
}
}
void
CmdNotifyPlaytree
::
execute
()
{
// Notify the playtree variable
Playtree
&
rVar
=
VlcProc
::
instance
(
getIntf
()
)
->
getPlaytreeVar
();
rVar
.
onChange
();
}
void
CmdSetText
::
execute
()
void
CmdSetText
::
execute
()
{
{
...
...
modules/gui/skins2/commands/cmd_vars.hpp
View file @
c7e38315
...
@@ -31,6 +31,8 @@ class VarText;
...
@@ -31,6 +31,8 @@ class VarText;
/// Command to notify the playlist of a change
/// Command to notify the playlist of a change
DEFINE_COMMAND
(
NotifyPlaylist
,
"notify playlist"
)
DEFINE_COMMAND
(
NotifyPlaylist
,
"notify playlist"
)
/// Command to notify the playtree of a change
DEFINE_COMMAND
(
NotifyPlaytree
,
"notify playtree"
)
/// Command to set a text variable
/// Command to set a text variable
...
...
modules/gui/skins2/controls/ctrl_list.cpp
View file @
c7e38315
...
@@ -481,8 +481,8 @@ void CtrlList::makeImage()
...
@@ -481,8 +481,8 @@ void CtrlList::makeImage()
int
yPos
=
0
;
int
yPos
=
0
;
for
(
it
=
m_rList
[
m_lastPos
];
it
!=
m_rList
.
end
()
&&
yPos
<
height
;
it
++
)
for
(
it
=
m_rList
[
m_lastPos
];
it
!=
m_rList
.
end
()
&&
yPos
<
height
;
it
++
)
{
{
UString
*
pStr
=
(
UString
*
)(
(
*
it
).
m_cString
.
get
());
UString
*
pStr
=
(
UString
*
)(
it
->
m_cString
.
get
());
uint32_t
color
=
(
(
*
it
).
m_playing
?
m_playColor
:
m_fgColor
);
uint32_t
color
=
(
it
->
m_playing
?
m_playColor
:
m_fgColor
);
// Draw the text
// Draw the text
GenericBitmap
*
pText
=
m_rFont
.
drawString
(
*
pStr
,
color
,
width
);
GenericBitmap
*
pText
=
m_rFont
.
drawString
(
*
pStr
,
color
,
width
);
...
...
modules/gui/skins2/controls/ctrl_tree.cpp
0 → 100644
View file @
c7e38315
/*****************************************************************************
* ctrl_tree.cpp
*****************************************************************************
* Copyright (C) 2003 VideoLAN
* $Id: ctrl_list.cpp 11009 2005-05-14 14:39:05Z ipkiss $
*
* Authors: Antoine Cellerier <dionoea@videolan.org>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111, USA.
*****************************************************************************/
#include <math.h>
#include "ctrl_tree.hpp"
#include "../src/os_factory.hpp"
#include "../src/os_graphics.hpp"
#include "../src/generic_bitmap.hpp"
#include "../src/generic_font.hpp"
#include "../src/scaled_bitmap.hpp"
#include "../utils/position.hpp"
#include "../utils/ustring.hpp"
#include "../events/evt_key.hpp"
#include "../events/evt_mouse.hpp"
#include "../events/evt_scroll.hpp"
#include "vlc_keys.h"
#ifdef sun
# include "solaris_specific.h" // for lrint
#endif
#define SCROLL_STEP 0.05
#define LINE_INTERVAL 1 // Number of pixels inserted between 2 lines
CtrlTree
::
CtrlTree
(
intf_thread_t
*
pIntf
,
VarTree
&
rTree
,
const
GenericFont
&
rFont
,
const
GenericBitmap
*
pBgBitmap
,
const
GenericBitmap
*
pItemBitmap
,
const
GenericBitmap
*
pOpenBitmap
,
const
GenericBitmap
*
pClosedBitmap
,
uint32_t
fgColor
,
uint32_t
playColor
,
uint32_t
bgColor1
,
uint32_t
bgColor2
,
uint32_t
selColor
,
const
UString
&
rHelp
,
VarBool
*
pVisible
)
:
CtrlGeneric
(
pIntf
,
rHelp
,
pVisible
),
m_rTree
(
rTree
),
m_rFont
(
rFont
),
m_pBgBitmap
(
pBgBitmap
),
m_pItemBitmap
(
pItemBitmap
),
m_pOpenBitmap
(
pOpenBitmap
),
m_pClosedBitmap
(
pClosedBitmap
),
m_fgColor
(
fgColor
),
m_playColor
(
playColor
),
m_bgColor1
(
bgColor1
),
m_bgColor2
(
bgColor2
),
m_selColor
(
selColor
),
m_pLastSelected
(
NULL
),
m_pImage
(
NULL
)
{
// Observe the tree and position variables
m_rTree
.
addObserver
(
this
);
m_rTree
.
getPositionVar
().
addObserver
(
this
);
m_lastPos
=
m_rTree
.
begin
();
makeImage
();
}
CtrlTree
::~
CtrlTree
()
{
m_rTree
.
getPositionVar
().
delObserver
(
this
);
m_rTree
.
delObserver
(
this
);
if
(
m_pImage
)
{
delete
m_pImage
;
}
}
int
CtrlTree
::
itemHeight
()
{
int
itemHeight
=
m_rFont
.
getSize
();
if
(
m_pClosedBitmap
)
{
itemHeight
=
__MAX
(
m_pClosedBitmap
->
getHeight
(),
itemHeight
);
}
if
(
m_pOpenBitmap
)
{
itemHeight
=
__MAX
(
m_pOpenBitmap
->
getHeight
(),
itemHeight
);
}
if
(
m_pItemBitmap
)
{
itemHeight
=
__MAX
(
m_pItemBitmap
->
getHeight
(),
itemHeight
);
}
itemHeight
+=
LINE_INTERVAL
;
return
itemHeight
;
}
int
CtrlTree
::
maxItems
()
{
const
Position
*
pPos
=
getPosition
();
if
(
!
pPos
)
{
return
-
1
;
}
return
pPos
->
getHeight
()
/
itemHeight
();
}
void
CtrlTree
::
onUpdate
(
Subject
<
VarTree
>
&
rTree
)
{
autoScroll
();
m_pLastSelected
=
NULL
;
}
void
CtrlTree
::
onUpdate
(
Subject
<
VarPercent
>
&
rPercent
)
{
// Determine what is the first item to display
VarTree
::
Iterator
it
=
m_rTree
.
begin
();
int
excessItems
=
m_rTree
.
visibleItems
()
-
maxItems
();
if
(
excessItems
>
0
)
{
VarPercent
&
rVarPos
=
m_rTree
.
getPositionVar
();
// a simple (int)(...) causes rounding errors !
#ifdef _MSC_VER
# define lrint (int)
#endif
it
=
m_rTree
.
visibleItem
(
lrint
(
(
1.0
-
rVarPos
.
get
())
*
(
double
)
excessItems
)
+
1
);
/* FIXME : shouldn't need this +1 */
}
if
(
m_lastPos
!=
it
)
{
// Redraw the control if the position has changed
m_lastPos
=
it
;
makeImage
();
notifyLayout
();
}
}
void
CtrlTree
::
onResize
()
{
// FIXME : shouldn't be the same as the onUpdate function ... but i'm lazy
// Determine what is the first item to display
VarTree
::
Iterator
it
=
m_rTree
.
begin
();
int
excessItems
=
m_rTree
.
visibleItems
()
-
maxItems
();
if
(
excessItems
>
0
)
{
VarPercent
&
rVarPos
=
m_rTree
.
getPositionVar
();
// a simple (int)(...) causes rounding errors !
#ifdef _MSC_VER
# define lrint (int)
#endif
it
=
m_rTree
.
visibleItem
(
lrint
(
(
1.0
-
rVarPos
.
get
())
*
(
double
)
excessItems
)
+
1
);
/* FIXME : shouldn't need this +1 */
}
// Redraw the control if the position has changed
m_lastPos
=
it
;
makeImage
();
notifyLayout
();
#if 0
// Determine what is the first item to display
VarTree::Iterator it = m_rTree.begin();
int excessItems = m_rTree.visibleItems() - maxItems();
if( excessItems > 0)
{
/* FIXME VarPercent &rVarPos = m_rTree.getPositionVar();
double newVal = 1.0 - (double)m_lastPos / excessItems;
if( newVal >= 0 )
{
// Change the position to keep the same first displayed item
rVarPos.set( 1.0 - (double)m_lastPos / excessItems );
}
else
{
// We cannot keep the current first item
m_lastPos = excessItems;
}*/
it = m_rTree.visibleItem( excessItems );
}
makeImage();
notifyLayout();
#endif
}
void
CtrlTree
::
onPositionChange
()
{
makeImage
();
notifyLayout
();
}
#define IT_DISP_LOOP_END( a ) \
if( a ->m_expanded && a ->size() ) \
{ \
a = a ->begin(); \
} \
else \
{ \
VarTree::Iterator it_old = a; \
a ++; \
if( it_old->parent() && it_old->parent()->end() == a ) \
{ \
a = it_old->uncle(); \
} \
}
void
CtrlTree
::
handleEvent
(
EvtGeneric
&
rEvent
)
{
// TODO TODO FIXME TODO TODO
if
(
rEvent
.
getAsString
().
find
(
"key:down"
)
!=
string
::
npos
)
{
int
key
=
((
EvtKey
&
)
rEvent
).
getKey
();
VarTree
::
Iterator
it
=
m_rTree
.
begin
();
bool
previousWasSelected
=
false
;
while
(
it
!=
m_rTree
.
end
()
)
{
VarTree
::
Iterator
next
=
it
;
IT_DISP_LOOP_END
(
next
);
if
(
key
==
KEY_UP
)
{
//Scroll up one item
if
(
(
it
->
parent
()
&&
it
!=
it
->
parent
()
->
begin
()
)
||
&*
it
!=
m_pLastSelected
)
{
bool
nextWasSelected
=
(
&*
next
==
m_pLastSelected
);
it
->
m_selected
=
nextWasSelected
;
if
(
nextWasSelected
)
{
m_pLastSelected
=
&*
it
;
}
}
}
else
if
(
key
==
KEY_DOWN
)
{
// Scroll down one item
if
(
(
it
->
parent
()
&&
next
!=
it
->
parent
()
->
end
()
)
||
&*
it
!=
m_pLastSelected
)
{
(
*
it
).
m_selected
=
previousWasSelected
;
}
if
(
previousWasSelected
)
{
m_pLastSelected
=
&*
it
;
previousWasSelected
=
false
;
}
else
{
previousWasSelected
=
(
&*
it
==
m_pLastSelected
);
}
}
else
if
(
key
==
KEY_RIGHT
)
{
// Go down one level
if
(
it
->
m_expanded
)
{
if
(
it
->
size
()
)
{
/* FIXME : finir */
m_pLastSelected
=
&*
(
it
->
begin
());
}
}
else
{
it
->
m_expanded
=
true
;
}
}
else
if
(
key
==
KEY_LEFT
)
{
// Go up one level (and close node)
// TODO
it
->
m_expanded
=
false
;
}
it
=
next
;
}
// Redraw the control
makeImage
();
notifyLayout
();
}
else
if
(
rEvent
.
getAsString
().
find
(
"mouse:left"
)
!=
string
::
npos
)
{
EvtMouse
&
rEvtMouse
=
(
EvtMouse
&
)
rEvent
;
const
Position
*
pos
=
getPosition
();
int
yPos
=
(
rEvtMouse
.
getYPos
()
-
pos
->
getTop
()
)
/
itemHeight
();
VarTree
::
Iterator
it
;
int
index
=
0
;
// TODO : add all other mouse controls
/**/
if
(
rEvent
.
getAsString
().
find
(
"mouse:left:down"
)
!=
string
::
npos
)
{
for
(
it
=
m_lastPos
;
it
!=
m_rTree
.
end
();
)
{
if
(
index
==
yPos
)
{
it
->
m_selected
=
true
;
m_pLastSelected
=
&*
it
;
}
else
{
it
->
m_selected
=
false
;
}
index
++
;
IT_DISP_LOOP_END
(
it
);
}
}
else
if
(
rEvent
.
getAsString
().
find
(
"mouse:left:dblclick"
)
!=
string
::
npos
)
{
for
(
it
=
m_lastPos
;
it
!=
m_rTree
.
end
();
)
{
if
(
index
==
yPos
)
{
it
->
m_selected
=
true
;
m_pLastSelected
=
&*
it
;
// Execute the action associated to this item
m_rTree
.
action
(
&*
it
);
}
else
{
it
->
m_selected
=
false
;
}
index
++
;
IT_DISP_LOOP_END
(
it
);
}
}
// Redraw the control
makeImage
();
notifyLayout
();
}
else
if
(
rEvent
.
getAsString
().
find
(
"scroll"
)
!=
string
::
npos
)
{
int
direction
=
((
EvtScroll
&
)
rEvent
).
getDirection
();
double
percentage
=
m_rTree
.
getPositionVar
().
get
();
if
(
direction
==
EvtScroll
::
kUp
)
{
percentage
+=
SCROLL_STEP
;
}
else
{
percentage
-=
SCROLL_STEP
;
}
m_rTree
.
getPositionVar
().
set
(
percentage
);
}
}
bool
CtrlTree
::
mouseOver
(
int
x
,
int
y
)
const
{
const
Position
*
pPos
=
getPosition
();
return
(
pPos
?
x
>=
0
&&
x
<=
pPos
->
getWidth
()
&&
y
>=
0
&&
y
<=
pPos
->
getHeight
()
:
false
);
}
void
CtrlTree
::
draw
(
OSGraphics
&
rImage
,
int
xDest
,
int
yDest
)
{
if
(
m_pImage
)
{
rImage
.
drawGraphics
(
*
m_pImage
,
0
,
0
,
xDest
,
yDest
);
}
}
void
CtrlTree
::
autoScroll
()
{
// TODO FIXME TODO
makeImage
();
notifyLayout
();
}
void
CtrlTree
::
makeImage
()
{
if
(
m_pImage
)
{
delete
m_pImage
;
}
// Get the size of the control
const
Position
*
pPos
=
getPosition
();
if
(
!
pPos
)
{
return
;
}
int
width
=
pPos
->
getWidth
();
int
height
=
pPos
->
getHeight
();
int
i_itemHeight
=
itemHeight
();
// Create an image
OSFactory
*
pOsFactory
=
OSFactory
::
instance
(
getIntf
()
);
m_pImage
=
pOsFactory
->
createOSGraphics
(
width
,
height
);
VarTree
::
Iterator
it
=
m_lastPos
;
if
(
m_pBgBitmap
)
{
// Draw the background bitmap
ScaledBitmap
bmp
(
getIntf
(),
*
m_pBgBitmap
,
width
,
height
);
m_pImage
->
drawBitmap
(
bmp
,
0
,
0
);
// FIXME : Take care of the selection color
for
(
int
yPos
=
0
;
yPos
<
height
;
yPos
+=
i_itemHeight
)
{
int
rectHeight
=
__MIN
(
i_itemHeight
,
height
-
yPos
);
if
(
it
!=
m_rTree
.
end
()
)
{
if
(
(
*
it
).
m_selected
)
{
m_pImage
->
fillRect
(
0
,
yPos
,
width
,
rectHeight
,
m_selColor
);
}
IT_DISP_LOOP_END
(
it
);
}
}
}
else
{
// FIXME (TRYME)
// Fill background with background color
uint32_t
bgColor
=
m_bgColor1
;
m_pImage
->
fillRect
(
0
,
0
,
width
,
height
,
bgColor
);
for
(
int
yPos
=
0
;
yPos
<
height
;
yPos
+=
i_itemHeight
)
{
int
rectHeight
=
__MIN
(
i_itemHeight
,
height
-
yPos
);
if
(
it
!=
m_rTree
.
end
()
)
{
uint32_t
color
=
(
it
->
m_selected
?
m_selColor
:
bgColor
);
m_pImage
->
fillRect
(
0
,
yPos
,
width
,
rectHeight
,
color
);
IT_DISP_LOOP_END
(
it
);
}
else
{
m_pImage
->
fillRect
(
0
,
yPos
,
width
,
rectHeight
,
bgColor
);
}
bgColor
=
(
bgColor
==
m_bgColor1
?
m_bgColor2
:
m_bgColor1
);
}
}
// fprintf( stderr, "done\n");
int
bitmapWidth
=
5
;
if
(
m_pClosedBitmap
)
{
bitmapWidth
=
__MAX
(
m_pClosedBitmap
->
getWidth
(),
bitmapWidth
);
}
if
(
m_pOpenBitmap
)
{
bitmapWidth
=
__MAX
(
m_pOpenBitmap
->
getWidth
(),
bitmapWidth
);
}
if
(
m_pItemBitmap
)
{
bitmapWidth
=
__MAX
(
m_pItemBitmap
->
getWidth
(),
bitmapWidth
);
}
bitmapWidth
+=
2
;
// FIXME : Draw the items
int
yPos
=
0
;
it
=
m_lastPos
;
while
(
it
!=
m_rTree
.
end
()
&&
yPos
<
height
)
{
const
GenericBitmap
*
m_pCurBitmap
;
UString
*
pStr
=
(
UString
*
)(
it
->
m_cString
.
get
());
uint32_t
color
=
(
it
->
m_playing
?
m_playColor
:
m_fgColor
);
// Draw the text
if
(
pStr
!=
NULL
){
int
depth
=
it
->
depth
();
GenericBitmap
*
pText
=
m_rFont
.
drawString
(
*
pStr
,
color
,
width
-
bitmapWidth
*
depth
);
if
(
!
pText
)
{
return
;
}
m_pCurBitmap
=
it
->
size
()
?
(
it
->
m_expanded
?
m_pOpenBitmap
:
m_pClosedBitmap
)
:
m_pItemBitmap
;
if
(
m_pCurBitmap
)
{
int
yPos2
=
yPos
+
(
i_itemHeight
-
m_pCurBitmap
->
getHeight
()
+
1
)
/
2
;
m_pImage
->
drawBitmap
(
*
m_pCurBitmap
,
0
,
0
,
bitmapWidth
*
(
depth
-
1
),
yPos2
,
m_pCurBitmap
->
getWidth
(),
__MIN
(
m_pCurBitmap
->
getHeight
(),
height
-
yPos2
),
true
);
}
else
{
/* it would be nice to draw something */
}
yPos
+=
i_itemHeight
-
pText
->
getHeight
();
int
ySrc
=
0
;
if
(
yPos
<
0
)
{
ySrc
=
-
yPos
;
yPos
=
0
;
}
int
lineHeight
=
__MIN
(
pText
->
getHeight
()
-
ySrc
,
height
-
yPos
);
m_pImage
->
drawBitmap
(
*
pText
,
0
,
ySrc
,
bitmapWidth
*
depth
,
yPos
,
pText
->
getWidth
(),
lineHeight
,
true
);
yPos
+=
(
pText
->
getHeight
()
-
ySrc
);
delete
pText
;
}
IT_DISP_LOOP_END
(
it
);
}
}
modules/gui/skins2/controls/ctrl_tree.hpp
0 → 100644
View file @
c7e38315
/*****************************************************************************
* ctrl_tree.hpp
*****************************************************************************
* Copyright (C) 2003 VideoLAN
* $Id: ctrl_list.hpp 11009 2005-05-14 14:39:05Z ipkiss $
*
* Authors: Antoine Cellerier
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111, USA.
*****************************************************************************/
#ifndef CTRL_TREE_HPP
#define CTRL_TREE_HPP
#include "ctrl_generic.hpp"
#include "../utils/observer.hpp"
#include "../utils/var_tree.hpp"
class
OSGraphics
;
class
GenericFont
;
class
GenericBitmap
;
/// Class for control tree
class
CtrlTree
:
public
CtrlGeneric
,
public
Observer
<
VarTree
>
,
public
Observer
<
VarPercent
>
{
public:
CtrlTree
(
intf_thread_t
*
pIntf
,
VarTree
&
rTree
,
const
GenericFont
&
rFont
,
const
GenericBitmap
*
pBgBitmap
,
const
GenericBitmap
*
pItemBitmap
,
const
GenericBitmap
*
pOpenBitmap
,
const
GenericBitmap
*
pClosedBitmap
,
uint32_t
fgColor
,
uint32_t
playColor
,
uint32_t
bgColor1
,
uint32_t
bgColor2
,
uint32_t
selColor
,
const
UString
&
rHelp
,
VarBool
*
pVisible
);
virtual
~
CtrlTree
();
/// Handle an event on the control
virtual
void
handleEvent
(
EvtGeneric
&
rEvent
);
/// Check whether coordinates are inside the control
virtual
bool
mouseOver
(
int
x
,
int
y
)
const
;
/// Draw the control on the given graphics
virtual
void
draw
(
OSGraphics
&
rImage
,
int
xDest
,
int
yDest
);
/// Called when the layout is resized
virtual
void
onResize
();
/// Return true if the control can gain the focus
virtual
bool
isFocusable
()
const
{
return
true
;
}
/// Get the type of control (custom RTTI)
virtual
string
getType
()
const
{
return
"tree"
;
}
private:
/// Tree associated to the control
VarTree
&
m_rTree
;
/// Font
const
GenericFont
&
m_rFont
;
/// Background bitmap
const
GenericBitmap
*
m_pBgBitmap
;
/// Item (leaf) bitmap
// (TODO : add different bitmaps for different item types
// like in the wx playlist)
const
GenericBitmap
*
m_pItemBitmap
;
/// Open (expanded) node bitmap
const
GenericBitmap
*
m_pOpenBitmap
;
/// Closed node bitmap
const
GenericBitmap
*
m_pClosedBitmap
;
/// Color of normal test
uint32_t
m_fgColor
;
/// Color of the playing item
uint32_t
m_playColor
;
/// Background colors, used when no background bitmap is given
uint32_t
m_bgColor1
,
m_bgColor2
;
/// Background of selected items
uint32_t
m_selColor
;
/// Pointer on the last selected item in the tree
VarTree
*
m_pLastSelected
;
/// Image of the control
OSGraphics
*
m_pImage
;
/// Last position
VarTree
::
Iterator
m_lastPos
;
/// Method called when the tree variable is modified
virtual
void
onUpdate
(
Subject
<
VarTree
>
&
rTree
);
// Method called when the position variable of the tree is modified
virtual
void
onUpdate
(
Subject
<
VarPercent
>
&
rPercent
);
/// Called when the position is set
virtual
void
onPositionChange
();
/// Compute the number of lines that can be displayed
int
maxItems
();
/// Compute the item's height (depends on fonts and images used)
int
itemHeight
();
/// Check if the tree must be scrolled
void
autoScroll
();
/// Draw the image of the control
void
makeImage
();
};
#endif
modules/gui/skins2/parser/builder.cpp
View file @
c7e38315
...
@@ -43,6 +43,7 @@
...
@@ -43,6 +43,7 @@
#include "../controls/ctrl_slider.hpp"
#include "../controls/ctrl_slider.hpp"
#include "../controls/ctrl_radialslider.hpp"
#include "../controls/ctrl_radialslider.hpp"
#include "../controls/ctrl_text.hpp"
#include "../controls/ctrl_text.hpp"
#include "../controls/ctrl_tree.hpp"
#include "../controls/ctrl_video.hpp"
#include "../controls/ctrl_video.hpp"
#include "../utils/position.hpp"
#include "../utils/position.hpp"
#include "../utils/var_bool.hpp"
#include "../utils/var_bool.hpp"
...
@@ -101,6 +102,7 @@ Theme *Builder::build()
...
@@ -101,6 +102,7 @@ Theme *Builder::build()
ADD_OBJECTS
(
RadialSlider
);
ADD_OBJECTS
(
RadialSlider
);
ADD_OBJECTS
(
Slider
);
ADD_OBJECTS
(
Slider
);
ADD_OBJECTS
(
List
);
ADD_OBJECTS
(
List
);
ADD_OBJECTS
(
Tree
);
ADD_OBJECTS
(
Video
);
ADD_OBJECTS
(
Video
);
return
m_pTheme
;
return
m_pTheme
;
...
@@ -628,6 +630,62 @@ void Builder::addList( const BuilderData::List &rData )
...
@@ -628,6 +630,62 @@ void Builder::addList( const BuilderData::List &rData )
m_pTheme
->
m_controls
[
rData
.
m_id
]
=
CtrlGenericPtr
(
pList
);
m_pTheme
->
m_controls
[
rData
.
m_id
]
=
CtrlGenericPtr
(
pList
);
}
}
void
Builder
::
addTree
(
const
BuilderData
::
Tree
&
rData
)
{
// Get the bitmaps, if any
GenericBitmap
*
pBgBmp
=
NULL
;
GenericBitmap
*
pItemBmp
=
NULL
;
GenericBitmap
*
pOpenBmp
=
NULL
;
GenericBitmap
*
pClosedBmp
=
NULL
;
GET_BMP
(
pBgBmp
,
rData
.
m_bgImageId
);
GET_BMP
(
pItemBmp
,
rData
.
m_itemImageId
);
GET_BMP
(
pOpenBmp
,
rData
.
m_openImageId
);
GET_BMP
(
pClosedBmp
,
rData
.
m_closedImageId
);
GenericLayout
*
pLayout
=
m_pTheme
->
getLayoutById
(
rData
.
m_layoutId
);
if
(
pLayout
==
NULL
)
{
msg_Err
(
getIntf
(),
"unknown layout id: %s"
,
rData
.
m_layoutId
.
c_str
()
);
return
;
}
GenericFont
*
pFont
=
getFont
(
rData
.
m_fontId
);
if
(
pFont
==
NULL
)
{
msg_Err
(
getIntf
(),
"Unknown font id: %s"
,
rData
.
m_fontId
.
c_str
()
);
return
;
}
// Get the list variable
Interpreter
*
pInterpreter
=
Interpreter
::
instance
(
getIntf
()
);
VarTree
*
pVar
=
pInterpreter
->
getVarTree
(
rData
.
m_var
,
m_pTheme
);
if
(
pVar
==
NULL
)
{
msg_Err
(
getIntf
(),
"No such list variable: %s"
,
rData
.
m_var
.
c_str
()
);
return
;
}
// Get the visibility variable
// XXX check when it is null
VarBool
*
pVisible
=
pInterpreter
->
getVarBool
(
rData
.
m_visible
,
m_pTheme
);
// Create the list control
CtrlTree
*
pTree
=
new
CtrlTree
(
getIntf
(),
*
pVar
,
*
pFont
,
pBgBmp
,
pItemBmp
,
pOpenBmp
,
pClosedBmp
,
rData
.
m_fgColor
,
rData
.
m_playColor
,
rData
.
m_bgColor1
,
rData
.
m_bgColor2
,
rData
.
m_selColor
,
UString
(
getIntf
(),
rData
.
m_help
.
c_str
()
),
pVisible
);
// Compute the position of the control
const
Position
pos
=
makePosition
(
rData
.
m_leftTop
,
rData
.
m_rightBottom
,
rData
.
m_xPos
,
rData
.
m_yPos
,
rData
.
m_width
,
rData
.
m_height
,
*
pLayout
);
pLayout
->
addControl
(
pTree
,
pos
,
rData
.
m_layer
);
m_pTheme
->
m_controls
[
rData
.
m_id
]
=
CtrlGenericPtr
(
pTree
);
}
void
Builder
::
addVideo
(
const
BuilderData
::
Video
&
rData
)
void
Builder
::
addVideo
(
const
BuilderData
::
Video
&
rData
)
{
{
...
...
modules/gui/skins2/parser/builder.hpp
View file @
c7e38315
...
@@ -77,6 +77,7 @@ class Builder: public SkinObject
...
@@ -77,6 +77,7 @@ class Builder: public SkinObject
void
addRadialSlider
(
const
BuilderData
::
RadialSlider
&
rData
);
void
addRadialSlider
(
const
BuilderData
::
RadialSlider
&
rData
);
void
addSlider
(
const
BuilderData
::
Slider
&
rData
);
void
addSlider
(
const
BuilderData
::
Slider
&
rData
);
void
addList
(
const
BuilderData
::
List
&
rData
);
void
addList
(
const
BuilderData
::
List
&
rData
);
void
addTree
(
const
BuilderData
::
Tree
&
rData
);
void
addVideo
(
const
BuilderData
::
Video
&
rData
);
void
addVideo
(
const
BuilderData
::
Video
&
rData
);
/// Compute the position of a control
/// Compute the position of a control
...
...
modules/gui/skins2/parser/builder_data.def
View file @
c7e38315
...
@@ -12,4 +12,5 @@ Text id:string xPos:int yPos:int visible:string fontId:string text:string width:
...
@@ -12,4 +12,5 @@ Text id:string xPos:int yPos:int visible:string fontId:string text:string width:
RadialSlider id:string visible:string xPos:int yPos:int leftTop:string rightBottom:string sequence:string nbImages:int minAngle:float maxAngle:float value:string tooltip:string help:string layer:int windowId:string layoutId:string
RadialSlider id:string visible:string xPos:int yPos:int leftTop:string rightBottom:string sequence:string nbImages:int minAngle:float maxAngle:float value:string tooltip:string help:string layer:int windowId:string layoutId:string
Slider id:string visible:string xPos:int yPos:int leftTop:string rightBottom:string upId:string downId:string overId:string points:string thickness:int value:string tooltip:string help:string layer:int windowId:string layoutId:string
Slider id:string visible:string xPos:int yPos:int leftTop:string rightBottom:string upId:string downId:string overId:string points:string thickness:int value:string tooltip:string help:string layer:int windowId:string layoutId:string
List id:string xPos:int yPos:int visible:string width:int height:int leftTop:string rightBottom:string fontId:string var:string bgImageId:string fgColor:uint32_t playColor:uint32_t bgColor1:uint32_t bgColor2:uint32_t selColor:uint32_t help:string layer:int windowId:string layoutId:string
List id:string xPos:int yPos:int visible:string width:int height:int leftTop:string rightBottom:string fontId:string var:string bgImageId:string fgColor:uint32_t playColor:uint32_t bgColor1:uint32_t bgColor2:uint32_t selColor:uint32_t help:string layer:int windowId:string layoutId:string
Tree id:string xPos:int yPos:int visible:string width:int height:int leftTop:string rightBottom:string fontId:string var:string bgImageId:string itemImageId:string openImageId:string closedImageId:string fgColor:uint32_t playColor:uint32_t bgColor1:uint32_t bgColor2:uint32_t selColor:uint32_t help:string layer:int windowId:string layoutId:string
Video id:string xPos:int yPos:int width:int height:int leftTop:string rightBottom:string visible:string help:string layer:int windowId:string layoutId:string
Video id:string xPos:int yPos:int width:int height:int leftTop:string rightBottom:string visible:string help:string layer:int windowId:string layoutId:string
modules/gui/skins2/parser/builder_data.hpp
View file @
c7e38315
...
@@ -5,7 +5,7 @@
...
@@ -5,7 +5,7 @@
* $Id$
* $Id$
*
*
* Authors: Cyril Deguet <asmax@via.ecp.fr>
* Authors: Cyril Deguet <asmax@via.ecp.fr>
* Olivier Teuli
è
re <ipkiss@via.ecp.fr>
* Olivier Teuli
e
re <ipkiss@via.ecp.fr>
*
*
* This program is free software; you can redistribute it and/or modify
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* it under the terms of the GNU General Public License as published by
...
@@ -328,6 +328,39 @@ m_id( id ), m_xPos( xPos ), m_yPos( yPos ), m_visible( visible ), m_width( width
...
@@ -328,6 +328,39 @@ m_id( id ), m_xPos( xPos ), m_yPos( yPos ), m_visible( visible ), m_width( width
/// List
/// List
list
<
List
>
m_listList
;
list
<
List
>
m_listList
;
/// Type definition
struct
Tree
{
Tree
(
const
string
&
id
,
int
xPos
,
int
yPos
,
const
string
&
visible
,
int
width
,
int
height
,
const
string
&
leftTop
,
const
string
&
rightBottom
,
const
string
&
fontId
,
const
string
&
var
,
const
string
&
bgImageId
,
const
string
&
itemImageId
,
const
string
&
openImageId
,
const
string
&
closedImageId
,
uint32_t
fgColor
,
uint32_t
playColor
,
uint32_t
bgColor1
,
uint32_t
bgColor2
,
uint32_t
selColor
,
const
string
&
help
,
int
layer
,
const
string
&
windowId
,
const
string
&
layoutId
)
:
m_id
(
id
),
m_xPos
(
xPos
),
m_yPos
(
yPos
),
m_visible
(
visible
),
m_width
(
width
),
m_height
(
height
),
m_leftTop
(
leftTop
),
m_rightBottom
(
rightBottom
),
m_fontId
(
fontId
),
m_var
(
var
),
m_bgImageId
(
bgImageId
),
m_itemImageId
(
itemImageId
),
m_openImageId
(
openImageId
),
m_closedImageId
(
closedImageId
),
m_fgColor
(
fgColor
),
m_playColor
(
playColor
),
m_bgColor1
(
bgColor1
),
m_bgColor2
(
bgColor2
),
m_selColor
(
selColor
),
m_help
(
help
),
m_layer
(
layer
),
m_windowId
(
windowId
),
m_layoutId
(
layoutId
)
{}
const
string
m_id
;
int
m_xPos
;
int
m_yPos
;
const
string
m_visible
;
int
m_width
;
int
m_height
;
const
string
m_leftTop
;
const
string
m_rightBottom
;
const
string
m_fontId
;
const
string
m_var
;
const
string
m_bgImageId
;
const
string
m_itemImageId
;
const
string
m_openImageId
;
const
string
m_closedImageId
;
uint32_t
m_fgColor
;
uint32_t
m_playColor
;
uint32_t
m_bgColor1
;
uint32_t
m_bgColor2
;
uint32_t
m_selColor
;
const
string
m_help
;
int
m_layer
;
const
string
m_windowId
;
const
string
m_layoutId
;
};
/// List
list
<
Tree
>
m_listTree
;
/// Type definition
/// Type definition
struct
Video
struct
Video
{
{
...
...
modules/gui/skins2/parser/gen_builder.py
View file @
c7e38315
...
@@ -18,7 +18,7 @@ hppfile.write(
...
@@ -18,7 +18,7 @@ hppfile.write(
* $Id$
* $Id$
*
*
* Authors: Cyril Deguet <asmax@via.ecp.fr>
* Authors: Cyril Deguet <asmax@via.ecp.fr>
* Olivier Teulire <ipkiss@via.ecp.fr>
* Olivier Teuli
e
re <ipkiss@via.ecp.fr>
*
*
* This program is free software; you can redistribute it and/or modify
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* it under the terms of the GNU General Public License as published by
...
...
modules/gui/skins2/parser/interpreter.cpp
View file @
c7e38315
...
@@ -26,6 +26,7 @@
...
@@ -26,6 +26,7 @@
#include "expr_evaluator.hpp"
#include "expr_evaluator.hpp"
#include "../commands/cmd_muxer.hpp"
#include "../commands/cmd_muxer.hpp"
#include "../commands/cmd_playlist.hpp"
#include "../commands/cmd_playlist.hpp"
#include "../commands/cmd_playtree.hpp"
#include "../commands/cmd_dialogs.hpp"
#include "../commands/cmd_dialogs.hpp"
#include "../commands/cmd_dummy.hpp"
#include "../commands/cmd_dummy.hpp"
#include "../commands/cmd_layout.hpp"
#include "../commands/cmd_layout.hpp"
...
@@ -79,6 +80,27 @@ Interpreter::Interpreter( intf_thread_t *pIntf ): SkinObject( pIntf )
...
@@ -79,6 +80,27 @@ Interpreter::Interpreter( intf_thread_t *pIntf ): SkinObject( pIntf )
CmdGenericPtr
(
new
CmdPlaylistRepeat
(
getIntf
(),
true
)
);
CmdGenericPtr
(
new
CmdPlaylistRepeat
(
getIntf
(),
true
)
);
m_commandMap
[
"playlist.setRepeat(false)"
]
=
m_commandMap
[
"playlist.setRepeat(false)"
]
=
CmdGenericPtr
(
new
CmdPlaylistRepeat
(
getIntf
(),
false
)
);
CmdGenericPtr
(
new
CmdPlaylistRepeat
(
getIntf
(),
false
)
);
REGISTER_CMD
(
"playtree.load()"
,
CmdDlgPlaytreeLoad
)
REGISTER_CMD
(
"playtree.save()"
,
CmdDlgPlaytreeSave
)
REGISTER_CMD
(
"playtree.add()"
,
CmdDlgAdd
)
VarTree
&
rVarTree
=
VlcProc
::
instance
(
getIntf
()
)
->
getPlaytreeVar
();
m_commandMap
[
"playtree.del()"
]
=
CmdGenericPtr
(
new
CmdPlaytreeDel
(
getIntf
(),
rVarTree
)
);
REGISTER_CMD
(
"playtree.next()"
,
CmdPlaytreeNext
)
REGISTER_CMD
(
"playtree.previous()"
,
CmdPlaytreePrevious
)
REGISTER_CMD
(
"playtree.sort()"
,
CmdPlaytreeSort
)
m_commandMap
[
"playtree.setRandom(true)"
]
=
CmdGenericPtr
(
new
CmdPlaytreeRandom
(
getIntf
(),
true
)
);
m_commandMap
[
"playtree.setRandom(false)"
]
=
CmdGenericPtr
(
new
CmdPlaytreeRandom
(
getIntf
(),
false
)
);
m_commandMap
[
"playtree.setLoop(true)"
]
=
CmdGenericPtr
(
new
CmdPlaytreeLoop
(
getIntf
(),
true
)
);
m_commandMap
[
"playtree.setLoop(false)"
]
=
CmdGenericPtr
(
new
CmdPlaytreeLoop
(
getIntf
(),
false
)
);
m_commandMap
[
"playtree.setRepeat(true)"
]
=
CmdGenericPtr
(
new
CmdPlaytreeRepeat
(
getIntf
(),
true
)
);
m_commandMap
[
"playtree.setRepeat(false)"
]
=
CmdGenericPtr
(
new
CmdPlaytreeRepeat
(
getIntf
(),
false
)
);
REGISTER_CMD
(
"vlc.fullscreen()"
,
CmdFullscreen
)
REGISTER_CMD
(
"vlc.fullscreen()"
,
CmdFullscreen
)
REGISTER_CMD
(
"vlc.play()"
,
CmdPlay
)
REGISTER_CMD
(
"vlc.play()"
,
CmdPlay
)
REGISTER_CMD
(
"vlc.pause()"
,
CmdPause
)
REGISTER_CMD
(
"vlc.pause()"
,
CmdPause
)
...
@@ -362,3 +384,10 @@ VarList *Interpreter::getVarList( const string &rName, Theme *pTheme )
...
@@ -362,3 +384,10 @@ VarList *Interpreter::getVarList( const string &rName, Theme *pTheme )
return
pVar
;
return
pVar
;
}
}
VarTree
*
Interpreter
::
getVarTree
(
const
string
&
rName
,
Theme
*
pTheme
)
{
// Try to get the variable from the variable manager
VarManager
*
pVarManager
=
VarManager
::
instance
(
getIntf
()
);
VarTree
*
pVar
=
(
VarTree
*
)
pVarManager
->
getVar
(
rName
,
"tree"
);
return
pVar
;
}
modules/gui/skins2/parser/interpreter.hpp
View file @
c7e38315
...
@@ -31,6 +31,7 @@
...
@@ -31,6 +31,7 @@
class
Theme
;
class
Theme
;
class
VarBool
;
class
VarBool
;
class
VarList
;
class
VarList
;
class
VarTree
;
class
VarPercent
;
class
VarPercent
;
...
@@ -59,6 +60,9 @@ class Interpreter: public SkinObject
...
@@ -59,6 +60,9 @@ class Interpreter: public SkinObject
/// Returns the list variable corresponding to the given name
/// Returns the list variable corresponding to the given name
VarList
*
getVarList
(
const
string
&
rName
,
Theme
*
pTheme
);
VarList
*
getVarList
(
const
string
&
rName
,
Theme
*
pTheme
);
/// Returns the tree variable corresponding to the given name
VarTree
*
getVarTree
(
const
string
&
rName
,
Theme
*
pTheme
);
private:
private:
/// Map of global commands
/// Map of global commands
map
<
string
,
CmdGenericPtr
>
m_commandMap
;
map
<
string
,
CmdGenericPtr
>
m_commandMap
;
...
...
modules/gui/skins2/parser/skin_parser.cpp
View file @
c7e38315
...
@@ -239,6 +239,46 @@ void SkinParser::handleBeginElement( const string &rName, AttrList_t &attr )
...
@@ -239,6 +239,46 @@ void SkinParser::handleBeginElement( const string &rName, AttrList_t &attr )
m_data
.
m_listList
.
push_back
(
listData
);
m_data
.
m_listList
.
push_back
(
listData
);
}
}
else
if
(
rName
==
"Playtree"
)
{
RequireDefault
(
"id"
);
RequireDefault
(
"font"
);
CheckDefault
(
"visible"
,
"true"
);
CheckDefault
(
"x"
,
"0"
);
CheckDefault
(
"y"
,
"0"
);
CheckDefault
(
"width"
,
"0"
);
CheckDefault
(
"height"
,
"0"
);
CheckDefault
(
"lefttop"
,
"lefttop"
);
CheckDefault
(
"rightbottom"
,
"lefttop"
);
CheckDefault
(
"bgimage"
,
"none"
);
CheckDefault
(
"itemimage"
,
"none"
);
CheckDefault
(
"openimage"
,
"none"
);
CheckDefault
(
"closedimage"
,
"none"
);
CheckDefault
(
"fgcolor"
,
"#000000"
);
CheckDefault
(
"playcolor"
,
"#FF0000"
);
CheckDefault
(
"bgcolor1"
,
"#FFFFFF"
);
CheckDefault
(
"bgcolor2"
,
"#FFFFFF"
);
CheckDefault
(
"selcolor"
,
"#0000FF"
);
CheckDefault
(
"help"
,
""
);
m_curListId
=
uniqueId
(
attr
[
"id"
]
);
const
BuilderData
::
Tree
treeData
(
m_curListId
,
atoi
(
attr
[
"x"
]
)
+
m_xOffset
,
atoi
(
attr
[
"y"
]
)
+
m_yOffset
,
attr
[
"visible"
],
atoi
(
attr
[
"width"
]),
atoi
(
attr
[
"height"
]
),
attr
[
"lefttop"
],
attr
[
"rightbottom"
],
attr
[
"font"
],
"playtree"
,
attr
[
"bgimage"
],
attr
[
"itemimage"
],
attr
[
"openimage"
],
attr
[
"closedimage"
],
convertColor
(
attr
[
"fgcolor"
]
),
convertColor
(
attr
[
"playcolor"
]
),
convertColor
(
attr
[
"bgcolor1"
]
),
convertColor
(
attr
[
"bgcolor2"
]
),
convertColor
(
attr
[
"selcolor"
]
),
attr
[
"help"
],
m_curLayer
,
m_curWindowId
,
m_curLayoutId
);
m_curLayer
++
;
m_data
.
m_listTree
.
push_back
(
treeData
);
}
else
if
(
rName
==
"RadialSlider"
)
else
if
(
rName
==
"RadialSlider"
)
{
{
RequireDefault
(
"sequence"
);
RequireDefault
(
"sequence"
);
...
@@ -291,6 +331,8 @@ void SkinParser::handleBeginElement( const string &rName, AttrList_t &attr )
...
@@ -291,6 +331,8 @@ void SkinParser::handleBeginElement( const string &rName, AttrList_t &attr )
{
{
// Slider associated to a list
// Slider associated to a list
newValue
=
"playlist.slider"
;
newValue
=
"playlist.slider"
;
// FIXME
newValue
=
"playtree.slider"
;
}
}
const
BuilderData
::
Slider
slider
(
uniqueId
(
attr
[
"id"
]
),
const
BuilderData
::
Slider
slider
(
uniqueId
(
attr
[
"id"
]
),
attr
[
"visible"
],
attr
[
"visible"
],
...
@@ -409,7 +451,7 @@ void SkinParser::handleEndElement( const string &rName )
...
@@ -409,7 +451,7 @@ void SkinParser::handleEndElement( const string &rName )
m_yOffsetList
.
pop_back
();
m_yOffsetList
.
pop_back
();
}
}
else
if
(
rName
==
"Playlist"
)
else
if
(
rName
==
"Playlist"
||
rName
==
"Playtree"
)
{
{
m_curListId
=
""
;
m_curListId
=
""
;
}
}
...
...
modules/gui/skins2/src/dialogs.cpp
View file @
c7e38315
...
@@ -27,6 +27,7 @@
...
@@ -27,6 +27,7 @@
#include "../commands/cmd_change_skin.hpp"
#include "../commands/cmd_change_skin.hpp"
#include "../commands/cmd_quit.hpp"
#include "../commands/cmd_quit.hpp"
#include "../commands/cmd_playlist.hpp"
#include "../commands/cmd_playlist.hpp"
#include "../commands/cmd_playtree.hpp"
/// Callback called when a new skin is chosen
/// Callback called when a new skin is chosen
...
@@ -71,6 +72,7 @@ void Dialogs::showPlaylistLoadCB( intf_dialog_args_t *pArg )
...
@@ -71,6 +72,7 @@ void Dialogs::showPlaylistLoadCB( intf_dialog_args_t *pArg )
// Push the command in the asynchronous command queue
// Push the command in the asynchronous command queue
AsyncQueue
*
pQueue
=
AsyncQueue
::
instance
(
pIntf
);
AsyncQueue
*
pQueue
=
AsyncQueue
::
instance
(
pIntf
);
pQueue
->
remove
(
"load playlist"
);
pQueue
->
remove
(
"load playlist"
);
pQueue
->
remove
(
"load playtree"
);
pQueue
->
push
(
CmdGenericPtr
(
pCmd
)
);
pQueue
->
push
(
CmdGenericPtr
(
pCmd
)
);
}
}
}
}
...
@@ -89,6 +91,7 @@ void Dialogs::showPlaylistSaveCB( intf_dialog_args_t *pArg )
...
@@ -89,6 +91,7 @@ void Dialogs::showPlaylistSaveCB( intf_dialog_args_t *pArg )
// Push the command in the asynchronous command queue
// Push the command in the asynchronous command queue
AsyncQueue
*
pQueue
=
AsyncQueue
::
instance
(
pIntf
);
AsyncQueue
*
pQueue
=
AsyncQueue
::
instance
(
pIntf
);
pQueue
->
remove
(
"load playlist"
);
pQueue
->
remove
(
"load playlist"
);
pQueue
->
remove
(
"load playtree"
);
pQueue
->
push
(
CmdGenericPtr
(
pCmd
)
);
pQueue
->
push
(
CmdGenericPtr
(
pCmd
)
);
}
}
}
}
...
...
modules/gui/skins2/src/vlcproc.cpp
View file @
c7e38315
...
@@ -80,6 +80,12 @@ VlcProc::VlcProc( intf_thread_t *pIntf ): SkinObject( pIntf ), m_pVout( NULL ),
...
@@ -80,6 +80,12 @@ VlcProc::VlcProc( intf_thread_t *pIntf ): SkinObject( pIntf ), m_pVout( NULL ),
REGISTER_VAR
(
m_cVarRandom
,
VarBoolImpl
,
"playlist.isRandom"
)
REGISTER_VAR
(
m_cVarRandom
,
VarBoolImpl
,
"playlist.isRandom"
)
REGISTER_VAR
(
m_cVarLoop
,
VarBoolImpl
,
"playlist.isLoop"
)
REGISTER_VAR
(
m_cVarLoop
,
VarBoolImpl
,
"playlist.isLoop"
)
REGISTER_VAR
(
m_cVarRepeat
,
VarBoolImpl
,
"playlist.isRepeat"
)
REGISTER_VAR
(
m_cVarRepeat
,
VarBoolImpl
,
"playlist.isRepeat"
)
REGISTER_VAR
(
m_cPlaytree
,
Playtree
,
"playtree"
)
pVarManager
->
registerVar
(
getPlaytreeVar
().
getPositionVarPtr
(),
"playtree.slider"
);
REGISTER_VAR
(
m_cVarRandom
,
VarBoolImpl
,
"playtree.isRandom"
)
REGISTER_VAR
(
m_cVarLoop
,
VarBoolImpl
,
"playtree.isLoop"
)
REGISTER_VAR
(
m_cVarRepeat
,
VarBoolImpl
,
"playtree.isRepeat"
)
REGISTER_VAR
(
m_cVarTime
,
StreamTime
,
"time"
)
REGISTER_VAR
(
m_cVarTime
,
StreamTime
,
"time"
)
REGISTER_VAR
(
m_cVarVolume
,
Volume
,
"volume"
)
REGISTER_VAR
(
m_cVarVolume
,
Volume
,
"volume"
)
REGISTER_VAR
(
m_cVarMute
,
VarBoolImpl
,
"vlc.isMute"
)
REGISTER_VAR
(
m_cVarMute
,
VarBoolImpl
,
"vlc.isMute"
)
...
@@ -292,11 +298,15 @@ int VlcProc::onIntfChange( vlc_object_t *pObj, const char *pVariable,
...
@@ -292,11 +298,15 @@ int VlcProc::onIntfChange( vlc_object_t *pObj, const char *pVariable,
// Create a playlist notify command
// Create a playlist notify command
CmdNotifyPlaylist
*
pCmd
=
new
CmdNotifyPlaylist
(
pThis
->
getIntf
()
);
CmdNotifyPlaylist
*
pCmd
=
new
CmdNotifyPlaylist
(
pThis
->
getIntf
()
);
// Create a playtree notify command
CmdNotifyPlaytree
*
pCmdTree
=
new
CmdNotifyPlaytree
(
pThis
->
getIntf
()
);
// Push the command in the asynchronous command queue
// Push the command in the asynchronous command queue
AsyncQueue
*
pQueue
=
AsyncQueue
::
instance
(
pThis
->
getIntf
()
);
AsyncQueue
*
pQueue
=
AsyncQueue
::
instance
(
pThis
->
getIntf
()
);
pQueue
->
remove
(
"notify playlist"
);
pQueue
->
remove
(
"notify playlist"
);
pQueue
->
remove
(
"notify playtree"
);
pQueue
->
push
(
CmdGenericPtr
(
pCmd
)
);
pQueue
->
push
(
CmdGenericPtr
(
pCmd
)
);
pQueue
->
push
(
CmdGenericPtr
(
pCmdTree
)
);
return
VLC_SUCCESS
;
return
VLC_SUCCESS
;
}
}
...
@@ -337,11 +347,15 @@ int VlcProc::onItemChange( vlc_object_t *pObj, const char *pVariable,
...
@@ -337,11 +347,15 @@ int VlcProc::onItemChange( vlc_object_t *pObj, const char *pVariable,
// Create a playlist notify command
// Create a playlist notify command
// TODO: selective update
// TODO: selective update
CmdNotifyPlaylist
*
pCmd
=
new
CmdNotifyPlaylist
(
pThis
->
getIntf
()
);
CmdNotifyPlaylist
*
pCmd
=
new
CmdNotifyPlaylist
(
pThis
->
getIntf
()
);
// Create a playtree notify command
CmdNotifyPlaytree
*
pCmdTree
=
new
CmdNotifyPlaytree
(
pThis
->
getIntf
()
);
// Push the command in the asynchronous command queue
// Push the command in the asynchronous command queue
AsyncQueue
*
pQueue
=
AsyncQueue
::
instance
(
pThis
->
getIntf
()
);
AsyncQueue
*
pQueue
=
AsyncQueue
::
instance
(
pThis
->
getIntf
()
);
pQueue
->
remove
(
"notify playlist"
);
pQueue
->
remove
(
"notify playlist"
);
pQueue
->
remove
(
"notify playtree"
);
pQueue
->
push
(
CmdGenericPtr
(
pCmd
)
);
pQueue
->
push
(
CmdGenericPtr
(
pCmd
)
);
pQueue
->
push
(
CmdGenericPtr
(
pCmdTree
)
);
return
VLC_SUCCESS
;
return
VLC_SUCCESS
;
}
}
...
@@ -362,10 +376,14 @@ int VlcProc::onPlaylistChange( vlc_object_t *pObj, const char *pVariable,
...
@@ -362,10 +376,14 @@ int VlcProc::onPlaylistChange( vlc_object_t *pObj, const char *pVariable,
// Create a playlist notify command
// Create a playlist notify command
// TODO: selective update
// TODO: selective update
CmdNotifyPlaylist
*
pCmd
=
new
CmdNotifyPlaylist
(
pThis
->
getIntf
()
);
CmdNotifyPlaylist
*
pCmd
=
new
CmdNotifyPlaylist
(
pThis
->
getIntf
()
);
// Create a playtree notify command
CmdNotifyPlaytree
*
pCmdTree
=
new
CmdNotifyPlaytree
(
pThis
->
getIntf
()
);
// Push the command in the asynchronous command queue
// Push the command in the asynchronous command queue
pQueue
->
remove
(
"notify playlist"
);
pQueue
->
remove
(
"notify playlist"
);
pQueue
->
remove
(
"notify playtree"
);
pQueue
->
push
(
CmdGenericPtr
(
pCmd
)
);
pQueue
->
push
(
CmdGenericPtr
(
pCmd
)
);
pQueue
->
push
(
CmdGenericPtr
(
pCmdTree
)
);
return
VLC_SUCCESS
;
return
VLC_SUCCESS
;
}
}
...
...
modules/gui/skins2/src/vlcproc.hpp
View file @
c7e38315
...
@@ -28,6 +28,7 @@
...
@@ -28,6 +28,7 @@
#include <set>
#include <set>
#include "../vars/playlist.hpp"
#include "../vars/playlist.hpp"
#include "../vars/playtree.hpp"
#include "../vars/time.hpp"
#include "../vars/time.hpp"
#include "../vars/volume.hpp"
#include "../vars/volume.hpp"
#include "../utils/var_text.hpp"
#include "../utils/var_text.hpp"
...
@@ -51,6 +52,9 @@ class VlcProc: public SkinObject
...
@@ -51,6 +52,9 @@ class VlcProc: public SkinObject
/// Getter for the playlist variable
/// Getter for the playlist variable
Playlist
&
getPlaylistVar
()
{
return
*
((
Playlist
*
)
m_cPlaylist
.
get
());
}
Playlist
&
getPlaylistVar
()
{
return
*
((
Playlist
*
)
m_cPlaylist
.
get
());
}
/// Getter for the playtree variable
Playtree
&
getPlaytreeVar
()
{
return
*
((
Playtree
*
)
m_cPlaytree
.
get
());
}
/// Getter for the time variable
/// Getter for the time variable
StreamTime
&
getTimeVar
()
{
return
*
((
StreamTime
*
)(
m_cVarTime
.
get
()));
}
StreamTime
&
getTimeVar
()
{
return
*
((
StreamTime
*
)(
m_cVarTime
.
get
()));
}
...
@@ -88,6 +92,8 @@ class VlcProc: public SkinObject
...
@@ -88,6 +92,8 @@ class VlcProc: public SkinObject
OSTimer
*
m_pTimer
;
OSTimer
*
m_pTimer
;
/// Playlist variable
/// Playlist variable
VariablePtr
m_cPlaylist
;
VariablePtr
m_cPlaylist
;
/// Playtree variable FIXME
VariablePtr
m_cPlaytree
;
VariablePtr
m_cVarRandom
;
VariablePtr
m_cVarRandom
;
VariablePtr
m_cVarLoop
;
VariablePtr
m_cVarLoop
;
VariablePtr
m_cVarRepeat
;
VariablePtr
m_cVarRepeat
;
...
...
modules/gui/skins2/utils/var_tree.cpp
0 → 100644
View file @
c7e38315
/*****************************************************************************
* var_tree.cpp
*****************************************************************************
* Copyright (C) 2005 VideoLAN
* $Id: var_bool.hpp 9934 2005-02-15 13:55:08Z courmisch $
*
* Authors: Antoine Cellerier <dionoea@videolan.org>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111, USA.
*****************************************************************************/
#include "var_tree.hpp"
const
string
VarTree
::
m_type
=
"tree"
;
VarTree
::
VarTree
(
intf_thread_t
*
pIntf
,
VarTree
*
m_pParent2
)
:
Variable
(
pIntf
)
{
m_selected
=
false
;
m_playing
=
false
;
m_expanded
=
true
;
m_pData
=
NULL
;
m_pParent
=
m_pParent2
;
// Create the position variable
m_cPosition
=
VariablePtr
(
new
VarPercent
(
pIntf
)
);
getPositionVar
().
set
(
1.0
);
}
VarTree
::~
VarTree
()
{
// TODO : check that children are deleted
}
void
VarTree
::
add
(
const
UStringPtr
&
rcString
,
bool
selected
,
bool
playing
,
bool
expanded
,
void
*
pData
)
{
m_children
.
push_back
(
VarTree
(
getIntf
(),
this
)
);
back
().
m_cString
=
rcString
;
back
().
m_selected
=
selected
;
back
().
m_playing
=
playing
;
back
().
m_expanded
=
expanded
;
back
().
m_pData
=
pData
;
notify
();
}
void
VarTree
::
delSelected
()
{
Iterator
it
=
begin
();
while
(
it
!=
end
()
)
{
//dig down the tree
if
(
size
()
)
it
->
delSelected
();
//stay on some level
if
(
it
->
m_selected
)
{
Iterator
oldIt
=
it
;
it
++
;
m_children
.
erase
(
oldIt
);
}
else
{
it
++
;
}
}
notify
();
}
void
VarTree
::
clear
()
{
m_children
.
clear
();
}
VarTree
::
Iterator
VarTree
::
operator
[](
int
n
)
{
Iterator
it
;
int
i
;
for
(
it
=
begin
(),
i
=
0
;
i
<
n
&&
it
!=
end
();
it
++
,
i
++
);
return
it
;
}
VarTree
::
ConstIterator
VarTree
::
operator
[](
int
n
)
const
{
ConstIterator
it
;
int
i
;
for
(
it
=
begin
(),
i
=
0
;
i
<
n
&&
it
!=
end
();
it
++
,
i
++
);
return
it
;
}
/* find iterator to next ancestor
* ... which means parent++ or grandparent++ or grandgrandparent++ ... */
VarTree
::
Iterator
VarTree
::
uncle
()
{
// fprintf( stderr, "trying to find uncle\n");
VarTree
*
p_parent
=
parent
();
if
(
p_parent
!=
NULL
)
{
VarTree
*
p_grandparent
=
p_parent
->
parent
();
while
(
p_grandparent
!=
NULL
)
{
Iterator
it
=
p_grandparent
->
begin
();
while
(
!
(
it
==
p_grandparent
->
end
())
&&
&
(
*
it
)
!=
p_parent
)
it
++
;
if
(
it
!=
p_grandparent
->
end
()
)
{
it
++
;
if
(
it
!=
p_grandparent
->
end
()
)
{
return
it
;
}
}
if
(
p_grandparent
->
parent
()
)
{
p_parent
=
p_grandparent
;
p_grandparent
=
p_parent
->
parent
();
}
else
p_grandparent
=
NULL
;
}
}
/* if we didn't return before, it means that we've reached the end */
return
root
()
->
end
();
}
void
VarTree
::
checkParents
(
VarTree
*
m_pParent2
)
{
m_pParent
=
m_pParent2
;
Iterator
it
=
begin
();
while
(
it
!=
end
()
)
{
it
->
checkParents
(
this
);
it
++
;
}
}
int
VarTree
::
visibleItems
()
{
int
i_count
=
size
();
Iterator
it
=
begin
();
while
(
it
!=
end
()
)
{
if
(
it
->
m_expanded
)
{
i_count
+=
it
->
visibleItems
();
}
it
++
;
}
return
i_count
;
}
VarTree
::
Iterator
VarTree
::
visibleItem
(
int
n
)
{
Iterator
it
=
begin
();
while
(
it
!=
end
()
)
{
n
--
;
if
(
n
<=
0
)
return
it
;
if
(
it
->
m_expanded
)
{
int
i
=
n
-
it
->
visibleItems
();
if
(
i
<=
0
)
return
it
->
visibleItem
(
n
);
n
=
i
;
}
it
++
;
}
return
end
();
}
modules/gui/skins2/utils/var_tree.hpp
0 → 100644
View file @
c7e38315
/*****************************************************************************
* var_tree.hpp
*****************************************************************************
* Copyright (C) 2005 VideoLAN
* $Id: var_bool.hpp 9934 2005-02-15 13:55:08Z courmisch $
*
* Authors: Antoine Cellerier <dionoea@videolan.org>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111, USA.
*****************************************************************************/
#ifndef VAR_TREE_HPP
#define VAR_TREE_HPP
#include <list>
#include "variable.hpp"
#include "observer.hpp"
#include "ustring.hpp"
#include "var_percent.hpp"
/// Tree variable
class
VarTree
:
public
Variable
,
public
Subject
<
VarTree
>
{
public:
VarTree
(
intf_thread_t
*
pIntf
,
VarTree
*
m_pParent2
);
virtual
~
VarTree
();
/// Get the variable type
virtual
const
string
&
getType
()
const
{
return
m_type
;
}
/// Add a pointer on string in the children's list
virtual
void
add
(
const
UStringPtr
&
rcString
,
bool
selected
=
true
,
bool
playing
=
true
,
bool
expanded
=
true
,
void
*
pData
=
NULL
);
/// Remove the selected item from the children's list
virtual
void
delSelected
();
/// Remove all elements from the children's list
virtual
void
clear
();
UStringPtr
m_cString
;
bool
m_selected
;
bool
m_playing
;
bool
m_expanded
;
void
*
m_pData
;
/// Get the number of children
int
size
()
const
{
return
m_children
.
size
();
}
/// Iterators
typedef
list
<
VarTree
>::
iterator
Iterator
;
typedef
list
<
VarTree
>::
const_iterator
ConstIterator
;
/// Begining of the children's list
Iterator
begin
()
{
return
m_children
.
begin
();
}
ConstIterator
begin
()
const
{
return
m_children
.
begin
();
}
/// End of children's list
Iterator
end
()
{
return
m_children
.
end
();
}
ConstIterator
end
()
const
{
return
m_children
.
end
();
}
/// Back of children's list
VarTree
&
back
()
{
return
m_children
.
back
();
}
/// Return an iterator on the n'th element of the children's list
Iterator
operator
[](
int
n
);
ConstIterator
operator
[](
int
n
)
const
;
/// Parent node
VarTree
*
parent
()
{
return
m_pParent
;
}
void
VarTree
::
checkParents
(
VarTree
*
m_pParent2
);
Iterator
uncle
();
/// Get root node
VarTree
*
root
()
{
VarTree
*
parent
=
this
;
while
(
parent
->
parent
()
!=
NULL
)
parent
=
parent
->
parent
();
return
parent
;
}
/// Get depth (root depth is 0)
int
depth
()
{
VarTree
*
parent
=
this
;
int
depth
=
0
;
while
(
(
parent
=
parent
->
parent
()
)
!=
NULL
)
depth
++
;
return
depth
;
}
/// Execute the action associated to this item
virtual
void
action
(
VarTree
*
pItem
)
{}
/// Get a reference on the position variable
VarPercent
&
getPositionVar
()
const
{
return
*
((
VarPercent
*
)
m_cPosition
.
get
());
}
/// Get a counted pointer on the position variable
const
VariablePtr
&
getPositionVarPtr
()
const
{
return
m_cPosition
;
}
/// Count the number of items that should be displayed if the playlist window wasn't limited
int
visibleItems
();
/// Return iterator to the n'th visible item
Iterator
visibleItem
(
int
n
);
private:
// intf_thread_t *pIntf;
///list of children
list
<
VarTree
>
m_children
;
///Pointer to parent node
VarTree
*
m_pParent
;
///Variable type
static
const
string
m_type
;
/// Position variable
VariablePtr
m_cPosition
;
};
#endif
modules/gui/skins2/vars/playtree.cpp
0 → 100644
View file @
c7e38315
/*****************************************************************************
* playtree.cpp
*****************************************************************************
* Copyright (C) 2005 VideoLAN
* $Id: playlist.hpp 8659 2004-09-07 21:16:49Z gbazin $
*
* Authors: Antoine Cellerier <dionoea@videolan.org>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111, USA.
*****************************************************************************/
#include <vlc/vlc.h>
#include "playtree.hpp"
#include "../utils/ustring.hpp"
#include "charset.h"
Playtree
::
Playtree
(
intf_thread_t
*
pIntf
)
:
VarTree
(
pIntf
,
/*m_parent = */
NULL
)
{
// Get the VLC playlist object
m_pPlaylist
=
pIntf
->
p_sys
->
p_playlist
;
// Try to guess the current charset
char
*
pCharset
;
vlc_current_charset
(
&
pCharset
);
iconvHandle
=
vlc_iconv_open
(
"UTF-8"
,
pCharset
);
msg_Dbg
(
pIntf
,
"Using character encoding: %s"
,
pCharset
);
free
(
pCharset
);
if
(
iconvHandle
==
(
vlc_iconv_t
)
-
1
)
{
msg_Warn
(
pIntf
,
"Unable to do requested conversion"
);
}
buildTree
();
}
Playtree
::~
Playtree
()
{
if
(
iconvHandle
!=
(
vlc_iconv_t
)
-
1
)
vlc_iconv_close
(
iconvHandle
);
// TODO : check that everything is destroyed
}
void
Playtree
::
delSelected
()
{
// TODO
notify
();
}
void
Playtree
::
action
(
VarTree
*
pItem
)
{
vlc_mutex_lock
(
&
m_pPlaylist
->
object_lock
);
VarTree
::
Iterator
it
;
if
(
pItem
->
size
()
)
{
it
=
pItem
->
begin
();
while
(
it
->
size
()
)
it
=
it
->
begin
();
}
playlist_Control
(
m_pPlaylist
,
PLAYLIST_VIEWPLAY
,
m_pPlaylist
->
status
.
i_view
,
pItem
->
size
()
?
(
playlist_item_t
*
)
pItem
->
m_pData
:
(
playlist_item_t
*
)
pItem
->
parent
()
->
m_pData
,
pItem
->
size
()
?
(
playlist_item_t
*
)
it
->
m_pData
:
(
playlist_item_t
*
)
pItem
->
m_pData
);
vlc_mutex_unlock
(
&
m_pPlaylist
->
object_lock
);
}
void
Playtree
::
onChange
()
{
/* FIXME : updateTree could be a nice idea so we don't have to
* start from scratch each time the playlist changes */
buildTree
();
notify
();
}
void
Playtree
::
buildNode
(
playlist_item_t
*
p_node
,
VarTree
&
m_pNode
)
{
fprintf
(
stderr
,
"[32;1mPlaytree::buildNode[0m
\n
"
);
for
(
int
i
=
0
;
i
<
p_node
->
i_children
;
i
++
)
{
fprintf
(
stderr
,
"[33;1m"
__FILE__
"%d :[0m adding playtree item : %s
\n
"
,
__LINE__
,
p_node
->
pp_children
[
i
]
->
input
.
psz_name
);
UString
*
pName
=
new
UString
(
getIntf
(),
p_node
->
pp_children
[
i
]
->
input
.
psz_name
);
m_pNode
.
add
(
UStringPtr
(
pName
),
false
,
m_pPlaylist
->
status
.
p_item
==
p_node
->
pp_children
[
i
],
true
,
p_node
->
pp_children
[
i
]
);
if
(
p_node
->
pp_children
[
i
]
->
i_children
)
{
buildNode
(
p_node
->
pp_children
[
i
],
m_pNode
.
back
()
);
}
}
}
void
Playtree
::
buildTree
()
{
clear
();
vlc_mutex_lock
(
&
m_pPlaylist
->
object_lock
);
playlist_view_t
*
p_view
;
p_view
=
playlist_ViewFind
(
m_pPlaylist
,
VIEW_CATEGORY
);
/* TODO : let the user chose the view type */
clear
();
/* XXX : do we need Playlist::clear() instead of VarTree::clear() ? */
/* Set the root's name */
UString
*
pName
=
new
UString
(
getIntf
(),
p_view
->
p_root
->
input
.
psz_name
);
m_cString
=
UStringPtr
(
pName
);
buildNode
(
p_view
->
p_root
,
*
this
);
vlc_mutex_unlock
(
&
m_pPlaylist
->
object_lock
);
checkParents
(
NULL
);
}
modules/gui/skins2/vars/playtree.hpp
0 → 100644
View file @
c7e38315
/*****************************************************************************
* playtree.hpp
*****************************************************************************
* Copyright (C) 2005 VideoLAN
* $Id: playlist.hpp 8659 2004-09-07 21:16:49Z gbazin $
*
* Authors: Antoine Cellerier <dionoea@videolan.org>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111, USA.
*****************************************************************************/
#ifndef PLAYTREE_HPP
#define PLAYTREE_HPP
#include "../utils/var_tree.hpp"
/// Variable for VLC playlist (new tree format)
class
Playtree
:
public
VarTree
{
public:
Playtree
(
intf_thread_t
*
pIntf
);
virtual
~
Playtree
();
/// Remove the selected elements from the list
virtual
void
delSelected
();
/// Execute the action associated to this item
virtual
void
action
(
VarTree
*
pItem
);
/// Function called to notify playlist changes
void
onChange
();
private:
/// VLC playlist object
playlist_t
*
m_pPlaylist
;
/// Iconv handle
vlc_iconv_t
iconvHandle
;
/// Build the list from the VLC playlist
void
buildTree
();
/// Update Node's children
void
buildNode
(
playlist_item_t
*
p_node
,
VarTree
&
m_pNode
);
};
#endif
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