UNPKG

react-planner

Version:

react-planner is a React Component for plans design. Draw a 2D floorplan and navigate it in 3D mode.

41 lines (32 loc) 1.22 kB
import * as Three from 'three'; import { List } from 'immutable'; import { COLORS } from '../../../shared-style'; export default function (width, height, grid, font) { let step = grid.properties.get('step'); let colors = grid.properties.has('color') ? new List([grid.properties.get('color')]) : grid.properties.get('colors'); let streak = new Three.Object3D(); streak.name = 'streak'; let counter = 0; for (let i = 0; i <= height; i += step) { let geometry = new Three.Geometry(); geometry.vertices.push(new Three.Vector3(0, 0, -i)); geometry.vertices.push(new Three.Vector3(width, 0, -i)); let color = colors.get(counter % colors.size); let material = new Three.LineBasicMaterial({ color }); if (counter % 5 == 0) { let shape = new Three.TextGeometry(('' + (counter * step)), { size: 16, height: 1, font }); let wrapper = new Three.MeshBasicMaterial({ color: COLORS.black }); let words = new Three.Mesh(shape, wrapper); words.rotation.x -= Math.PI / 2; words.position.set(-90, 0, -i); streak.add(words); } streak.add(new Three.LineSegments(geometry, material)); counter++; } return streak; }