 c4038d795d
			
		
	
	c4038d795d
	
	
	
		
			
			This CL changes the SoundMeter to be root-mean-square. It also changes the interface between the meter and the display to be based on the display calling down to the meter rather than the meter calling up to the display. A graphic display of the results is also added. BUG= R=cwilso@google.com, dutton@google.com, henrika@webrtc.org, juberti@webrtc.org Review URL: https://webrtc-codereview.appspot.com/5439004 git-svn-id: http://webrtc.googlecode.com/svn/trunk@5256 4adac7df-926f-26a2-2b94-8c16560cd09d
		
			
				
	
	
		
			140 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			140 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| var RTCPeerConnection = null;
 | |
| var getUserMedia = null;
 | |
| var attachMediaStream = null;
 | |
| var reattachMediaStream = null;
 | |
| var webrtcDetectedBrowser = null;
 | |
| var webrtcDetectedVersion = null;
 | |
| 
 | |
| function trace(text) {
 | |
|   // This function is used for logging.
 | |
|   if (text[text.length - 1] == '\n') {
 | |
|     text = text.substring(0, text.length - 1);
 | |
|   }
 | |
|   console.log((performance.now() / 1000).toFixed(3) + ": " + text);
 | |
| }
 | |
| 
 | |
| if (navigator.mozGetUserMedia) {
 | |
|   console.log("This appears to be Firefox");
 | |
| 
 | |
|   webrtcDetectedBrowser = "firefox";
 | |
| 
 | |
|   webrtcDetectedVersion =
 | |
|            parseInt(navigator.userAgent.match(/Firefox\/([0-9]+)\./)[1], 10);
 | |
| 
 | |
|   // The RTCPeerConnection object.
 | |
|   RTCPeerConnection = mozRTCPeerConnection;
 | |
| 
 | |
|   // The RTCSessionDescription object.
 | |
|   RTCSessionDescription = mozRTCSessionDescription;
 | |
| 
 | |
|   // The RTCIceCandidate object.
 | |
|   RTCIceCandidate = mozRTCIceCandidate;
 | |
| 
 | |
|   // Get UserMedia (only difference is the prefix).
 | |
|   // Code from Adam Barth.
 | |
|   getUserMedia = navigator.mozGetUserMedia.bind(navigator);
 | |
| 
 | |
|   // Creates iceServer from the url for FF.
 | |
|   createIceServer = function(url, username, password) {
 | |
|     var iceServer = null;
 | |
|     var url_parts = url.split(':');
 | |
|     if (url_parts[0].indexOf('stun') === 0) {
 | |
|       // Create iceServer with stun url.
 | |
|       iceServer = { 'url': url };
 | |
|     } else if (url_parts[0].indexOf('turn') === 0) {
 | |
|       if (webrtcDetectedVersion < 27) {
 | |
|         // Create iceServer with turn url.
 | |
|         // Ignore the transport parameter from TURN url for FF version <=27.
 | |
|         var turn_url_parts = url.split("?");
 | |
|         // Return null for createIceServer if transport=tcp.
 | |
|         if (turn_url_parts[1].indexOf('transport=udp') === 0) {
 | |
|           iceServer = { 'url': turn_url_parts[0],
 | |
|                         'credential': password,
 | |
|                         'username': username };
 | |
|         }
 | |
|       } else {
 | |
|         // FF 27 and above supports transport parameters in TURN url,
 | |
|         // So passing in the full url to create iceServer.
 | |
|         iceServer = { 'url': url,
 | |
|                       'credential': password,
 | |
|                       'username': username };
 | |
|       }
 | |
|     }
 | |
|     return iceServer;
 | |
|   };
 | |
| 
 | |
|   // Attach a media stream to an element.
 | |
|   attachMediaStream = function(element, stream) {
 | |
|     console.log("Attaching media stream");
 | |
|     element.mozSrcObject = stream;
 | |
|     element.play();
 | |
|   };
 | |
| 
 | |
|   reattachMediaStream = function(to, from) {
 | |
|     console.log("Reattaching media stream");
 | |
|     to.mozSrcObject = from.mozSrcObject;
 | |
|     to.play();
 | |
|   };
 | |
| 
 | |
|   // Fake get{Video,Audio}Tracks
 | |
|   if (!MediaStream.prototype.getVideoTracks) {
 | |
|     MediaStream.prototype.getVideoTracks = function() {
 | |
|       return [];
 | |
|     };
 | |
|   }
 | |
| 
 | |
|   if (!MediaStream.prototype.getAudioTracks) {
 | |
|     MediaStream.prototype.getAudioTracks = function() {
 | |
|       return [];
 | |
|     };
 | |
|   }
 | |
| } else if (navigator.webkitGetUserMedia) {
 | |
|   console.log("This appears to be Chrome");
 | |
| 
 | |
|   webrtcDetectedBrowser = "chrome";
 | |
|   webrtcDetectedVersion =
 | |
|          parseInt(navigator.userAgent.match(/Chrom(e|ium)\/([0-9]+)\./)[2], 10);
 | |
| 
 | |
|   // Creates iceServer from the url for Chrome.
 | |
|   createIceServer = function(url, username, password) {
 | |
|     var iceServer = null;
 | |
|     var url_parts = url.split(':');
 | |
|     if (url_parts[0].indexOf('stun') === 0) {
 | |
|       // Create iceServer with stun url.
 | |
|       iceServer = { 'url': url };
 | |
|     } else if (url_parts[0].indexOf('turn') === 0) {
 | |
|       // Chrome M28 & above uses below TURN format.
 | |
|       iceServer = { 'url': url,
 | |
|                     'credential': password,
 | |
|                     'username': username };
 | |
|     }
 | |
|     return iceServer;
 | |
|   };
 | |
| 
 | |
|   // The RTCPeerConnection object.
 | |
|   RTCPeerConnection = webkitRTCPeerConnection;
 | |
| 
 | |
|   // Get UserMedia (only difference is the prefix).
 | |
|   // Code from Adam Barth.
 | |
|   getUserMedia = navigator.webkitGetUserMedia.bind(navigator);
 | |
| 
 | |
|   // Attach a media stream to an element.
 | |
|   attachMediaStream = function(element, stream) {
 | |
|     if (typeof element.srcObject !== 'undefined') {
 | |
|       element.srcObject = stream;
 | |
|     } else if (typeof element.mozSrcObject !== 'undefined') {
 | |
|       element.mozSrcObject = stream;
 | |
|     } else if (typeof element.src !== 'undefined') {
 | |
|       element.src = URL.createObjectURL(stream);
 | |
|     } else {
 | |
|       console.log('Error attaching stream to element.');
 | |
|     }
 | |
|   };
 | |
| 
 | |
|   reattachMediaStream = function(to, from) {
 | |
|     to.src = from.src;
 | |
|   };
 | |
| } else {
 | |
|   console.log("Browser does not appear to be WebRTC-capable");
 | |
| }
 |