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
54227611
Commit
54227611
authored
Aug 14, 2013
by
Petri Hintukainen
Committed by
Rafaël Carré
Aug 16, 2013
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
bluray: fixed title selection and title info when using menus
Signed-off-by:
Rafaël Carré
<
funman@videolan.org
>
parent
4aebfa36
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
73 additions
and
26 deletions
+73
-26
modules/access/bluray.c
modules/access/bluray.c
+73
-26
No files found.
modules/access/bluray.c
View file @
54227611
...
@@ -200,7 +200,7 @@ static es_out_t *esOutNew(demux_t *p_demux);
...
@@ -200,7 +200,7 @@ static es_out_t *esOutNew(demux_t *p_demux);
static
int
blurayControl
(
demux_t
*
,
int
,
va_list
);
static
int
blurayControl
(
demux_t
*
,
int
,
va_list
);
static
int
blurayDemux
(
demux_t
*
);
static
int
blurayDemux
(
demux_t
*
);
static
void
blurayInitTitles
(
demux_t
*
p_demux
);
static
void
blurayInitTitles
(
demux_t
*
p_demux
,
int
menu_titles
);
static
int
bluraySetTitle
(
demux_t
*
p_demux
,
int
i_title
);
static
int
bluraySetTitle
(
demux_t
*
p_demux
,
int
i_title
);
static
void
blurayOverlayProc
(
void
*
ptr
,
const
BD_OVERLAY
*
const
overlay
);
static
void
blurayOverlayProc
(
void
*
ptr
,
const
BD_OVERLAY
*
const
overlay
);
...
@@ -382,14 +382,15 @@ static int blurayOpen(vlc_object_t *object)
...
@@ -382,14 +382,15 @@ static int blurayOpen(vlc_object_t *object)
if
(
!
p_sys
->
p_meta
)
if
(
!
p_sys
->
p_meta
)
msg_Warn
(
p_demux
,
"Failed to get meta info."
);
msg_Warn
(
p_demux
,
"Failed to get meta info."
);
blurayInitTitles
(
p_demux
);
p_sys
->
b_menu
=
var_InheritBool
(
p_demux
,
"bluray-menu"
);
blurayInitTitles
(
p_demux
,
disc_info
->
num_hdmv_titles
+
disc_info
->
num_bdj_titles
+
1
/*Top Menu*/
+
1
/*First Play*/
);
/*
/*
* Initialize the event queue, so we can receive events in blurayDemux(Menu).
* Initialize the event queue, so we can receive events in blurayDemux(Menu).
*/
*/
bd_get_event
(
p_sys
->
bluray
,
NULL
);
bd_get_event
(
p_sys
->
bluray
,
NULL
);
p_sys
->
b_menu
=
var_InheritBool
(
p_demux
,
"bluray-menu"
);
if
(
p_sys
->
b_menu
)
{
if
(
p_sys
->
b_menu
)
{
p_sys
->
p_input
=
demux_GetParentInput
(
p_demux
);
p_sys
->
p_input
=
demux_GetParentInput
(
p_demux
);
if
(
unlikely
(
!
p_sys
->
p_input
))
{
if
(
unlikely
(
!
p_sys
->
p_input
))
{
...
@@ -1078,46 +1079,66 @@ static void bluraySendOverlayToVout(demux_t *p_demux)
...
@@ -1078,46 +1079,66 @@ static void bluraySendOverlayToVout(demux_t *p_demux)
p_sys
->
p_overlays
[
p_sys
->
current_overlay
]
->
status
=
Outdated
;
p_sys
->
p_overlays
[
p_sys
->
current_overlay
]
->
status
=
Outdated
;
}
}
static
void
bluray
InitTitles
(
demux_t
*
p_demux
)
static
void
bluray
UpdateTitleInfo
(
demux_t
*
p_demux
,
input_title_t
*
t
,
int
i_title_idx
,
int
i_playlist
)
{
{
demux_sys_t
*
p_sys
=
p_demux
->
p_sys
;
demux_sys_t
*
p_sys
=
p_demux
->
p_sys
;
BLURAY_TITLE_INFO
*
title_info
=
NULL
;
/* get and set the titles */
if
(
i_playlist
>=
0
)
unsigned
i_title
=
bd_get_titles
(
p_sys
->
bluray
,
TITLES_RELEVANT
,
60
);
title_info
=
bd_get_playlist_info
(
p_sys
->
bluray
,
i_playlist
,
0
);
int64_t
duration
=
0
;
else
if
(
i_title_idx
>=
0
)
title_info
=
bd_get_title_info
(
p_sys
->
bluray
,
i_title_idx
,
0
);
for
(
unsigned
int
i
=
0
;
i
<
i_title
;
i
++
)
{
if
(
!
title_info
)
{
input_title_t
*
t
=
vlc_input_title_New
();
return
;
if
(
!
t
)
}
break
;
BLURAY_TITLE_INFO
*
title_info
=
bd_get_title_info
(
p_sys
->
bluray
,
i
,
0
);
if
(
!
title_info
)
{
vlc_input_title_Delete
(
t
);
break
;
}
t
->
i_length
=
FROM_TICKS
(
title_info
->
duration
);
t
->
i_length
=
FROM_TICKS
(
title_info
->
duration
);
if
(
!
t
->
i_seekpoint
)
{
for
(
unsigned
int
j
=
0
;
j
<
title_info
->
chapter_count
;
j
++
)
{
for
(
unsigned
int
j
=
0
;
j
<
title_info
->
chapter_count
;
j
++
)
{
seekpoint_t
*
s
=
vlc_seekpoint_New
();
seekpoint_t
*
s
=
vlc_seekpoint_New
();
if
(
!
s
)
{
if
(
!
s
)
{
bd_free_title_info
(
title_info
);
vlc_input_title_Delete
(
t
);
break
;
break
;
}
}
s
->
i_time_offset
=
title_info
->
chapters
[
j
].
offset
;
s
->
i_time_offset
=
title_info
->
chapters
[
j
].
offset
;
TAB_APPEND
(
t
->
i_seekpoint
,
t
->
seekpoint
,
s
);
TAB_APPEND
(
t
->
i_seekpoint
,
t
->
seekpoint
,
s
);
}
}
}
bd_free_title_info
(
title_info
);
}
static
void
blurayInitTitles
(
demux_t
*
p_demux
,
int
menu_titles
)
{
demux_sys_t
*
p_sys
=
p_demux
->
p_sys
;
int64_t
duration
=
0
;
/* get and set the titles */
unsigned
i_title
=
menu_titles
;
if
(
t
->
i_length
>
duration
)
{
if
(
!
p_sys
->
b_menu
)
duration
=
t
->
i_length
;
i_title
=
bd_get_titles
(
p_sys
->
bluray
,
TITLES_RELEVANT
,
60
);
p_sys
->
i_longest_title
=
i
;
for
(
unsigned
int
i
=
0
;
i
<
i_title
;
i
++
)
{
input_title_t
*
t
=
vlc_input_title_New
();
if
(
!
t
)
break
;
if
(
!
p_sys
->
b_menu
)
{
blurayUpdateTitleInfo
(
p_demux
,
t
,
i
,
-
1
);
if
(
t
->
i_length
>
duration
)
{
duration
=
t
->
i_length
;
p_sys
->
i_longest_title
=
i
;
}
}
else
if
(
i
==
0
)
{
t
->
psz_name
=
strdup
(
_
(
"Top Menu"
));
}
else
if
(
i
==
i_title
-
1
)
{
t
->
psz_name
=
strdup
(
_
(
"First Play"
));
}
}
TAB_APPEND
(
p_sys
->
i_title
,
p_sys
->
pp_title
,
t
);
TAB_APPEND
(
p_sys
->
i_title
,
p_sys
->
pp_title
,
t
);
bd_free_title_info
(
title_info
);
}
}
}
}
...
@@ -1158,9 +1179,12 @@ static void blurayUpdatePlaylist(demux_t *p_demux, unsigned i_playlist)
...
@@ -1158,9 +1179,12 @@ static void blurayUpdatePlaylist(demux_t *p_demux, unsigned i_playlist)
p_demux
->
p_sys
->
i_current_clip
=
0
;
p_demux
->
p_sys
->
i_current_clip
=
0
;
/* read title info and init some values */
/* read title info and init some values */
p_demux
->
info
.
i_title
=
bd_get_current_title
(
p_demux
->
p_sys
->
bluray
);
if
(
!
p_demux
->
p_sys
->
b_menu
)
p_demux
->
info
.
i_title
=
bd_get_current_title
(
p_demux
->
p_sys
->
bluray
);
p_demux
->
info
.
i_seekpoint
=
0
;
p_demux
->
info
.
i_seekpoint
=
0
;
p_demux
->
info
.
i_update
|=
INPUT_UPDATE_TITLE
|
INPUT_UPDATE_SEEKPOINT
;
p_demux
->
info
.
i_update
|=
INPUT_UPDATE_TITLE
|
INPUT_UPDATE_SEEKPOINT
;
blurayUpdateTitleInfo
(
p_demux
,
p_demux
->
p_sys
->
pp_title
[
p_demux
->
info
.
i_title
],
-
1
,
i_playlist
);
}
}
/*****************************************************************************
/*****************************************************************************
...
@@ -1170,6 +1194,24 @@ static int bluraySetTitle(demux_t *p_demux, int i_title)
...
@@ -1170,6 +1194,24 @@ static int bluraySetTitle(demux_t *p_demux, int i_title)
{
{
demux_sys_t
*
p_sys
=
p_demux
->
p_sys
;
demux_sys_t
*
p_sys
=
p_demux
->
p_sys
;
if
(
p_sys
->
b_menu
)
{
if
(
i_title
<=
0
)
{
msg_Dbg
(
p_demux
,
"Playing TopMenu Title"
);
}
else
if
(
i_title
>=
(
int
)
p_sys
->
i_title
-
1
)
{
msg_Dbg
(
p_demux
,
"Playing FirstPlay Title"
);
i_title
=
BLURAY_TITLE_FIRST_PLAY
;
}
else
{
msg_Dbg
(
p_demux
,
"Playing Title %i"
,
i_title
);
}
if
(
bd_play_title
(
p_demux
->
p_sys
->
bluray
,
i_title
)
==
0
)
{
msg_Err
(
p_demux
,
"cannot play bd title '%d'"
,
i_title
);
return
VLC_EGENERIC
;
}
return
VLC_SUCCESS
;
}
/* Looking for the main title, ie the longest duration */
/* Looking for the main title, ie the longest duration */
if
(
i_title
<
0
)
if
(
i_title
<
0
)
i_title
=
p_sys
->
i_longest_title
;
i_title
=
p_sys
->
i_longest_title
;
...
@@ -1364,9 +1406,14 @@ static void blurayHandleEvent(demux_t *p_demux, const BD_EVENT *e)
...
@@ -1364,9 +1406,14 @@ static void blurayHandleEvent(demux_t *p_demux, const BD_EVENT *e)
switch
(
e
->
event
)
{
switch
(
e
->
event
)
{
case
BD_EVENT_TITLE
:
case
BD_EVENT_TITLE
:
if
(
e
->
param
==
BLURAY_TITLE_FIRST_PLAY
)
p_demux
->
info
.
i_title
=
p_sys
->
i_title
-
1
;
else
p_demux
->
info
.
i_title
=
e
->
param
;
/* this is feature title, we don't know yet which playlist it will play (if any) */
/* this is feature title, we don't know yet which playlist it will play (if any) */
p_sys
->
i_playlist
=
-
1
;
p_sys
->
i_playlist
=
-
1
;
/* reset title infos here ? */
/* reset title infos here ? */
p_demux
->
info
.
i_update
|=
INPUT_UPDATE_TITLE
|
INPUT_UPDATE_SEEKPOINT
;
/* might be BD-J title with no video */
break
;
break
;
case
BD_EVENT_PLAYLIST
:
case
BD_EVENT_PLAYLIST
:
/* Start of playlist playback (?????.mpls) */
/* Start of playlist playback (?????.mpls) */
...
...
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