Threejs引入字体,实现3D文字,Canvas画布作为纹理贴图实现滚动字幕

简介: Threejs引入字体,实现3D文字,Canvas画布作为纹理贴图实现滚动字幕

1,介绍


该示例使用的是 r95版本Three.js库。

主要实现功能:Threejs引入字体,实现3D文字,Canvas画布作为纹理贴图实现滚动字幕。效果图如下:


2,主要说明


1,使用FontLoader加载字体,显示3D文字

2,使用Canvas作为纹理贴图,实现滚动字幕


Three.js提供了几种可以在场景中使用的字体。这些字体基于由TypeFace.js库提供的字体。TypeFace.js库可以将TrueType和OpenType字体转换为JavaScript文件或者JSON文件,以便在网页中的JavaScript程序中直接使用。在旧版本的Three.js使用字体时,需要用转换得到的JavaScript文件,而新版Three.js改为使用JSON文件了。


转换得到JSON文件后,你可以使用THREE.FontLoader加载字体,,并将字体对象赋给THREE.TextGeometry的font属性。


使用Facetype.js生成json字体入口

用于Threejs的谷歌字体库地址入口


function add3DFont() {
  new THREE.FontLoader().load('font/FZYaoTi_Regular.json', function(font) {
    //加入立体文字
    var text = new THREE.TextGeometry("左本的博客,Three.js3D文字", {
      // 设定文字字体
      font: font,
      //尺寸
      size: 24,
      //厚度
      height: 5
    });
    text.computeBoundingBox();
    // 设置偏移
    text.translate(-220, 0, 0);
    //3D文字材质
    var m = new THREE.MeshStandardMaterial({
      color: "#FF0000"
    });
    fontMesh = new THREE.Mesh(text, m)
    fontMesh.position.y = 100;
    scene.add(fontMesh);
  });
}

创建Canvas设置字体填充文字,作为纹理CanvasTexture引入到材质MeshPhongMaterial中。


// 创建LED电子屏幕
function addLEDScreen() {
  var canvas = document.createElement("canvas");
  canvas.width = 512;
  canvas.height = 64;
  var c = canvas.getContext('2d');
  c.fillStyle = "#aaaaff";
  c.fillRect(0, 0, 512, 64);
  // 文字
  c.beginPath();
  c.translate(256, 32);
  c.fillStyle = "#FF0000"; //文本填充颜色
  c.font = "bold 28px 宋体"; //字体样式设置
  c.textBaseline = "middle"; //文本与fillText定义的纵坐标
  c.textAlign = "center"; //文本居中(以fillText定义的横坐标)
  c.fillText("左本的博客,Three.js3D文字", 0, 0);
  var cubeGeometry = new THREE.BoxGeometry(512, 64, 5);
  canvasTexture = new THREE.CanvasTexture(canvas);
  canvasTexture.wrapS = THREE.RepeatWrapping;
  var material = new THREE.MeshPhongMaterial({
    map: canvasTexture, // 设置纹理贴图
  });
  var cube = new THREE.Mesh(cubeGeometry, material);
  cube.rotation.y += Math.PI; //-逆时针旋转,+顺时针
  scene.add(cube);
}
目录
相关文章
Threejs实现模拟河流,水面水流,水管水流,海面
Threejs实现模拟河流,水面水流,水管水流,海面
3399 0
Threejs实现模拟河流,水面水流,水管水流,海面
|
存储 前端开发 JavaScript
three.js 纹理
纹理是添加到材料中的图像或颜色,以提供更多细节或美感。纹理是Three.js中必不可少的主题。在本节中,我们将了解如何将基本纹理应用于我们的材质。
288 0
|
JavaScript
Threejs实现标签,自定义样式显示标签
Threejs实现标签,自定义样式显示标签
1907 0
Threejs实现标签,自定义样式显示标签
|
开发框架
threejs做特效:实现物体的发光效果-EffectComposer详解!
【8月更文挑战第7天】实现物体的发光效果-EffectComposer详解!
2270 6
threejs做特效:实现物体的发光效果-EffectComposer详解!
ThreeJs给物体添加贴图
这篇文章详细说明了在Three.js中如何给3D物体添加贴图,并展示了实现局部贴图的技术和方法。
626 1
ThreeJs给物体添加贴图
|
前端开发
ThreeJs通过canvas和Sprite添加标签
这篇文章介绍了在Three.js中利用Canvas和Sprite实现动态文本标签的方法,使得标签可以跟随模型并在3D空间中始终保持面向摄像机。
608 0
ThreeJs通过canvas和Sprite添加标签
|
存储 开发框架 JavaScript
Threejs中三维物体和HTML的爱恨情仇:CSS2DRenderer
【8月更文挑战第7天】Threejs中三维物体和HTML的爱恨情仇:CSS2DRenderer
1345 4
Threejs中三维物体和HTML的爱恨情仇:CSS2DRenderer
【threejs教程】让你的场景贴图变得多姿多彩:UV坐标详解
【8月更文挑战第6天】threejs教程:让你的场景贴图变得多姿多彩,UV坐标详解
720 5
【threejs教程】让你的场景贴图变得多姿多彩:UV坐标详解
|
API
【threejs教程】场景视角切换的神器:轨道控制器
【8月更文挑战第5天】threejs教程:场景视角切换的神器,轨道控制器
922 1
【threejs教程】场景视角切换的神器:轨道控制器
|
API
【threejs教程】让你的场景五颜绿色:纹理贴图与环境贴图
【8月更文挑战第6天】【threejs教程】让你的场景五颜绿色:纹理贴图与环境贴图
779 11