three.js(16)-精灵图

作者: 姜治宇 | 来源:发表于2021-12-01 17:40 被阅读0次

Sprite精灵图是指场景中的二维图像。
这种图是永远面向相机的平面,通常用来加载纹理。

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <script src="http://www.yanhuangxueyuan.com/versions/threejsR92/build/three.js"></script>
    <script src="http://www.yanhuangxueyuan.com/threejs/examples/js/controls/OrbitControls.js"></script>
    <script src="http://www.yanhuangxueyuan.com/threejs/examples/js/loaders/GLTFLoader.js"></script>
    <title>Document</title>
</head>

<body>
    <div id="webgl"></div>
</body>

</html>
<script>
    var scene = new THREE.Scene();
    var axes = new THREE.AxesHelper(50);//添加辅助坐标系
    scene.add(axes);
    //================================地面================================================//
    var plane = new THREE.PlaneGeometry(150, 50);
    var materialPlane = new THREE.MeshBasicMaterial({
        color: 0xcccccc
    });
    var planeMesh = new THREE.Mesh(plane, materialPlane);
    planeMesh.rotation.x = -0.5 * Math.PI; //沿x轴翻转90°,即为展平效果
    planeMesh.position.set(0, 0, 0);

    scene.add(planeMesh);
    //====================精灵图(canvas)=================//
    scene.add(createSprite(getCanvas()));

    //=============================相机=============================================//
    var camera = new THREE.PerspectiveCamera(45, 2, 0.1, 2000);
    camera.position.set(10, 10, 10);
    camera.lookAt(scene.position);


    /**
     * 创建渲染器对象
     */
    var renderer = new THREE.WebGLRenderer({
        antialias: true //消除锯齿
    });

    renderer.setSize(1000, 500);
    renderer.setClearColor(0xb9d3ff, 1);

    renderer.render(scene, camera);
    var cont = document.getElementById('webgl');
    cont.appendChild(renderer.domElement);

    //增加鼠标拾取效果
    var controls = new THREE.OrbitControls(camera, renderer.domElement);
    controls.addEventListener('change', () => {
        renderer.render(scene, camera);
    });

    function createSprite(canvas){
        let texture =new THREE.Texture(canvas);
        texture.needsUpdate = true;
        let material = new THREE.SpriteMaterial({
            map:texture
        });
        let mesh = new THREE.Sprite(material);
        mesh.position.set(0,2,0);
        return mesh;

    }
    function getCanvas(){
        let canvas = document.createElement('canvas');
        canvas.width = 200;
        canvas.height = 200;
        let ctx = canvas.getContext('2d');
        ctx.fillStyle = '#ff0000';
        ctx.arc(100,100,100,0,2*Math.PI);//画圆
        ctx.fill();
        ctx.fillStyle = "#ffff00";
        ctx.font = "Bold 100px Arial";
        ctx.fillText("你好",0,120);//写字
        return canvas;
    }

</script>
canvas.gif

相关文章

  • three.js(16)-精灵图

    Sprite精灵图是指场景中的二维图像。这种图是永远面向相机的平面,通常用来加载纹理。

  • three.js 全景重力感应

    实现three.js 全景图 demo 使用three.js 写了球体和圆柱体版本的3D重力感应全景图,支持手指触...

  • spriteMaterial (rotate) 旋转问题

    spriteMaterial是Three.js中的点精灵材质。利用它我们可以在场景中加载图片,贴上纹理。并且效果很...

  • 08-精灵图的利弊

    CSS Sprites 、精灵图、 雪碧图 都是一个概念 * 我对精灵图的简单看法 关于精灵图我简单的介绍一下:...

  • Github Repository 可视化 (D3.js &am

    Github Repository 可视化 (D3.js & Three.js) 先上 Demo 链接 & 效果图...

  • 任务9- CSS常见技巧

    1、CSS Sprite(雪碧图|精灵图)指什么? 有什么作用 简介CSS Sprites(雪碧图|精灵图)是一种...

  • THREE.js_的使用(例子)

    THREE.js 下载 THREE.js 官方文档 THREE.js 中文基础教程 THREE.MeshLine ...

  • 逐帧自适应精灵图+css3实现小动画

    这个是固定像素的逐帧精灵图: 自适应任意尺寸的精灵图:

  • CSS精灵图

    什么是CSS精灵图? CSS精灵图是一种图像合成技术 CSS精灵图作用 可以减少请求次数,以及降低服务器处理压力 ...

  • CSS常见技巧

    1.CSS Sprite(雪碧图|精灵图)指什么? 有什么作用 CSS Sprite(雪碧图|精灵图)指该方法是将...

网友评论

    本文标题:three.js(16)-精灵图

    本文链接:https://www.haomeiwen.com/subject/zjosxrtx.html