Skip to content

Instantly share code, notes, and snippets.

@nianxy
Created November 23, 2023 06:03
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save nianxy/7bdf3a0c439d39513ea5f79647e385c5 to your computer and use it in GitHub Desktop.
Save nianxy/7bdf3a0c439d39513ea5f79647e385c5 to your computer and use it in GitHub Desktop.
Test of Threejs sRGB texture update
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>sRGB Demo</title>
<style>
body {
/* overflow: hidden; */
border: none;
margin: 0;
background-color: #f7f5f4;
}
#container {
position: absolute;
left: 0;
top: 0;
width: 100vw;
height: 100vh;
}
#canvas {
position: absolute;
left: 0;
top: 0;
width: 100%;
height: 100%;
}
</style>
</head>
<body>
<script src="https://cdnjs.cloudflare.com/ajax/libs/three.js/0.149.0/three.min.js"></script>
<div id="container">
<canvas id="canvas"></canvas>
</div>
<script>
class App {
constructor(container, image) {
this.image = image;
this.fpsDom = document.createElement('div');
this.fpsDom.style.position = 'fixed';
this.fpsDom.style.left = '20px';
this.fpsDom.style.top = '20px';
this.fpsDom.style.backgroundColor = 'rgba(0, 0, 0, 0.7)';
this.fpsDom.style.color = '#fff';
this.fpsDom.style.padding = '5px';
this.fpsDom.innerText = '0.0'
document.body.appendChild(this.fpsDom);
this.frameCount = 0;
this.lastFpsTime = 0;
this.webglCanvas = document.getElementById('canvas');
const rect = this.webglCanvas.getBoundingClientRect();
this.webglCanvas.width = rect.width * window.devicePixelRatio;
this.webglCanvas.height = rect.height * window.devicePixelRatio;
// console.log(this.webglCanvas.width, this.webglCanvas.height);
this.initThree();
const render = () => {
const tm = performance.now();
requestAnimationFrame(render);
++this.frameCount;
const now = performance.now();
if (now - this.lastFpsTime>1000) {
this.fpsDom.innerText = (this.frameCount*1000/(now-this.lastFpsTime)).toFixed(1);
this.frameCount = 0;
this.lastFpsTime = now;
}
if (!this.videoMesh.material.map) {
this.videoMesh.material.map = new THREE.CanvasTexture(this.image);
this.videoMesh.material.map.generateMipmaps = false;
this.videoMesh.material.map.minFilter = THREE.LinearFilter;
this.videoMesh.material.map.magFilter = THREE.LinearFilter;
this.videoMesh.material.map.encoding = THREE.sRGBEncoding;
} else {
this.videoMesh.material.map.needsUpdate = true;
}
this.renderer.render(this.scene, this.camera);
// console.log('render', (performance.now() - tm).toFixed(1));
}
render();
}
initThree() {
this.renderer = new THREE.WebGLRenderer({
alpha: false,
antialias: false,
canvas: this.webglCanvas,
});
this.renderer.setPixelRatio(1);
this.renderer.setSize(this.webglCanvas.width, this.webglCanvas.height, false);
this.renderer.outputEncoding = THREE.sRGBEncoding;
this.camera = new THREE.PerspectiveCamera();
this.camera.position.set(0, 0, 1);
const geometry = new THREE.PlaneGeometry( 1, 1 );
const material = new THREE.MeshBasicMaterial();
this.videoMesh = new THREE.Mesh( geometry, material );
this.videoMesh.position.set(0, 0, 0);
this.scene = new THREE.Scene();
this.scene.add(this.videoMesh);
}
}
const container = document.getElementById('container');
const img = new Image();
img.src = '';
img.onload = () => {
const c = document.createElement('canvas');
c.width = 1080;
c.height = 1920;
c.getContext('2d').drawImage(img, 0, 0, c.width, c.height);
const app = new App(container, c);
}
</script>
</body>
</html>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment