mirror of
https://github.com/mii443/libdatachannel.git
synced 2025-08-23 15:48:03 +00:00
Cleaned up addVideoCodec
This commit is contained in:
@ -190,17 +190,21 @@ public:
|
|||||||
public:
|
public:
|
||||||
Audio(string mid = "audio", Direction dir = Direction::SendOnly);
|
Audio(string mid = "audio", Direction dir = Direction::SendOnly);
|
||||||
|
|
||||||
void addAudioCodec(int payloadType, const string &codec);
|
void addAudioCodec(int payloadType, const string &codec, const std::optional<std::string>& profile=
|
||||||
|
"minptime=10; maxaveragebitrate=96000; stereo=1; sprop-stereo=1; useinbandfec=1");
|
||||||
void addOpusCodec(int payloadType);
|
void addOpusCodec(int payloadType);
|
||||||
|
|
||||||
void addRTXCodec(unsigned int payloadType, unsigned int originalPayloadType, unsigned int clockRate);
|
|
||||||
};
|
};
|
||||||
|
|
||||||
class RTC_CPP_EXPORT Video : public Media {
|
class RTC_CPP_EXPORT Video : public Media {
|
||||||
public:
|
public:
|
||||||
Video(string mid = "video", Direction dir = Direction::SendOnly);
|
Video(string mid = "video", Direction dir = Direction::SendOnly);
|
||||||
|
|
||||||
void addVideoCodec(int payloadType, const string &codec);
|
// Use Constrained Baseline profile Level 4.2 (necessary for Firefox)
|
||||||
|
// https://developer.mozilla.org/en-US/docs/Web/Media/Formats/WebRTC_codecs#Supported_video_codecs
|
||||||
|
// TODO: Should be 42E0 but 42C0 appears to be more compatible. Investigate this.
|
||||||
|
void addVideoCodec(int payloadType, const string &codec, const std::optional<std::string>&
|
||||||
|
profile="profile-level-id=42e01f;packetization-mode=1;level-asymmetry-allowed=1");
|
||||||
|
|
||||||
void addH264Codec(int payloadType);
|
void addH264Codec(int payloadType);
|
||||||
void addVP8Codec(int payloadType);
|
void addVP8Codec(int payloadType);
|
||||||
void addVP9Codec(int payloadType);
|
void addVP9Codec(int payloadType);
|
||||||
|
@ -702,29 +702,14 @@ void Description::Media::removeFormat(const string &fmt) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Description::Video::addVideoCodec(int payloadType, const string &codec) {
|
void Description::Video::addVideoCodec(int payloadType, const string &codec, const std::optional<std::string>& profile) {
|
||||||
RTPMap map(std::to_string(payloadType) + ' ' + codec + "/90000");
|
RTPMap map(std::to_string(payloadType) + ' ' + codec + "/90000");
|
||||||
map.addFB("nack");
|
map.addFB("nack");
|
||||||
map.addFB("nack pli");
|
map.addFB("nack pli");
|
||||||
// map.addFB("nack fir");
|
// map.addFB("ccm fir");
|
||||||
map.addFB("goog-remb");
|
map.addFB("goog-remb");
|
||||||
if (codec == "H264") {
|
if (profile)
|
||||||
// Use Constrained Baseline profile Level 4.2 (necessary for Firefox)
|
map.fmtps.emplace_back(*profile);
|
||||||
// https://developer.mozilla.org/en-US/docs/Web/Media/Formats/WebRTC_codecs#Supported_video_codecs
|
|
||||||
// TODO: Should be 42E0 but 42C0 appears to be more compatible. Investigate this.
|
|
||||||
map.fmtps.emplace_back(
|
|
||||||
"profile-level-id=4de01f;packetization-mode=1;level-asymmetry-allowed=1");
|
|
||||||
|
|
||||||
// Because certain Android devices don't like me, let us just negotiate some random
|
|
||||||
// {
|
|
||||||
// RTPMap map(std::to_string(payloadType + 1) + ' ' + codec + "/90000");
|
|
||||||
// map.addFB("nack");
|
|
||||||
// map.addFB("nack pli");
|
|
||||||
// // map.addFB("nack fir");
|
|
||||||
// map.addFB("goog-remb");
|
|
||||||
// addRTPMap(map);
|
|
||||||
// }
|
|
||||||
}
|
|
||||||
addRTPMap(map);
|
addRTPMap(map);
|
||||||
|
|
||||||
// // RTX Packets
|
// // RTX Packets
|
||||||
@ -741,10 +726,11 @@ void Description::Video::addVideoCodec(int payloadType, const string &codec) {
|
|||||||
// ";rtx-time=3000"); addRTPMap(rtx);
|
// ";rtx-time=3000"); addRTPMap(rtx);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Description::Audio::addAudioCodec(int payloadType, const string &codec) {
|
void Description::Audio::addAudioCodec(int payloadType, const string &codec, const std::optional<std::string>& profile) {
|
||||||
// TODO This 48000/2 should be parameterized
|
// TODO This 48000/2 should be parameterized
|
||||||
RTPMap map(std::to_string(payloadType) + ' ' + codec + "/48000/2");
|
RTPMap map(std::to_string(payloadType) + ' ' + codec + "/48000/2");
|
||||||
map.fmtps.emplace_back("minptime=10; maxaveragebitrate=96000; stereo=1; sprop-stereo=1; useinbandfec=1");
|
if (profile)
|
||||||
|
map.fmtps.emplace_back(*profile);
|
||||||
addRTPMap(map);
|
addRTPMap(map);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user