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
44a2950f
Commit
44a2950f
authored
Jul 10, 2003
by
Michael Niedermayer
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
flv cleanup / simplify
Originally committed as revision 2026 to
svn://svn.ffmpeg.org/ffmpeg/trunk
parent
bbdd42d3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
31 additions
and
86 deletions
+31
-86
h263.c
libavcodec/h263.c
+28
-86
mpegvideo.c
libavcodec/mpegvideo.c
+2
-0
mpegvideo.h
libavcodec/mpegvideo.h
+1
-0
No files found.
libavcodec/h263.c
View file @
44a2950f
...
@@ -152,13 +152,12 @@ static void float_aspect_to_info(MpegEncContext * s, float aspect){
...
@@ -152,13 +152,12 @@ static void float_aspect_to_info(MpegEncContext * s, float aspect){
s
->
aspect_ratio_info
=
FF_ASPECT_EXTENDED
;
s
->
aspect_ratio_info
=
FF_ASPECT_EXTENDED
;
}
}
void
h263
_encode_picture_header
(
MpegEncContext
*
s
,
int
picture_number
)
void
ff_flv
_encode_picture_header
(
MpegEncContext
*
s
,
int
picture_number
)
{
{
int
format
;
int
format
;
align_put_bits
(
&
s
->
pb
);
align_put_bits
(
&
s
->
pb
);
if
(
s
->
h263_flv
)
{
put_bits
(
&
s
->
pb
,
17
,
1
);
put_bits
(
&
s
->
pb
,
17
,
1
);
put_bits
(
&
s
->
pb
,
5
,
(
s
->
h263_flv
-
1
));
/* 0: h263 escape codes 1: 11-bit escape codes */
put_bits
(
&
s
->
pb
,
5
,
(
s
->
h263_flv
-
1
));
/* 0: h263 escape codes 1: 11-bit escape codes */
put_bits
(
&
s
->
pb
,
8
,
(((
int64_t
)
s
->
picture_number
*
30
*
s
->
avctx
->
frame_rate_base
)
/
put_bits
(
&
s
->
pb
,
8
,
(((
int64_t
)
s
->
picture_number
*
30
*
s
->
avctx
->
frame_rate_base
)
/
...
@@ -197,8 +196,13 @@ void h263_encode_picture_header(MpegEncContext * s, int picture_number)
...
@@ -197,8 +196,13 @@ void h263_encode_picture_header(MpegEncContext * s, int picture_number)
s
->
y_dc_scale_table
=
s
->
y_dc_scale_table
=
s
->
c_dc_scale_table
=
ff_mpeg1_dc_scale_table
;
s
->
c_dc_scale_table
=
ff_mpeg1_dc_scale_table
;
}
}
return
;
}
}
void
h263_encode_picture_header
(
MpegEncContext
*
s
,
int
picture_number
)
{
int
format
;
align_put_bits
(
&
s
->
pb
);
/* Update the pointer to last GOB */
/* Update the pointer to last GOB */
s
->
ptr_lastgob
=
pbBufPtr
(
&
s
->
pb
);
s
->
ptr_lastgob
=
pbBufPtr
(
&
s
->
pb
);
...
@@ -1011,10 +1015,7 @@ void h263_encode_mb(MpegEncContext * s,
...
@@ -1011,10 +1015,7 @@ void h263_encode_mb(MpegEncContext * s,
for
(
i
=
0
;
i
<
6
;
i
++
)
{
for
(
i
=
0
;
i
<
6
;
i
++
)
{
/* encode each block */
/* encode each block */
if
(
s
->
h263_flv
>
1
)
h263_encode_block
(
s
,
block
[
i
],
i
);
h263_flv_encode_block
(
s
,
block
[
i
],
i
);
else
h263_encode_block
(
s
,
block
[
i
],
i
);
/* Update INTRADC for decoding */
/* Update INTRADC for decoding */
if
(
s
->
h263_aic
&&
s
->
mb_intra
)
{
if
(
s
->
h263_aic
&&
s
->
mb_intra
)
{
...
@@ -1613,6 +1614,7 @@ static void h263_encode_block(MpegEncContext * s, DCTELEM * block, int n)
...
@@ -1613,6 +1614,7 @@ static void h263_encode_block(MpegEncContext * s, DCTELEM * block, int n)
code
=
get_rl_index
(
rl
,
last
,
run
,
level
);
code
=
get_rl_index
(
rl
,
last
,
run
,
level
);
put_bits
(
&
s
->
pb
,
rl
->
table_vlc
[
code
][
1
],
rl
->
table_vlc
[
code
][
0
]);
put_bits
(
&
s
->
pb
,
rl
->
table_vlc
[
code
][
1
],
rl
->
table_vlc
[
code
][
0
]);
if
(
code
==
rl
->
n
)
{
if
(
code
==
rl
->
n
)
{
if
(
s
->
h263_flv
<=
1
){
put_bits
(
&
s
->
pb
,
1
,
last
);
put_bits
(
&
s
->
pb
,
1
,
last
);
put_bits
(
&
s
->
pb
,
6
,
run
);
put_bits
(
&
s
->
pb
,
6
,
run
);
...
@@ -1625,83 +1627,23 @@ static void h263_encode_block(MpegEncContext * s, DCTELEM * block, int n)
...
@@ -1625,83 +1627,23 @@ static void h263_encode_block(MpegEncContext * s, DCTELEM * block, int n)
put_bits
(
&
s
->
pb
,
5
,
slevel
&
0x1f
);
put_bits
(
&
s
->
pb
,
5
,
slevel
&
0x1f
);
put_bits
(
&
s
->
pb
,
6
,
(
slevel
>>
5
)
&
0x3f
);
put_bits
(
&
s
->
pb
,
6
,
(
slevel
>>
5
)
&
0x3f
);
}
}
}
else
{
}
else
{
put_bits
(
&
s
->
pb
,
1
,
sign
);
if
(
slevel
<
64
&&
slevel
>
-
64
)
{
}
/* 7-bit level */
last_non_zero
=
i
;
put_bits
(
&
s
->
pb
,
1
,
0
);
}
put_bits
(
&
s
->
pb
,
1
,
last
);
}
put_bits
(
&
s
->
pb
,
6
,
run
);
}
put_bits
(
&
s
->
pb
,
7
,
slevel
&
0x7f
);
/**
}
else
{
* encodes a 8x8 block.
/* 11-bit level */
* @param block the 8x8 block
put_bits
(
&
s
->
pb
,
1
,
1
);
* @param n block index (0-3 are luma, 4-5 are chroma)
put_bits
(
&
s
->
pb
,
1
,
last
);
*/
put_bits
(
&
s
->
pb
,
6
,
run
);
static
void
h263_flv_encode_block
(
MpegEncContext
*
s
,
DCTELEM
*
block
,
int
n
)
{
int
level
,
run
,
last
,
i
,
j
,
last_index
,
last_non_zero
,
sign
,
slevel
,
code
;
RLTable
*
rl
;
rl
=
&
rl_inter
;
if
(
s
->
mb_intra
&&
!
s
->
h263_aic
)
{
/* DC coef */
level
=
block
[
0
];
/* 255 cannot be represented, so we clamp */
if
(
level
>
254
)
{
level
=
254
;
block
[
0
]
=
254
;
}
/* 0 cannot be represented also */
else
if
(
level
<
1
)
{
level
=
1
;
block
[
0
]
=
1
;
}
if
(
level
==
128
)
//FIXME check rv10
put_bits
(
&
s
->
pb
,
8
,
0xff
);
else
put_bits
(
&
s
->
pb
,
8
,
level
&
0xff
);
i
=
1
;
}
else
{
i
=
0
;
if
(
s
->
h263_aic
&&
s
->
mb_intra
)
rl
=
&
rl_intra_aic
;
}
/* AC coefs */
last_index
=
s
->
block_last_index
[
n
];
last_non_zero
=
i
-
1
;
for
(;
i
<=
last_index
;
i
++
)
{
j
=
s
->
intra_scantable
.
permutated
[
i
];
level
=
block
[
j
];
if
(
level
)
{
run
=
i
-
last_non_zero
-
1
;
last
=
(
i
==
last_index
);
sign
=
0
;
slevel
=
level
;
if
(
level
<
0
)
{
sign
=
1
;
level
=
-
level
;
}
code
=
get_rl_index
(
rl
,
last
,
run
,
level
);
put_bits
(
&
s
->
pb
,
rl
->
table_vlc
[
code
][
1
],
rl
->
table_vlc
[
code
][
0
]);
if
(
code
==
rl
->
n
)
{
assert
(
slevel
!=
0
);
if
(
slevel
<
64
&&
slevel
>
-
64
)
{
/* 7-bit level */
put_bits
(
&
s
->
pb
,
1
,
0
);
put_bits
(
&
s
->
pb
,
1
,
last
);
put_bits
(
&
s
->
pb
,
6
,
run
);
put_bits
(
&
s
->
pb
,
7
,
slevel
&
0x7f
);
}
else
{
/* 11-bit level */
put_bits
(
&
s
->
pb
,
1
,
1
);
put_bits
(
&
s
->
pb
,
1
,
last
);
put_bits
(
&
s
->
pb
,
6
,
run
);
put_bits
(
&
s
->
pb
,
11
,
slevel
&
0x7ff
);
put_bits
(
&
s
->
pb
,
11
,
slevel
&
0x7ff
);
}
}
}
}
else
{
}
else
{
put_bits
(
&
s
->
pb
,
1
,
sign
);
put_bits
(
&
s
->
pb
,
1
,
sign
);
}
}
...
...
libavcodec/mpegvideo.c
View file @
44a2950f
...
@@ -3401,6 +3401,8 @@ static void encode_picture(MpegEncContext *s, int picture_number)
...
@@ -3401,6 +3401,8 @@ static void encode_picture(MpegEncContext *s, int picture_number)
mpeg4_encode_picture_header
(
s
,
picture_number
);
mpeg4_encode_picture_header
(
s
,
picture_number
);
else
if
(
s
->
h263_rv10
)
else
if
(
s
->
h263_rv10
)
rv10_encode_picture_header
(
s
,
picture_number
);
rv10_encode_picture_header
(
s
,
picture_number
);
else
if
(
s
->
codec_id
==
CODEC_ID_FLV1
)
ff_flv_encode_picture_header
(
s
,
picture_number
);
else
else
h263_encode_picture_header
(
s
,
picture_number
);
h263_encode_picture_header
(
s
,
picture_number
);
break
;
break
;
...
...
libavcodec/mpegvideo.h
View file @
44a2950f
...
@@ -819,6 +819,7 @@ void mpeg4_encode_mb(MpegEncContext *s,
...
@@ -819,6 +819,7 @@ void mpeg4_encode_mb(MpegEncContext *s,
DCTELEM
block
[
6
][
64
],
DCTELEM
block
[
6
][
64
],
int
motion_x
,
int
motion_y
);
int
motion_x
,
int
motion_y
);
void
h263_encode_picture_header
(
MpegEncContext
*
s
,
int
picture_number
);
void
h263_encode_picture_header
(
MpegEncContext
*
s
,
int
picture_number
);
void
ff_flv_encode_picture_header
(
MpegEncContext
*
s
,
int
picture_number
);
int
h263_encode_gob_header
(
MpegEncContext
*
s
,
int
mb_line
);
int
h263_encode_gob_header
(
MpegEncContext
*
s
,
int
mb_line
);
int16_t
*
h263_pred_motion
(
MpegEncContext
*
s
,
int
block
,
int16_t
*
h263_pred_motion
(
MpegEncContext
*
s
,
int
block
,
int
*
px
,
int
*
py
);
int
*
px
,
int
*
py
);
...
...
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