jsketcher/web/app/cad/craft/datum/csysObject.js
2018-10-30 23:01:57 -07:00

84 lines
2.2 KiB
JavaScript

import {
Geometry, Line, LineBasicMaterial, MeshBasicMaterial, MeshLambertMaterial, Object3D, Quaternion,
Vector3
} from 'three';
import {AXIS} from '../../../math/l3space';
import {MeshArrow} from 'scene/objects/auxiliary';
import {OnTopOfAll} from 'scene/materialMixins';
export default class CSysObject3D extends Object3D {
constructor(csys, sceneSetup, arrowParams) {
super();
this.csys = csys;
this.sceneSetup = sceneSetup;
function createBasisArrow(axis, color) {
let meshArrow = new MeshArrow({
dir: axis,
color,
length: CSYS_SIZE_MODEL,
headLength: 30,
headWidth: 15,
lineWidth: 2,
materialCreate: p => new MeshLambertMaterial(p),
...arrowParams
});
return meshArrow;
}
this.xAxis = createBasisArrow(AXIS.X, 0xFF0000);
this.yAxis = createBasisArrow(AXIS.Y, 0x00FF00);
this.zAxis = createBasisArrow(AXIS.Z, 0x0000FF);
this.add(this.xAxis);
this.add(this.yAxis);
this.add(this.zAxis);
}
updateMatrix() {
let {origin: o, x, y, z} = this.csys;
let k = this.viewScaleFactor();
this.matrix.set(
k*x.x, k*y.x, k*z.x, o.x,
k*x.y, k*y.y, k*z.y, o.y,
k*x.z, k*y.z, k*z.z, o.z,
0, 0, 0, 1
);
// this.scale.set(k, k, k);
// super.updateMatrix();
}
viewScaleFactor() {
let container = this.sceneSetup.container;
let viewHeight = container.clientHeight;
let camera = this.sceneSetup.camera;
if (camera.isOrthographicCamera) {
return viewHeight / (camera.top - camera.bottom) / camera.zoom * 2;
} else {
let p = new Vector3().copy(this.csys.origin);
let cp = new Vector3().copy(camera.position);
let z = p.sub(cp).length();
let tanHFov = Math.atan((camera.fov / 2) / 180 * Math.PI);
let fitUnits = tanHFov * z * 2;
let modelTakingPart = CSYS_SIZE_MODEL / fitUnits;
let modelActualSizePx = viewHeight * modelTakingPart;
return SIZE_PX / modelActualSizePx;
}
}
dispose() {
this.xAxis.dispose();
this.yAxis.dispose();
this.zAxis.dispose();
}
}
export const CSYS_SIZE_MODEL = 100;
const SIZE_PX = 50;