This section describes the status of this document at the time of its publication. Other documents may supersede this document. A list of current W3C publications and the latest revision of this technical report can be found in the W3C technical reports index at http://www.w3.org/TR/.
This document is not complete. It is subject to major changes and, while early experimentations are encouraged, it is therefore not intended for implementation. The Media Capture Task Force expects this specification to evolve significantly based on:
This document was published by the Web Real-Time Communication Working Group as an Editor's Draft. If you wish to make comments regarding this document, please send them to public-media-capture@w3.org (subscribe, archives). All feedback is welcome.
Publication as an Editor's Draft does not imply endorsement by the W3C Membership. This is a draft document and may be updated, replaced or obsoleted by other documents at any time. It is inappropriate to cite this document as other than work in progress.
This document was produced by a group operating under the 5 February 2004 W3C Patent Policy. W3C maintains a public list of any patent disclosures (Web Real-Time Communication Working Group, Device APIs Working Group) made in connection with the deliverables of the group; that page also includes instructions for disclosing a patent. An individual who has actual knowledge of a patent which the individual believes contains Essential Claim(s) must disclose the information in accordance with section 6 of the W3C Patent Policy.
This proposal attempts to make basic recording very simple, while still allowing for more complex use cases. In the simplest case, the application instatiates the MediaRecorder object, calls record() and then calls stopRecord() or waits for the MediaStream to be ended. The contents of the recording will be made available in the platform's default encoding via the dataavailable event. Functions are available to query the platform's available set of encodings, and to select the desired ones if the author wishes. The application can also choose how much data it wants to receive at one time. By default a Blob containing the entire recording is returned when the recording finishes. However the application can choose to receive smaller buffers of data at regular intervals.
[Constructor (MediaStream stream)]
interface MediaRecorder : EventTarget {
readonly attribute MediaStream
mediaStream;
readonly attribute Boolean
recording;
readonly attribute Boolean
paused;
attribute EventHandler
onrecording;
attribute EventHandler
onpaused;
attribute EventHandler
onresume;
attribute EventHandler
onstoprecording;
attribute EventHandler
ondataavailable;
attribute EventHandler
onrecordingerror;
attribute EventHandler
onrecordingerrorwithdata;
attribute EventHandler
onrecordingwarning;
void record (optional long timeSlice);
void pauseRecording ();
void resumeRecording ();
void stopRecording ();
void requestData();
AvailableRecordingFormats getRecordingOptions ();
void setRecordingOptions (RecordingFormat RequestedFormats);
};
The MediaRecorder()
constructor takes one argument which
must be of type MediaStream
(see Media-Capture). When the constructor
is invoked, the UA must construct a new MediaRecorder
object,
set its mediaStream attribute to be the provided MediaStream, set its recording attribute to 'false'
and return the object.
mediaStream
of type MediaStream
, readonlyThe MediaStream passed in to the constructor.
recording
of type Boolean
, readonlyTrue if 'record()' has been called and not stopped. Otherwise False.
paused
of type Boolean
, readonlyTrue if 'pause()' has been called and gathering of data has paused. Otherwise False.
onrecording
of type EventHandler
Called to handle the recording event.
onpaused
of type EventHandler
Called to handle the paused event.
onresume
of type EventHandler
Called to handle the resume event.
onstoprecording
of type EventHandler
Called to handle the stoprecording event.
ondataavailable
of type EventHandler
Called to handle the dataavailable event. Note that the Blob (see FILEAPI) of recorded data is contained in this event and can be accessed via the 'detail' attribute.
onrecordingerror
of type EventHandler
Called to handle the recordingerror event.
onrecordingerrorwithdata
of type EventHandler
Called to handle the recordingerrorwithdata event when data is returned. Note that a Blob (see FILEAPI) of data recorded up to time of the error occurrence is contained in this event and can be accessed via the 'data' attribute. More detailed error information is available in the 'detail' attribute.
onrecordingwarning
of type EventHandler
Called to handle the recordingwarning event.
record
When a
object’s MediaRecorder
record()
method is invoked,
the user agent must queue a task that runs the following steps:
recordingwarning
event and abort these steps.recording
event and start gathering the
data into a Blob (see FILEAPI). timeSlice
argument has been provided, then once timeSlice
milliseconds of data have been colleced, raise a dataavailable
event containing
the Blob of collected data, and start gathering a new Blob of data. Otherwise (if timeSlice
has not been provided), continue gathering data into the original Blob.dataavailable
event containing the Blob of data.stoprecording
event.Note that the stopRecording()
, pauseRecording()
and
requestData()
also affect the recording behavior.
The UA must record the MediaStream
in such a way that the original Tracks can be retrieved at playback time. If any Track within the
MediaStream is muted, the UA
must insert black frames or silence until the Track is unmuted. If the UA is
unable to start recording or at any point is unable to contine recording, it must raise
a recordingerror
event, follwowed by a dataavailable
event containing
the Blob it has gathered, follwed by the stoprecording
event.
pauseRecording
When a
object’s MediaRecorder
pauseRecording
method is invoked,
the user agent must queue a task that runs the following steps:
resumeRecording
When a
object’s MediaRecorder
resumeRecording
method is invoked,
the user agent must queue a task that runs the following steps:
stopRecording
When a
object’s MediaRecorder
stopRecording
method is invoked,
the user agent must queue a task that runs the following steps:
requestData
When a
object’s MediaRecorder
requestData()
method is invoked,
the user agent must queue a task that runs the following steps:
recordingwarning
event and abort these steps.dataavailable
event containing the current Blob of saved data.getRecordingOptions
When a
object’s MediaRecorder
getRecordingOptions()
method is invoked,
the user agent must return a
availableRecordingFormats structure
containing the set of recording formats that it supports.
setRecordingOptions
When a
object’s MediaRecorder
setRecordingOptions()
method is invoked,
the user agent must run the following steps:
recordingwarning
event and abort these steps.requestedFormats
argument,
if the UA does not support it, raise a recordingwarning
event, set encodings
back to its value in step 2, and terminate these steps. Otherwise
replace the corresponding member of encodings with the specified value.AvailableRecordingFormats
dictionary AvailableRecordingFormats {
sequence<DOMString> containerEncodingFormats;
sequence<DOMString> audioEncodingFormats;
sequence<DOMString> videoEncodingFormats;
sequence<VideoRecordingDimension> videoRecordingDimensionOptions;
};
containerEncodingFormats
of type sequence<DOMtring>
A list of the container encoding formats that the platform supports.
audioEncodingFormats
of type sequence<DOMtring>
A list of the audio encoding formats that the platform supports.
videoEncodingFormats
of type sequence<DOMtring>
A list of the video encoding formats that the platform supports.
videoRecordingDimensionOptions
of type sequence<VideoRecordingDimension>
A list of the video recording dimension options that the platform supports.
The UA must be able to play back any encoding format that it can record into. The UA must support a container format capable of holding at least two video Tracks and two audio Tracks.
If videoRecordingDimensionFormats
is not specified, then a platform default option for video recording dimensions must be used.
VideoRecordingDimension
dictionary RecordingFormat {
<unsigned long> width;
<unsigned long> height;
};
width
of type <DOMtring>
A width option of a width/height pair for video recording that the platform supports.
height
of type <DOMtring>
A height option of a width/height pair for video recording that the platform supports.
RecordingFormat
dictionary RecordingFormat {
<DOMString> containerEncodingFormat;
<DOMString> audioEncodingFormat;
<DOMString> videoEncodingFormat;
<VideoRecordingDimension> videoDimension;
};
containerEncodingFormat
of type <DOMtring>
The container encoding format to use for recording. If it is not specified, the platform default will be used.
audioEncodingFormat
of type <DOMtring>
The audio encoding format to use for recording. If it is not specified, the platform default will be used.
videoEncodingFormat
of type <DOMtring>
The video encoding format to use for recording. If it is not specified, the platform default will be used.
videoDimension
of type <VideoRecordingDimension>
The length/width pair to use for recording. If it is not specified, the platform default will be used.
If a fatal error occurs while recording is occuring, the UA must raise a recordingerror, followed by a dataavailable event, containing any data that it has gathered, and then a recordingdone event. The UA may set platform-specific limits, such those for the minimum and maximum Blob size that it will support, or the number of Tracks it will record at once. It must signal a fatal error if these limits are exceeded. If a non-fatal error occurs during recording, the UA should raise a recordingwarning event, with data indicating the nature of the problem, and continue recording.
The following additional events fire on
objects:MediaRecorder
Event name | Interface | Fired when... |
---|---|---|
recording |
Event |
The UA has started recording data on the Track. |
paused |
Event |
The UA has paused recording data on the Stream. |
resume |
Event |
The UA has resumed a previously-paused recording. |
stoprecording |
Event |
The UA has stopped recording data on the Track. |
dataavailable |
CustomEvent |
The UA returns data to the application. This 'detail' attribute of this event contains a Blob of recorded data. |
recordingerror |
CustomEvent |
A fatal error has occurred and the UA has stopped recording. More detailed error information is available in the 'detail' attribute. |
recordingerrorwithdata |
CustomEvent |
A fatal error has occurred and the UA has stopped recording, but recorded data up to the time of the error is being returned in the 'data' attribute. More detailed error information is available in the 'detail' attribute. |
recordingwarning |
CustomEvent |
A problem has occurred, but the UA has not stopped recording. More detailed information is available in the 'detail' attribute. |
Upon an error event occuring, a common set of error codes must be returned in the 'detail' attribute.
[NoInterfaceObject] interface detail { const unsigned short UNKNOWN_ERROR = 1; const unsigned short MEMORY_UNAVAILABLE = 2; const unsigned short DEVICE_ERROR = 3; readonly attribute unsigned short code; };
The code
attribute must return the
appropriate code from the following list:
UNKNOWN_ERROR
(numeric value 1)
MEMORY_UNAVAILABLE
(numeric value 2)
DEVICE_ERROR
(numeric value 3)