wisemapping-frontend/packages/web2d/lib/components/CurvedLine.js

125 lines
2.9 KiB
JavaScript
Raw Normal View History

2021-07-16 16:41:58 +02:00
/*
* Copyright [2015] [wisemapping]
*
* Licensed under WiseMapping Public License, Version 1.0 (the "License").
* It is basically the Apache License, Version 2.0 (the "License") plus the
* "powered by wisemapping" text requirement on every single page;
* you may not use this file except in compliance with the License.
* You may obtain a copy of the license at
*
* http://www.wisemapping.org/license
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
const Element = require('./Element').default;
const Toolkit = require('./Toolkit').default;
const CurvedLine = new Class({
2021-10-05 01:56:40 +02:00
Extends: Element,
initialize(attributes) {
const peer = Toolkit.createCurvedLine();
const defaultAttributes = {
strokeColor: 'blue', strokeWidth: 1, strokeStyle: 'solid', strokeOpacity: 1,
};
for (const key in attributes) {
defaultAttributes[key] = attributes[key];
}
this.parent(peer, defaultAttributes);
},
2021-07-16 16:41:58 +02:00
2021-10-05 01:56:40 +02:00
getType() {
return 'CurvedLine';
},
2021-07-16 16:41:58 +02:00
2021-10-05 01:56:40 +02:00
setFrom(x, y) {
$assert(!isNaN(x), 'x must be defined');
$assert(!isNaN(y), 'y must be defined');
2021-07-16 16:41:58 +02:00
2021-10-05 01:56:40 +02:00
this._peer.setFrom(x, y);
},
2021-07-16 16:41:58 +02:00
2021-10-05 01:56:40 +02:00
setTo(x, y) {
$assert(!isNaN(x), 'x must be defined');
$assert(!isNaN(y), 'y must be defined');
2021-07-16 16:41:58 +02:00
2021-10-05 01:56:40 +02:00
this._peer.setTo(x, y);
},
2021-07-16 16:41:58 +02:00
2021-10-05 01:56:40 +02:00
getFrom() {
return this._peer.getFrom();
},
2021-07-16 16:41:58 +02:00
2021-10-05 01:56:40 +02:00
getTo() {
return this._peer.getTo();
},
2021-07-16 16:41:58 +02:00
2021-10-05 01:56:40 +02:00
setShowEndArrow(visible) {
this._peer.setShowEndArrow(visible);
},
2021-07-16 16:41:58 +02:00
2021-10-05 01:56:40 +02:00
isShowEndArrow() {
return this._peer.isShowEndArrow();
},
2021-07-16 16:41:58 +02:00
2021-10-05 01:56:40 +02:00
setShowStartArrow(visible) {
this._peer.setShowStartArrow(visible);
},
2021-07-16 16:41:58 +02:00
2021-10-05 01:56:40 +02:00
isShowStartArrow() {
return this._peer.isShowStartArrow();
},
2021-07-16 16:41:58 +02:00
2021-10-05 01:56:40 +02:00
setSrcControlPoint(control) {
this._peer.setSrcControlPoint(control);
},
2021-07-16 16:41:58 +02:00
2021-10-05 01:56:40 +02:00
setDestControlPoint(control) {
this._peer.setDestControlPoint(control);
},
2021-07-16 16:41:58 +02:00
2021-10-05 01:56:40 +02:00
getControlPoints() {
return this._peer.getControlPoints();
},
2021-07-16 16:41:58 +02:00
2021-10-05 01:56:40 +02:00
isSrcControlPointCustom() {
return this._peer.isSrcControlPointCustom();
},
2021-07-16 16:41:58 +02:00
2021-10-05 01:56:40 +02:00
isDestControlPointCustom() {
return this._peer.isDestControlPointCustom();
},
2021-07-16 16:41:58 +02:00
2021-10-05 01:56:40 +02:00
setIsSrcControlPointCustom(isCustom) {
this._peer.setIsSrcControlPointCustom(isCustom);
},
2021-07-16 16:41:58 +02:00
2021-10-05 01:56:40 +02:00
setIsDestControlPointCustom(isCustom) {
this._peer.setIsDestControlPointCustom(isCustom);
},
2021-07-16 16:41:58 +02:00
2021-10-05 01:56:40 +02:00
updateLine(avoidControlPointFix) {
return this._peer.updateLine(avoidControlPointFix);
},
2021-07-16 16:41:58 +02:00
2021-10-05 01:56:40 +02:00
setStyle(style) {
this._peer.setLineStyle(style);
},
2021-07-16 16:41:58 +02:00
2021-10-05 01:56:40 +02:00
getStyle() {
return this._peer.getLineStyle();
},
2021-07-16 16:41:58 +02:00
2021-10-05 01:56:40 +02:00
setDashed(length, spacing) {
this._peer.setDashed(length, spacing);
},
2021-07-16 16:41:58 +02:00
});
CurvedLine.SIMPLE_LINE = false;
CurvedLine.NICE_LINE = true;
export default CurvedLine;