TextGeometry.js 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. /**
  2. * Text = 3D Text
  3. *
  4. * parameters = {
  5. * font: <THREE.Font>, // font
  6. *
  7. * size: <float>, // size of the text
  8. * depth: <float>, // thickness to extrude text
  9. * curveSegments: <int>, // number of points on the curves
  10. *
  11. * bevelEnabled: <bool>, // turn on bevel
  12. * bevelThickness: <float>, // how deep into text bevel goes
  13. * bevelSize: <float>, // how far from text outline (including bevelOffset) is bevel
  14. * bevelOffset: <float> // how far from text outline does bevel start
  15. * }
  16. */
  17. import {
  18. ExtrudeGeometry
  19. } from 'three';
  20. class TextGeometry extends ExtrudeGeometry {
  21. constructor( text, parameters = {} ) {
  22. const font = parameters.font;
  23. if ( font === undefined ) {
  24. super(); // generate default extrude geometry
  25. } else {
  26. const shapes = font.generateShapes( text, parameters.size );
  27. // translate parameters to ExtrudeGeometry API
  28. if ( parameters.depth === undefined && parameters.height !== undefined ) {
  29. console.warn( 'THREE.TextGeometry: .height is now depreciated. Please use .depth instead' ); // @deprecated, r163
  30. }
  31. parameters.depth = parameters.depth !== undefined ?
  32. parameters.depth : parameters.height !== undefined ?
  33. parameters.height : 50;
  34. // defaults
  35. if ( parameters.bevelThickness === undefined ) parameters.bevelThickness = 10;
  36. if ( parameters.bevelSize === undefined ) parameters.bevelSize = 8;
  37. if ( parameters.bevelEnabled === undefined ) parameters.bevelEnabled = false;
  38. super( shapes, parameters );
  39. }
  40. this.type = 'TextGeometry';
  41. }
  42. }
  43. export { TextGeometry };