Change back so that Android ApprtcDemo only use one MediaStream containing both audio and video.
The reason is that the desktop apprtcdemo only handle one MediaStream and this doesn't play audio if it receive two streams. TEST=Test that a call with audio and video can be setup between an Android device and a desktop client using apprtc.appspot.com. BUG=4051,3786 R=henrika@webrtc.org Review URL: https://webrtc-codereview.appspot.com/31069004 git-svn-id: http://webrtc.googlecode.com/svn/trunk@7781 4adac7df-926f-26a2-2b94-8c16560cd09d
This commit is contained in:
@@ -77,7 +77,7 @@ public class PeerConnectionClient {
|
|||||||
private boolean isInitiator;
|
private boolean isInitiator;
|
||||||
private boolean useFrontFacingCamera = true;
|
private boolean useFrontFacingCamera = true;
|
||||||
private SessionDescription localSdp = null; // either offer or answer SDP
|
private SessionDescription localSdp = null; // either offer or answer SDP
|
||||||
private MediaStream videoMediaStream = null;
|
private MediaStream mediaStream = null;
|
||||||
|
|
||||||
public PeerConnectionClient(
|
public PeerConnectionClient(
|
||||||
Activity activity,
|
Activity activity,
|
||||||
@@ -116,19 +116,17 @@ public class PeerConnectionClient {
|
|||||||
// EnumSet.of(Logging.TraceLevel.TRACE_ALL),
|
// EnumSet.of(Logging.TraceLevel.TRACE_ALL),
|
||||||
// Logging.Severity.LS_SENSITIVE);
|
// Logging.Severity.LS_SENSITIVE);
|
||||||
|
|
||||||
|
mediaStream = factory.createLocalMediaStream("ARDAMS");
|
||||||
if (videoConstraints != null) {
|
if (videoConstraints != null) {
|
||||||
videoMediaStream = factory.createLocalMediaStream("ARDAMSVideo");
|
mediaStream.addTrack(createVideoTrack(useFrontFacingCamera));
|
||||||
videoMediaStream.addTrack(createVideoTrack(useFrontFacingCamera));
|
|
||||||
pc.addStream(videoMediaStream);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (signalingParameters.audioConstraints != null) {
|
if (signalingParameters.audioConstraints != null) {
|
||||||
MediaStream lMS = factory.createLocalMediaStream("ARDAMSAudio");
|
mediaStream.addTrack(factory.createAudioTrack(
|
||||||
lMS.addTrack(factory.createAudioTrack(
|
|
||||||
AUDIO_TRACK_ID,
|
AUDIO_TRACK_ID,
|
||||||
factory.createAudioSource(signalingParameters.audioConstraints)));
|
factory.createAudioSource(signalingParameters.audioConstraints)));
|
||||||
pc.addStream(lMS);
|
|
||||||
}
|
}
|
||||||
|
pc.addStream(mediaStream);
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isHDVideo() {
|
public boolean isHDVideo() {
|
||||||
@@ -443,9 +441,9 @@ public class PeerConnectionClient {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
pc.removeStream(videoMediaStream);
|
pc.removeStream(mediaStream);
|
||||||
VideoTrack currentTrack = videoMediaStream.videoTracks.get(0);
|
VideoTrack currentTrack = mediaStream.videoTracks.get(0);
|
||||||
videoMediaStream.removeTrack(currentTrack);
|
mediaStream.removeTrack(currentTrack);
|
||||||
|
|
||||||
String trackId = currentTrack.id();
|
String trackId = currentTrack.id();
|
||||||
// On Android, there can only be one camera open at the time and we
|
// On Android, there can only be one camera open at the time and we
|
||||||
@@ -456,8 +454,8 @@ public class PeerConnectionClient {
|
|||||||
|
|
||||||
useFrontFacingCamera = !useFrontFacingCamera;
|
useFrontFacingCamera = !useFrontFacingCamera;
|
||||||
VideoTrack newTrack = createVideoTrack(useFrontFacingCamera);
|
VideoTrack newTrack = createVideoTrack(useFrontFacingCamera);
|
||||||
videoMediaStream.addTrack(newTrack);
|
mediaStream.addTrack(newTrack);
|
||||||
pc.addStream(videoMediaStream);
|
pc.addStream(mediaStream);
|
||||||
|
|
||||||
SessionDescription remoteDesc = pc.getRemoteDescription();
|
SessionDescription remoteDesc = pc.getRemoteDescription();
|
||||||
if (localSdp == null || remoteDesc == null) {
|
if (localSdp == null || remoteDesc == null) {
|
||||||
|
Reference in New Issue
Block a user