mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
Bug 792675. Part 7: Add support for MediaStream URIs to media elements. r=cpearce
--HG-- extra : rebase_source : 1c27fa7038dcdd3ab4e7eac6219b2ed5a6affa4a
This commit is contained in:
parent
8e76b2dcac
commit
6b2b2ee5c8
@ -429,9 +429,9 @@ protected:
|
||||
void SetPlayedOrSeeked(bool aValue);
|
||||
|
||||
/**
|
||||
* Initialize the media element for playback of mSrcAttrStream
|
||||
* Initialize the media element for playback of aStream
|
||||
*/
|
||||
void SetupSrcMediaStreamPlayback();
|
||||
void SetupSrcMediaStreamPlayback(nsDOMMediaStream* aStream);
|
||||
/**
|
||||
* Stop playback on mSrcStream.
|
||||
*/
|
||||
|
@ -64,6 +64,7 @@
|
||||
#include "MediaStreamGraph.h"
|
||||
#include "nsDOMMediaStream.h"
|
||||
#include "nsIScriptError.h"
|
||||
#include "nsHostObjectProtocolHandler.h"
|
||||
|
||||
#include "nsCSSParser.h"
|
||||
#include "nsIMediaList.h"
|
||||
@ -758,7 +759,7 @@ void nsHTMLMediaElement::SelectResource()
|
||||
// If we have a 'src' attribute, use that exclusively.
|
||||
nsAutoString src;
|
||||
if (mSrcAttrStream) {
|
||||
SetupSrcMediaStreamPlayback();
|
||||
SetupSrcMediaStreamPlayback(mSrcAttrStream);
|
||||
} else if (GetAttr(kNameSpaceID_None, nsGkAtoms::src, src)) {
|
||||
nsCOMPtr<nsIURI> uri;
|
||||
nsresult rv = NewURIFromString(src, getter_AddRefs(uri));
|
||||
@ -766,6 +767,7 @@ void nsHTMLMediaElement::SelectResource()
|
||||
LOG(PR_LOG_DEBUG, ("%p Trying load from src=%s", this, NS_ConvertUTF16toUTF8(src).get()));
|
||||
NS_ASSERTION(!mIsLoadingFromSourceChildren,
|
||||
"Should think we're not loading from source children by default");
|
||||
|
||||
mLoadingSrc = uri;
|
||||
if (mPreloadAction == nsHTMLMediaElement::PRELOAD_NONE) {
|
||||
// preload:none media, suspend the load here before we make any
|
||||
@ -1035,7 +1037,7 @@ nsresult nsHTMLMediaElement::LoadResource()
|
||||
mCORSMode = AttrValueToCORSMode(GetParsedAttr(nsGkAtoms::crossorigin));
|
||||
|
||||
nsHTMLMediaElement* other = LookupMediaElementURITable(mLoadingSrc);
|
||||
if (other) {
|
||||
if (other && other->mDecoder) {
|
||||
// Clone it.
|
||||
nsresult rv = InitializeDecoderAsClone(other->mDecoder);
|
||||
// Get the mimetype from the element we clone, since we will not get it via
|
||||
@ -1062,6 +1064,21 @@ nsresult nsHTMLMediaElement::LoadResource()
|
||||
return NS_ERROR_FAILURE;
|
||||
}
|
||||
|
||||
if (IsMediaStreamURI(mLoadingSrc)) {
|
||||
nsCOMPtr<nsIDOMMediaStream> stream;
|
||||
rv = NS_GetStreamForMediaStreamURI(mLoadingSrc, getter_AddRefs(stream));
|
||||
if (NS_FAILED(rv)) {
|
||||
nsCString specUTF8;
|
||||
mLoadingSrc->GetSpec(specUTF8);
|
||||
NS_ConvertUTF8toUTF16 spec(specUTF8);
|
||||
const PRUnichar* params[] = { spec.get() };
|
||||
ReportLoadError("MediaLoadInvalidURI", params, ArrayLength(params));
|
||||
return rv;
|
||||
}
|
||||
SetupSrcMediaStreamPlayback(static_cast<nsDOMMediaStream*>(stream.get()));
|
||||
return NS_OK;
|
||||
}
|
||||
|
||||
nsCOMPtr<nsILoadGroup> loadGroup = GetDocumentLoadGroup();
|
||||
|
||||
// check for a Content Security Policy to pass down to the channel
|
||||
@ -2765,11 +2782,11 @@ private:
|
||||
bool mDidHaveCurrentData;
|
||||
};
|
||||
|
||||
void nsHTMLMediaElement::SetupSrcMediaStreamPlayback()
|
||||
void nsHTMLMediaElement::SetupSrcMediaStreamPlayback(nsDOMMediaStream* aStream)
|
||||
{
|
||||
NS_ASSERTION(!mSrcStream && !mSrcStreamListener, "Should have been ended already");
|
||||
|
||||
mSrcStream = mSrcAttrStream;
|
||||
mSrcStream = aStream;
|
||||
// XXX if we ever support capturing the output of a media element which is
|
||||
// playing a stream, we'll need to add a CombineWithPrincipal call here.
|
||||
mSrcStreamListener = new StreamListener(this);
|
||||
|
@ -0,0 +1,62 @@
|
||||
<!DOCTYPE HTML>
|
||||
<html>
|
||||
<head>
|
||||
<title>Test that a MediaStream captured from one element plays back in another</title>
|
||||
<script type="text/javascript" src="/tests/SimpleTest/SimpleTest.js"></script>
|
||||
<link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css" />
|
||||
<script type="text/javascript" src="manifest.js"></script>
|
||||
</head>
|
||||
<body>
|
||||
<pre id="test">
|
||||
<script class="testbody" type="text/javascript">
|
||||
SimpleTest.waitForExplicitFinish();
|
||||
|
||||
var manager = new MediaTestManager;
|
||||
|
||||
function checkDrawImage(vout) {
|
||||
var canvas = document.createElement("canvas");
|
||||
var ctx = canvas.getContext("2d");
|
||||
ctx.drawImage(vout, 0, 0);
|
||||
var imgData = ctx.getImageData(0, 0, 1, 1);
|
||||
is(imgData.data[3], 255, "Check video frame pixel has been drawn");
|
||||
}
|
||||
|
||||
function startTest(test, token) {
|
||||
manager.started(token);
|
||||
|
||||
var v = document.createElement('video');
|
||||
var vout = document.createElement('video');
|
||||
vout.token = token;
|
||||
|
||||
v.src = test.name;
|
||||
var stream = v.mozCaptureStreamUntilEnded();
|
||||
is(stream.currentTime, 0, test.name + " stream initial currentTime");
|
||||
vout.src = URL.createObjectURL(stream);
|
||||
|
||||
var checkEnded = function(test, vout, stream) { return function() {
|
||||
is(stream.currentTime, vout.currentTime, test.name + " stream final currentTime");
|
||||
if (test.duration) {
|
||||
ok(Math.abs(vout.currentTime - test.duration) < 0.1,
|
||||
test.name + " current time at end: " + vout.currentTime + " should be: " + test.duration);
|
||||
}
|
||||
is(vout.readyState, vout.HAVE_CURRENT_DATA, test.name + " checking readyState");
|
||||
ok(vout.ended, test.name + " checking playback has ended");
|
||||
if (test.type.match(/^video/)) {
|
||||
checkDrawImage(vout);
|
||||
}
|
||||
vout.parentNode.removeChild(vout);
|
||||
URL.revokeObjectURL(vout.src);
|
||||
manager.finished(vout.token);
|
||||
}}(test, vout, stream);
|
||||
vout.addEventListener("ended", checkEnded, false);
|
||||
|
||||
document.body.appendChild(vout);
|
||||
v.play();
|
||||
vout.play();
|
||||
}
|
||||
|
||||
manager.runTests([getPlayableVideo(gSmallTests)], startTest);
|
||||
</script>
|
||||
</pre>
|
||||
</body>
|
||||
</html>
|
Loading…
Reference in New Issue
Block a user