Embed: allow webrtc to change playback rate
This commit is contained in:
		
							parent
							
								
									7557cacc17
								
							
						
					
					
						commit
						8a68738995
					
				
					 4 changed files with 41 additions and 4 deletions
				
			
		
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							|  | @ -420,7 +420,9 @@ var MistUtil = { | ||||||
|       }, |       }, | ||||||
|       sanitizeHost: function(host){ |       sanitizeHost: function(host){ | ||||||
|         var split = MistUtil.http.url.split(host); |         var split = MistUtil.http.url.split(host); | ||||||
|         return split.protocol + "//" + split.host + (split.port && (split.port != "") ? ":"+split.port : "") + (split.hash && (split.hash != "") ? "#"+split.hash : "") + (split.path ? split.path : ""); |         var out = split.protocol + "//" + split.host + (split.port && (split.port != "") ? ":"+split.port : "") + (split.hash && (split.hash != "") ? "#"+split.hash : "") + (split.path ? (split.path.charAt(0) == "/" ? split.path : "/"+split.path) : ""); | ||||||
|  |         console.log("converted",host,"to",out); | ||||||
|  |         return out; | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   }, |   }, | ||||||
|  |  | ||||||
|  | @ -136,9 +136,15 @@ p.prototype.build = function (MistVideo,callback) { | ||||||
|         currenttracks = ev.tracks; |         currenttracks = ev.tracks; | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     on_seek: function(){ |     on_seek: function(e){ | ||||||
|       var thisPlayer = this; |       var thisPlayer = this; | ||||||
|       MistUtil.event.send("seeked",seekoffset,video); |       MistUtil.event.send("seeked",seekoffset,video); | ||||||
|  |        | ||||||
|  |       //set playback rate to auto if seek was to live point
 | ||||||
|  |       if (e.live_point) { | ||||||
|  |         thisPlayer.webrtc.playbackrate("auto"); | ||||||
|  |       } | ||||||
|  |        | ||||||
|       if ("seekPromise" in this.webrtc.signaling){ |       if ("seekPromise" in this.webrtc.signaling){ | ||||||
|         video.play().then(function(){ |         video.play().then(function(){ | ||||||
|           if ("seekPromise" in thisPlayer.webrtc.signaling) { |           if ("seekPromise" in thisPlayer.webrtc.signaling) { | ||||||
|  | @ -152,6 +158,10 @@ p.prototype.build = function (MistVideo,callback) { | ||||||
|       } |       } | ||||||
|       else { video.play(); } |       else { video.play(); } | ||||||
|     }, |     }, | ||||||
|  |     on_speed: function(e){ | ||||||
|  |       this.webrtc.play_rate = e.play_rate_curr; | ||||||
|  |       MistUtil.event.send("ratechange",e,video); | ||||||
|  |     }, | ||||||
|     on_stop: function(){ |     on_stop: function(){ | ||||||
|       MistVideo.log("Websocket sent on_stop"); |       MistVideo.log("Websocket sent on_stop"); | ||||||
|       MistUtil.event.send("ended",null,video); |       MistUtil.event.send("ended",null,video); | ||||||
|  | @ -164,6 +174,7 @@ p.prototype.build = function (MistVideo,callback) { | ||||||
|     this.peerConn = null; |     this.peerConn = null; | ||||||
|     this.localOffer = null; |     this.localOffer = null; | ||||||
|     this.isConnected = false; |     this.isConnected = false; | ||||||
|  |     this.play_rate = "auto"; | ||||||
|     var thisWebRTCPlayer = this; |     var thisWebRTCPlayer = this; | ||||||
|      |      | ||||||
|     this.on_event = function(ev) { |     this.on_event = function(ev) { | ||||||
|  | @ -256,6 +267,19 @@ p.prototype.build = function (MistVideo,callback) { | ||||||
|       obj.type = "tracks"; |       obj.type = "tracks"; | ||||||
|       this.signaling.send(obj); |       this.signaling.send(obj); | ||||||
|     }; |     }; | ||||||
|  |     this.playbackrate = function(value) { | ||||||
|  |       if (typeof value == "undefined") { | ||||||
|  |         return (me.webrtc.play_rate == "auto" ? 1 : me.webrtc.play_rate); | ||||||
|  |       } | ||||||
|  |        | ||||||
|  |       if (!this.isConnected) { throw "Not connected, cannot change playback rate." } | ||||||
|  |        | ||||||
|  |       this.signaling.send({ | ||||||
|  |         type: "set_speed", | ||||||
|  |         play_rate: value | ||||||
|  |       }); | ||||||
|  |        | ||||||
|  |     }; | ||||||
|     this.getStats = function(callback){ |     this.getStats = function(callback){ | ||||||
|       this.peerConn.getStats().then(function(d){ |       this.peerConn.getStats().then(function(d){ | ||||||
|         var output = {}; |         var output = {}; | ||||||
|  | @ -342,6 +366,17 @@ p.prototype.build = function (MistVideo,callback) { | ||||||
|     } |     } | ||||||
|   }); |   }); | ||||||
|    |    | ||||||
|  |   //override playbackrate
 | ||||||
|  |   Object.defineProperty(this.api,"playbackRate",{ | ||||||
|  |     get: function(){ | ||||||
|  |       return me.webrtc.playbackrate(); | ||||||
|  |     }, | ||||||
|  |     set: function(value){ | ||||||
|  |       return me.webrtc.playbackrate(value); | ||||||
|  |       //TODO send playbackrate changed event?
 | ||||||
|  |     } | ||||||
|  |   }); | ||||||
|  |    | ||||||
|   //redirect properties
 |   //redirect properties
 | ||||||
|   //using a function to make sure the "item" is in the correct scope
 |   //using a function to make sure the "item" is in the correct scope
 | ||||||
|   function reroute(item) { |   function reroute(item) { | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Cat
						Cat