把前端从CircuitVerse中拆了出来
This commit is contained in:
commit
5bf1284599
2182 changed files with 189323 additions and 0 deletions
84
simulator/src/modules/Arrow.js
Executable file
84
simulator/src/modules/Arrow.js
Executable file
|
@ -0,0 +1,84 @@
|
|||
import CircuitElement from "../circuitElement";
|
||||
import Node, { findNode } from "../node";
|
||||
import simulationArea from "../simulationArea";
|
||||
import { correctWidth, lineTo, moveTo, arc } from "../canvasApi";
|
||||
import { changeInputSize } from "../modules";
|
||||
/**
|
||||
* @class
|
||||
* Arrow
|
||||
* @extends CircuitElement
|
||||
* @param {number} x - x coordinate of element.
|
||||
* @param {number} y - y coordinate of element.
|
||||
* @param {Scope=} scope - Cirucit on which element is drawn
|
||||
* @param {string=} dir - direction of element
|
||||
* @category modules
|
||||
*/
|
||||
import { colors } from "../themer/themer";
|
||||
|
||||
export default class Arrow extends CircuitElement {
|
||||
constructor(x, y, scope = globalScope, dir = "RIGHT") {
|
||||
super(x, y, scope, dir, 8);
|
||||
/* this is done in this.baseSetup() now
|
||||
this.scope['Arrow'].push(this);
|
||||
*/
|
||||
this.rectangleObject = false;
|
||||
this.fixedBitWidth = true;
|
||||
this.setDimensions(30, 20);
|
||||
}
|
||||
|
||||
/**
|
||||
* @memberof Arrow
|
||||
* fn to create save Json Data of object
|
||||
* @return {JSON}
|
||||
*/
|
||||
customSave() {
|
||||
const data = {
|
||||
constructorParamaters: [this.direction],
|
||||
};
|
||||
return data;
|
||||
}
|
||||
|
||||
/**
|
||||
* @memberof Arrow
|
||||
* function to draw element
|
||||
*/
|
||||
customDraw() {
|
||||
var ctx = simulationArea.context;
|
||||
ctx.lineWidth = correctWidth(3);
|
||||
const xx = this.x;
|
||||
const yy = this.y;
|
||||
ctx.strokeStyle = colors["stroke_alt"];
|
||||
ctx.fillStyle = colors["fill"];
|
||||
|
||||
ctx.beginPath();
|
||||
|
||||
moveTo(ctx, -30, -3, xx, yy, this.direction);
|
||||
lineTo(ctx, 10, -3, xx, yy, this.direction);
|
||||
lineTo(ctx, 10, -15, xx, yy, this.direction);
|
||||
lineTo(ctx, 30, 0, xx, yy, this.direction);
|
||||
lineTo(ctx, 10, 15, xx, yy, this.direction);
|
||||
lineTo(ctx, 10, 3, xx, yy, this.direction);
|
||||
lineTo(ctx, -30, 3, xx, yy, this.direction);
|
||||
ctx.closePath();
|
||||
ctx.stroke();
|
||||
if (
|
||||
(this.hover && !simulationArea.shiftDown) ||
|
||||
simulationArea.lastSelected === this ||
|
||||
simulationArea.multipleObjectSelections.contains(this)
|
||||
)
|
||||
ctx.fillStyle = colors["hover_select"];
|
||||
ctx.fill();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @memberof Arrow
|
||||
* Help Tip
|
||||
* @type {string}
|
||||
* @category modules
|
||||
*/
|
||||
Arrow.prototype.tooltipText = "Arrow ToolTip : Arrow Selected.";
|
||||
Arrow.prototype.propagationDelayFixed = true;
|
||||
Arrow.prototype.helplink =
|
||||
"https://docs.circuitverse.org/#/annotation?id=arrow";
|
||||
Arrow.prototype.objectType = "Arrow";
|
Loading…
Add table
Add a link
Reference in a new issue