Indexing into three labels - colours for 24-cell
This commit is contained in:
		
							parent
							
								
									d09dca808f
								
							
						
					
					
						commit
						399a29c30e
					
				
							
								
								
									
										44
									
								
								main.js
									
									
									
									
									
								
							
							
						
						
									
										44
									
								
								main.js
									
									
									
									
									
								
							| @ -3,10 +3,10 @@ import * as THREE from 'three'; | |||||||
| import * as SHAPES from './shapes.js'; | import * as SHAPES from './shapes.js'; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| const NODE_SIZE = 0.07; | const NODE_SIZE = 0.08; | ||||||
| const LINK_SIZE = 0.03; | const LINK_SIZE = 0.02; | ||||||
| const NODE_OPACITY = 1.0; | const NODE_OPACITY = 1.0; | ||||||
| const LINK_OPACITY = 0.8; | const LINK_OPACITY = 0.7; | ||||||
| 
 | 
 | ||||||
| const HYPERPLANE = 2; | const HYPERPLANE = 2; | ||||||
| 
 | 
 | ||||||
| @ -99,9 +99,9 @@ function fourDtoV3(x, y, z, w, rotations) { | |||||||
| 
 | 
 | ||||||
| class FourDShape extends THREE.Group { | class FourDShape extends THREE.Group { | ||||||
| 
 | 
 | ||||||
| 	constructor(node_m, link_m, structure) { | 	constructor(node_ms, link_m, structure) { | ||||||
| 		super(); | 		super(); | ||||||
| 		this.node_m = node_m; | 		this.node_ms = node_ms; | ||||||
| 		this.link_m = link_m; | 		this.link_m = link_m; | ||||||
| 		this.nodes4 = structure.nodes; | 		this.nodes4 = structure.nodes; | ||||||
| 		this.nodes3 = {}; | 		this.nodes3 = {}; | ||||||
| @ -109,9 +109,9 @@ class FourDShape extends THREE.Group { | |||||||
| 		this.initShapes(); | 		this.initShapes(); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	makeNode(v3) { | 	makeNode(material, v3) { | ||||||
| 		const geometry = new THREE.SphereGeometry(NODE_SIZE); | 		const geometry = new THREE.SphereGeometry(NODE_SIZE); | ||||||
| 		const sphere = new THREE.Mesh(geometry, this.node_m); | 		const sphere = new THREE.Mesh(geometry, material); | ||||||
| 		sphere.position.copy(v3); | 		sphere.position.copy(v3); | ||||||
| 		this.add(sphere); | 		this.add(sphere); | ||||||
| 		return sphere; | 		return sphere; | ||||||
| @ -150,9 +150,10 @@ class FourDShape extends THREE.Group { | |||||||
| 	initShapes() { | 	initShapes() { | ||||||
| 		for( const n of this.nodes4 ) { | 		for( const n of this.nodes4 ) { | ||||||
| 			const v3 = fourDtoV3(n.x, n.y, n.z, n.w, []); | 			const v3 = fourDtoV3(n.x, n.y, n.z, n.w, []); | ||||||
|  | 			const material = this.node_ms[n.label]; | ||||||
| 			this.nodes3[n.id] = { | 			this.nodes3[n.id] = { | ||||||
| 				v3: v3, | 				v3: v3, | ||||||
| 				object: this.makeNode(v3) | 				object: this.makeNode(material, v3) | ||||||
| 			}; | 			}; | ||||||
| 		} | 		} | ||||||
| 		for( const l of this.links ) { | 		for( const l of this.links ) { | ||||||
| @ -198,18 +199,26 @@ const renderer = new THREE.WebGLRenderer({antialias: true}); | |||||||
| renderer.setSize( window.innerWidth, window.innerHeight ); | renderer.setSize( window.innerWidth, window.innerHeight ); | ||||||
| document.body.appendChild( renderer.domElement ); | document.body.appendChild( renderer.domElement ); | ||||||
| 
 | 
 | ||||||
|  | const struct = SHAPES.cell24(); | ||||||
| 
 | 
 | ||||||
|  | // TODO = automate going from struct labels to colours, this now only
 | ||||||
|  | // works with the 24-cell
 | ||||||
| 
 | 
 | ||||||
|  | const node_ms = {}; | ||||||
| 
 | 
 | ||||||
| const node_m = new THREE.MeshStandardMaterial( | node_ms["RED"] = new THREE.MeshStandardMaterial( { color: 0x990044 } ); | ||||||
| 	{ color: 0x990044 } ); | node_ms["GREEN"] = new THREE.MeshStandardMaterial( { color: 0xffffee } ); | ||||||
|  | node_ms["BLUE"] = new THREE.MeshStandardMaterial( { color: 0x101010 } ); | ||||||
| 
 | 
 | ||||||
|  | for( const label in node_ms ) { | ||||||
|  | 	const node_m = node_ms[label]; | ||||||
| 	node_m.roughness = 0.2; | 	node_m.roughness = 0.2; | ||||||
| 
 | 
 | ||||||
| 	if( NODE_OPACITY < 1.0 ) { | 	if( NODE_OPACITY < 1.0 ) { | ||||||
| 		node_m.transparent = true;	 | 		node_m.transparent = true;	 | ||||||
| 		node_m.opacity = NODE_OPACITY; | 		node_m.opacity = NODE_OPACITY; | ||||||
| 	} | 	} | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| const link_m = new THREE.MeshStandardMaterial( | const link_m = new THREE.MeshStandardMaterial( | ||||||
| @ -224,32 +233,37 @@ if( LINK_OPACITY < 1.0 ) { | |||||||
| 	link_m.opacity = LINK_OPACITY; | 	link_m.opacity = LINK_OPACITY; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| const struct = SHAPES.cell24(); |  | ||||||
| 
 | 
 | ||||||
| const shape = new FourDShape(node_m, link_m, struct); | const shape = new FourDShape(node_ms, link_m, struct); | ||||||
| 
 | 
 | ||||||
| scene.add(shape); | scene.add(shape); | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| camera.position.z = 4; | camera.position.z = 4; | ||||||
| 
 | 
 | ||||||
|  | const dragK = 0.01; | ||||||
|  | 
 | ||||||
| let theta = 0; | let theta = 0; | ||||||
| let psi = 0; | let psi = 0; | ||||||
| let startX = 0; | let startX = 0; | ||||||
| let startY = 0; | let startY = 0; | ||||||
|  | let startX0 = 0; | ||||||
|  | let startY0 = 0; | ||||||
| 
 | 
 | ||||||
| renderer.domElement.addEventListener("mousedown", (event) => { | renderer.domElement.addEventListener("mousedown", (event) => { | ||||||
| 	if( event.buttons === 1 ) { | 	if( event.buttons === 1 ) { | ||||||
| 		startX = event.clientX; | 		startX = event.clientX; | ||||||
| 		startY = event.clientY; | 		startY = event.clientY; | ||||||
|  | 		startX0 = theta / dragK; | ||||||
|  | 		startY0 = theta / dragK; | ||||||
| 	} | 	} | ||||||
| }) | }) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| renderer.domElement.addEventListener("mousemove", (event) => { | renderer.domElement.addEventListener("mousemove", (event) => { | ||||||
| 	if( event.buttons === 1 ) { | 	if( event.buttons === 1 ) { | ||||||
| 		theta = (event.clientX - startX) * 0.01; | 		theta = (event.clientX - startX + startX0) * dragK; | ||||||
| 		psi = (event.clientY - startY) * 0.01; | 		psi = (event.clientY - startY + startY0) * dragK; | ||||||
| 	} | 	} | ||||||
| }) | }) | ||||||
| 
 | 
 | ||||||
| @ -260,7 +274,7 @@ const rotation = new THREE.Matrix4(); | |||||||
| function animate() { | function animate() { | ||||||
| 	requestAnimationFrame( animate ); | 	requestAnimationFrame( animate ); | ||||||
| 
 | 
 | ||||||
| 	const rotations = [rotYZ(theta), rotXW(psi)]; | 	const rotations = [rotYZ(theta), rotXZ(psi)]; | ||||||
| 	shape.render3(rotations); | 	shape.render3(rotations); | ||||||
| 
 | 
 | ||||||
| 	renderer.render( scene, camera ); | 	renderer.render( scene, camera ); | ||||||
|  | |||||||
							
								
								
									
										17
									
								
								shapes.js
									
									
									
									
									
								
							
							
						
						
									
										17
									
								
								shapes.js
									
									
									
									
									
								
							| @ -124,6 +124,14 @@ export const TESSERACT = { | |||||||
| 	] | 	] | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | // this was done manually and I'm not sure if it's right
 | ||||||
|  | 
 | ||||||
|  | const CELL24_INDEXING = { | ||||||
|  | 	x: { y: 'RED', z: 'BLUE', w: 'GREEN' }, | ||||||
|  | 	y: { z: 'GREEN', w: 'BLUE' }, | ||||||
|  | 	z: { w: 'RED' }  | ||||||
|  | }; | ||||||
|  | 
 | ||||||
| function make_24cell_vertices() { | function make_24cell_vertices() { | ||||||
| 	const axes = [ 'x', 'y', 'z', 'w' ]; | 	const axes = [ 'x', 'y', 'z', 'w' ]; | ||||||
| 	const nodes = []; | 	const nodes = []; | ||||||
| @ -132,9 +140,14 @@ function make_24cell_vertices() { | |||||||
| 		for ( let q = p + 1; q < 4; q++ ) { | 		for ( let q = p + 1; q < 4; q++ ) { | ||||||
| 			const a1 = axes[p]; | 			const a1 = axes[p]; | ||||||
| 			const a2 = axes[q]; | 			const a2 = axes[q]; | ||||||
|  | 			const label = CELL24_INDEXING[a1][a2]; | ||||||
| 			for ( const v1 of [ -1, 1 ] ) { | 			for ( const v1 of [ -1, 1 ] ) { | ||||||
| 				for ( const v2 of [ -1, 1 ] ) { | 				for ( const v2 of [ -1, 1 ] ) { | ||||||
| 					const node = { id: i, x: 0, y: 0, z: 0, w:0 }; | 					const node = { | ||||||
|  | 						id: i, | ||||||
|  | 						x: 0, y: 0, z: 0, w:0, | ||||||
|  | 						label: label | ||||||
|  | 					}; | ||||||
| 					node[a1] = v1; | 					node[a1] = v1; | ||||||
| 					node[a2] = v2; | 					node[a2] = v2; | ||||||
| 					nodes.push(node); | 					nodes.push(node); | ||||||
| @ -177,6 +190,6 @@ export const cell24 = () => { | |||||||
| 	const nodes = make_24cell_vertices(); | 	const nodes = make_24cell_vertices(); | ||||||
| 	const links = make_24cell_edges(nodes); | 	const links = make_24cell_edges(nodes); | ||||||
| 
 | 
 | ||||||
| 	return { nodes: nodes, links: links }; | 	return { nodes: nodes, links: links, labels: [ "RED", "GREEN", "BLUE" ] }; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user