5

如何在three.js 中创建一个椭圆?

我看过这个: 在 THREE.js 中绘制一个椭圆

但是,如果有人可以提供一个工作示例,那就太酷了。

我试过这个:

ellipse = new THREE.EllipseCurve(0,0,200,400,45,45,10);

但这对我不起作用。我不知道参数是什么意思,所以我只是盲目地去做。

编辑:当我尝试创建椭圆曲线时,出现错误“定义不是函数” 。

编辑2:发现我必须包含 Curves.js 才能使其工作,但在某个地方有一个工作示例对我和其他人来说仍然非常好,因为我之前粘贴的 stackoverflow 链接没有示例。

4

4 回答 4

2

我不熟悉 THREE.js,但是查看代码,参数似乎是
(Center_Xpos, Center_Ypos, Xradius, Yradius, StartAngle, EndAngle, isClockwise) 您的定义不起作用的一个原因,因为您将开始和结束角度都设置为相同的东西。

于 2012-08-07T17:55:16.630 回答
1

这里有一个例子,下面是我的例子:

var scene = new THREE.Scene();
var material = new THREE.LineBasicMaterial({color:0x000000, opacity:1});
var ellipse = new THREE.EllipseCurve(0, 0, 1, 5, 0, 2.0 * Math.PI, false);
var ellipsePath = new THREE.CurvePath();
ellipsePath.add(ellipse);
var ellipseGeometry = ellipsePath.createPointsGeometry(100);
ellipseGeometry.computeTangents();
var line = new THREE.Line(ellipseGeometry, material);
scene.add( line );

注意:这不是一个完整的示例,<script src="js/three.min.js"></script>如果您想查看结果,您应该添加其余代码。

于 2013-05-31T07:51:24.380 回答
1

您可以直接设置一个圆形几何体并将其比例设置为:object.scale.setY(2.5); 这可以很容易地形成一个椭圆形,而无需使用任何形状或曲线。

于 2019-03-25T13:23:15.887 回答
0

这是一个完整的工作示例

<!doctype html>
<html>
<head>
<title>example</title>
<script src="threejs/build/three.min.js"></script>
<script src="threejs/src/core/Curve.js"></script>
<script src="threejs/examples/js/controls/OrbitControls.js"></script>
</head>

<body>
<script>
var parent, renderer, scene, camera, controls, pivot1, pivot2, pivot3;

init();
animate();

function init() {

    // info
    info = document.createElement( 'div' );
    info.style.position = 'absolute';
    info.style.top = '30px';
    info.style.width = '100%';
    info.style.textAlign = 'center';
    info.style.color = '#fff';
    info.style.fontWeight = 'bold';
    info.style.backgroundColor = 'transparent';
    info.style.zIndex = '1';
    info.style.fontFamily = 'Monospace';
    info.innerHTML = 'Drag your cursor to rotate camera';
    document.body.appendChild( info );

    // renderer
    renderer = new THREE.CanvasRenderer();
    renderer.setSize( window.innerWidth, window.innerHeight );
    renderer.physicallyBasedShading = true;
    document.body.appendChild( renderer.domElement );

    // scene
    scene = new THREE.Scene();

    // camera
    camera = new THREE.PerspectiveCamera( 40, window.innerWidth / window.innerHeight, 0.1, 100 );
    camera.position.set( 20, 20, 20 );

    // controls
    controls = new THREE.OrbitControls( camera );

    // axes
    scene.add( new THREE.AxisHelper( 20 ) );



    var material = new THREE.LineBasicMaterial({color:0x000000, opacity:1});
    var ellipse = new THREE.EllipseCurve(0, 0, 1, 4, 0, 2.0 * Math.PI, false);
    var ellipsePath = new THREE.CurvePath();
    ellipsePath.add(ellipse);
    var ellipseGeometry = ellipsePath.createPointsGeometry(100);
    ellipseGeometry.computeTangents();
    var line = new THREE.Line(ellipseGeometry, material);
    scene.add( line );
}


function animate() {
    requestAnimationFrame( animate );
    controls.update();
    renderer.render( scene, camera );

}

</script>
</body>
</html>
于 2013-12-28T02:37:01.447 回答