g6/demos/gallery-university.html
2018-07-12 21:38:24 +08:00

134 lines
3.8 KiB
HTML
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>画廊-浙江省各城市大学分布</title>
<style>
.label {
fill: white;
}
</style>
</head>
<body>
<div id="mountNode" style="background: #0F141F;"></div>
<p>数据来源https://github.com/hugg95/university-data</p>
<p>描述:展示了浙江省,各个城市,本科和专科的数量及分布情况。</p>
<p>解读:杭州作为省会城市拥有最多的高校,各个城市专科和本科学校的数量基本持平。</p>
<script src="./assets/jquery-3.2.1.min.js"></script>
<script src="./assets/d3-4.13.0.min.js"></script>
<script src="../build/g6.js"></script>
<script src="../build/plugin.tool.d3.mapper.js"></script>
<script>
$.getJSON('./assets/data/university.json', data => {
const Mapper = window.ToolD3Mapper;
const Util = G6.Util;
const { forceSimulation, forceLink, forceManyBody, forceX, forceY } = d3;
const nodeColorMapper = new Mapper('node', '办学层次', 'color', ['#4BA4C4', '#F0D79F', '#FF8B33']);
let simulation;
// 注册城市文本导引信息
G6.registerGuide('city-label', {
draw(item) {
const tree = item.getGraph();
const roots = tree.getRoots();
const group = item.getGraphicGroup();
roots.forEach(root => {
const bbox = Util.getTotalBBox(root.getAllChildren().map(child => {
return child.getBBox();
}));
const model = root.getModel();
group.addShape('text', {
attrs: {
x: bbox.minX,
y: bbox.minY - 8,
text: model.name,
fill: '#ccc',
},
});
});
},
});
const tree = new G6.Tree({
container: 'mountNode',
height: window.innerHeight,
plugins: [nodeColorMapper],
layout() {
const nodes = tree.getNodes().map(node => {
return node.getModel();
});
const edges = tree.getEdges().map(edge => {
return Util.mix({}, edge.getModel());
});
simulation && simulation.stop();
simulation = forceSimulation(nodes)
.force('charge', forceManyBody())
.force('link', forceLink(edges).id(d => {
return d.id;
}).distance(20)
.strength(1))
.force('y', forceY())
.on('tick', () => {
tree.updateNodePosition();
});
},
});
tree.node({
size: 10,
style: {
stroke: null
}
});
tree.edge({
style() {
return {
strokeOpacity: 0.6
}
}
});
tree.read(data);
tree.add('guide', {
shape: 'city-label',
});
tree.translate(tree.getWidth() / 2, tree.getHeight() / 2);
// 拖拽画布交互
let lastPoint;
tree.on('canvas:mouseenter', () => {
tree.css({
cursor: '-webkit-grabbing',
});
});
tree.on('dragstart', () => {
tree.css({
cursor: '-webkit-grabbing',
});
});
tree.on('drag', ev => {
if (lastPoint) {
tree.translate(ev.domX - lastPoint.x, ev.domY - lastPoint.y);
}
lastPoint = {
x: ev.domX,
y: ev.domY,
};
});
tree.on('dragend', () => {
lastPoint = undefined;
tree.css({
cursor: '-webkit-grab',
});
});
tree.on('canvas:mouseleave', () => {
lastPoint = undefined;
});
});
</script>
</body>
</html>