
[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]
게시글 목록
| 번호 | 제목 |
|---|---|
| 17819 |
JavaScript
당신이 알아야 할 자바스크립트의 강력한 7가지 팁
3
|
| 17818 |
JavaScript
자바스크립트 코드를 더 깔끔하고 보기 좋게 작성하는 팁
1
|
| 17817 |
PHP
chatgtp
|
| 17816 |
JavaScript
textarea 자동 높이 설정하기.
1
|
| 17814 | |
| 17811 |
JavaScript
자바스크립트 플래이그라운드 - RUNJS
|
| 17810 | |
| 17809 | |
| 17808 |
JavaScript
16진수 색상코드 확인함수
|
| 17803 | |
| 17799 | |
| 17798 | |
| 17797 |
JavaScript
동영상파일 썸네일 만들기
8
|
| 17795 |
JavaScript
div태그의 사이즈가 변경되는 이벤트를 처리하기
|
| 17794 |
JavaScript
초->hh:mm:ss로 변환하는 함수
1
|
| 17793 |
JavaScript
JSON Beautify
|
| 17790 |
PHP
JSONP실례
|
| 17789 | |
| 17786 |
JavaScript
ThreeJS로 3디지구에 포인트 찍고 정보 현시기능
|
| 17774 | |
| 17760 | |
| 17755 | |
| 17750 | |
| 17729 | |
| 17722 | |
| 17714 | |
| 17708 | |
| 17686 | |
| 17676 |
JavaScript
유튜브 풀화면 묵음배경 예제
9
|
| 17666 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기