-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy paththree-demo.html
108 lines (83 loc) · 3.48 KB
/
three-demo.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
<html>
<head>
<script src="https://aframe.io/releases/1.3.0/aframe.min.js"></script>
<script async src="https://unpkg.com/[email protected]/dist/es-module-shims.js"></script>
<script src="https://unpkg.com/[email protected]/examples/js/geometries/DecalGeometry.js"></script>
<script src="https://unpkg.com/[email protected]/examples/js/controls/OrbitControls.js"></script>
</head>
<body>
</body>
<script>
/* import * as THREE from "https://threejs.org/build/three.module.js";
import { OrbitControls } from "https://threejs.org/examples/jsm/controls/OrbitControls.js";
import { DecalGeometry } from "https://threejs.org/examples/jsm/geometries/DecalGeometry.js";
*/
// from: https://discourse.threejs.org/t/good-and-relatively-simple-examples-of-decalgeometry/13089
// from: https://jsfiddle.net/zrq6unge/1/
var mesh, renderer, scene, camera, controls;
var mouse, raycaster, helper, decalMaterial;
init();
animate();
function init() {
// renderer
renderer = new THREE.WebGLRenderer();
renderer.setSize( window.innerWidth, window.innerHeight );
renderer.setPixelRatio( window.devicePixelRatio );
document.body.appendChild( renderer.domElement );
// scene
scene = new THREE.Scene();
// camera
camera = new THREE.PerspectiveCamera( 40, window.innerWidth / window.innerHeight, 1, 10000 );
camera.position.set( 20, 20, 20 );
// controls
controls = new THREE.OrbitControls( camera, renderer.domElement );
// ambient
scene.add( new THREE.AmbientLight( 0x222222 ) );
// light
var light = new THREE.DirectionalLight( 0xffffff, 1 );
light.position.set( 20,20, 0 );
scene.add( light );
// axes
scene.add( new THREE.AxesHelper( 20 ) );
// geometry
var geometry = new THREE.SphereGeometry( 5, 12, 8 );
// material
var material = new THREE.MeshPhongMaterial( {
color: 0x00ffff,
flatShading: true,
} );
// mesh
mesh = new THREE.Mesh( geometry, material );
scene.add( mesh );
// decal related stuff
mouse = new THREE.Vector2();
raycaster = new THREE.Raycaster();
helper = new THREE.Object3D();
decalMaterial = new THREE.MeshBasicMaterial( { color: 'red', depthWrite: false, polygonOffset: true, polygonOffsetFactor: - 4, } );
document.addEventListener( 'click', onClick );
}
function onClick( event ) {
event.preventDefault();
mouse.x = ( event.clientX / window.innerWidth ) * 2 - 1;
mouse.y = - ( event.clientY / window.innerHeight ) * 2 + 1;
raycaster.setFromCamera( mouse, camera );
var intersects = raycaster.intersectObject( mesh );
if ( intersects.length > 0 ) {
var n = intersects[ 0 ].face.normal.clone();
n.transformDirection( mesh.matrixWorld );
n.add( intersects[ 0 ].point );
helper.position.copy( intersects[ 0 ].point );
helper.lookAt( n );
var position = intersects[ 0 ].point;
var size = new THREE.Vector3( 1, 1, 1 );
var decalGeometry = new THREE.DecalGeometry( mesh, position, helper.rotation, size );
var decal = new THREE.Mesh( decalGeometry, decalMaterial );
scene.add( decal );
}
}
function animate() {
requestAnimationFrame( animate );
renderer.render( scene, camera );
}
</script>
</html>