Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add code examples #18

Merged
merged 4 commits into from
Jul 3, 2023
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
67 changes: 64 additions & 3 deletions index.html
Original file line number Diff line number Diff line change
Expand Up @@ -65,6 +65,65 @@ <h3>Use case #2: Efficiency enhancements during RTC</h3>
</p>
</section>
</section>
<section id="examples">
<h2>Examples</h2>
<p>
In the basic example below, a {{CaptureController}} is passed to
{{MediaDevices/getDisplayMedia()}}. An event handler is set on that object in order to
receive {{CapturedMouseEvent}}s with the mouse coordinates over the captured surface.
</p>
<pre class="example highlight">
try {
const controller = new CaptureController();
controller.oncapturedmousechange = (event) => {
console.log(`Mouse coordinates: x=${event.surfaceX}, y=${event.surfaceY}`);
};
let mediaStream = await navigator.mediaDevices.getDisplayMedia({ controller });
} catch (e) {
console.log(`Unable to acquire screen capture: ${e}`);
}
</pre>
<p>
In the following example, the
<a data-cite="screen-capture/#dfn-cursor">cursor constraint</a> is used to omit the cursor
from the captured display surface. The mouse coordinates are transmitted via a
<a data-cite="webrtc/#rtcdatachannel">RTCDataChannel</a> to the receiving application, which
can then redraw the cursor.
</p>
<pre class="example highlight">
// An peer-to-peer connection is established and a data channel created for
// transmitting the mouse events.
const configuration = {iceServers: [{urls: 'stun:stun.example.org'}]};
const pc = new RTCPeerConnection(configuration);
const channel = pc.createDataChannel('mouse-events', {negotiated: true, id: 0});

// On the capturing side, the capture session is initialized with the mouse
// cursor ommitted from the captured surface. The mouse coordinates are
// transmitted via the data channel.
const controller = new CaptureController();
controller.oncapturedmousechange = (event) => {
channel.send(JSON.stringify({x: event.surfaceX, y: event.surfaceY}));
};
const mediaStream = await navigator.mediaDevices.getDisplayMedia({
video: { cursor: "never" },
controller: controller,
});
pc.addTrack(mediaStream.getVideoTracks()[0], mediaStream);
...

// On the receiving side, the remote stream is rendered in a video and the
// coordinates received from the data channel are used to redraw the cursor.
const remoteView = document.getElementById('my-video-element');
channel.onmessage = ({data}) => redrawCursor(removeView, JSON.parse(data));
pc.ontrack = ({track, streams}) => {
track.onunmute = () => {
if (remoteView.srcObject) return;
remoteView.srcObject = streams[0];
};
};
...
</pre>
</section>
<section id="captured-mouse-change-event">
<h2>CapturedMouseEvent interface</h2>
<p>
Expand All @@ -89,13 +148,15 @@ <h2>CapturedMouseEvent interface</h2>
<dd>
<p>Constructs a new {{CapturedMouseEvent}}.</p>
<p>The arguments are passed as is to {{Event}}'s constructor.</p>
<p>If any of {{CapturedMouseEventInit.surfaceX}} or
{{CapturedMouseEventInit.surfaceY}} is negative, and they are not
both equal to -1, then the constructor
<p>
If any of {{CapturedMouseEventInit.surfaceX}} or {{CapturedMouseEventInit.surfaceY}} is
negative, and they are not both equal to -1, then the constructor
<a data-cite="WEBIDL#dfn-throw">throws</a> a
<a data-cite="WEBIDL#exceptiondef-rangeerror">RangeError</a>
exception.
</p>
</dd>

<dt><dfn attribute>surfaceX</dfn></dt>
<dd>
<p>
Expand Down