2017-12-22 23:00:23 +01:00
|
|
|
/// <reference path="./moduleView.ts" />
|
2017-12-18 22:04:17 +01:00
|
|
|
|
|
|
|
namespace pxsim.visuals {
|
|
|
|
|
2018-01-04 23:03:50 +01:00
|
|
|
export class MediumMotorView extends MotorView implements LayoutElement {
|
2017-12-18 22:04:17 +01:00
|
|
|
|
|
|
|
constructor(port: number) {
|
2018-01-04 23:03:50 +01:00
|
|
|
super(MEDIUM_MOTOR_SVG, "medium-motor", NodeType.MediumMotor, port, "medmotor_Hole");
|
2017-12-18 22:04:17 +01:00
|
|
|
}
|
|
|
|
|
2018-03-28 22:36:52 +02:00
|
|
|
protected optimizeForLightMode() {
|
|
|
|
(this.content.getElementById(this.normalizeId('medmotor_box_wgradient')) as SVGElement).style.fill = '#a8aaa8';
|
|
|
|
}
|
|
|
|
|
2017-12-18 22:04:17 +01:00
|
|
|
public getPaddingRatio() {
|
2018-04-10 01:24:01 +02:00
|
|
|
return 1 / 8;
|
|
|
|
}
|
|
|
|
|
|
|
|
getWiringRatio() {
|
|
|
|
return 0.5;
|
2017-12-18 22:04:17 +01:00
|
|
|
}
|
|
|
|
|
2018-01-04 23:03:50 +01:00
|
|
|
protected renderMotorAngle(holeEl: Element, angle: number) {
|
2017-12-27 23:48:15 +01:00
|
|
|
const width = 44.45;
|
|
|
|
const height = 44.45;
|
|
|
|
const transform = `translate(2 1.84) rotate(${angle} ${width / 2} ${height / 2})`;
|
2017-12-18 22:04:17 +01:00
|
|
|
holeEl.setAttribute("transform", transform);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|