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
46238b95
Commit
46238b95
authored
Feb 18, 2014
by
Petri Hintukainen
Committed by
Jean-Baptiste Kempf
Feb 19, 2014
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
bluray: implement still image timing
Signed-off-by:
Jean-Baptiste Kempf
<
jb@videolan.org
>
parent
ea9687d4
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
52 additions
and
0 deletions
+52
-0
modules/access/bluray.c
modules/access/bluray.c
+52
-0
No files found.
modules/access/bluray.c
View file @
46238b95
...
@@ -138,6 +138,7 @@ struct demux_sys_t
...
@@ -138,6 +138,7 @@ struct demux_sys_t
bool
b_menu
;
bool
b_menu
;
bool
b_menu_open
;
bool
b_menu_open
;
bool
b_popup_available
;
bool
b_popup_available
;
mtime_t
i_still_end_time
;
/* */
/* */
input_thread_t
*
p_input
;
input_thread_t
*
p_input
;
...
@@ -291,6 +292,7 @@ static int blurayOpen(vlc_object_t *object)
...
@@ -291,6 +292,7 @@ static int blurayOpen(vlc_object_t *object)
p_sys
->
i_audio_stream
=
-
1
;
p_sys
->
i_audio_stream
=
-
1
;
p_sys
->
i_spu_stream
=
-
1
;
p_sys
->
i_spu_stream
=
-
1
;
p_sys
->
i_video_stream
=
-
1
;
p_sys
->
i_video_stream
=
-
1
;
p_sys
->
i_still_end_time
=
0
;
/* init demux info fields */
/* init demux info fields */
p_demux
->
info
.
i_update
=
0
;
p_demux
->
info
.
i_update
=
0
;
...
@@ -1394,6 +1396,46 @@ static int blurayControl(demux_t *p_demux, int query, va_list args)
...
@@ -1394,6 +1396,46 @@ static int blurayControl(demux_t *p_demux, int query, va_list args)
return
VLC_SUCCESS
;
return
VLC_SUCCESS
;
}
}
static
void
blurayResetStillImage
(
demux_t
*
p_demux
)
{
demux_sys_t
*
p_sys
=
p_demux
->
p_sys
;
if
(
p_sys
->
i_still_end_time
)
{
p_sys
->
i_still_end_time
=
0
;
blurayResetParser
(
p_demux
);
es_out_Control
(
p_demux
->
out
,
ES_OUT_RESET_PCR
);
}
}
static
void
blurayStillImage
(
demux_t
*
p_demux
,
unsigned
i_timeout
)
{
demux_sys_t
*
p_sys
=
p_demux
->
p_sys
;
/* time period elapsed ? */
if
(
p_sys
->
i_still_end_time
>
0
&&
p_sys
->
i_still_end_time
<=
mdate
())
{
msg_Dbg
(
p_demux
,
"Still image end"
);
bd_read_skip_still
(
p_sys
->
bluray
);
blurayResetStillImage
(
p_demux
);
return
;
}
/* show last frame as still image */
if
(
!
p_sys
->
i_still_end_time
)
{
if
(
i_timeout
)
{
msg_Dbg
(
p_demux
,
"Still image (%d seconds)"
,
i_timeout
);
p_sys
->
i_still_end_time
=
mdate
()
+
i_timeout
*
CLOCK_FREQ
;
}
else
{
msg_Dbg
(
p_demux
,
"Still image (infinite)"
);
p_sys
->
i_still_end_time
=
-
1
;
}
}
/* avoid busy loops (read returns no data) */
msleep
(
40000
);
}
static
void
blurayStreamSelect
(
demux_t
*
p_demux
,
uint32_t
i_type
,
uint32_t
i_id
)
static
void
blurayStreamSelect
(
demux_t
*
p_demux
,
uint32_t
i_type
,
uint32_t
i_id
)
{
{
demux_sys_t
*
p_sys
=
p_demux
->
p_sys
;
demux_sys_t
*
p_sys
=
p_demux
->
p_sys
;
...
@@ -1448,6 +1490,8 @@ static void blurayUpdatePlaylist(demux_t *p_demux, unsigned i_playlist)
...
@@ -1448,6 +1490,8 @@ static void blurayUpdatePlaylist(demux_t *p_demux, unsigned i_playlist)
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
);
blurayUpdateTitleInfo
(
p_demux
,
p_demux
->
p_sys
->
pp_title
[
p_demux
->
info
.
i_title
],
-
1
,
i_playlist
);
blurayResetStillImage
(
p_demux
);
}
}
static
void
blurayUpdateCurrentClip
(
demux_t
*
p_demux
,
uint32_t
clip
)
static
void
blurayUpdateCurrentClip
(
demux_t
*
p_demux
,
uint32_t
clip
)
...
@@ -1466,6 +1510,8 @@ static void blurayUpdateCurrentClip(demux_t *p_demux, uint32_t clip)
...
@@ -1466,6 +1510,8 @@ static void blurayUpdateCurrentClip(demux_t *p_demux, uint32_t clip)
assert
(
info
->
clips
[
p_sys
->
i_current_clip
].
video_stream_count
>=
1
);
assert
(
info
->
clips
[
p_sys
->
i_current_clip
].
video_stream_count
>=
1
);
p_sys
->
i_video_stream
=
info
->
clips
[
p_sys
->
i_current_clip
].
video_streams
[
0
].
pid
;
p_sys
->
i_video_stream
=
info
->
clips
[
p_sys
->
i_current_clip
].
video_streams
[
0
].
pid
;
bd_free_title_info
(
info
);
bd_free_title_info
(
info
);
blurayResetStillImage
(
p_demux
);
}
}
static
void
blurayHandleEvent
(
demux_t
*
p_demux
,
const
BD_EVENT
*
e
)
static
void
blurayHandleEvent
(
demux_t
*
p_demux
,
const
BD_EVENT
*
e
)
...
@@ -1514,6 +1560,12 @@ static void blurayHandleEvent(demux_t *p_demux, const BD_EVENT *e)
...
@@ -1514,6 +1560,12 @@ static void blurayHandleEvent(demux_t *p_demux, const BD_EVENT *e)
case
BD_EVENT_IG_STREAM
:
case
BD_EVENT_IG_STREAM
:
break
;
break
;
/*
* playback control events
*/
case
BD_EVENT_STILL_TIME
:
blurayStillImage
(
p_demux
,
e
->
param
);
break
;
case
BD_EVENT_DISCONTINUITY
:
case
BD_EVENT_DISCONTINUITY
:
/* reset demuxer (partially decoded PES packets must be dropped) */
/* reset demuxer (partially decoded PES packets must be dropped) */
blurayResetParser
(
p_demux
);
blurayResetParser
(
p_demux
);
...
...
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