Spaces:
Running
Running
/** | |
* Text = 3D Text | |
* | |
* parameters = { | |
* font: <THREE.Font>, // font | |
* | |
* size: <float>, // size of the text | |
* depth: <float>, // thickness to extrude text | |
* curveSegments: <int>, // number of points on the curves | |
* | |
* bevelEnabled: <bool>, // turn on bevel | |
* bevelThickness: <float>, // how deep into text bevel goes | |
* bevelSize: <float>, // how far from text outline (including bevelOffset) is bevel | |
* bevelOffset: <float> // how far from text outline does bevel start | |
* } | |
*/ | |
import { | |
ExtrudeGeometry | |
} from 'three'; | |
class TextGeometry extends ExtrudeGeometry { | |
constructor( text, parameters = {} ) { | |
const font = parameters.font; | |
if ( font === undefined ) { | |
super(); // generate default extrude geometry | |
} else { | |
const shapes = font.generateShapes( text, parameters.size ); | |
// defaults | |
if ( parameters.depth === undefined ) parameters.depth = 50; | |
if ( parameters.bevelThickness === undefined ) parameters.bevelThickness = 10; | |
if ( parameters.bevelSize === undefined ) parameters.bevelSize = 8; | |
if ( parameters.bevelEnabled === undefined ) parameters.bevelEnabled = false; | |
super( shapes, parameters ); | |
} | |
this.type = 'TextGeometry'; | |
} | |
} | |
export { TextGeometry }; | |