1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
|
<!DOCTYPE HTML>
<meta charset="utf-8">
<body>
<script type="application/javascript">
function ok(expect, msg) {
window.parent.postMessage({"type": "status", status: !!expect, msg}, "*");
}
window.onmessage = function(event) {
ok(!!event.data.bitmap1, "Get the 1st ImageBitmap from the main script.");
ok(!!event.data.bitmap2, "Get the 2st ImageBitmap from the main script.");
// send the first original ImageBitmap back to the main window
window.parent.postMessage({"type":"bitmap1", "bitmap":event.data.bitmap1}, "*");
// create a new ImageBitmap from the 2nd original ImageBitmap
// and then send the newly created ImageBitmap back to the main window
var promise = createImageBitmap(event.data.bitmap2);
promise.then(
function(bitmap) {
ok(true, "Successfully create a new ImageBitmap from the 2nd original bitmap in worker.");
// send the newly created ImageBitmap back to the main window
window.parent.postMessage({"type":"bitmap2", "bitmap":bitmap}, "*");
// finish the test
window.parent.postMessage({"type": "finish"}, "*");
},
function() {
ok(false, "Cannot create a new bitmap from the original bitmap in worker.");
}
);
}
</script>
</body>
|