Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in / Register
Toggle navigation
F
ffmpeg.wasm-core
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Linshizhi
ffmpeg.wasm-core
Commits
f8678dce
Commit
f8678dce
authored
Sep 08, 2013
by
Clément Bœsch
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
avformat/vobsub: fix seeking.
parent
53fb52ac
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
30 additions
and
2 deletions
+30
-2
mpeg.c
libavformat/mpeg.c
+16
-0
subtitles.c
libavformat/subtitles.c
+14
-2
No files found.
libavformat/mpeg.c
View file @
f8678dce
...
...
@@ -701,6 +701,7 @@ static int vobsub_read_header(AVFormatContext *s)
st
->
id
=
stream_id
;
st
->
codec
->
codec_type
=
AVMEDIA_TYPE_SUBTITLE
;
st
->
codec
->
codec_id
=
AV_CODEC_ID_DVD_SUBTITLE
;
avpriv_set_pts_info
(
st
,
64
,
1
,
1000
);
av_dict_set
(
&
st
->
metadata
,
"language"
,
id
,
0
);
av_log
(
s
,
AV_LOG_DEBUG
,
"IDX stream[%d] id=%s
\n
"
,
stream_id
,
id
);
header_parsed
=
1
;
...
...
@@ -865,6 +866,21 @@ static int vobsub_read_seek(AVFormatContext *s, int stream_index,
int64_t
min_ts
,
int64_t
ts
,
int64_t
max_ts
,
int
flags
)
{
MpegDemuxContext
*
vobsub
=
s
->
priv_data
;
/* Rescale requested timestamps based on the first stream (timebase is the
* same for all subtitles stream within a .idx/.sub). Rescaling is done just
* like in avformat_seek_file(). */
if
(
stream_index
==
-
1
&&
s
->
nb_streams
!=
1
)
{
AVRational
time_base
=
s
->
streams
[
0
]
->
time_base
;
ts
=
av_rescale_q
(
ts
,
AV_TIME_BASE_Q
,
time_base
);
min_ts
=
av_rescale_rnd
(
min_ts
,
time_base
.
den
,
time_base
.
num
*
(
int64_t
)
AV_TIME_BASE
,
AV_ROUND_UP
|
AV_ROUND_PASS_MINMAX
);
max_ts
=
av_rescale_rnd
(
max_ts
,
time_base
.
den
,
time_base
.
num
*
(
int64_t
)
AV_TIME_BASE
,
AV_ROUND_DOWN
|
AV_ROUND_PASS_MINMAX
);
}
return
ff_subtitles_queue_seek
(
&
vobsub
->
q
,
s
,
stream_index
,
min_ts
,
ts
,
max_ts
,
flags
);
}
...
...
libavformat/subtitles.c
View file @
f8678dce
...
...
@@ -111,7 +111,8 @@ int ff_subtitles_queue_seek(FFDemuxSubtitlesQueue *q, AVFormatContext *s, int st
for
(
i
=
0
;
i
<
q
->
nb_subs
;
i
++
)
{
int64_t
pts
=
q
->
subs
[
i
].
pts
;
uint64_t
ts_diff
=
FFABS
(
pts
-
ts
);
if
(
pts
>=
min_ts
&&
pts
<=
max_ts
&&
ts_diff
<
min_ts_diff
)
{
if
((
stream_index
==
-
1
||
q
->
subs
[
i
].
stream_index
==
stream_index
)
&&
pts
>=
min_ts
&&
pts
<=
max_ts
&&
ts_diff
<
min_ts_diff
)
{
min_ts_diff
=
ts_diff
;
idx
=
i
;
}
...
...
@@ -121,13 +122,24 @@ int ff_subtitles_queue_seek(FFDemuxSubtitlesQueue *q, AVFormatContext *s, int st
/* look back in the latest subtitles for overlapping subtitles */
ts_selected
=
q
->
subs
[
idx
].
pts
;
for
(
i
=
idx
-
1
;
i
>=
0
;
i
--
)
{
if
(
q
->
subs
[
i
].
duration
<=
0
)
if
(
q
->
subs
[
i
].
duration
<=
0
||
(
stream_index
!=
-
1
&&
q
->
subs
[
i
].
stream_index
!=
stream_index
))
continue
;
if
(
q
->
subs
[
i
].
pts
>
ts_selected
-
q
->
subs
[
i
].
duration
)
idx
=
i
;
else
break
;
}
/* If the queue is used to store multiple subtitles streams (like with
* VobSub) and the stream index is not specified, we need to make sure
* to focus on the smallest file position offset for a same timestamp;
* queue is ordered by pts and then filepos, so we can take the first
* entry for a given timestamp. */
if
(
stream_index
==
-
1
)
while
(
idx
>
0
&&
q
->
subs
[
idx
-
1
].
pts
==
q
->
subs
[
idx
].
pts
)
idx
--
;
q
->
current_sub_idx
=
idx
;
}
return
0
;
...
...
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