首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用ThreeJS绘制二维物体的三维几何

用ThreeJS绘制二维物体的三维几何
EN

Stack Overflow用户
提问于 2013-09-29 07:24:55
回答 1查看 4.9K关注 0票数 2

我对Three.js非常陌生,我一直在尝试实现以下内容:

假设我有一个x和y坐标数组,用于浏览器视图端口中的某个形状。我想在Three.JS中渲染这些形状,这样我就可以在z方向上增加一个高度。

这个形状本身实际上是一个“建筑物”,在这里我有它的平面坐标数组,我想通过在Z方向增加一个高度来对它进行3 3Dify。

我应该使用什么几何/材料/技术来实现这一点?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-09-29 08:42:41

使用ExtrudeGeometry,您可以将一个2D元素(坐标)挤压到Three.js中的一个3D对象。

这里的例子:http://stemkoski.github.io/Three.js/Extrusion.html

这里的文档:http://threejs.org/docs/#Reference/Extras.Geometries/ExtrudeGeometry

示例中的代码:

代码语言:javascript
复制
var starPoints = [];

starPoints.push( new THREE.Vector2 (   0,  50 ) );
starPoints.push( new THREE.Vector2 (  10,  10 ) );
starPoints.push( new THREE.Vector2 (  40,  10 ) );
starPoints.push( new THREE.Vector2 (  20, -10 ) );
starPoints.push( new THREE.Vector2 (  30, -50 ) );
starPoints.push( new THREE.Vector2 (   0, -20 ) );
starPoints.push( new THREE.Vector2 ( -30, -50 ) );
starPoints.push( new THREE.Vector2 ( -20, -10 ) );
starPoints.push( new THREE.Vector2 ( -40,  10 ) );
starPoints.push( new THREE.Vector2 ( -10,  10 ) );

var starShape = new THREE.Shape( starPoints );

var extrusionSettings = {
    size: 30, height: 4, curveSegments: 3,
    bevelThickness: 1, bevelSize: 2, bevelEnabled: false,
    material: 0, extrudeMaterial: 1
};

var starGeometry = new THREE.ExtrudeGeometry( starShape, extrusionSettings );

var materialFront = new THREE.MeshBasicMaterial( { color: 0xffff00 } );
var materialSide = new THREE.MeshBasicMaterial( { color: 0xff8800 } );
var materialArray = [ materialFront, materialSide ];
var starMaterial = new THREE.MeshFaceMaterial(materialArray);

var star = new THREE.Mesh( starGeometry, starMaterial );
star.position.set(0,50,0);
scene.add(star);

// add a wireframe to model
var wireframeTexture = new THREE.MeshBasicMaterial( { color: 0x000000, wireframe: true, transparent: true } ); 
var star = new THREE.Mesh( starGeometry, wireframeTexture );
star.position.set(0,50,0);
scene.add(star);
票数 8
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/19075535

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档