Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
小白菜888
Ffmpeg
提交
44a2950f
F
Ffmpeg
项目概览
小白菜888
/
Ffmpeg
通知
3
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
F
Ffmpeg
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
44a2950f
编写于
7月 10, 2003
作者:
M
Michael Niedermayer
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
flv cleanup / simplify
Originally committed as revision 2026 to
svn://svn.ffmpeg.org/ffmpeg/trunk
上级
bbdd42d3
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
31 addition
and
86 deletion
+31
-86
libavcodec/h263.c
libavcodec/h263.c
+28
-86
libavcodec/mpegvideo.c
libavcodec/mpegvideo.c
+2
-0
libavcodec/mpegvideo.h
libavcodec/mpegvideo.h
+1
-0
未找到文件。
libavcodec/h263.c
浏览文件 @
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
浏览文件 @
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
浏览文件 @
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
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录