服务器的响应:
{
"rtcid": "wKAm8eeyI-mQ5dsslkhu",
"msgType": "offer",
"senderrtcid": "53wp_LP5CYDie3eIlkhw",
"msgData": {
"type": "offer",
"sdp": "v=0rno=- 951920257545056255 2 IN IP4 127.0.0.1rns=-rnt=0 0rna=group:BUNDLE audio videorna=msid-semantic: WMS OfkjcHABgxUkHlk8mfJ8ayYZdCHqdpQGFSTMrnm=audio 1 RTP/SAVPF 111 103 104 0 8 106 105 13 126rnc=IN IP4 0.0.0.0rna=rtcp:1 IN IP4 0.0.0.0rna=ice-ufrag:CF4q+RW54gQVPaz0rna=ice-pwd:hEIbgX4MME6cPkZKGih7bjQMrna=ice-options:google-icerna=fingerprint:sha-256 1E:7F:B8:BA:1A:8D:76:BE:A9:A5:A3:9D:59:3E:CC:BD:1B:90:7B:89:EF:F0:03:B3:9A:CA:9C:07:02:97:53:6Frna=setup:actpassrna=mid:audiorna=extmap:1 urn:ietf:params:rtp-hdrext:ssrc-audio-levelrna=extmap:3 http://www.webrtc.org/experiments/rtp-hdrext/abs-send-timerna=sendrecvrna=rtcp-muxrna=rtpmap:111 opus/48000/2rna=fmtp:111 minptime=10rna=rtpmap:103 ISAC/16000rna=rtpmap:104 ISAC/32000rna=rtpmap:0 PCMU/8000rna=rtpmap:8 PCMA/8000rna=rtpmap:106 CN/32000rna=rtpmap:105 CN/16000rna=rtpmap:13 CN/8000rna=rtpmap:126 telephone-event/8000rna=maxptime:60rna=ssrc:777379316 cname:Dl+cb/nGYCzEcTvHrna=ssrc:777379316 msid:OfkjcHABgxUkHlk8mfJ8ayYZdCHqdpQGFSTM 0937b040-5691-4ae3-b533-dd9ce82c4393rna=ssrc:777379316 mslabel:OfkjcHABgxUkHlk8mfJ8ayYZdCHqdpQGFSTMrna=ssrc:777379316 label:0937b040-5691-4ae3-b533-dd9ce82c4393rnm=video 1 RTP/SAVPF 100 116 117 96rnc=IN IP4 0.0.0.0rna=rtcp:1 IN IP4 0.0.0.0rna=ice-ufrag:CF4q+RW54gQVPaz0rna=ice-pwd:hEIbgX4MME6cPkZKGih7bjQMrna=ice-options:google-icerna=fingerprint:sha-256 1E:7F:B8:BA:1A:8D:76:BE:A9:A5:A3:9D:59:3E:CC:BD:1B:90:7B:89:EF:F0:03:B3:9A:CA:9C:07:02:97:53:6Frna=setup:actpassrna=mid:videorna=extmap:2 urn:ietf:params:rtp-hdrext:toffsetrna=extmap:3 http://www.webrtc.org/experiments/rtp-hdrext/abs-send-timerna=sendrecvrna=rtcp-muxrna=rtpmap:100 VP8/90000rna=rtcp-fb:100 ccm firrna=rtcp-fb:100 nackrna=rtcp-fb:100 nack plirna=rtcp-fb:100 goog-rembrna=rtpmap:116 red/90000rna=rtpmap:117 ulpfec/90000rna=rtpmap:96 rtx/90000rna=fmtp:96 apt=100rna=ssrc-group:FID 187598656 415229902rna=ssrc:187598656 cname:Dl+cb/nGYCzEcTvHrna=ssrc:187598656 msid:OfkjcHABgxUkHlk8mfJ8ayYZdCHqdpQGFSTM 02ab4641-6cd5-43be-b0fe-9952585642bfrna=ssrc:187598656 mslabel:OfkjcHABgxUkHlk8mfJ8ayYZdCHqdpQGFSTMrna=ssrc:187598656 label:02ab4641-6cd5-43be-b0fe-9952585642bfrna=ssrc:415229902 cname:Dl+cb/nGYCzEcTvHrna=ssrc:415229902 msid:OfkjcHABgxUkHlk8mfJ8ayYZdCHqdpQGFSTM 02ab4641-6cd5-43be-b0fe-9952585642bfrna=ssrc:415229902 mslabel:OfkjcHABgxUkHlk8mfJ8ayYZdCHqdpQGFSTMrna=ssrc:415229902 label:02ab4641-6cd5-43be-b0fe-9952585642bfrn"
},
"serverTime": 1431342100822
}
log
libjingle: Ignored line: c=IN IP4 0.0.0.0
libjingle: Error(transport.cc:97): Answerer must use either active or passive value for setup attribute.
libjingle:Error(webrtcsession.cc:272): Failed to set remote answer sdp: Failed to push down transport description: Answerer must use either active or passive value for setup attribute.
**首先,我创建要约并添加localDescription,然后使用EMIT将其发送到服务器,并且服务器返回回调包含远程SDP **
public void onCreateSuccess(SessionDescription arg0) {
// TODO Auto-generated method stub
try {
if(arg0.type.canonicalForm().equalsIgnoreCase("answer")){
peer.setRemoteDescription(this, sdp);
// mListener.onAddRemoteStream(localMS, 0);
}
else{
payload = new JSONObject();
payload.put("type", arg0.type.canonicalForm());
Log.d("offer", arg0.type.canonicalForm().toString());
payload.put("sdp", arg0.description);
sendMessage("rtcsid", arg0.type.canonicalForm(), payload);
peer.setLocalDescription(this, arg0);
}
} catch (JSONException e) {
e.printStackTrace();
}
icecandidate:
public void onIceCandidate(IceCandidate arg0) {
// TODO Auto-generated method stub
Log.d("IceCandidate", arg0.toString());
JSONObject payload = new JSONObject();
try {
payload.put("type", arg0.sdpMLineIndex);
Log.d("sdpMLineIndex", Integer.toString(arg0.sdpMLineIndex));
payload.put("id", arg0.sdpMid);
Log.d("sdpMid", arg0.sdpMid.toString());
payload.put("type", arg0.sdp);
Log.d("candidate", arg0.sdp.toString());
sendMessage("easyrtcsid", "candidate", payload);
if(peer.getRemoteDescription()!=null){
IceCandidate candidate = new IceCandidate(
arg0.sdpMid,
arg0.sdpMLineIndex,
arg0.sdp.toString()
);
peer.addIceCandidate(candidate);
}
} catch (JSONException e) {
e.printStackTrace();
}
}
候选人的日志
{
05-11 14:59:28.495: I/libjingle(14672): Local and Remote descriptions must be applied to get SSL Role of the session.
05-11 14:59:28.495: I/libjingle(14672): Transport: audio, allocating candidates
05-11 14:59:28.495: D/IceGatheringChange(14672): GATHERING
05-11 14:59:28.495: I/libjingle(14672): Transport: audio, allocating candidates
05-11 14:59:28.495: D/IceGatheringChange(14672): GATHERING
05-11 14:59:28.495: I/libjingle(14672): Transport: video, allocating candidates
05-11 14:59:28.495: D/IceGatheringChange(14672): GATHERING
05-11 14:59:28.495: I/libjingle(14672): Transport: video, allocating candidates
05-11 14:59:28.495: D/IceGatheringChange(14672): GATHERING
05-11 14:59:28.495: I/libjingle(14672): Jingle:Net[wlan0:10.0.0.0/8:Unknown]: Allocation Phase=Udp
05-11 14:59:28.505: I/libjingle(14672): Jingle:Port[:1:0::Net[wlan0:10.0.0.0/8:Unknown]]: Port created
05-11 14:59:28.505: I/libjingle(14672): AllocationSequence: UDPPort will be handling the STUN candidate generation.
05-11 14:59:28.505: I/libjingle(14672): Adding allocated port for audio
05-11 14:59:28.505: I/libjingle(14672): Jingle:Port[audio:1:0::Net[wlan0:10.0.0.0/8:Unknown]]: Added port to allocator
05-11 14:59:28.525: D/IceCandidate(14672): audio:0:candidate:1281544012 1 udp 2122260223 10.0.0.112 49865 typ host generation 0
05-11 14:59:28.525: D/sdpMLineIndex(14672): 0
05-11 14:59:28.525: D/sdpMid(14672): audio
05-11 14:59:28.525: D/candidate(14672): candidate:1281544012 1 udp 2122260223 10.0.0.112 49865 typ host generation 0
05-11 14:59:28.525: I/libjingle(14672): Jingle:Net[wlan0:10.0.0.0/8:Unknown]: Allocation Phase=Udp
05-11 14:59:28.525: I/libjingle(14672): Jingle:Port[:1:0::Net[wlan0:10.0.0.0/8:Unknown]]: Port created
05-11 14:59:28.525: I/libjingle(14672): AllocationSequence: UDPPort will be handling the STUN candidate generation.
05-11 14:59:28.525: I/libjingle(14672): Adding allocated port for audio
05-11 14:59:28.525: I/libjingle(14672): Jingle:Port[audio:2:0::Net[wlan0:10.0.0.0/8:Unknown]]: Added port to allocator
05-11 14:59:28.555: D/IceCandidate(14672): audio:0:candidate:1281544012 2 udp 2122260222 10.0.0.112 36221 typ host generation 0
05-11 14:59:28.555: D/sdpMLineIndex(14672): 0
05-11 14:59:28.555: D/sdpMid(14672): audio
05-11 14:59:28.555: D/candidate(14672): candidate:1281544012 2 udp 2122260222 10.0.0.112 36221 typ host generation 0
05-11 14:59:28.555: I/libjingle(14672): Jingle:Net[wlan0:10.0.0.0/8:Unknown]: Allocation Phase=Udp
05-11 14:59:28.555: I/libjingle(14672): Jingle:Port[:1:0::Net[wlan0:10.0.0.0/8:Unknown]]: Port created
05-11 14:59:28.555: I/libjingle(14672): AllocationSequence: UDPPort will be handling the STUN candidate generation.
05-11 14:59:28.555: I/libjingle(14672): Adding allocated port for video
05-11 14:59:28.555: I/libjingle(14672): Jingle:Port[video:1:0::Net[wlan0:10.0.0.0/8:Unknown]]: Added port to allocator
05-11 14:59:28.565: D/IceCandidate(14672): video:1:candidate:1281544012 1 udp 2122260223 10.0.0.112 57380 typ host generation 0
05-11 14:59:28.565: D/sdpMLineIndex(14672): 1
05-11 14:59:28.565: D/sdpMid(14672): video
05-11 14:59:28.565: D/candidate(14672): candidate:1281544012 1 udp 2122260223 10.0.0.112 57380 typ host generation 0
05-11 14:59:28.575: I/libjingle(14672): Jingle:Net[wlan0:10.0.0.0/8:Unknown]: Allocation Phase=Udp
05-11 14:59:28.575: I/libjingle(14672): Jingle:Port[:1:0::Net[wlan0:10.0.0.0/8:Unknown]]: Port created
05-11 14:59:28.575: I/libjingle(14672): AllocationSequence: UDPPort will be handling the STUN candidate generation.
05-11 14:59:28.575: I/libjingle(14672): Adding allocated port for video
05-11 14:59:28.575: I/libjingle(14672): Jingle:Port[video:2:0::Net[wlan0:10.0.0.0/8:Unknown]]: Added port to allocator
05-11 14:59:28.605: D/IceCandidate(14672): video:1:candidate:1281544012 2 udp 2122260222 10.0.0.112 48445 typ host generation 0
05-11 14:59:28.605: D/sdpMLineIndex(14672): 1
05-11 14:59:28.605: D/sdpMid(14672): video
05-11 14:59:28.605: D/candidate(14672): candidate:1281544012 2 udp 2122260222 10.0.0.112 48445 typ host generation 0
05-11 14:59:28.625: W/libjingle(14672): Warning(thread.cc:320): Waiting for the thread to join, but blocking calls have been disallowed
05-11 14:59:28.625: W/libjingle(14672): Warning(thread.cc:320): Waiting for the thread to join, but blocking calls have been disallowed
05-11 14:59:28.625: W/libjingle(14672): Warning(thread.cc:320): Waiting for the thread to join, but blocking calls have been disallowed
05-11 14:59:28.625: W/libjingle(14672): Warning(thread.cc:320): Waiting for the thread to join, but blocking calls have been disallowed
05-11 14:59:28.625: W/libjingle(14672): Warning(thread.cc:320): Waiting for the thread to join, but blocking calls have been disallowed
05-11 14:59:28.625: W/libjingle(14672): Warning(thread.cc:320): Waiting for the thread to join, but blocking calls have been disallowed
05-11 14:59:28.625: W/libjingle(14672): Warning(thread.cc:320): Waiting for the thread to join, but blocking calls have been disallowed
05-11 14:59:28.625: W/libjingle(14672): Warning(thread.cc:320): Waiting for the thread to join, but blocking calls have been disallowed
05-11 14:59:28.625: W/libjingle(14672): Warning(thread.cc:320): Waiting for the thread to join, but blocking calls have been disallowed
05-11 14:59:28.625: W/libjingle(14672): Warning(thread.cc:320): Waiting for the thread to join, but blocking calls have been disallowed
05-11 14:59:28.625: I/libjingle(14672): Jingle:Net[wlan0:10.0.0.0/8:Unknown]: Allocation Phase=Relay
05-11 14:59:28.625: I/libjingle(14672): Jingle:Net[wlan0:10.0.0.0/8:Unknown]: Allocation Phase=Relay
05-11 14:59:28.635: W/libjingle(14672): Warning(thread.cc:320): Waiting for the thread to join, but blocking calls have been disallowed
05-11 14:59:28.635: I/libjingle(14672): Jingle:Net[wlan0:10.0.0.0/8:Unknown]: Allocation Phase=Relay
05-11 14:59:28.635: W/libjingle(14672): Warning(thread.cc:320): Waiting for the thread to join, but blocking calls have been disallowed
05-11 14:59:28.635: D/IceCandidate(14672): audio:0:candidate:2940422560 1 udp 1686052607 197.44.239.36 49865 typ srflx raddr 10.0.0.112 rport 49865 generation 0
05-11 14:59:28.635: D/sdpMLineIndex(14672): 0
05-11 14:59:28.635: D/sdpMid(14672): audio
05-11 14:59:28.635: D/candidate(14672): candidate:2940422560 1 udp 1686052607 197.44.239.36 49865 typ srflx raddr 10.0.0.112 rport 49865 generation 0
05-11 14:59:28.645: D/IceCandidate(14672): audio:0:candidate:2940422560 2 udp 1686052606 197.44.239.36 36221 typ srflx raddr 10.0.0.112 rport 36221 generation 0
05-11 14:59:28.645: D/sdpMLineIndex(14672): 0
05-11 14:59:28.645: D/sdpMid(14672): audio
05-11 14:59:28.645: D/candidate(14672): candidate:2940422560 2 udp 1686052606 197.44.239.36 36221 typ srflx raddr 10.0.0.112 rport 36221 generation 0
05-11 14:59:28.665: I/libjingle(14672): Jingle:Net[wlan0:10.0.0.0/8:Unknown]: Allocation Phase=Relay
05-11 14:59:28.675: D/IceCandidate(14672): video:1:candidate:2940422560 1 udp 1686052607 197.44.239.36 57380 typ srflx raddr 10.0.0.112 rport 57380 generation 0
05-11 14:59:28.675: D/sdpMLineIndex(14672): 1
05-11 14:59:28.675: D/sdpMid(14672): video
05-11 14:59:28.675: D/candidate(14672): candidate:2940422560 1 udp 1686052607 197.44.239.36 57380 typ srflx raddr 10.0.0.112 rport 57380 generation 0
05-11 14:59:28.685: I/libjingle(14672): Jingle:Net[wlan0:10.0.0.0/8:Unknown]: Allocation Phase=Tcp
05-11 14:59:28.685: I/libjingle(14672): Jingle:Port[:1:0:local:Net[wlan0:10.0.0.0/8:Unknown]]: Port created
05-11 14:59:28.685: I/libjingle(14672): Adding allocated port for audio
05-11 14:59:28.685: I/libjingle(14672): Jingle:Port[audio:1:0:local:Net[wlan0:10.0.0.0/8:Unknown]]: Added port to allocator
05-11 14:59:28.685: I/libjingle(14672): Jingle:Net[wlan0:10.0.0.0/8:Unknown]: Allocation Phase=Tcp
05-11 14:59:28.685: D/IceCandidate(14672): audio:0:candidate:48313276 1 tcp 1518280447 10.0.0.112 40627 typ host tcptype passive generation 0
05-11 14:59:28.685: D/sdpMLineIndex(14672): 0
05-11 14:59:28.685: D/sdpMid(14672): audio
05-11 14:59:28.685: D/candidate(14672): candidate:48313276 1 tcp 1518280447 10.0.0.112 40627 typ host tcptype passive generation 0
05-11 14:59:28.685: I/libjingle(14672): Jingle:Port[:1:0:local:Net[wlan0:10.0.0.0/8:Unknown]]: Port created
05-11 14:59:28.685: I/libjingle(14672): Adding allocated port for audio
05-11 14:59:28.685: I/libjingle(14672): Jingle:Port[audio:2:0:local:Net[wlan0:10.0.0.0/8:Unknown]]: Added port to allocator
05-11 14:59:28.685: I/libjingle(14672): Jingle:Net[wlan0:10.0.0.0/8:Unknown]: Allocation Phase=Tcp
05-11 14:59:28.685: D/IceCandidate(14672): audio:0:candidate:48313276 2 tcp 1518280446 10.0.0.112 48390 typ host tcptype passive generation 0
05-11 14:59:28.685: D/sdpMLineIndex(14672): 0
05-11 14:59:28.685: D/sdpMid(14672): audio
05-11 14:59:28.685: D/candidate(14672): candidate:48313276 2 tcp 1518280446 10.0.0.112 48390 typ host tcptype passive generation 0
05-11 14:59:28.695: I/libjingle(14672): Jingle:Port[:1:0:local:Net[wlan0:10.0.0.0/8:Unknown]]: Port created
05-11 14:59:28.695: I/libjingle(14672): Adding allocated port for video
05-11 14:59:28.695: I/libjingle(14672): Jingle:Port[video:1:0:local:Net[wlan0:10.0.0.0/8:Unknown]]: Added port to allocator
05-11 14:59:28.695: D/IceCandidate(14672): video:1:candidate:48313276 1 tcp 1518280447 10.0.0.112 60960 typ host tcptype passive generation 0
05-11 14:59:28.695: D/sdpMLineIndex(14672): 1
05-11 14:59:28.695: D/sdpMid(14672): video
05-11 14:59:28.695: D/candidate(14672): candidate:48313276 1 tcp 1518280447 10.0.0.112 60960 typ host tcptype passive generation 0
05-11 14:59:28.705: D/IceCandidate(14672): video:1:candidate:2940422560 2 udp 1686052606 197.44.239.36 48445 typ srflx raddr 10.0.0.112 rport 48445 generation 0
05-11 14:59:28.705: D/sdpMLineIndex(14672): 1
05-11 14:59:28.715: D/sdpMid(14672): video
05-11 14:59:28.715: D/candidate(14672): candidate:2940422560 2 udp 1686052606 197.44.239.36 48445 typ srflx raddr 10.0.0.112 rport 48445 generation 0
05-11 14:59:28.725: I/libjingle(14672): Jingle:Net[wlan0:10.0.0.0/8:Unknown]: Allocation Phase=Tcp
05-11 14:59:28.725: I/libjingle(14672): Jingle:Port[:1:0:local:Net[wlan0:10.0.0.0/8:Unknown]]: Port created
05-11 14:59:28.725: I/libjingle(14672): Adding allocated port for video
05-11 14:59:28.725: I/libjingle(14672): Jingle:Port[video:2:0:local:Net[wlan0:10.0.0.0/8:Unknown]]: Added port to allocator
05-11 14:59:28.725: D/IceCandidate(14672): video:1:candidate:48313276 2 tcp 1518280446 10.0.0.112 59723 typ host tcptype passive generation 0
05-11 14:59:28.725: D/sdpMLineIndex(14672): 1
05-11 14:59:28.725: D/sdpMid(14672): video
05-11 14:59:28.725: D/candidate(14672): candidate:48313276 2 tcp 1518280446 10.0.0.112 59723 typ host tcptype passive generation 0
05-11 14:59:28.735: I/libjingle(14672): Jingle:Net[wlan0:10.0.0.0/8:Unknown]: Allocation Phase=SslTcp
05-11 14:59:28.735: I/libjingle(14672): Jingle:Net[wlan0:10.0.0.0/8:Unknown]: Allocation Phase=SslTcp
05-11 14:59:28.735: I/libjingle(14672): All candidates gathered for audio:2:0
05-11 14:59:28.735: I/libjingle(14672): Transport: audio, component 2 allocation complete
05-11 14:59:28.745: I/libjingle(14672): Jingle:Net[wlan0:10.0.0.0/8:Unknown]: Allocation Phase=SslTcp
05-11 14:59:28.745: I/libjingle(14672): All candidates gathered for video:1:0
05-11 14:59:28.745: I/libjingle(14672): Transport: video, component 1 allocation complete
05-11 14:59:28.775: I/libjingle(14672): Jingle:Net[wlan0:10.0.0.0/8:Unknown]: Allocation Phase=SslTcp
05-11 14:59:28.775: I/libjingle(14672): All candidates gathered for video:2:0
05-11 14:59:28.775: I/libjingle(14672): Transport: video, component 2 allocation complete
05-11 14:59:28.775: I/libjingle(14672): Transport: video allocation complete
05-11 14:59:28.775: I/libjingle(14672): Candidate allocation not done for audio
05-11 14:59:28.795: I/libjingle(14672): All candidates gathered for audio:1:0
05-11 14:59:28.795: I/libjingle(14672): Transport: audio, component 1 allocation complete
05-11 14:59:28.795: I/libjingle(14672): Transport: audio allocation complete
05-11 14:59:28.795: I/libjingle(14672): Candidate gathering is complete.
05-11 14:59:28.795: D/IceGatheringChange(14672): COMPLETE
}
MediaConstraints
pcConstraints.mandatory.add(new MediaConstraints.KeyValuePair("OfferToReceiveAudio", "true"));
pcConstraints.mandatory.add(new MediaConstraints.KeyValuePair("OfferToReceiveVideo", "true"));
pcConstraints.optional.add(new MediaConstraints.KeyValuePair("DtlsSrtpKeyAgreement", "true"));
请记住,这是我自己谦虚的代码,它可能不是完美的,而且很难将所有内容复制到您自己的项目中。它对我有用,但这并不意味着对其他所有人都会。
设置呼叫的过程如下(请注意,这不是用石头设置):
有2个设备A和B,都连接到某种信号服务器,以使他们可以交换sdps和coct候选者,并互相邀请呼叫等...
a开始呼叫,第一步可能是发送邀请。
//initialize the peerconnection factory
PeerConnectionFactory.initializeAndroidGlobals(MainActivity.context, true, true, true, parent.tex_remote);
factory = new PeerConnectionFactory();
//ice server initialization
ArrayList<PeerConnection.IceServer> iceServers = new ArrayList<>();
iceServers.add(new PeerConnection.IceServer("stun:stun.xxx.xxx:xxx"));
iceServers.add(new PeerConnection.IceServer("turn:turn.xxx.xxx:xxx", "xxx", "xxx"));
//create a new contraints object to configure the connection
MediaConstraints connectionConstraints = new MediaConstraints();
connectionConstraints.mandatory.add(new MediaConstraints.KeyValuePair("offerToReceiveAudio", "true"));
connectionConstraints.mandatory.add(new MediaConstraints.KeyValuePair("offerToReceiveVideo", "true"));
connectionConstraints.optional.add(new MediaConstraints.KeyValuePair("DtlsSrtpKeyAgreement", "true"));
//create a new peerconnection object
peerConnection = factory.createPeerConnection(iceServers, connectionConstraints, observer);
完成此操作后,您可以使用以下代码来初始化本地媒体流:
来初始化本地媒体流。//create a new audio and video source, this is the stream that will be sent to the remote
VideoSource videoSource = factory.createVideoSource(VideoCapturer.create("Camera 1, Facing front, Orientation 270"), new MediaConstraints());
AudioSource audioSource = factory.createAudioSource(new MediaConstraints());
//create a new audio and video track
VideoTrack videoTrack = factory.createVideoTrack("ARDAMSv0", videoSource);
AudioTrack audioTrack = factory.createAudioTrack("ARDAMSa0", audioSource);
//create a new media stream, this holds all local streams and their tracks
MediaStream lms = factory.createLocalMediaStream("ARDAMS");
//create a new video renderer and add it to the video track
VideoRenderer renderer = new VideoRenderer(parent);
videoTrack.addRenderer(renderer);
//add the video track to the stream
lms.addTrack(videoTrack);
//add the audio track to the stream
lms.addTrack(audioTrack);
//add the stream to the connection
peerConnection.addStream(lms);
同时,B将从信号服务器接收呼叫邀请,并且必须向用户提供某种传入的呼叫视图。当用户决定接听电话时,B将Accept信号发送回A。
接收此接受信号时,是时候开始设置呼叫本身了。如果成功:
peerConnection.createOffer(observer, new MediaConstraints());
在OnCreateSuccess()中,您可以使用新创建的SDP调用SetLocalDescription()。您还必须将此SDP发送到B,因此您最好在这里这样做:
peerConnection.setLocalDescription(this, sessionDescription);
//send this SDP to your remote peer
b现在将收到A的报价,您必须通过调用SetRemotedEscription()来设置该优惠:
peerConnection.setRemoteDescription(observer, sdp);
如果成功成功,库将调用onsetsuccess()。在OnSetsuccess()中,您可以致电CreateAnswer():
peerConnection.createAnswer(observer, constraints);
因为您现在确定您拥有初始优惠SDP集。图书馆将为您再次致电onCreateSuccess()。与A的报价相同的事情现在是B的答案。它将答案设置为本地SDP,并将其发送到:
peerConnection.setLocalDescription(this, sessionDescription);
//send this SDP to your remote peer
完成所有操作后,交换SDP已完成。该库还将多次调用onicecandidate()。当您从其他同伴那里收到ICE候选人时,您只需要将此冰上的候选者发送到另一个同伴。
pcConstraints.optional.add(new KeyValuePair("DtlsSrtpKeyAgreement", "true"));
pcConstraints.optional.add(new KeyValuePair("RtpDataChannels", "true"));