pxt-ev3/sim/visuals/nodes/largeMotorView.ts

33 lines
1.0 KiB
TypeScript
Raw Normal View History

/// <reference path="./moduleView.ts" />
2017-12-18 22:04:17 +01:00
namespace pxsim.visuals {
export class LargeMotorView extends ModuleView implements LayoutElement {
2017-12-18 22:04:17 +01:00
private static ROTATING_ECLIPSE_ID = "hole";
2017-12-18 22:04:17 +01:00
constructor(port: number) {
super(LARGE_MOTOR_SVG, "large-motor", NodeType.LargeMotor, port);
}
updateState() {
const motorState = ev3board().getMotors()[this.port];
if (!motorState) return;
const speed = motorState.getSpeed();
if (!speed) return;
this.setMotorAngle(motorState.getAngle());
2017-12-18 22:04:17 +01:00
}
private setMotorAngle(angle: number) {
2017-12-18 22:04:17 +01:00
const holeEl = this.content.getElementById(this.normalizeId(LargeMotorView.ROTATING_ECLIPSE_ID))
const width = 125.92;
const height = 37.9;
2017-12-18 22:04:17 +01:00
const transform = `rotate(${angle} ${width / 2} ${height / 2})`;
holeEl.setAttribute("transform", transform);
}
getWiringRatio() {
return 0.37;
2017-12-18 22:04:17 +01:00
}
}
}