Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
Z
ZLMediaKit
概览
Overview
Details
Activity
Cycle Analytics
版本库
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
问题
0
Issues
0
列表
Board
标记
里程碑
合并请求
0
Merge Requests
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
Snippets
成员
Collapse sidebar
Close sidebar
活动
图像
聊天
创建新问题
作业
提交
Issue Boards
Open sidebar
张翔宇
ZLMediaKit
Commits
e36194ae
Commit
e36194ae
authored
Jul 03, 2019
by
xiongziliang
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
完善对pts的支持
parent
f6ff2172
隐藏空白字符变更
内嵌
并排
正在显示
8 个修改的文件
包含
56 行增加
和
46 行删除
+56
-46
src/Common/Device.cpp
+7
-7
src/Common/Device.h
+3
-2
src/Extension/AAC.h
+5
-5
src/Extension/Frame.h
+20
-9
src/Extension/H264.h
+10
-13
src/Extension/H265.h
+7
-6
src/MediaFile/MediaReader.cpp
+3
-3
src/MediaFile/MediaReader.h
+1
-1
没有找到文件。
src/Common/Device.cpp
查看文件 @
e36194ae
...
...
@@ -86,13 +86,14 @@ void DevChannel::inputPCM(char* pcData, int iDataLen, uint32_t uiStamp) {
}
#endif //ENABLE_FAAC
void
DevChannel
::
inputH264
(
const
char
*
pcData
,
int
iDataLen
,
uint32_t
uiStamp
)
{
if
(
uiStamp
==
0
){
uiStamp
=
(
uint32_t
)
_aTicker
[
0
].
elapsedTime
();
void
DevChannel
::
inputH264
(
const
char
*
pcData
,
int
iDataLen
,
uint32_t
dts
,
uint32_t
pts
)
{
if
(
dts
==
0
){
dts
=
(
uint32_t
)
_aTicker
[
0
].
elapsedTime
();
}
if
(
pts
==
0
){
pts
=
dts
;
}
int
prefixeSize
;
if
(
memcmp
(
"
\x00\x00\x00\x01
"
,
pcData
,
4
)
==
0
)
{
prefixeSize
=
4
;
}
else
if
(
memcmp
(
"
\x00\x00\x01
"
,
pcData
,
3
)
==
0
)
{
...
...
@@ -100,8 +101,7 @@ void DevChannel::inputH264(const char* pcData, int iDataLen, uint32_t uiStamp) {
}
else
{
prefixeSize
=
0
;
}
inputFrame
(
std
::
make_shared
<
H264FrameNoCopyAble
>
((
char
*
)
pcData
,
iDataLen
,
uiStamp
,
prefixeSize
));
inputFrame
(
std
::
make_shared
<
H264FrameNoCopyAble
>
((
char
*
)
pcData
,
iDataLen
,
dts
,
pts
,
prefixeSize
));
}
void
DevChannel
::
inputAAC
(
const
char
*
pcData
,
int
iDataLen
,
uint32_t
uiStamp
,
bool
withAdtsHeader
)
{
...
...
src/Common/Device.h
查看文件 @
e36194ae
...
...
@@ -97,9 +97,10 @@ public:
* 输入264帧
* @param pcData 264单帧数据指针
* @param iDataLen 数据指针长度
* @param uiStamp 时间戳,单位毫秒;等于0时内部会自动生成时间戳
* @param dts 解码时间戳,单位毫秒;等于0时内部会自动生成时间戳
* @param pts 播放时间戳,单位毫秒;等于0时内部会赋值为dts
*/
void
inputH264
(
const
char
*
pcData
,
int
iDataLen
,
uint32_t
uiStamp
);
void
inputH264
(
const
char
*
pcData
,
int
iDataLen
,
uint32_t
dts
,
uint32_t
pts
=
0
);
/**
* 输入可能带adts头的aac帧
...
...
src/Extension/AAC.h
查看文件 @
e36194ae
...
...
@@ -109,11 +109,11 @@ class AACFrameNoCopyAble : public FrameNoCopyAble {
public
:
typedef
std
::
shared_ptr
<
AACFrameNoCopyAble
>
Ptr
;
AACFrameNoCopyAble
(
char
*
ptr
,
uint32_t
size
,
uint32_t
stamp
,
int
prefixeSize
=
7
){
buffer
_ptr
=
ptr
;
buffer
_size
=
size
;
timeStamp
=
stamp
;
iP
refixSize
=
prefixeSize
;
AACFrameNoCopyAble
(
char
*
ptr
,
uint32_t
size
,
uint32_t
dts
,
int
prefixeSize
=
7
){
_ptr
=
ptr
;
_size
=
size
;
_dts
=
dts
;
_p
refixSize
=
prefixeSize
;
}
TrackType
getTrackType
()
const
override
{
...
...
src/Extension/Frame.h
查看文件 @
e36194ae
...
...
@@ -285,22 +285,33 @@ class FrameNoCopyAble : public Frame{
public
:
typedef
std
::
shared_ptr
<
FrameNoCopyAble
>
Ptr
;
char
*
data
()
const
override
{
return
buffer
_ptr
;
return
_ptr
;
}
uint32_t
size
()
const
override
{
return
buffer
_size
;
return
_size
;
}
uint32_t
dts
()
const
override
{
return
timeStamp
;
return
_dts
;
}
uint32_t
pts
()
const
override
{
if
(
_pts
){
return
_pts
;
}
return
dts
();
}
uint32_t
prefixSize
()
const
override
{
return
iP
refixSize
;
return
_p
refixSize
;
}
public
:
char
*
buffer_ptr
;
uint32_t
buffer_size
;
uint32_t
timeStamp
;
uint32_t
iPrefixSize
;
protected
:
char
*
_ptr
;
uint32_t
_size
;
uint32_t
_dts
;
uint32_t
_pts
=
0
;
uint32_t
_prefixSize
;
};
...
...
src/Extension/H264.h
查看文件 @
e36194ae
...
...
@@ -96,11 +96,12 @@ class H264FrameNoCopyAble : public FrameNoCopyAble {
public
:
typedef
std
::
shared_ptr
<
H264FrameNoCopyAble
>
Ptr
;
H264FrameNoCopyAble
(
char
*
ptr
,
uint32_t
size
,
uint32_t
stamp
,
int
prefixeSize
=
4
){
buffer_ptr
=
ptr
;
buffer_size
=
size
;
timeStamp
=
stamp
;
iPrefixSize
=
prefixeSize
;
H264FrameNoCopyAble
(
char
*
ptr
,
uint32_t
size
,
uint32_t
dts
,
uint32_t
pts
,
int
prefixeSize
=
4
){
_ptr
=
ptr
;
_size
=
size
;
_dts
=
dts
;
_pts
=
pts
;
_prefixSize
=
prefixeSize
;
}
TrackType
getTrackType
()
const
override
{
...
...
@@ -112,19 +113,17 @@ public:
}
bool
keyFrame
()
const
override
{
return
H264_TYPE
(
buffer_ptr
[
iP
refixSize
])
==
H264Frame
::
NAL_IDR
;
return
H264_TYPE
(
_ptr
[
_p
refixSize
])
==
H264Frame
::
NAL_IDR
;
}
};
class
H264FrameSubFrame
:
public
H264FrameNoCopyAble
{
public
:
typedef
std
::
shared_ptr
<
H264FrameSubFrame
>
Ptr
;
H264FrameSubFrame
(
const
Frame
::
Ptr
&
strongRef
,
char
*
ptr
,
uint32_t
size
,
uint32_t
stamp
,
int
prefixeSize
)
:
H264FrameNoCopyAble
(
ptr
,
size
,
stamp
,
prefixeSize
){
char
*
ptr
,
uint32_t
size
,
int
prefixeSize
)
:
H264FrameNoCopyAble
(
ptr
,
size
,
strongRef
->
dts
(),
strongRef
->
pts
(),
prefixeSize
){
_strongRef
=
strongRef
;
}
private
:
...
...
@@ -234,7 +233,6 @@ public:
H264FrameSubFrame
::
Ptr
sub_frame
=
std
::
make_shared
<
H264FrameSubFrame
>
(
frame
,
frame
->
data
(),
len
+
frame
->
prefixSize
(),
frame
->
stamp
(),
frame
->
prefixSize
());
inputFrame_l
(
sub_frame
);
first_frame
=
false
;
...
...
@@ -242,7 +240,6 @@ public:
H264FrameSubFrame
::
Ptr
sub_frame
=
std
::
make_shared
<
H264FrameSubFrame
>
(
frame
,
(
char
*
)
ptr
,
len
,
frame
->
stamp
(),
3
);
inputFrame_l
(
sub_frame
);
}
...
...
src/Extension/H265.h
查看文件 @
e36194ae
...
...
@@ -125,11 +125,12 @@ class H265FrameNoCopyAble : public FrameNoCopyAble {
public
:
typedef
std
::
shared_ptr
<
H265FrameNoCopyAble
>
Ptr
;
H265FrameNoCopyAble
(
char
*
ptr
,
uint32_t
size
,
uint32_t
stamp
,
int
prefixeSize
=
4
)
{
buffer_ptr
=
ptr
;
buffer_size
=
size
;
timeStamp
=
stamp
;
iPrefixSize
=
prefixeSize
;
H265FrameNoCopyAble
(
char
*
ptr
,
uint32_t
size
,
uint32_t
dts
,
uint32_t
pts
,
int
prefixeSize
=
4
)
{
_ptr
=
ptr
;
_size
=
size
;
_dts
=
dts
;
_pts
=
pts
;
_prefixSize
=
prefixeSize
;
}
TrackType
getTrackType
()
const
override
{
...
...
@@ -141,7 +142,7 @@ public:
}
bool
keyFrame
()
const
override
{
int
type
=
H265_TYPE
(((
uint8_t
*
)
buffer_ptr
)[
iP
refixSize
]);
int
type
=
H265_TYPE
(((
uint8_t
*
)
_ptr
)[
_p
refixSize
]);
return
H265Frame
::
isKeyFrame
(
type
);
}
};
...
...
src/MediaFile/MediaReader.cpp
查看文件 @
e36194ae
...
...
@@ -221,7 +221,7 @@ inline bool MediaReader::readVideoSample(int iTimeInc,bool justSeekSyncFrame) {
break
;
}
memcpy
(
pBytes
+
iOffset
,
"\x0\x0\x0\x1"
,
4
);
writeH264
(
pBytes
+
iOffset
,
iFrameLen
+
4
,
(
double
)
_video_ms
*
iIdx
/
_video_num_samples
);
writeH264
(
pBytes
+
iOffset
,
iFrameLen
+
4
,
(
double
)
_video_ms
*
iIdx
/
_video_num_samples
,
0
);
iOffset
+=
(
iFrameLen
+
4
);
}
}
else
if
(
_bSyncSample
){
...
...
@@ -259,8 +259,8 @@ inline bool MediaReader::readAudioSample(int iTimeInc,bool justSeekSyncFrame) {
return
false
;
}
inline
void
MediaReader
::
writeH264
(
uint8_t
*
pucData
,
int
iLen
,
uint32_t
uiStamp
)
{
_mediaMuxer
->
inputFrame
(
std
::
make_shared
<
H264FrameNoCopyAble
>
((
char
*
)
pucData
,
iLen
,
uiStamp
));
inline
void
MediaReader
::
writeH264
(
uint8_t
*
pucData
,
int
iLen
,
uint32_t
dts
,
uint32_t
pts
)
{
_mediaMuxer
->
inputFrame
(
std
::
make_shared
<
H264FrameNoCopyAble
>
((
char
*
)
pucData
,
iLen
,
dts
,
pts
));
}
inline
void
MediaReader
::
writeAAC
(
uint8_t
*
pucData
,
int
iLen
,
uint32_t
uiStamp
)
{
...
...
src/MediaFile/MediaReader.h
查看文件 @
e36194ae
...
...
@@ -97,7 +97,7 @@ private:
bool
readSample
(
int
iTimeInc
,
bool
justSeekSyncFrame
);
inline
bool
readVideoSample
(
int
iTimeInc
,
bool
justSeekSyncFrame
);
inline
bool
readAudioSample
(
int
iTimeInc
,
bool
justSeekSyncFrame
);
inline
void
writeH264
(
uint8_t
*
pucData
,
int
iLen
,
uint32_t
uiStamp
);
inline
void
writeH264
(
uint8_t
*
pucData
,
int
iLen
,
uint32_t
dts
,
uint32_t
pts
);
inline
void
writeAAC
(
uint8_t
*
pucData
,
int
iLen
,
uint32_t
uiStamp
);
private
:
MP4FileHandle
_hMP4File
=
MP4_INVALID_FILE_HANDLE
;
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论