var camera, scene, renderer, controls;
var labelX, labelY, labelY;
var loader = new THREE.FontLoader();
loader.load("https://raw.githubusercontent.com/mrdoob/three.js/dev/examples/fonts/helvetiker_regular.typeface.json", function (font_) {
init(font_);
});
function init(font_) {
camera = new THREE.PerspectiveCamera( 35, window.innerWidth / window.innerHeight, 1, 1000 );
camera.position.set(256, 512, 512);
camera.lookAt(new THREE.Vector3(0, 0, 0));
scene = new THREE.Scene();
renderer = new THREE.WebGLRenderer( { antialias: true } );
renderer.setPixelRatio( window.devicePixelRatio );
renderer.setSize( window.innerWidth, window.innerHeight );
renderer.setClearColor( 0xDEDEDE, 1.0 );
document.body.appendChild( renderer.domElement );
controls = new THREE.OrbitControls(camera, renderer.domElement);
controls.enableDamping = true;
controls.enablePan = true;
controls.dampingFactor = 0.25;
controls.mouseButtons = {
LEFT: THREE.MOUSE.LEFT,
MIDDLE: THREE.MOUSE.MIDDLE,
RIGHT: THREE.MOUSE.RIGHT
};
var material = new THREE.LineBasicMaterial( { color: 0x000000 } );
var geometry = new THREE.Geometry();
geometry.vertices.push(new THREE.Vector3(-196, 0, 0));
geometry.vertices.push(new THREE.Vector3(196, 0, 0));
var xLine = new THREE.Line(geometry, material);
scene.add(xLine);
var geometry = new THREE.Geometry();
geometry.vertices.push(new THREE.Vector3(0, -196, 0));
geometry.vertices.push(new THREE.Vector3(0, 196, 0));
var yLine = new THREE.Line(geometry, material);
scene.add(yLine);
var geometry = new THREE.Geometry();
geometry.vertices.push(new THREE.Vector3(0, 0, -196));
geometry.vertices.push(new THREE.Vector3(0, 0, 196));
var zLine = new THREE.Line(geometry, material);
scene.add(zLine);
var textMaterial = new THREE.MeshBasicMaterial({ color: 0x000000 });
var textX = new THREE.TextGeometry("label_x", {
font: font_,
size: 6,
height: 0.1,
curveSegments: 12,
bevelEnabled: false,
});
labelX = new THREE.Mesh(textX, textMaterial);
labelX.position.set(180, 0, -6);
labelX.geometry.center();
labelX.rotateX(-Math.PI/2)
scene.add(labelX);
var textY = new THREE.TextGeometry("label_y", {
font: font_,
size: 6,
height: 0.1,
curveSegments: 12,
bevelEnabled: false,
});
labelY = new THREE.Mesh(textY, textMaterial);
labelY.position.set(6, 180, 0);
labelY.geometry.center();
labelY.rotateZ(Math.PI/2)
scene.add(labelY);
var textZ = new THREE.TextGeometry("label_z", {
font: font_,
size: 6,
height: 0.1,
curveSegments: 12,
bevelEnabled: false,
});
labelZ = new THREE.Mesh(textZ, textMaterial);
labelZ.position.set(-6, 0, -180);
labelZ.geometry.center();
labelZ.rotateY(Math.PI/2)
labelZ.rotateX(-Math.PI/2)
scene.add(labelZ);
window.addEventListener( 'resize', onWindowResize, false );
animate();
}
function onWindowResize() {
camera.aspect = window.innerWidth / window.innerHeight;
camera.updateProjectionMatrix();
renderer.setSize( window.innerWidth, window.innerHeight );
}
function animate() {
if(camera.position.y < 0){
labelX.rotation.set(Math.PI/2, 0, 0);
labelZ.rotation.set(0, Math.PI/2, 0);
labelZ.rotateX(Math.PI/2);
}else{
labelX.rotation.set(-Math.PI/2, 0, 0);
labelZ.rotation.set(0, Math.PI/2, 0);
labelZ.rotateX(-Math.PI/2);
}
if(camera.position.z < 0){
labelY.rotation.set(0, -Math.PI, -Math.PI/2);
}else{
labelY.rotation.set(0, 0, Math.PI/2);
}
controls.update();
requestAnimationFrame( animate );
renderer.render( scene, camera );
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/three.js/98/three.min.js"></script>
<script src="https://cdn.rawgit.com/mrdoob/three.js/master/examples/js/controls/OrbitControls.js"></script>
Собственно, я пытался это сделать.