2016-06-21 15 views
2

私はワイヤーフレームの球を持っています。頂点に点を追加したいと思います。これに似た何か:Three.jsの頂点に点を追加する

sphere wireframe with dots:。私は各頂点にドットを追加するにはどうすればよい

var scene = new THREE.Scene(); 

var camera = new THREE.PerspectiveCamera(75, window.innerWidth/window.innerHeight, 0.1, 1000); 

var renderer = new THREE.WebGLRenderer({ alpha: true }); 
    renderer.setSize(window.innerWidth, window.innerHeight); 
    document.body.appendChild(renderer.domElement); 

var geometry = new THREE.SphereGeometry(3.25, 32, 20); 
var material = new THREE.MeshLambertMaterial({ color: 0x43CC4C, wireframe: true }); 

var sphere = new THREE.Mesh(geometry, material); 
scene.add(sphere); 

var pointLight = new THREE.PointLight(0xFFFFFF); 
pointLight.position.x = 80; 
pointLight.position.y = 80; 
pointLight.position.z = 130; 
scene.add(pointLight); 

camera.position.z = 5; 

function render() { 
    renderer.render(scene, camera); 
} 

render(); 

[codepen here]

はここにすべての私のjsですか?

答えて

6

同様の結果が得られる例を示します。

私はIcosahedronGeometryと呼ばれる余分なジオメトリタイプを追加しましたし、私はそれが私がtrueに設定wireframeMeshPhongMaterialを使用しているラインのためのポイントを、作成するために、頂点だ使用しています。

ポイントのサイズを変更したり、シェイプ/テクスチャに置き換えることができます。

// Extra geometry 
 
THREE.IcosahedronGeometry = function(radius, detail) { 
 
    var t = (1 + Math.sqrt(5))/2; 
 
    var vertices = [-1, t, 0, 1, t, 0, -1, -t, 0, 1, -t, 0, 
 
    0, -1, t, 0, 1, t, 0, -1, -t, 0, 1, -t, 
 
    t, 0, -1, t, 0, 1, -t, 0, -1, -t, 0, 1 
 
    ]; 
 
    var indices = [ 
 
    0, 11, 5, 0, 5, 1, 0, 1, 7, 0, 7, 10, 0, 10, 11, 
 
    1, 5, 9, 5, 11, 4, 11, 10, 2, 10, 7, 6, 7, 1, 8, 
 
    3, 9, 4, 3, 4, 2, 3, 2, 6, 3, 6, 8, 3, 8, 9, 
 
    4, 9, 5, 2, 4, 11, 6, 2, 10, 8, 6, 7, 9, 8, 1 
 
    ]; 
 
    THREE.PolyhedronGeometry.call(this, vertices, indices, radius, detail); 
 
    this.type = 'IcosahedronGeometry'; 
 
    this.parameters = { 
 
    radius: radius, 
 
    detail: detail 
 
    }; 
 
}; 
 

 
THREE.IcosahedronGeometry.prototype = Object.create(THREE.PolyhedronGeometry.prototype); 
 
THREE.IcosahedronGeometry.prototype.constructor = THREE.IcosahedronGeometry; 
 

 
// Scene 
 
var scene = new THREE.Scene(); 
 
var camera = new THREE.PerspectiveCamera(75, window.innerWidth/window.innerHeight, 0.1, 1000); 
 

 
var renderer = new THREE.WebGLRenderer({ 
 
    antialias: 1 
 
}); 
 

 
renderer.setClearColor(0xf7f7f7); 
 
renderer.setSize(window.innerWidth, window.innerHeight); 
 
document.body.appendChild(renderer.domElement); 
 

 
scene.fog = new THREE.Fog(0xd4d4d4, 8, 20); 
 

 
// Create vertex points 
 
var mesh = new THREE.IcosahedronGeometry(10, 1); // radius, detail 
 
var vertices = mesh.vertices; 
 
var positions = new Float32Array(vertices.length * 3); 
 
for (var i = 0, l = vertices.length; i < l; i++) { 
 
    vertices[i].toArray(positions, i * 3); 
 
} 
 

 
var geometry = new THREE.BufferGeometry(); 
 
geometry.addAttribute('position', new THREE.BufferAttribute(positions, 3)); 
 

 
var material = new THREE.PointsMaterial({ 
 
    size: 0.4, 
 
    vertexColors: THREE.VertexColors, 
 
    color: 0x252525 
 
}); 
 
var points = new THREE.Points(geometry, material); 
 

 
var object = new THREE.Object3D(); 
 

 
object.add(points); 
 

 

 

 
object.add(new THREE.Mesh(
 
    mesh, 
 
    new THREE.MeshPhongMaterial({ 
 
    color: 0x616161, 
 
    emissive: 0xa1a1a1, 
 
    wireframe: true, 
 
    fog: 1 
 
    }) 
 

 
)); 
 

 
scene.add(object); 
 

 
camera.position.z = 20; 
 

 
var render = function() { 
 
    requestAnimationFrame(render); 
 

 
    object.rotation.x += 0.01; 
 
    object.rotation.y += 0.01; 
 

 
    renderer.render(scene, camera); 
 
}; 
 

 
render();
body { 
 
    margin: 0; 
 
} 
 
canvas { 
 
    width: 100%; 
 
    height: 100% 
 
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/2.1.3/jquery.min.js"></script> 
 
<script src="https://ajax.googleapis.com/ajax/libs/threejs/r76/three.min.js"></script>

+0

ニース、しかし、あなたの変数名、信じられないほど混乱しています。 'mesh'はジオメトリ、' sphere'は点群、 'mesh2'はObject3Dです。 'transparent'はブール値でなければなりません。 – WestLangley

+0

@WestLangley 'LineBasicMaterial'にそのパラメータが存在しないので、私はそれらの名前を変更して' transparent'を削除しました。 – Erevald

+0

はい、あります。これは「材料」の特性です。 – WestLangley

関連する問題