1
0

PureTextLabel.js 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. import * as THREE from "three";
  2. export default class PureTextLabel extends THREE.Mesh {
  3. constructor(text, outline) {
  4. let res = 5;
  5. const width = 150 * res;
  6. const height = 15 * res;
  7. var canvas = document.createElement("canvas");
  8. canvas.width = width;
  9. canvas.height = height;
  10. let fontFamily = "Arial";
  11. let fontSize = 7 * res;
  12. let offsetX = 75 * res;
  13. let offsetY = 10 * res;
  14. var context = canvas.getContext("2d");
  15. context.fillStyle = "transparent";
  16. context.rect(0, 0, width, height);
  17. context.fill();
  18. context.font = "normal " + fontSize + "px " + fontFamily;
  19. context.fillStyle = "#000000";
  20. context.textAlign = "center";
  21. context.fillText(text, offsetX, offsetY);
  22. const canvas_map = new THREE.Texture(canvas);
  23. canvas_map.colorSpace = THREE.SRGBColorSpace;
  24. canvas_map.needsUpdate = true;
  25. canvas_map.anisotropy = 4;
  26. const g = new THREE.PlaneGeometry(1.5, 0.15);
  27. g.rotateX(-Math.PI / 2);
  28. // const texture = new THREE.CanvasTexture(canvas_map);
  29. const m = new THREE.MeshBasicMaterial({
  30. map: canvas_map,
  31. transparent: true, // 允许材质透明
  32. });
  33. super(g, m);
  34. this.name = "textlabel_" + text;
  35. }
  36. }