
[code]
import * as THREE from "https://cdn.skypack.dev/three@0.136.0";
import {OrbitControls} from "https://cdn.skypack.dev/three@0.136.0/examples/jsm/controls/OrbitControls";
import {createNoise2D} from "https://cdn.skypack.dev/simplex-noise@4.0.0";
console.clear();
let scene = new THREE.Scene();
scene.background = new THREE.Color(0x7f7f7f);
let camera = new THREE.PerspectiveCamera(45, innerWidth / innerHeight, 1, 1000);
camera.position.set(-5, 10, 10).setLength(20);
let renderer = new THREE.WebGLRenderer({antialias: true});
renderer.setSize(innerWidth, innerHeight);
document.body.appendChild(renderer.domElement);
window.addEventListener("resize", event => {
camera.aspect = innerWidth / innerHeight;
camera.updateProjectionMatrix();
renderer.setSize(innerWidth, innerHeight);
})
let controls = new OrbitControls(camera, renderer.domElement);
controls.enableDamping = true;
let light = new THREE.DirectionalLight(0xffffff, 0.5);
light.position.set(0.75, 0.5, 1);
scene.add(light, new THREE.AmbientLight(0xffffff, 0.5));
scene.add(new THREE.GridHelper());
class ProgressBar extends THREE.Sprite{
constructor(_progress){
super();
this.scale.set(2, 0.1);
this.material = new THREE.SpriteMaterial({
onBeforeCompile: shader => {
shader.uniforms.progress = _progress;
shader.fragmentShader = `
#define ss(a, b, c) smoothstep(a, b, c)
uniform float progress;
${shader.fragmentShader}
`.replace(
`outgoingLight = diffuseColor.rgb;`,
`outgoingLight = diffuseColor.rgb;
vec3 backColor = mix(vec3(0), vec3(0, 0.5, 0), progress);
float pb = step(progress, vUv.x);
outgoingLight.rgb = mix(vec3(0, 1, 0), backColor, pb);
`
);
console.log(shader.fragmentShader);
}
});
this.material.defines = {"USE_UV" : ""};
this.center.set(0.5, 0);
}
}
class ProgressObject extends THREE.Object3D{
constructor(height){
const rand = Math.random() * 100;
const noise = createNoise2D();
super();
let _progress = {value: 0.5};
let og = new THREE.BoxGeometry().translate(0, 0.5, 0);
let om = new THREE.MeshLambertMaterial();
let o = new THREE.Mesh(og, om);
o.scale.y = height;
let lg = new THREE.EdgesGeometry(new THREE.BoxGeometry());
lg.translate(0, 0.5, 0);
lg.scale(1, height, 1);
let lm = new THREE.LineBasicMaterial({color: new THREE.Color(Math.random() * 0xffffff).multiplyScalar(0.5).addScalar(0.5)});
let l = new THREE.LineSegments(lg, lm);
let pbar = new ProgressBar(_progress);
pbar.position.y = height * 1.1;
this.add(o, l, pbar);
this.update = val => {
_progress.value = noise(val, 0.25) * 0.5 + 0.5;
o.scale.y = height * _progress.value;
}
}
}
let tmu = THREE.MathUtils;
let POs = new Array(5).fill().map(o => {
let po = new ProgressObject(tmu.randInt(2, 5));
po.position.x = tmu.randInt(-5, 4) + 0.5;
po.position.z = tmu.randInt(-5, 4) + 0.5;
scene.add(po);
return po
})
let clock = new THREE.Clock();
renderer.setAnimationLoop(() => {
controls.update();
let t = clock.getElapsedTime() * 0.5;
POs.forEach(po => {po.update(t)});
renderer.render(scene, camera);
});
[/code]
게시글 목록
| 번호 | 제목 |
|---|---|
| 18200 | |
| 18195 | |
| 18193 | |
| 18181 | |
| 18179 | |
| 18173 | |
| 18170 | |
| 18164 | |
| 18158 | |
| 18155 | |
| 18152 |
JavaScript
한글과컴퓨터 키워드추출스크립트.
2
|
| 18151 | |
| 18150 |
JavaScript
위에서 아래로 내려오는 효과 6가지
|
| 18140 | |
| 18139 | |
| 18138 |
JavaScript
마우스로 td 간격 조정하기.
1
|
| 18131 | |
| 18130 |
JavaScript
엘레먼트에 다이렉트로 변수,배열,객체 심기
|
| 18120 | |
| 18119 | |
| 18118 |
jQuery
0원팁- 숫자형 아이디에 접근하기
1
|
| 18117 |
jQuery
유용하게 써먹는 반응형 grid
1
|
| 18116 | |
| 18111 |
MySQL
db에서 트리거 만들기
|
| 18110 | |
| 18108 |
JavaScript
디바운스 debounce의 개념
1
|
| 18107 |
JavaScript
jquery 타이머 만들기
2
|
| 18106 | |
| 18100 | |
| 18090 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기