Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
小白菜888
Ffmpeg
提交
33605366
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,发现更多精彩内容 >>
提交
33605366
编写于
3月 08, 2009
作者:
B
Baptiste Coudurier
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
compute media info in write_header
Originally committed as revision 17889 to
svn://svn.ffmpeg.org/ffmpeg/trunk
上级
cd34fd9c
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
19 addition
and
17 deletion
+19
-17
libavformat/gxfenc.c
libavformat/gxfenc.c
+19
-17
未找到文件。
libavformat/gxfenc.c
浏览文件 @
33605366
...
...
@@ -416,26 +416,11 @@ static int gxf_write_umf_track_description(AVFormatContext *s)
ByteIOContext
*
pb
=
s
->
pb
;
GXFContext
*
gxf
=
s
->
priv_data
;
int64_t
pos
=
url_ftell
(
pb
);
int
tracks
[
255
]
=
{
0
};
int
i
;
gxf
->
umf_track_offset
=
pos
-
gxf
->
umf_start_offset
;
for
(
i
=
0
;
i
<
s
->
nb_streams
;
++
i
)
{
AVStream
*
st
=
s
->
streams
[
i
];
GXFStreamContext
*
sc
=
st
->
priv_data
;
int
id
=
0
;
switch
(
st
->
codec
->
codec_id
)
{
case
CODEC_ID_MPEG1VIDEO
:
id
=
'L'
;
break
;
case
CODEC_ID_MPEG2VIDEO
:
id
=
'M'
;
break
;
case
CODEC_ID_PCM_S16LE
:
id
=
'A'
;
break
;
case
CODEC_ID_DVVIDEO
:
id
=
sc
->
track_type
==
6
?
'E'
:
'D'
;
break
;
case
CODEC_ID_MJPEG
:
id
=
'V'
;
break
;
default:
break
;
}
sc
->
media_info
=
id
<<
8
;
/* FIXME first 10 audio tracks are 0 to 9 next 22 are A to V */
sc
->
media_info
|=
'0'
+
(
tracks
[
id
]
++
);
GXFStreamContext
*
sc
=
s
->
streams
[
i
]
->
priv_data
;
put_le16
(
pb
,
sc
->
media_info
);
put_le16
(
pb
,
1
);
}
...
...
@@ -593,7 +578,8 @@ static int gxf_write_header(AVFormatContext *s)
{
ByteIOContext
*
pb
=
s
->
pb
;
GXFContext
*
gxf
=
s
->
priv_data
;
int
i
;
uint8_t
tracks
[
255
]
=
{
0
};
int
i
,
media_info
=
0
;
gxf
->
flags
|=
0x00080000
;
/* material is simple clip */
for
(
i
=
0
;
i
<
s
->
nb_streams
;
++
i
)
{
...
...
@@ -626,6 +612,7 @@ static int gxf_write_header(AVFormatContext *s)
sc
->
fields
=
-
2
;
gxf
->
audio_tracks
++
;
gxf
->
flags
|=
0x04000000
;
/* audio is 16 bit pcm */
media_info
=
'A'
;
}
else
if
(
st
->
codec
->
codec_type
==
CODEC_TYPE_VIDEO
)
{
/* FIXME check from time_base ? */
if
(
st
->
codec
->
height
==
480
||
st
->
codec
->
height
==
512
)
{
/* NTSC or NTSC+VBI */
...
...
@@ -645,20 +632,33 @@ static int gxf_write_header(AVFormatContext *s)
sc
->
sample_size
=
st
->
codec
->
bit_rate
;
sc
->
fields
=
2
;
/* interlaced */
switch
(
st
->
codec
->
codec_id
)
{
case
CODEC_ID_MJPEG
:
sc
->
track_type
=
1
;
gxf
->
flags
|=
0x00004000
;
media_info
=
'J'
;
break
;
case
CODEC_ID_MPEG1VIDEO
:
sc
->
track_type
=
9
;
gxf
->
mpeg_tracks
++
;
media_info
=
'L'
;
break
;
case
CODEC_ID_MPEG2VIDEO
:
sc
->
first_gop_closed
=
-
1
;
sc
->
track_type
=
4
;
gxf
->
mpeg_tracks
++
;
gxf
->
flags
|=
0x00008000
;
media_info
=
'M'
;
break
;
case
CODEC_ID_DVVIDEO
:
if
(
st
->
codec
->
pix_fmt
==
PIX_FMT_YUV422P
)
{
sc
->
media_type
+=
2
;
sc
->
track_type
=
6
;
gxf
->
flags
|=
0x00002000
;
media_info
=
'E'
;
}
else
{
sc
->
track_type
=
5
;
gxf
->
flags
|=
0x00001000
;
media_info
=
'D'
;
}
break
;
default:
...
...
@@ -666,6 +666,8 @@ static int gxf_write_header(AVFormatContext *s)
return
-
1
;
}
}
/* FIXME first 10 audio tracks are 0 to 9 next 22 are A to V */
sc
->
media_info
=
media_info
<<
8
|
(
'0'
+
tracks
[
media_info
]
++
);
}
if
(
ff_audio_interleave_init
(
s
,
GXF_samples_per_frame
,
(
AVRational
){
1
,
48000
})
<
0
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录