blob: 0a1f9b6e0c2a4eb9f31699409038c2ec70ee8ab7 [file] [log] [blame]
<!DOCTYPE html>
<title>Texture demos</title>
<meta charset="utf-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<script type="text/javascript" src="https://particles.skia.org/dist/canvaskit.js"></script>
<style>
canvas {
border: 1px dashed grey;
}
#sourceImage, #sourceVideo {
width: 100px;
height: 100px;
border: 1px solid red;
cursor: pointer;
}
</style>
<body>
<h1>User Defined Textures</h1>
<p>Tap on one of the texture sources to switch to it.</p>
<canvas id=draw width=500 height=500></canvas>
<img id="sourceImage" src="/demos/textures/testimg.png">
<video id="sourceVideo" autoplay muted></video>
</body>
<script type="text/javascript" charset="utf-8">
const ckLoaded = CanvasKitInit({ locateFile: (file) => 'https://particles.skia.org/dist/' + file });
const canvasEle = document.getElementById('draw');
const imgEle = document.getElementById('sourceImage');
const videoEle = document.getElementById('sourceVideo');
// Links the web cam to the video element.
navigator.mediaDevices.getUserMedia({ video: true }).then((stream) => {
videoEle.srcObject = stream;
}).catch((err) => {
console.error("Could not set up video", err);
});
// Enables switching between texture sources.
let srcEle = imgEle;
imgEle.addEventListener('click', () => {
srcEle = imgEle;
});
videoEle.addEventListener('click', () => {
srcEle = videoEle;
});
Promise.all([
ckLoaded,
imgEle.decode(),
]).then(([
CanvasKit,
shouldBeNull,
]) => {
const surface = CanvasKit.MakeCanvasSurface('draw');
if (!surface) {
throw 'Could not make surface';
}
const paint = new CanvasKit.Paint();
// This image will have its underlying texture re-used once per frame.
const img = surface.makeImageFromTextureSource(srcEle);
let lastTS = Date.now();
function drawFrame(canvas) {
const now = Date.now();
canvas.rotate(10 * (now - lastTS) / 1000, 250, 250);
lastTS = now;
// Re-use the image's underlying texture, but replace the contents of the old texture
// with the contents of srcEle
surface.updateTextureFromSource(img, srcEle);
canvas.clear(CanvasKit.Color(200, 200, 200));
canvas.drawImage(img, 5, 5, paint);
surface.requestAnimationFrame(drawFrame);
}
surface.requestAnimationFrame(drawFrame);
});
</script>