three.js - 三个js : Create a vertical ruler with measurements

标签 three.js

我想创建一个垂直标尺,其测量值如下图所示。任何人都可以帮助我。

var material = new THREE.LineBasicMaterial({
            color: 0x07E1E1,
            linewidth: 3
        });

        var geometry = new THREE.Geometry();
        geometry.vertices.push(
            new THREE.Vector3( 0, 0, 0 ),
            new THREE.Vector3( 0, 1100, 0 ),
            new THREE.Vector3( 0, 0, 0 )
        );


        var line = new THREE.Line( geometry, material );
        scene.add( line );
        line.position.set(-550, -550, 200);

但它并没有像图像和测量值那样......

最佳答案

您可以使用 LineBasicMaterial 和 Line 元素。

    var camera, scene, renderer, object;

    init();

    function init() {
        var container;
        container = document.getElementById( 'container' );
        camera = new THREE.PerspectiveCamera( 75, window.innerWidth / window.innerHeight, 1, 1100 );
        camera.target = new THREE.Vector3( 0, 0, 0 );
        scene = new THREE.Scene();

        object = new THREE.Object3D();
        var lineMtr = new THREE.LineBasicMaterial({ color: 0xffffff, linewidth: 3, opacity: 1 });
        var geo = new THREE.Geometry();
        geo.vertices.push(new THREE.Vector3(0, 10 ,3));
        geo.vertices.push(new THREE.Vector3(0, 0 ,3));
        var line = new THREE.Line(geo, lineMtr);
        var i = 0, l = 10;
        object.add(line);
        while (i <= l) {
            var geoSegm = new THREE.Geometry();
            geoSegm.vertices.push(new THREE.Vector3(0.1, i, 3));
            geoSegm.vertices.push(new THREE.Vector3(0, i, 3));
            var lineSegm = new THREE.Line(geoSegm, lineMtr);
                object.add(lineSegm);
            var textSprite = makeTextSprite((i * 10).toString(), {r: 255, g: 255, b: 255, a: 255}, new THREE.Vector3(0.2, i, 3), Math.PI);
            object.add(textSprite);
            i++;
        }
        renderer = new THREE.WebGLRenderer();
        renderer.setPixelRatio( window.devicePixelRatio );
        renderer.setSize( window.innerWidth, window.innerHeight );
    }

    function animate() {
        requestAnimationFrame( animate );
        renderer.render( scene, camera );
    }

您可以为 SpriteMaterial 创建纹理,然后将 Sprite 用于标尺文本。

    function makeTextSprite(label, fontColor, pos, rot) {
        var fontface = "Arial";
        var fontsize = 100;
        var canvas = document.createElement('canvas');
        var context = canvas.getContext('2d');
        context.font = "Bold " + fontsize.toString() + "px " + fontface;
        var metrics = context.measureText(label);
        context.rotate(-Math.PI);
        context.translate(-canvas.width, -canvas.height);
        context.fillStyle = "rgba(" + fontColor.r + "," + fontColor.g + "," + fontColor.b + "," + fontColor.a + ")";
        context.fillText(label, 0, 100);

        var texture = new THREE.Texture(canvas);
        texture.needsUpdate = true;
        texture.center = new THREE.Vector2(0.5, 0.5);
        texture.rotation = Math.PI;

        var spriteMaterial = new THREE.SpriteMaterial({
            map: texture, color: 0xffffff
        });
        var sprite = new THREE.Sprite(spriteMaterial);
        sprite.scale.set(0.25, 0.25, 0.25);
        sprite.position.set(pos.x, pos.y, pos.z);
        return sprite;
    }

我在该链接中使用了代码 http://jsfiddle.net/3mrzL75h/19/ 乍一看,您看不到标尺,将相机向右拖动。

关于three.js - 三个js : Create a vertical ruler with measurements,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53260137/

相关文章:

javascript - 如何在 Three.js 中导入 VRML 文件?

javascript - 如何覆盖 TypeScript UMD 全局类型定义?

javascript - ThreeJS FBX模型是片面的

javascript - Physij 更新物体质量

javascript - 来自 npm : import THREE. Lut() 的 Three.js

javascript - Three.js 在删除和创建对象后变得非常慢

three.js - 向这个 obj 的每一侧添加不同的颜色

opengl-es - 带有柏林噪声的 GLSL 阴影

javascript - THREE.Audio - 获取当前时间并设置 onEnded 函数

svg - 挤出具有多个孔的多个多边形并对组合形状进行纹理化