Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
小白菜888
Ffmpeg
提交
db7ae7d1
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,发现更多精彩内容 >>
提交
db7ae7d1
编写于
2月 15, 2008
作者:
V
Vitor Sessak
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Simplify avcodec_default_get_buffer()
Originally committed as revision 11962 to
svn://svn.ffmpeg.org/ffmpeg/trunk
上级
4fe109eb
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
19 addition
and
17 deletion
+19
-17
libavcodec/utils.c
libavcodec/utils.c
+19
-17
未找到文件。
libavcodec/utils.c
浏览文件 @
db7ae7d1
...
...
@@ -31,6 +31,7 @@
#include "integer.h"
#include "opt.h"
#include "crc.h"
#include "imgconvert.h"
#include <stdarg.h>
#include <limits.h>
#include <float.h>
...
...
@@ -271,7 +272,8 @@ int avcodec_default_get_buffer(AVCodecContext *s, AVFrame *pic){
buf
->
last_pic_num
=
*
picture_number
;
}
else
{
int
h_chroma_shift
,
v_chroma_shift
;
int
pixel_size
,
size
[
4
];
int
size
[
4
]
=
{
0
};
int
tmpsize
;
AVPicture
picture
;
avcodec_get_chroma_sub_sample
(
s
->
pix_fmt
,
&
h_chroma_shift
,
&
v_chroma_shift
);
...
...
@@ -284,23 +286,23 @@ int avcodec_default_get_buffer(AVCodecContext *s, AVFrame *pic){
}
avcodec_align_dimensions
(
s
,
&
w
,
&
h
);
avpicture_fill
(
&
picture
,
NULL
,
s
->
pix_fmt
,
w
,
h
);
pixel_size
=
picture
.
linesize
[
0
]
*
8
/
w
;
//av_log(NULL, AV_LOG_ERROR, "%d %d %d %d\n", (int)picture.data[1], w, h, s->pix_fmt);
assert
(
pixel_size
>=
1
);
//FIXME next ensures that linesize= 2^x uvlinesize, that is needed because some MC code assumes it
if
(
pixel_size
==
3
*
8
)
w
=
ALIGN
(
w
,
STRIDE_ALIGN
<<
h_chroma_shift
);
ff_fill_linesize
(
&
picture
,
s
->
pix_fmt
,
w
);
for
(
i
=
1
;
i
<
4
;
i
++
)
picture
.
linesize
[
i
]
=
ALIGN
(
picture
.
linesize
[
i
],
STRIDE_ALIGN
);
/* next ensures that linesize= 2^x uvlinesize, that is needed because
* some MC code assumes it */
if
(
picture
.
linesize
[
1
])
picture
.
linesize
[
0
]
=
ALIGN
(
picture
.
linesize
[
0
],
picture
.
linesize
[
1
]);
else
w
=
ALIGN
(
pixel_size
*
w
,
STRIDE_ALIGN
<<
(
h_chroma_shift
+
3
))
/
pixel_size
;
size
[
1
]
=
avpicture_fill
(
&
picture
,
NULL
,
s
->
pix_fmt
,
w
,
h
);
size
[
0
]
=
picture
.
linesize
[
0
]
*
h
;
size
[
1
]
-=
size
[
0
];
size
[
2
]
=
size
[
3
]
=
0
;
if
(
picture
.
data
[
2
])
size
[
1
]
=
size
[
2
]
=
size
[
1
]
/
2
;
if
(
picture
.
data
[
3
])
size
[
3
]
=
picture
.
linesize
[
3
]
*
h
;
picture
.
linesize
[
0
]
=
ALIGN
(
picture
.
linesize
[
0
],
STRIDE_ALIGN
);
tmpsize
=
ff_fill_pointer
(
&
picture
,
NULL
,
s
->
pix_fmt
,
h
);
for
(
i
=
0
;
i
<
3
&&
picture
.
data
[
i
+
1
];
i
++
)
size
[
i
]
=
picture
.
data
[
i
+
1
]
-
picture
.
data
[
i
];
size
[
i
]
=
tmpsize
-
size
[
i
];
buf
->
last_pic_num
=
-
256
*
256
*
256
*
64
;
memset
(
buf
->
base
,
0
,
sizeof
(
buf
->
base
));
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录