mirror of
https://github.com/ZLMediaKit/ZLMediaKit.git
synced 2024-11-24 11:40:37 +08:00
Compare commits
3 Commits
87708dafb7
...
02480ac7f6
Author | SHA1 | Date | |
---|---|---|---|
|
02480ac7f6 | ||
|
de7afaf992 | ||
|
9de09a4f68 |
@ -54,7 +54,9 @@ void RtspMediaSource::onWrite(RtpPacket::Ptr rtp, bool keyPos) {
|
|||||||
assert(rtp->type >= 0 && rtp->type < TrackMax);
|
assert(rtp->type >= 0 && rtp->type < TrackMax);
|
||||||
auto &track = _tracks[rtp->type];
|
auto &track = _tracks[rtp->type];
|
||||||
auto stamp = rtp->getStampMS();
|
auto stamp = rtp->getStampMS();
|
||||||
if (track) {
|
bool is_video = rtp->type == TrackVideo;
|
||||||
|
// 音频总是更新,视频在关键包时更新
|
||||||
|
if (track && ((keyPos && _have_video && is_video) || (!is_video))) {
|
||||||
track->_seq = rtp->getSeq();
|
track->_seq = rtp->getSeq();
|
||||||
track->_time_stamp = rtp->getStamp() * uint64_t(1000) / rtp->sample_rate;
|
track->_time_stamp = rtp->getStamp() * uint64_t(1000) / rtp->sample_rate;
|
||||||
track->_ssrc = rtp->getSSRC();
|
track->_ssrc = rtp->getSSRC();
|
||||||
@ -77,7 +79,7 @@ void RtspMediaSource::onWrite(RtpPacket::Ptr rtp, bool keyPos) {
|
|||||||
regist();
|
regist();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
bool is_video = rtp->type == TrackVideo;
|
|
||||||
PacketCache<RtpPacket>::inputPacket(stamp, is_video, std::move(rtp), keyPos);
|
PacketCache<RtpPacket>::inputPacket(stamp, is_video, std::move(rtp), keyPos);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -833,7 +833,7 @@ void RtspSession::handleReq_Play(const Parser &parser) {
|
|||||||
|
|
||||||
rtp_info << "url=" << track->getControlUrl(_content_base) << ";"
|
rtp_info << "url=" << track->getControlUrl(_content_base) << ";"
|
||||||
<< "seq=" << track->_seq << ";"
|
<< "seq=" << track->_seq << ";"
|
||||||
<< "rtptime=" << (int) (track->_time_stamp * (track->_samplerate / 1000)) << ",";
|
<< "rtptime=" << (int64_t)(track->_time_stamp) * (int64_t)(track->_samplerate/ 1000) << ",";
|
||||||
}
|
}
|
||||||
|
|
||||||
rtp_info.pop_back();
|
rtp_info.pop_back();
|
||||||
|
@ -35,7 +35,8 @@ namespace mediakit {
|
|||||||
XX(video_orientation, "urn:3gpp:video-orientation") \
|
XX(video_orientation, "urn:3gpp:video-orientation") \
|
||||||
XX(toffset, "urn:ietf:params:rtp-hdrext:toffset") \
|
XX(toffset, "urn:ietf:params:rtp-hdrext:toffset") \
|
||||||
XX(av1, "https://aomediacodec.github.io/av1-rtp-spec/#dependency-descriptor-rtp-header-extension") \
|
XX(av1, "https://aomediacodec.github.io/av1-rtp-spec/#dependency-descriptor-rtp-header-extension") \
|
||||||
XX(encrypt, "urn:ietf:params:rtp-hdrext:encrypt")
|
XX(encrypt, "urn:ietf:params:rtp-hdrext:encrypt") \
|
||||||
|
XX(video_layers_allocation00, "http://www.webrtc.org/experiments/rtp-hdrext/video-layers-allocation00") \
|
||||||
|
|
||||||
enum class RtpExtType : uint8_t {
|
enum class RtpExtType : uint8_t {
|
||||||
padding = 0,
|
padding = 0,
|
||||||
|
Loading…
Reference in New Issue
Block a user