একবার একটি RTCPeerConnection
একটি দূরবর্তী পিয়ারের সাথে সংযুক্ত হলে, তাদের মধ্যে অডিও এবং ভিডিও স্ট্রিম করা সম্ভব। এটি সেই বিন্দু যেখানে আমরা getUserMedia()
থেকে RTCPeerConnection
এর সাথে প্রাপ্ত স্ট্রীমটিকে সংযুক্ত করি। একটি মিডিয়া স্ট্রীমে কমপক্ষে একটি মিডিয়া ট্র্যাক থাকে এবং আমরা যখন রিমোট পিয়ারে মিডিয়া ট্রান্সমিট করতে চাই তখন এগুলি আলাদাভাবে RTCPeerConnection
এ যোগ করা হয়।
const localStream = await getUserMedia({video: true, audio: true});
const peerConnection = new RTCPeerConnection(iceConfig);
localStream.getTracks().forEach(track => {
peerConnection.addTrack(track, localStream);
});
রিমোট পিয়ারের সাথে সংযুক্ত হওয়ার আগে RTCPeerConnection
এ ট্র্যাকগুলি যোগ করা যেতে পারে, তাই সংযোগ সম্পূর্ণ হওয়ার জন্য অপেক্ষা না করে যত তাড়াতাড়ি সম্ভব এই সেটআপটি সম্পাদন করা বোধগম্য।
দূরবর্তী ট্র্যাক যোগ করা হচ্ছে
অন্য পিয়ার দ্বারা যোগ করা দূরবর্তী ট্র্যাকগুলি পেতে, আমরা track
ইভেন্টের জন্য স্থানীয় RTCPeerConnection
এ একজন শ্রোতাকে রেজিস্টার করি। RTCTrackEvent
এ MediaStream
অবজেক্টের একটি অ্যারে রয়েছে যেগুলিতে পিয়ারের সংশ্লিষ্ট স্থানীয় স্ট্রিমগুলির মতো একই MediaStream.id
মান রয়েছে৷ আমাদের উদাহরণে, প্রতিটি ট্র্যাক শুধুমাত্র একটি একক প্রবাহের সাথে যুক্ত।
উল্লেখ্য যে মিডিয়াস্ট্রিম আইডি পিয়ার কানেকশনের উভয় পাশে মিলে গেলেও MediaStream
MediaStreamTrack
ক্ষেত্রে এটি সাধারণত সত্য নয়৷
const remoteVideo = document.querySelector('#remoteVideo');
peerConnection.addEventListener('track', async (event) => {
const [remoteStream] = event.streams;
remoteVideo.srcObject = remoteStream;
});