라디안과 디그리
1. 디그리 => 한바퀴 도는 각 360도 단위를 디그리라고 한다.
2. 라디안 => 호의길이와 반지름의 비율 각도를 나타내는 단위
data:image/s3,"s3://crabby-images/22057/22057d0422874615ba9c46c2fb27e304057018e2" alt=""
180도 = PI 라디안
360도 = 2*PI 라디안
90도 = PI/2 라디안
1 라디안은 약 57.2958도
data:image/s3,"s3://crabby-images/82fcc/82fcc15cf1c1a21f75b5464922b2e5f1a0eacf98" alt=""
사진 설명을 입력하세요.
60도 회전을 원할때 threejs 에서는 degToRad라는 함수로 쉽게 사용 가
const angle = THREE.MathUtils.degToRad(60);
data:image/s3,"s3://crabby-images/b6d3b/b6d3b80a76f968fb56eb7cfd659afea17a8c98e6" alt=""
회전
data:image/s3,"s3://crabby-images/db0a7/db0a767857b4a5bbc5818992568215857a3c996f" alt=""
각도와 각속도를 이용한 큐브 회전
let angle = 0; // 초기 각도
const angularVelocity = THREE.MathUtils.degToRad(60); // 각속도 (초당 60도)
// 애니메이션 루프 설정
function animate() {
requestAnimationFrame(animate);
// 각도 업데이트
angle += angularVelocity * 0.01; // 0.01은 시간 경과를 나타내는 임의의 값 (60FPS 기준)
// 큐브 회전 적용
// cube.rotation.x = angle;
cube.rotation.y = angle;
renderer.render(scene, camera);
}
animate();
data:image/s3,"s3://crabby-images/321f8/321f8854b8e09cfda665d631e25d597fcf5e792a" alt=""
삼각법
data:image/s3,"s3://crabby-images/04d16/04d162dba4351cc6d9f462e4a49097ef168e35dc" alt=""
사진 설명을 입력하세요.
data:image/s3,"s3://crabby-images/1bb8d/1bb8d2dde8e7e10dfc687e151c18dc56773ae94f" alt=""
사진 설명을 입력하세요.
data:image/s3,"s3://crabby-images/245e6/245e66a3327c3b6101272c26240fdb75d9913424" alt=""
위와 같은 추의 예제를 만들고 각도만큼 회전하 예제를 만들고 싶다.
import * as THREE from 'three';
const natureofcode3 = () => {
const scene = new THREE.Scene();
const camera = new THREE.PerspectiveCamera(
75,
window.innerWidth / window.innerHeight,
0.1,
1000
);
const renderer = new THREE.WebGLRenderer();
renderer.setSize(window.innerWidth, window.innerHeight);
document.body.appendChild(renderer.domElement);
// 그룹 생성
const group = new THREE.Group();
// 공 생성
const sphereGeometry = new THREE.SphereGeometry(0.5, 32, 32);
const sphereMaterial = new THREE.MeshBasicMaterial({ color: 0xff0000 });
const sphere = new THREE.Mesh(sphereGeometry, sphereMaterial);
sphere.position.set(-5, -3, 0); // 공을 중심에서 5단위 떨어진 위치에 설정
group.add(sphere);
// 선 생성
const lineMaterial = new THREE.LineBasicMaterial({ color: 0xffffff });
const points = [];
points.push(new THREE.Vector3(0, 0, 0));
points.push(new THREE.Vector3(-5, -3, 0));
const lineGeometry = new THREE.BufferGeometry().setFromPoints(points);
const line = new THREE.Line(lineGeometry, lineMaterial);
group.add(line);
scene.add(group);
let prevTime = performance.now(); // 이전 프레임 시간 저장할 변수
// 카메라 위치 설정
camera.position.z = 10;
const angleRadi = Math.atan2(5, 3); // 라디안 단위
const angleDeg = THREE.MathUtils.radToDeg(angleRadi); // 디그리 단위
console.log(angleDeg);
// 애니메이션 루프 설정
function animate(time) {
requestAnimationFrame(animate);
// 프레임 간격 계산
const deltaTime = time - prevTime;
prevTime = time;
// 그룹 회전 적용 (프레임 간격을 고려하여 천천히 회전)
group.rotation.z += angleRadi * (deltaTime / 600);
renderer.render(scene, camera);
}
animate(performance.now()); // 초기 프레임 시간 전달
};
export default natureofcode3;
선의 벡터값이 -5,-3,0 각도를 구하기 위해서 5와3의 아크 탄젠트 값을 구한다.
탄젠트 값은 두 점 사이의 기울기를 계산하거나, 삼각형의 비율을 계산하는 데 사용하나 우리는 각도가 필요하다. y를x로 나눈 아크 탄젠트 값을 구하면
1.03으로 대략 59.03도가 나온다 결과 값은 아래와 같다.
data:image/s3,"s3://crabby-images/3391b/3391b55bc70ac2f764567e395636cc21d5ba40c1" alt=""
atan2를 사용한 이유는 그냥 atan만 사용하면 벡터 방향이 달라도 같은 값이 나오게 된다.
그러나 atan2를 사용하게 되면 정확한 각도 값을 가질 수 있다.
data:image/s3,"s3://crabby-images/10f43/10f434facc5ac101deb80a91c4f31503e0451be1" alt=""
사진 설명을 입력하세요.
data:image/s3,"s3://crabby-images/86e6e/86e6e2214b367b6694b7629956d6a2a7612d73ef" alt=""
사진 설명을 입력하세요.
위는 탄젠트 수식으로 각도가 45도이면 탄젠트 값은 1이되고 이는 윗변과 마주 보는 변과 인접한 변의 길이가 같음을 의미한다.
이를 통해 반대로 사용하면 각도를 알 수 있다는 뜻으로 아래와 같이 탄젠트가 넘어가면서 아크탄제트가 되고 2변의 길이를 이용해서 각도를 구할 수 있다.
data:image/s3,"s3://crabby-images/de9f1/de9f148dcc3256909407f0a36398cf536bb8b80e" alt=""
data:image/s3,"s3://crabby-images/865f9/865f9a29ca5290d8f7ebafce8b01da6781f5a781" alt=""
x가5고 y가 3이면 위와 같이 각도는 1.03으로 나온다.