mirror of
https://github.com/GNS3/gns3-web-ui.git
synced 2025-01-02 02:56:42 +00:00
Serial Link, fixes: #4
This commit is contained in:
parent
d32c1b6112
commit
5690db42cd
32
src/app/cartography/shared/widgets/ethernet-link.widget.ts
Normal file
32
src/app/cartography/shared/widgets/ethernet-link.widget.ts
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
import {Widget} from "./widget";
|
||||||
|
import {SVGSelection} from "../../../map/models/types";
|
||||||
|
|
||||||
|
import { line } from "d3-shape";
|
||||||
|
import {Link} from "../models/link.model";
|
||||||
|
|
||||||
|
export class EthernetLinkWidget implements Widget {
|
||||||
|
|
||||||
|
public draw(view: SVGSelection, link: Link) {
|
||||||
|
const link_data = [[
|
||||||
|
[link.source.x, link.source.y],
|
||||||
|
[link.target.x, link.target.y]
|
||||||
|
]];
|
||||||
|
|
||||||
|
const value_line = line();
|
||||||
|
|
||||||
|
let link_path = view.select<SVGPathElement>('path');
|
||||||
|
|
||||||
|
if (!link_path.node()) {
|
||||||
|
link_path = view.append<SVGPathElement>('path');
|
||||||
|
}
|
||||||
|
|
||||||
|
const link_path_data = link_path.data(link_data);
|
||||||
|
|
||||||
|
link_path_data
|
||||||
|
.attr('d', value_line)
|
||||||
|
.attr('stroke', '#000')
|
||||||
|
.attr('stroke-width', '2');
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -6,11 +6,20 @@ import { SVGSelection } from "../../../map/models/types";
|
|||||||
import { Link } from "../models/link.model";
|
import { Link } from "../models/link.model";
|
||||||
import { LinkStatus } from "../models/link-status.model";
|
import { LinkStatus } from "../models/link-status.model";
|
||||||
import { MultiLinkCalculatorHelper } from "../../map/helpers/multi-link-calculator-helper";
|
import { MultiLinkCalculatorHelper } from "../../map/helpers/multi-link-calculator-helper";
|
||||||
|
import {SerialLinkWidget} from "./serial-link.widget";
|
||||||
|
import {EthernetLinkWidget} from "./ethernet-link.widget";
|
||||||
|
|
||||||
|
|
||||||
export class LinksWidget implements Widget {
|
export class LinksWidget implements Widget {
|
||||||
private multiLinkCalculatorHelper = new MultiLinkCalculatorHelper();
|
private multiLinkCalculatorHelper = new MultiLinkCalculatorHelper();
|
||||||
|
|
||||||
|
private getLinkWidget(link: Link) {
|
||||||
|
if (link.link_type === 'serial') {
|
||||||
|
return new SerialLinkWidget();
|
||||||
|
}
|
||||||
|
return new EthernetLinkWidget();
|
||||||
|
}
|
||||||
|
|
||||||
public draw(view: SVGSelection, links: Link[]) {
|
public draw(view: SVGSelection, links: Link[]) {
|
||||||
const self = this;
|
const self = this;
|
||||||
|
|
||||||
@ -31,26 +40,12 @@ export class LinksWidget implements Widget {
|
|||||||
|
|
||||||
link.merge(link_enter)
|
link.merge(link_enter)
|
||||||
.each(function (this: SVGGElement, l: Link) {
|
.each(function (this: SVGGElement, l: Link) {
|
||||||
const link_data = [[
|
|
||||||
[l.source.x, l.source.y],
|
|
||||||
[l.target.x, l.target.y]
|
|
||||||
]];
|
|
||||||
|
|
||||||
const link_group = select<SVGGElement, Link>(this);
|
const link_group = select<SVGGElement, Link>(this);
|
||||||
const value_line = line();
|
const link_widget = self.getLinkWidget(l);
|
||||||
|
|
||||||
let link_path = link_group.select<SVGPathElement>('path');
|
link_widget.draw(link_group, l);
|
||||||
|
|
||||||
if (!link_path.node()) {
|
const link_path = link_group.select<SVGPathElement>('path');
|
||||||
link_path = link_group.append<SVGPathElement>('path');
|
|
||||||
}
|
|
||||||
|
|
||||||
const link_path_data = link_path.data(link_data);
|
|
||||||
|
|
||||||
link_path_data
|
|
||||||
.attr('d', value_line)
|
|
||||||
.attr('stroke', '#000')
|
|
||||||
.attr('stroke-width', '1');
|
|
||||||
|
|
||||||
const start_point: SVGPoint = link_path.node().getPointAtLength(50);
|
const start_point: SVGPoint = link_path.node().getPointAtLength(50);
|
||||||
const end_point: SVGPoint = link_path.node().getPointAtLength(link_path.node().getTotalLength() - 50);
|
const end_point: SVGPoint = link_path.node().getPointAtLength(link_path.node().getTotalLength() - 50);
|
||||||
|
57
src/app/cartography/shared/widgets/serial-link.widget.ts
Normal file
57
src/app/cartography/shared/widgets/serial-link.widget.ts
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
import {Widget} from "./widget";
|
||||||
|
import {SVGSelection} from "../../../map/models/types";
|
||||||
|
import {Link} from "../models/link.model";
|
||||||
|
import { path } from "d3-path";
|
||||||
|
|
||||||
|
|
||||||
|
export class SerialLinkWidget implements Widget {
|
||||||
|
|
||||||
|
public draw(view: SVGSelection, link: Link) {
|
||||||
|
const dx = link.target.x - link.source.x;
|
||||||
|
const dy = link.target.y - link.source.y;
|
||||||
|
|
||||||
|
const vector_angle = Math.atan2(dy, dx);
|
||||||
|
const rot_angle = -Math.PI / 4.0;
|
||||||
|
const vect_rot = [
|
||||||
|
Math.cos(vector_angle + rot_angle),
|
||||||
|
Math.sin(vector_angle + rot_angle)
|
||||||
|
];
|
||||||
|
|
||||||
|
const angle_source = [
|
||||||
|
link.source.x + dx / 2.0 + 15 * vect_rot[0],
|
||||||
|
link.source.y + dy / 2.0 + 15 * vect_rot[1]
|
||||||
|
];
|
||||||
|
|
||||||
|
const angle_target = [
|
||||||
|
link.target.x - dx / 2.0 - 15 * vect_rot[0],
|
||||||
|
link.target.y - dy / 2.0 - 15 * vect_rot[1]
|
||||||
|
];
|
||||||
|
|
||||||
|
const line_data = [
|
||||||
|
[link.source.x, link.source.y],
|
||||||
|
angle_source,
|
||||||
|
angle_target,
|
||||||
|
[link.target.x, link.target.y]
|
||||||
|
];
|
||||||
|
|
||||||
|
let link_path = view.select<SVGPathElement>('path');
|
||||||
|
|
||||||
|
if (!link_path.node()) {
|
||||||
|
link_path = view.append<SVGPathElement>('path');
|
||||||
|
}
|
||||||
|
|
||||||
|
const line_generator = path();
|
||||||
|
line_generator.moveTo(line_data[0][0], line_data[0][1]);
|
||||||
|
line_generator.lineTo(line_data[1][0], line_data[1][1]);
|
||||||
|
line_generator.lineTo(line_data[2][0], line_data[2][1]);
|
||||||
|
line_generator.lineTo(line_data[3][0], line_data[3][1]);
|
||||||
|
|
||||||
|
link_path
|
||||||
|
.attr('d', line_generator.toString())
|
||||||
|
.attr('stroke', '#B22222')
|
||||||
|
.attr('fill', 'none')
|
||||||
|
.attr('stroke-width', '2');
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user