我正在尝试将此jsfiddle example用于Zeppelin笔记本电脑。该示例使用vis.js库,并引入了通过右键单击并绘制矩形形状来选择子图的功能。 我总体上对angular和Java脚本的了解非常有限,并希望能得到一些指针来解决我遇到的问题。
这是笔记本中的相应单元格:
%angular
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/vis/4.21.0/vis.min.css"/>
<script src="https://cdnjs.cloudflare.com/ajax/libs/d3/4.12.2/d3.min.js" type="text/javascript"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/vis/4.21.0/vis.js" type="text/javascript"></script>
<div id='network'/>
<script type="text/javascript">
const nodes = new vis.DataSet([
{ id: 1, label: 'Node 1' },
{ id: 2, label: 'Node 2' },
{ id: 3, label: 'Node 3' },
{ id: 4, label: 'Node 4' },
{ id: 5, label: 'Node 5' }
]);
const edges = new vis.DataSet([
{ from: 1, to: 3 },
{ from: 1, to: 2 },
{ from: 2, to: 4 },
{ from: 2, to: 5 }
]);
const options = {
layout: { randomSeed: 2 },
interaction:{
hover: true,
multiselect: true
}
};
// Everything is in there
const makeMeMultiSelect = (container, network, nodes) => {
const NO_CLICK = 0;
const RIGHT_CLICK = 3;
// Disable default right-click dropdown menu
container[0].oncontextmenu = () => false;
// State
let drag = false, DOMRect = {};
// Selector
const canvasify = (DOMx, DOMy) => {
const { x, y } = network.DOMtoCanvas({ x: DOMx, y: DOMy });
return [x, y];
};
const correctRange = (start, end) =>
start < end ? [start, end] : [end, start];
const selectFromDOMRect = () => {
const [sX, sY] = canvasify(DOMRect.startX, DOMRect.startY);
const [eX, eY] = canvasify(DOMRect.endX, DOMRect.endY);
const [startX, endX] = correctRange(sX, eX);
const [startY, endY] = correctRange(sY, eY);
network.selectNodes(nodes.get().reduce(
(selected, { id }) => {
const { x, y } = network.getPositions(id)[id];
return (startX <= x && x <= endX && startY <= y && y <= endY) ?
selected.concat(id) : selected;
}, []
));
}
// Listeners
container.on("mousedown", function({ which, pageX, pageY }) {
// When mousedown, save the initial rectangle state
if(which === RIGHT_CLICK) {
Object.assign(DOMRect, {
startX: pageX - this.offsetLeft,
startY: pageY - this.offsetTop,
endX: pageX - this.offsetLeft,
endY: pageY - this.offsetTop
});
drag = true;
}
});
container.on("mousemove", function({ which, pageX, pageY }) {
// Make selection rectangle disappear when accidently mouseupped outside 'container'
if(which === NO_CLICK && drag) {
drag = false;
network.redraw();
}
// When mousemove, update the rectangle state
else if(drag) {
Object.assign(DOMRect, {
endX: pageX - this.offsetLeft,
endY: pageY - this.offsetTop
});
network.redraw();
}
});
container.on("mouseup", function({ which }) {
// When mouseup, select the nodes in the rectangle
if(which === RIGHT_CLICK) {
drag = false;
network.redraw();
selectFromDOMRect();
}
});
// Drawer
network.on('afterDrawing', ctx => {
if(drag) {
const [startX, startY] = canvasify(DOMRect.startX, DOMRect.startY);
const [endX, endY] = canvasify(DOMRect.endX, DOMRect.endY);
ctx.setLineDash([5]);
ctx.strokeStyle = 'rgba(78, 146, 237, 0.75)';
ctx.strokeRect(startX, startY, endX - startX, endY - startY);
ctx.setLineDash([]);
ctx.fillStyle = 'rgba(151, 194, 252, 0.45)';
ctx.fillRect(startX, startY, endX - startX, endY - startY);
}
});
}; // end makeMeMultiSelect
$(document).ready(() => {
const container = $("#network");
const network = new vis.Network(container[0], { nodes, edges }, options);
makeMeMultiSelect(container, network, nodes);
});
</script>
如果执行此单元格,则会在控制台中收到以下错误消息:SyntaxError: redeclaration of const nodes
。
如果将所有const
都更改为var
,则可以得到图形的显示,但是可以通过右键单击来选择图形的一部分的功能(通过右键单击并绘制图形矩形)不起作用。
Zeppelin版本:0.8.1-快照