Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-2-2
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-2-2
Commits
48fd6e79
Commit
48fd6e79
authored
Nov 19, 2008
by
Jean-Paul Saman
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
(live555) RTSP fastforward works from Qt4 interface.
parent
b6a59e00
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
40 additions
and
24 deletions
+40
-24
modules/demux/live555.cpp
modules/demux/live555.cpp
+40
-24
No files found.
modules/demux/live555.cpp
View file @
48fd6e79
...
@@ -40,7 +40,7 @@
...
@@ -40,7 +40,7 @@
#include <vlc_common.h>
#include <vlc_common.h>
#include <vlc_plugin.h>
#include <vlc_plugin.h>
#include <vlc_input.h>
#include <vlc_demux.h>
#include <vlc_demux.h>
#include <vlc_interface.h>
#include <vlc_interface.h>
#include <vlc_network.h>
#include <vlc_network.h>
...
@@ -1231,14 +1231,14 @@ static int Control( demux_t *p_demux, int i_query, va_list args )
...
@@ -1231,14 +1231,14 @@ static int Control( demux_t *p_demux, int i_query, va_list args )
pi64
=
(
int64_t
*
)
va_arg
(
args
,
int64_t
*
);
pi64
=
(
int64_t
*
)
va_arg
(
args
,
int64_t
*
);
if
(
p_sys
->
i_npt_length
>
0
)
if
(
p_sys
->
i_npt_length
>
0
)
{
{
*
pi64
=
p_sys
->
i_npt_length
*
1000000.0
;
*
pi64
=
(
int64_t
)((
double
)
p_sys
->
i_npt_length
*
1000000.0
)
;
return
VLC_SUCCESS
;
return
VLC_SUCCESS
;
}
}
return
VLC_EGENERIC
;
return
VLC_EGENERIC
;
case
DEMUX_GET_POSITION
:
case
DEMUX_GET_POSITION
:
pf
=
(
double
*
)
va_arg
(
args
,
double
*
);
pf
=
(
double
*
)
va_arg
(
args
,
double
*
);
if
(
p_sys
->
i_npt_length
>
0
&&
p_sys
->
i_npt
>
0
)
if
(
(
p_sys
->
i_npt_length
>
0
)
&&
(
p_sys
->
i_npt
>
0
)
)
{
{
*
pf
=
(
(
double
)
p_sys
->
i_npt
/
(
double
)
p_sys
->
i_npt_length
);
*
pf
=
(
(
double
)
p_sys
->
i_npt
/
(
double
)
p_sys
->
i_npt_length
);
return
VLC_SUCCESS
;
return
VLC_SUCCESS
;
...
@@ -1247,12 +1247,12 @@ static int Control( demux_t *p_demux, int i_query, va_list args )
...
@@ -1247,12 +1247,12 @@ static int Control( demux_t *p_demux, int i_query, va_list args )
case
DEMUX_SET_POSITION
:
case
DEMUX_SET_POSITION
:
case
DEMUX_SET_TIME
:
case
DEMUX_SET_TIME
:
if
(
p_sys
->
rtsp
&&
p_sys
->
i_npt_length
>
0
)
if
(
p_sys
->
rtsp
&&
(
p_sys
->
i_npt_length
>
0
)
)
{
{
int
i
;
int
i
;
float
time
;
float
time
;
if
(
i_query
==
DEMUX_SET_TIME
&&
p_sys
->
i_npt
>
0
)
if
(
(
i_query
==
DEMUX_SET_TIME
)
&&
(
p_sys
->
i_npt
>
0
)
)
{
{
i64
=
(
int64_t
)
va_arg
(
args
,
int64_t
);
i64
=
(
int64_t
)
va_arg
(
args
,
int64_t
);
time
=
(
float
)((
double
)
i64
/
(
double
)
1000000.0
);
/* in second */
time
=
(
float
)((
double
)
i64
/
(
double
)
1000000.0
);
/* in second */
...
@@ -1313,35 +1313,41 @@ static int Control( demux_t *p_demux, int i_query, va_list args )
...
@@ -1313,35 +1313,41 @@ static int Control( demux_t *p_demux, int i_query, va_list args )
#endif
#endif
return
VLC_SUCCESS
;
return
VLC_SUCCESS
;
#if 0
case
DEMUX_CAN_CONTROL_RATE
:
case
DEMUX_CAN_CONTROL_RATE
:
pb
=
(
bool
*
)
va_arg
(
args
,
bool
*
);
pb
=
(
bool
*
)
va_arg
(
args
,
bool
*
);
pb2
=
(
bool
*
)
va_arg
(
args
,
bool
*
);
pb2
=
(
bool
*
)
va_arg
(
args
,
bool
*
);
*pb = p_sys->rtsp != NULL && p_sys->i_npt_length > 0 && !var_GetBool( p_demux, "rtsp-kasenna" );
*
pb
=
(
p_sys
->
rtsp
!=
NULL
)
&&
(
p_sys
->
i_npt_length
>
0
)
&&
!
var_GetBool
(
p_demux
,
"rtsp-kasenna"
);
*
pb2
=
false
;
*
pb2
=
false
;
return
VLC_SUCCESS
;
return
VLC_SUCCESS
;
case
DEMUX_SET_RATE
:
case
DEMUX_SET_RATE
:
{
{
double f_scale;
double
f_scale
,
f_old_scale
;
int
i
;
if( !p_sys->rtsp || p_sys->i_npt_length <= 0 || var_GetBool( p_demux, "rtsp-kasenna" ) )
if
(
!
p_sys
->
rtsp
||
(
p_sys
->
i_npt_length
<=
0
)
||
var_GetBool
(
p_demux
,
"rtsp-kasenna"
)
)
return
VLC_EGENERIC
;
return
VLC_EGENERIC
;
/* TODO we might want to ensure that the new rate is different from
/* According to RFC 2326 p56 chapter 12.35 a RTSP server that
* old rate after playMediaSession...
* supports Scale should:
* I have no idea how the server map the requested rate to the
*
* ones it supports.
* "The server should try to approximate the viewing rate, but may
* ex:
* restrict the range of scale values that it supports. The response
* current is x2 we request x1.5 if the server return x2 we will
* MUST contain the actual scale value chosen by the server."
* never succeed to return to x1.
*
* In this case we should retry with a lower rate until we have
* Scale = 1 indicates normal play
* one (even x1).
* Scale > 1 indicates fast forward
* Scale < 1 && Scale > 0 indicates slow motion
* Scale < 0 value indicates rewind
*/
*/
pi_int
=
(
int
*
)
va_arg
(
args
,
int
*
);
pi_int
=
(
int
*
)
va_arg
(
args
,
int
*
);
f_scale = (double)INPUT_RATE_DEFAULT / (*p_int);
f_scale
=
(
double
)
INPUT_RATE_DEFAULT
/
(
*
pi_int
);
f_old_scale
=
p_sys
->
ms
->
scale
();
/* Passing -1 for the start and end time will mean liveMedia won't
/* Passing -1 for the start and end time will mean liveMedia won't
* create a Range: section for the RTSP message. The server should
* create a Range: section for the RTSP message. The server should
...
@@ -1352,15 +1358,25 @@ static int Control( demux_t *p_demux, int i_query, va_list args )
...
@@ -1352,15 +1358,25 @@ static int Control( demux_t *p_demux, int i_query, va_list args )
p_sys
->
env
->
getResultMsg
()
);
p_sys
->
env
->
getResultMsg
()
);
return
VLC_EGENERIC
;
return
VLC_EGENERIC
;
}
}
if
(
p_sys
->
ms
->
scale
()
==
f_old_scale
)
{
msg_Err
(
p_demux
,
"no scale change using old Scale %0.2f"
,
p_sys
->
ms
->
scale
()
);
return
VLC_EGENERIC
;
}
/* ReSync the stream */
/* ReSync the stream */
p_sys
->
i_npt_start
=
0
;
p_sys
->
i_npt_start
=
0
;
p_sys
->
i_pcr
=
0
;
p_sys
->
i_pcr
=
0
;
p_sys->i_npt = 0.;
p_sys
->
i_npt
=
0.
0
;
*pi_int = (int)( INPUT_RATE_DEFAULT / p_sys->ms->scale() + 0.5 );
es_out_Control
(
p_demux
->
out
,
ES_OUT_RESET_PCR
);
*
pi_int
=
(
int
)(
INPUT_RATE_DEFAULT
/
p_sys
->
ms
->
scale
()
);
msg_Dbg
(
p_demux
,
"PLAY with new Scale %0.2f (%d)"
,
p_sys
->
ms
->
scale
(),
(
*
pi_int
)
);
return
VLC_SUCCESS
;
return
VLC_SUCCESS
;
}
}
#endif
case
DEMUX_SET_PAUSE_STATE
:
case
DEMUX_SET_PAUSE_STATE
:
{
{
...
...
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