I am currently experimenting with ThreeJS decals. I have successfully added a stunning decal to my sphere.
Below is the code snippet I am using to place the decal on my sphere. (Please disregard any custom classes mentioned in the code.)
// Creating the sphere
var mainMesh = new THREE.Mesh(
new THREE.SphereGeometry(7, 16, 16),
new THREE.MeshBasicMaterial({ color: 0x00a1fd })
);
// Defining the decal material
var decalMaterial = new THREE.MeshPhongMaterial({
color : 0xff0000,
specular : 0x444444,
map : TextureLoader.instance.getTexture('http://threejs.org/examples/textures/decal/decal-diffuse.png'),
normalMap : TextureLoader.instance.getTexture('http://threejs.org/examples/textures/decal/decal-normal.jpg'),
normalScale : new THREE.Vector2( 1, 1 ),
shininess : 30,
transparent : true,
depthTest : true,
depthWrite : false,
polygonOffset : true,
polygonOffsetFactor : -4,
wireframe : false
});
// Creating the decal itself
var decal = new THREE.Mesh(
new THREE.DecalGeometry(
mainMesh,
new THREE.Vector3(0, 2.5, 3),
new THREE.Vector3(0, 0, 0),
new THREE.Vector3(8, 8, 8),
new THREE.Vector3(1, 1, 1)
),
decalMaterial.clone()
);
// Adding mesh, decal, and helpers to the scene
scene.add(
mainMesh,
new THREE.HemisphereLight(0xffffff, 0, 1),
decal,
new THREE.WireframeHelper(decal, 0xffff00)
);
decal.add(new THREE.BoxHelper(decal, 0xffff00));
Now, I want to move this decal on my sphere and update the decal geometry accordingly.
However, when I call decal.geometry.computeDecal()
, the decal mesh does not update. I am unable to find a solution to this issue.
function moveDecal()
{
decal.translateX(1);
decal.geometry.computeDecal();
};
As per the DecalGeometry
class, the computeDecal
function should update various elements like vertices, colors, UVs, etc.
this.computeDecal = function() {
// [...]
this.verticesNeedUpdate = true;
this.elementsNeedUpdate = true;
this.morphTargetsNeedUpdate = true;
this.uvsNeedUpdate = true;
this.normalsNeedUpdate = true;
this.colorsNeedUpdate = true;
};
Any assistance on this matter would be greatly appreciated! :D
PS: ThreeJS r80