वेबआरटीसी - मीडियास्ट्रीम एपीआई

MediaStream API को स्थानीय कैमरा और माइक्रोफोन से मीडिया स्ट्रीम को आसानी से एक्सेस करने के लिए डिज़ाइन किया गया था। GetUserMedia () विधि स्थानीय इनपुट डिवाइस का उपयोग करने की प्राथमिक तरीका है।

एपीआई के कुछ प्रमुख बिंदु हैं -

  • एक वास्तविक समय मीडिया स्ट्रीम वीडियो या ऑडियो के रूप में एक स्ट्रीम ऑब्जेक्ट द्वारा दर्शाया जाता है

  • यह उपयोगकर्ता अनुमतियों के माध्यम से एक सुरक्षा स्तर प्रदान करता है, जिससे उपयोगकर्ता वेब एप्लिकेशन को स्ट्रीम शुरू करने से पहले पूछ सकता है

  • इनपुट उपकरणों का चयन मीडियास्ट्रीम एपीआई द्वारा किया जाता है (उदाहरण के लिए, जब डिवाइस से जुड़े दो कैमरे या माइक्रोफोन हैं)

प्रत्येक MediaStream ऑब्जेक्ट में कई MediaStreamTrack ऑब्जेक्ट शामिल हैं। वे विभिन्न इनपुट उपकरणों से वीडियो और ऑडियो का प्रतिनिधित्व करते हैं।

प्रत्येक MediaStreamTrack ऑब्जेक्ट में कई चैनल (दाएं और बाएं ऑडियो चैनल) शामिल हो सकते हैं। ये MediaStream API द्वारा परिभाषित सबसे छोटे भाग हैं।

MediaStream ऑब्जेक्ट को आउटपुट करने के दो तरीके हैं। सबसे पहले, हम एक वीडियो या ऑडियो तत्व में आउटपुट प्रस्तुत कर सकते हैं। दूसरे, हम आउटपुट को RTCPeerConnection ऑब्जेक्ट में भेज सकते हैं, जो फिर इसे एक दूरस्थ सहकर्मी को भेजते हैं।

MediaStream API का उपयोग करना

चलो एक सरल WebRTC एप्लिकेशन बनाएं। यह स्क्रीन पर एक वीडियो तत्व दिखाएगा, कैमरा का उपयोग करने के लिए उपयोगकर्ता की अनुमति मांगेगा, और ब्राउज़र में एक लाइव वीडियो स्ट्रीम दिखाएगा। एक index.html फ़ाइल बनाएँ -

<!DOCTYPE html> 
<html lang = "en">
 
   <head> 
      <meta charset = "utf-8" /> 
   </head> 
	
   <body> 
      <video autoplay></video> 
      <script src = "client.js"></script> 
   </body>
	
</html>

फिर client.js फ़ाइल बनाएं और निम्नलिखित जोड़ें;

function hasUserMedia() { 
   //check if the browser supports the WebRTC 
   return !!(navigator.getUserMedia || navigator.webkitGetUserMedia || 
      navigator.mozGetUserMedia); 
} 

if (hasUserMedia()) { 
   navigator.getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia
      || navigator.mozGetUserMedia; 
		
   //enabling video and audio channels 
   navigator.getUserMedia({ video: true, audio: true }, function (stream) { 
      var video = document.querySelector('video'); 
		
      //inserting our stream to the video tag     
      video.src = window.URL.createObjectURL(stream); 
   }, function (err) {}); 
} else { 
   alert("WebRTC is not supported"); 
}

यहां हम hasUserMedia () फ़ंक्शन बनाते हैं जो यह जांचता है कि WebRTC समर्थित है या नहीं। फिर हम getUserMedia फ़ंक्शन का उपयोग करते हैं जहां दूसरा पैरामीटर एक कॉलबैक है जो उपयोगकर्ता के डिवाइस से आने वाली धारा को स्वीकार करता है। फिर हम अपनी स्ट्रीम को window.URL.createObjectURL का उपयोग करते हुए वीडियो एलिमेंट में लोड करते हैं जो एक URL बनाता है जो पैरामीटर में दी गई ऑब्जेक्ट का प्रतिनिधित्व करता है।

अब अपने पृष्ठ को ताज़ा करें, अनुमति दें पर क्लिक करें, और आपको स्क्रीन पर अपना चेहरा देखना चाहिए।

वेब सर्वर का उपयोग करके अपनी सभी लिपियों को चलाना याद रखें। हम पहले से ही WebRTC पर्यावरण ट्यूटोरियल में एक स्थापित कर चुके हैं।

मीडियास्ट्रीम एपीआई

गुण

  • MediaStream.active (read only) - अगर मीडियास्ट्रीम सक्रिय है, या असत्य है तो सही है।

  • MediaStream.ended (read only, deprecated)- अगर वस्तु पर समाप्त घटना को निकाल दिया गया है, तो सही लौटें , जिसका अर्थ है कि धारा पूरी तरह से पढ़ी गई है, या गलत है अगर धारा का अंत नहीं हुआ है।

  • MediaStream.id (read only) - वस्तु के लिए एक विशिष्ट पहचानकर्ता।

  • MediaStream.label (read only, deprecated) - उपयोगकर्ता एजेंट द्वारा निर्दिष्ट एक अद्वितीय पहचानकर्ता।

आप देख सकते हैं कि मेरे ब्राउज़र में उपरोक्त गुण कैसे दिखते हैं -

इवेंट हैंडलर

  • MediaStream.onactive- एक सक्रिय घटना के लिए एक हैंडलर जिसे निकाल दिया जाता है जब एक MediaStream ऑब्जेक्ट सक्रिय हो जाता है।

  • MediaStream.onaddtrack- जब एक नया MediaStreamTrack ऑब्जेक्ट जोड़ा जाता है , तो एक एडट्रैक इवेंट के लिए एक हैंडलर ।

  • MediaStream.onended (deprecated)- समाप्त होने वाली घटना के लिए एक हैंडलर जिसे स्ट्रीमिंग समाप्त होने पर निकाल दिया जाता है।

  • MediaStream.oninactive- एक निष्क्रिय घटना के लिए एक हैंडलर जिसे निकाल दिया जाता है जब एक MediaStream ऑब्जेक्ट निष्क्रिय हो जाता है।

  • MediaStream.onremovetrack- जब एक MediaStreamTrack ऑब्जेक्ट को इससे निकाल दिया जाता है, तो एक निकालने वाली घटना के लिए एक हैंडलर को निकाल दिया जाता है।

तरीकों

  • MediaStream.addTrack()- MediaStreamTrack ऑब्जेक्ट को MediaStream के तर्क के रूप में जोड़ता है । यदि ट्रैक पहले ही जोड़ दिया गया है, तो कुछ भी नहीं होता है।

  • MediaStream.clone() - एक नई आईडी के साथ MediaStream ऑब्जेक्ट का क्लोन लौटाता है।

  • MediaStream.getAudioTracks()- रिटर्न ऑडियो की एक सूची MediaStreamTrack से वस्तुओं MediaStream वस्तु।

  • MediaStream.getTrackById()- आईडी द्वारा ट्रैक लौटाता है। यदि तर्क रिक्त है या ID नहीं मिला है, तो यह रिक्त हो जाता है। यदि कई ट्रैक्स में एक ही आईडी है, तो यह पहले वाला है।

  • MediaStream.getTracks()- रिटर्न सभी की एक सूची MediaStreamTrack से वस्तुओं MediaStream वस्तु।

  • MediaStream.getVideoTracks()- वीडियो की एक सूची देता है MediaStreamTrack से वस्तुओं MediaStream वस्तु।

  • MediaStream.removeTrack()- MediaStream से दिए गए तर्क के रूप में दिए गए MediaStreamTrack ऑब्जेक्ट को हटा देता है । यदि ट्रैक पहले ही हटा दिया गया है, तो कुछ भी नहीं होता है।

उपरोक्त एपीआई का परीक्षण करने के लिए निम्नलिखित में से index.html को बदलें।

<!DOCTYPE html> 
<html lang = "en">
 
   <head> 
      <meta charset = "utf-8" /> 
   </head>
	
   <body> 
      <video autoplay></video> 
      <div><button id = "btnGetAudioTracks">getAudioTracks()
         </button></div> 
      <div><button id = "btnGetTrackById">getTrackById()
         </button></div> 
      <div><button id = "btnGetTracks">getTracks()</button></div> 
      <div><button id = "btnGetVideoTracks">getVideoTracks()
         </button></div> 
      <div><button id = "btnRemoveAudioTrack">removeTrack() - audio
         </button></div> 
      <div><button id = "btnRemoveVideoTrack">removeTrack() - video
         </button></div> 
      <script src = "client.js"></script> 
   </body> 
	
</html>

हमने कई MediaStream API को आज़माने के लिए कुछ बटन जोड़े। फिर हमें अपने नए बनाए गए बटन के लिए ईवेंट हैंडलर जोड़ना चाहिए। संशोधित client.js इस तरह से फाइल -

var stream;
  
function hasUserMedia() { 
   //check if the browser supports the WebRTC 
   return !!(navigator.getUserMedia || navigator.webkitGetUserMedia || 
      navigator.mozGetUserMedia); 
} 
 
if (hasUserMedia()) {
   navigator.getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia
      || navigator.mozGetUserMedia; 
		
   //enabling video and audio channels 
   navigator.getUserMedia({ video: true, audio: true }, function (s) { 
      stream = s; 
      var video = document.querySelector('video'); 
		
      //inserting our stream to the video tag     
      video.src = window.URL.createObjectURL(stream); 
   }, function (err) {}); 
	
} else { 
   alert("WebRTC is not supported"); 
}
  
btnGetAudioTracks.addEventListener("click", function(){ 
   console.log("getAudioTracks"); 
   console.log(stream.getAudioTracks()); 
});
  
btnGetTrackById.addEventListener("click", function(){ 
   console.log("getTrackById"); 
   console.log(stream.getTrackById(stream.getAudioTracks()[0].id)); 
});
  
btnGetTracks.addEventListener("click", function(){ 
   console.log("getTracks()"); 
   console.log(stream.getTracks()); 
});
 
btnGetVideoTracks.addEventListener("click", function(){ 
   console.log("getVideoTracks()"); 
   console.log(stream.getVideoTracks()); 
});

btnRemoveAudioTrack.addEventListener("click", function(){ 
   console.log("removeAudioTrack()"); 
   stream.removeTrack(stream.getAudioTracks()[0]); 
});
  
btnRemoveVideoTrack.addEventListener("click", function(){ 
   console.log("removeVideoTrack()"); 
   stream.removeTrack(stream.getVideoTracks()[0]); 
});

अब अपने पेज को रिफ्रेश करें। पर क्लिक करें getAudioTracks () बटन, फिर पर क्लिक करें ऑडियो - removeTrack () बटन। ऑडियो ट्रैक को अब हटा दिया जाना चाहिए। फिर वीडियो ट्रैक के लिए भी ऐसा ही करें।

यदि आप getTracks () बटन पर क्लिक करते हैं तो आपको सभी MediaStreamTracks (सभी कनेक्टेड वीडियो और ऑडियो इनपुट) को देखना चाहिए । इसके बाद getTrackById () पर क्लिक करके ऑडियो मीडियास्ट्रीमट्रैक प्राप्त करें।

सारांश

इस अध्याय में, हमने MediaStream API का उपयोग करके एक सरल WebRTC एप्लिकेशन बनाया। अब आपके पास WebRTC कार्य करने वाले विभिन्न MediaStream API का स्पष्ट अवलोकन होना चाहिए।