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
JavaScript
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;
}