TheOneAndOnlySammy
TheOneAndOnlySammy

Reputation: 21

How to make a three.js cube have different colors on different sides?

I am new to three.js, and in a program I am creating, I would like to make different colors for different sides of the cube. The arrow keys control cube rotation. For example, could I have red on one facet, orange on another, yellow on another, green on another, blue on another, and purple on the last?

Here is the javascript code I have so far:

var scene, camera, renderer, cube;
var rotateSpeed = 0.1; // initial rotation speed
var cubeRotation = { x: 0, y: 0, z: 0 };

function createCube() {
  var geometry = new THREE.BoxGeometry( 1, 1, 1 );
  var cubeMaterial = new THREE.MeshBasicMaterial({ color: 0x00ffff })
  cube = new THREE.Mesh(geometry, cubeMaterial);
  scene.add(cube);
}
function init() {
  scene = new THREE.Scene();
  camera = new THREE.PerspectiveCamera(75, window.innerWidth / window.innerHeight, 0.1, 1000);
  camera.position.z = 5;
  renderer = new THREE.WebGLRenderer();
  renderer.setSize(window.innerWidth, window.innerHeight);
  document.body.appendChild(renderer.domElement);
  createCube();
}

function animate() {
  requestAnimationFrame(animate);

  // Update cube rotation based on arrow key input
  cube.rotation.x = cubeRotation.x;
  cube.rotation.y = cubeRotation.y;
  cube.rotation.z = cubeRotation.z;

  renderer.render(scene, camera);
}

// Function to handle key presses (arrow keys)
function onKeyDown(event) {
  switch(event.keyCode) {
    case 37: // Left arrow
      cubeRotation.y -= rotateSpeed;
      break;
    case 38: // Up arrow
      cubeRotation.x -= rotateSpeed;
      break;
    case 39: // Right arrow
      cubeRotation.y += rotateSpeed;
      break;
    case 40: // Down arrow
      cubeRotation.x += rotateSpeed;
      break;
  }
}

// Add event listener for keydown
window.addEventListener('keydown', onKeyDown, false);

// Initialize and animate
init();
animate();

Upvotes: 0

Views: 84

Answers (1)

Łukasz Daniel Mastalerz
Łukasz Daniel Mastalerz

Reputation: 2275

@Roko C. Buljan THREE.FaceColors is deprecated. And removed in r125.

Try something like this:

*{margin:0};
<script type="importmap">
  {
"imports": {
  "three": "https://unpkg.com/[email protected]/build/three.module.js",
  "three/addons/": "https://unpkg.com/[email protected]/examples/jsm/"
}
  }
</script>

<script type="module">
import * as THREE from "three";
import { OrbitControls } from 'three/addons/controls/OrbitControls.js';

var scene, camera, renderer, cube;

var rotateSpeed = 0.1;

var cubeRotation = { x: 0, y: 0, z: 0 };

function createCube() {

  var geometry = new THREE.BoxGeometry(1, 1, 1);

  var materials = [

new THREE.MeshBasicMaterial({ color: 0xff0000 }),

new THREE.MeshBasicMaterial({ color: 0xffa500 }),

new THREE.MeshBasicMaterial({ color: 0xffff00 }),

new THREE.MeshBasicMaterial({ color: 0x008000 }),

new THREE.MeshBasicMaterial({ color: 0x0000ff }),

new THREE.MeshBasicMaterial({ color: 0x800080 })

  ];

  cube = new THREE.Mesh(geometry, materials);

  scene.add(cube);

}

function init() {

  scene = new THREE.Scene();

  camera = new THREE.PerspectiveCamera(75, window.innerWidth / window.innerHeight, 0.1, 1000);

  camera.position.z = 5;

renderer = new THREE.WebGLRenderer();

  renderer.setSize(window.innerWidth, window.innerHeight);

  document.body.appendChild(renderer.domElement);

  var controls = new OrbitControls(camera, renderer.domElement);

  createCube();

}

function animate() {

  requestAnimationFrame(animate);

  cube.rotation.x = cubeRotation.x;

  cube.rotation.y = cubeRotation.y;

  cube.rotation.z = cubeRotation.z;

  renderer.render(scene, camera);

}

function onKeyDown(event) {

  switch (event.keyCode) {

case 37:

  cubeRotation.y -= rotateSpeed;

  break;

case 38:

  cubeRotation.x -= rotateSpeed;

  break;
case 39:

  cubeRotation.y += rotateSpeed;

  break;

case 40:

  cubeRotation.x += rotateSpeed;

  break;

  }

}

window.addEventListener('keydown', onKeyDown, false);

init();

animate();

</script>

Upvotes: 1

Related Questions