Я пытаюсь вложить средство просмотра 3D-модели в адаптивный макет с другой информацией, например текстом. Я использовал window.innerWidth и window.innerHeight, но затем я переключился на .clientWidth и .clientHeight, чтобы размер рендеринга контролировался css, но он не рендерится.
Я использовал этот сайт для помощи https://greggman.com/downloads/examples/three-by-css/three-by-css.html
<!DOCTYPE html>
<html>
<head>
<title>threejs - basic</title>
<style type="text/css">
body{
margin: 0;
overflow: hidden;
}
canvas{
display: inline-block;
background: red;
width: 40%;
height: 40%;
}
</style>
</head>
<body>
<canvas id="myCanvas"></canvas>
<canvas>
<p>hi</p>
</canvas>
<canvas id="myCanvas"></canvas>
<canvas id="myCanvas"></canvas>
<canvas id="myCanvas"></canvas>
<script src="https://cdnjs.cloudflare.com/ajax/libs/three.js/95/three.js"></script>
<script >
var renderer,
scene,
camera,
myCanvas = document.getElementById('myCanvas');
//Renderer
renderer = new THREE.WebGLRenderer({canvas: myCanvas, antialias: true});
renderer.setClearColor(0x000000);
renderer.setPixelRatio(window.devicePixelRatio);
renderer.setSize(canvas.clientWidth, window.clientHeight);
//Camera
camera = new THREE.PerspectiveCamera(50, canvas.clientWidth / window.clientHeight, .01, 3000);
//Scene
scene = new THREE.Scene();
//Lights
var light = new THREE.AmbientLight(0xffffff, 0.5);
scene.add(light);
var light2= new THREE.PointLight(0xffffff, 0.5);
scene.add(light2);
var geometry = new THREE.BoxGeometry(100,100);
//Geometry Material
var material = new THREE.MeshLambertMaterial({color:0xF3FFE2});
var mesh = new THREE.Mesh(geometry, material);
mesh.position.z = -1000;
scene.add(mesh);
//RenderLoop
render();
var delta = 0;
function render(){
//RotateMeshes
mesh.rotation.x += .0001
mesh.rotation.y += .001
mesh.rotation.z += .001
//ActiveVertices
delta += 0.1;
geometry.vertices[0].x = -25 + Math.sin(delta) * 50;
geometry.verticesNeedUpdate = true;
renderer.render(scene, camera);
requestAnimationFrame(render);
};
</script>
</body>
</html>