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);
}
目录
相关文章
|
3月前
ThreeJs创建圆环
这篇文章介绍了如何在Three.js中创建一个圆环(torus),包括设置圆环的几何形状、材质以及将其添加到场景中的具体步骤。
73 0
ThreeJs创建圆环
学习CSS3 中的渐变、阴影与遮罩
CSS3的渐变、阴影和遮罩特性极大地丰富了网页设计。渐变让颜色平滑过渡,赋予页面流动美感;阴影增加元素立体感,引导视觉焦点;遮罩通过隐藏或显示部分元素创造独特视觉效果。这些特性组合使用,可打造丰富多彩、立体生动的视觉体验,并可通过CSS3动画增强动态效果,使网页更具活力。正确应用这些特性需考虑参数调整及跨浏览器兼容性,以确保最佳展示效果。
|
6月前
|
前端开发
css特效——Photoshop选区(动感的虚线选框,支持不规则的选框)
css特效——Photoshop选区(动感的虚线选框,支持不规则的选框)
42 1
|
6月前
|
前端开发
Canvas背景色绘画样式设计
Canvas背景色绘画样式设计
|
前端开发
用CSS绘制最常见的40种形状和图形(一)
用CSS绘制最常见的40种形状和图形(一)
93 0
|
8月前
|
前端开发
CSS小技巧之绘制心形图案
CSS小技巧之绘制心形图案
112 0
|
前端开发
【前端切图】CSS文字渐变和背景渐变
【前端切图】CSS文字渐变和背景渐变
89 0
|
前端开发
css实现文字的条纹阴影效果
css实现文字的条纹阴影效果
124 1
|
前端开发
用CSS绘制最常见的40种形状和图形(二)
用CSS绘制最常见的40种形状和图形(二)
111 0
|
前端开发
前端 SVG 与 Canvas 框架案例 (画线、矩形、箭头、文字 ....)
前端 SVG 与 Canvas 框架案例 (画线、矩形、箭头、文字 ....)
153 0