| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143 | 
/** Licensed to the Apache Software Foundation (ASF) under one* or more contributor license agreements.  See the NOTICE file* distributed with this work for additional information* regarding copyright ownership.  The ASF licenses this file* to you under the Apache License, Version 2.0 (the* "License"); you may not use this file except in compliance* with the License.  You may obtain a copy of the License at**   http://www.apache.org/licenses/LICENSE-2.0** 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.*/var zrUtil = require("zrender/lib/core/util");var List = require("../../data/List");var Graph = require("../../data/Graph");var linkList = require("../../data/helper/linkList");var createDimensions = require("../../data/helper/createDimensions");var CoordinateSystem = require("../../CoordinateSystem");var createListFromArray = require("./createListFromArray");/** Licensed to the Apache Software Foundation (ASF) under one* or more contributor license agreements.  See the NOTICE file* distributed with this work for additional information* regarding copyright ownership.  The ASF licenses this file* to you under the Apache License, Version 2.0 (the* "License"); you may not use this file except in compliance* with the License.  You may obtain a copy of the License at**   http://www.apache.org/licenses/LICENSE-2.0** 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.*//** * 从邻接矩阵生成 * ``` *        TARGET *    -1--2--3--4--5- *  1| x  x  x  x  x *  2| x  x  x  x  x *  3| x  x  x  x  x  SOURCE *  4| x  x  x  x  x *  5| x  x  x  x  x * ``` * * @param {Array.<Object>} nodes 节点信息 * @param {Array} matrix 邻接矩阵 * @param {module:echarts/model/Series} * @param {boolean} directed 是否是有向图 * @return {module:echarts/data/Graph} */function _default(nodes, matrix, hostModel, directed) {  var graph = new Graph(directed);  for (var i = 0; i < nodes.length; i++) {    graph.addNode(zrUtil.retrieve( // Id, name, dataIndex    nodes[i].id, nodes[i].name, i), i);  }  var size = matrix.length;  var links = [];  var linkCount = 0;  for (var i = 0; i < size; i++) {    for (var j = 0; j < size; j++) {      var val = matrix[i][j];      if (val === 0) {        continue;      }      var n1 = graph.nodes[i];      var n2 = graph.nodes[j];      var edge = graph.addEdge(n1, n2, linkCount);      if (edge) {        linkCount++;        links.push({          value: val        });      }    }  }  var coordSys = hostModel.get('coordinateSystem');  var nodeData;  if (coordSys === 'cartesian2d' || coordSys === 'polar') {    nodeData = createListFromArray({      data: nodes    }, hostModel);  } else {    // FIXME    var coordSysCtor = CoordinateSystem.get(coordSys); // FIXME    var dimensionNames = createDimensions(nodes, {      coordDimensions: (coordSysCtor && coordSysCtor.type !== 'view' ? coordSysCtor.dimensions || [] : []).concat(['value'])    });    nodeData = new List(dimensionNames, hostModel);    nodeData.initData(nodes);  }  var edgeData = new List(['value'], hostModel);  edgeData.initData(links);  linkList({    mainData: nodeData,    struct: graph,    structAttr: 'graph',    datas: {      node: nodeData,      edge: edgeData    },    datasAttr: {      node: 'data',      edge: 'edgeData'    }  }); // Update dataIndex of nodes and edges because invalid edge may be removed  graph.update();  return graph;}module.exports = _default;
 |