{"id":514,"date":"2015-02-11T11:17:23","date_gmt":"2015-02-11T03:17:23","guid":{"rendered":"http:\/\/www.daliane.com\/?p=514"},"modified":"2015-02-11T13:02:55","modified_gmt":"2015-02-11T05:02:55","slug":"d3js_layout_xiang_jie_cluster_-_ji_qun_tu","status":"publish","type":"post","link":"http:\/\/www.daliane.com\/category\/jinjiaoyou\/d3js_layout_xiang_jie_cluster_-_ji_qun_tu\/","title":{"rendered":"D3js Layout \u8be6\u89e3Cluster  \u2014-  \u96c6\u7fa4\u56fe"},"content":{"rendered":"<p>\u96c6\u7fa4\u56fe\uff08 Cluster \uff09\u901a\u5e38\u7528\u4e8e\u8868\u793a\u5305\u542b\u4e0e\u88ab\u5305\u542b\u5173\u7cfb\u3002<\/p>\n<p>\u73b0\u5728\u6211\u4eec\u7ed9\u51fa\u6570\u636e\uff0c\u5e76\u5c06\u5176\u53ef\u89c6\u5316\u3002\u6570\u636e\u7684\u5185\u5bb9\u4e3a\uff1a\u4e2d\u56fd\u91cc\u5305\u542b\u7684\u90e8\u5206\u7701\u4efd\uff0c\u7701\u4efd\u91cc\u5305\u542b\u7684\u90e8\u5206\u57ce\u5e02\u3002\u6211\u4eec\u8bb2\u6570\u636e\u6587\u4ef6\u5199\u5728\u4e00\u4e2a JSON \u6587\u4ef6\u4e2d\uff0c\u518d\u7528 D3 \u6765\u8bfb\u53d6\u3002 JSON(JavaScript Object Notation) \u662f\u4e00\u79cd\u8f7b\u91cf\u7ea7\u7684\u6570\u636e\u4ea4\u6362\u683c\u5f0f\u3002\u5173\u4e8e\u5b83\u7684\u8bed\u6cd5\u89c4\u5219\uff0c\u8bf7\u5404\u4f4d\u81ea\u884c\u67e5\u8be2\u767e\u5ea6\u767e\u79d1\u7b49\u3002\u6570\u636e\u5982\u4e0b\uff1a<\/p>\n<blockquote><p>{<br \/>\n&#8220;name&#8221;:&#8221;\u4e2d\u56fd&#8221;,<br \/>\n&#8220;children&#8221;:<br \/>\n[<br \/>\n{<br \/>\n&#8220;name&#8221;:&#8221;\u6d59\u6c5f&#8221; ,<br \/>\n&#8220;children&#8221;:<br \/>\n[<br \/>\n{&#8220;name&#8221;:&#8221;\u676d\u5dde&#8221; },<br \/>\n{&#8220;name&#8221;:&#8221;\u5b81\u6ce2&#8221; },<br \/>\n{&#8220;name&#8221;:&#8221;\u6e29\u5dde&#8221; },<br \/>\n{&#8220;name&#8221;:&#8221;\u7ecd\u5174&#8221; }<br \/>\n]<br \/>\n},<\/p>\n<p>{<br \/>\n&#8220;name&#8221;:&#8221;\u5e7f\u897f&#8221; ,<br \/>\n&#8220;children&#8221;:<br \/>\n[<br \/>\n{&#8220;name&#8221;:&#8221;\u6842\u6797&#8221;},<br \/>\n{&#8220;name&#8221;:&#8221;\u5357\u5b81&#8221;},<br \/>\n{&#8220;name&#8221;:&#8221;\u67f3\u5dde&#8221;},<br \/>\n{&#8220;name&#8221;:&#8221;\u9632\u57ce\u6e2f&#8221;}<br \/>\n]<br \/>\n},<\/p>\n<p>{<br \/>\n&#8220;name&#8221;:&#8221;\u9ed1\u9f99\u6c5f&#8221;,<br \/>\n&#8220;children&#8221;:<br \/>\n[<br \/>\n{&#8220;name&#8221;:&#8221;\u54c8\u5c14\u6ee8&#8221;},<br \/>\n{&#8220;name&#8221;:&#8221;\u9f50\u9f50\u54c8\u5c14&#8221;},<br \/>\n{&#8220;name&#8221;:&#8221;\u7261\u4e39\u6c5f&#8221;},<br \/>\n{&#8220;name&#8221;:&#8221;\u5927\u5e86&#8221;}<br \/>\n]<br \/>\n},<\/p>\n<p>{<br \/>\n&#8220;name&#8221;:&#8221;\u65b0\u7586&#8221; ,<br \/>\n&#8220;children&#8221;:<br \/>\n[<br \/>\n{&#8220;name&#8221;:&#8221;\u4e4c\u9c81\u6728\u9f50&#8221;},<br \/>\n{&#8220;name&#8221;:&#8221;\u514b\u62c9\u739b\u4f9d&#8221;},<br \/>\n{&#8220;name&#8221;:&#8221;\u5410\u9c81\u756a&#8221;},<br \/>\n{&#8220;name&#8221;:&#8221;\u54c8\u5bc6&#8221;}<br \/>\n]<br \/>\n}<br \/>\n]<br \/>\n}<\/p><\/blockquote>\n<p>&nbsp;<\/p>\n<p>&nbsp;<\/p>\n<p>\u5176\u5b9e\u6211\u4eec\u5149\u4ece\u6570\u636e\u4e0a\u770b\uff0c\u4e5f\u5f88\u5bb9\u6613\u770b\u51fa\u5b83\u4eec\u662f\u7528\u6765\u8868\u793a\u4ec0\u4e48\u7684\uff0c\u662f\u4ec0\u4e48\u5173\u7cfb\u3002\u597d\uff0c\u73b0\u5728\u5f00\u59cb\u8fdb\u884c\u53ef\u89c6\u5316\u3002\u540c\u6837\u7684\uff0c\u5148\u8981\u7528 Layout \u8f6c\u6362\u6570\u636e\u3002<br \/>\n[javascript] view plaincopy\u5728CODE\u4e0a\u67e5\u770b\u4ee3\u7801\u7247\u6d3e\u751f\u5230\u6211\u7684\u4ee3\u7801\u7247<br \/>\nvar cluster = d3.layout.cluster()<br \/>\n.size([height, width &#8211; 200]);<br \/>\n\u4e0a\u9762\u4ee3\u7801\u5b9a\u4e49\u4e86\u4e00\u4e2a cluster \u7684\u6570\u636e\u8f6c\u6362\u51fd\u6570\u3002.size \u51fd\u6570\u7528\u4e8e\u8bbe\u5b9a\u8f6c\u6362\u540e\u7684\u5c3a\u5bf8\u3002\u63a5\u4e0b\u6765\u8981\u7528\u8fd9\u4e2a\u51fd\u6570\u6765\u8f6c\u6362\u6570\u636e\uff1a<br \/>\n[javascript] view plaincopy\u5728CODE\u4e0a\u67e5\u770b\u4ee3\u7801\u7247\u6d3e\u751f\u5230\u6211\u7684\u4ee3\u7801\u7247<br \/>\nd3.json(&#8220;city.json&#8221;, function(error, root) {<\/p>\n<p>var nodes = cluster.nodes(root);<br \/>\nvar links = cluster.links(nodes);<\/p>\n<p>console.log(nodes);<br \/>\nconsole.log(links);<\/p>\n<p>}<\/p>\n<p>&nbsp;<\/p>\n<p>\u6709\u4e86\u8f6c\u6362\u540e\u7684\u6570\u636e\uff0c\u5c31\u53ef\u4ee5\u7ed8\u5236\u4e86\u3002\u5176\u5b9e D3 \u5df2\u7ecf\u57fa\u672c\u4e0a\u4e3a\u6211\u4eec\u51c6\u5907\u597d\u4e86\u7ed8\u5236\u7684\u51fd\u6570\uff0c\u6211\u4eec\u8981\u5b66\u4e60\u7684\u4ec5\u4ec5\u662f\u67e5\u8be2\u5e76\u4f7f\u7528\u5b83\u4eec\u3002<\/p>\n<p>\u7ed8\u5236\u7ebf\u6761\uff0c\u6211\u4eec\u53ef\u4ee5\u4f7f\u7528\uff1a<\/p>\n<p>[javascript] view plaincopy\u5728CODE\u4e0a\u67e5\u770b\u4ee3\u7801\u7247\u6d3e\u751f\u5230\u6211\u7684\u4ee3\u7801\u7247<br \/>\nvar diagonal = d3.svg.diagonal()<br \/>\n.projection(function(d) { return [d.y, d.x]; });<br \/>\n\u8fd9\u662f\u7528\u4e8e\u7ed8\u5236\u5bf9\u6389\u7ebf\u7684\u51fd\u6570\uff0c .projection \u7528\u4e8e\u8bbe\u5b9a\u5b83\u7684\u6295\u5f71\u3002\u7ed8\u5236\u7684\u65f6\u5019\uff0c\u6211\u4eec\u8fd9\u6837\u4f7f\u7528\u5b83\uff1a<br \/>\n[javascript] view plaincopy\u5728CODE\u4e0a\u67e5\u770b\u4ee3\u7801\u7247\u6d3e\u751f\u5230\u6211\u7684\u4ee3\u7801\u7247<br \/>\nvar link = svg.selectAll(&#8220;.link&#8221;)<br \/>\n.data(links)<br \/>\n.enter()<br \/>\n.append(&#8220;path&#8221;)<br \/>\n.attr(&#8220;class&#8221;, &#8220;link&#8221;)<br \/>\n.attr(&#8220;d&#8221;, diagonal);<br \/>\n\u8fd9\u6837\u5c31\u7ed8\u5236\u4e86\u6240\u6709\u8282\u70b9\u4e4b\u95f4\u7684\u8fde\u7ebf\u3002\u63a5\u4e0b\u6765\u6211\u4eec\u518d\u7ed8\u5236\u8282\u70b9\u3002\u8282\u70b9\u8fd8\u662f\u4f7f\u7528 svg \u4e2d\u7684 circle \u6765\u7ed8\u5236\uff0c\u8fd9\u91cc\u5c31\u4e0d\u590d\u8ff0\u4e86\uff0c\u524d\u9762\u5df2\u7ecf\u8bb2\u8fc7\u4e86\uff0c\u60a8\u4e5f\u53ef\u4ee5\u81ea\u5df1\u67e5\u770b\u6e90\u4ee3\u7801\u3002\u7ed3\u679c\u56fe\u4e3a\uff1a<\/p>\n<p>&nbsp;<\/p>\n<p><a href=\"http:\/\/www.daliane.com\/wp-content\/uploads\/2015\/02\/2015-02-11_113409.jpg\"><img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-medium wp-image-518\" src=\"http:\/\/www.daliane.com\/wp-content\/uploads\/2015\/02\/2015-02-11_113409-267x300.jpg\" alt=\"2015-02-11_113409\" width=\"267\" height=\"300\" srcset=\"http:\/\/www.daliane.com\/wp-content\/uploads\/2015\/02\/2015-02-11_113409-267x300.jpg 267w, http:\/\/www.daliane.com\/wp-content\/uploads\/2015\/02\/2015-02-11_113409.jpg 485w\" sizes=\"(max-width: 267px) 100vw, 267px\" \/><\/a><\/p>\n<blockquote><p>&lt;html&gt;<br \/>\n&lt;head&gt;<br \/>\n&lt;meta charset=&#8221;utf-8&#8243;&gt;<br \/>\n&lt;title&gt;Cluster&lt;\/title&gt;<br \/>\n&lt;\/head&gt;<br \/>\n&lt;style&gt;<br \/>\n.node circle {<br \/>\nfill: #fff;<br \/>\nstroke: steelblue;<br \/>\nstroke-width: 1.5px;<br \/>\n}<br \/>\n.node {<br \/>\nfont: 12px sans-serif;<br \/>\n}<br \/>\n.link {<br \/>\nfill: none;<br \/>\nstroke: #ccc;<br \/>\nstroke-width: 1.5px;<br \/>\n}<br \/>\n&lt;\/style&gt;<br \/>\n&lt;body&gt;<br \/>\n&lt;script src=&#8221;.\/js\/d3.min.js&#8221; charset=&#8221;utf-8&#8243;&gt;&lt;\/script&gt;<br \/>\n&lt;script&gt;<br \/>\nvar width = 500,<br \/>\nheight = 500;<\/p>\n<p>\/\/\u5b9a\u4e49\u4e86\u4e00\u4e2a cluster\uff08\u96c6\u7fa4\uff09 \u7684\u6570\u636e\u8f6c\u6362\u51fd\u6570\u3002<br \/>\nvar cluster = d3.layout.cluster()<br \/>\n.size([height, width &#8211; 200]);<\/p>\n<p>\/\/\/\/\u5b9a\u4e49\u5e03\u5c40\u65b9\u5411<br \/>\nvar diagonal = d3.svg.diagonal()<br \/>\n.projection(function(d) { return [d.y, d.x]; });<\/p>\n<p>\/\/\u6dfb\u52a0\u753b\u5e03<br \/>\nvar svg = d3.select(&#8220;body&#8221;).append(&#8220;svg&#8221;)<br \/>\n.attr(&#8220;width&#8221;, width)<br \/>\n.attr(&#8220;height&#8221;, height)<br \/>\n.append(&#8220;g&#8221;)<br \/>\n\/\/\u65cb\u8f6c<br \/>\n.attr(&#8220;transform&#8221;, &#8220;translate(40,0)&#8221;);<\/p>\n<p>\/\/ d3.json \u7528\u4e8e\u8bfb\u53d6 JSON \u6587\u4ef6\u3002\u8981\u6ce8\u610f\uff0cd3.json \u53ea\u80fd\u7528\u4e8e\u7f51\u7edc\u8bfb\u53d6\uff0c\u6240\u4ee5\u60a8\u5fc5\u987b\u642d\u5efa\u4e00\u4e2a\u670d\u52a1\u5668\u6765\u4f7f\u7528\u5b83<\/p>\n<p>d3.json(&#8220;city.json&#8221;, function(error, root) {<br \/>\nvar nodes = cluster.nodes(root);<br \/>\nvar links = cluster.links(nodes);<br \/>\n\/\/\u4e3a\u5173\u7cfb\u96c6\u5408\u8bbe\u7f6e\u8d1d\u585e\u5c14\u66f2\u7ebf\u8fde\u63a5<br \/>\nvar link = svg.selectAll(&#8220;.link&#8221;)<br \/>\n.data(links)<br \/>\n.enter()<br \/>\n.append(&#8220;path&#8221;)<br \/>\n.attr(&#8220;class&#8221;, &#8220;link&#8221;)<br \/>\n.attr(&#8220;d&#8221;, diagonal);<br \/>\n\/\/\u6839\u636enode\u96c6\u5408\u751f\u6210\u8282\u70b9<br \/>\nvar node = svg.selectAll(&#8220;.node&#8221;)<br \/>\n.data(nodes)<br \/>\n.enter()<br \/>\n.append(&#8220;g&#8221;)<br \/>\n.attr(&#8220;class&#8221;, &#8220;node&#8221;)<br \/>\n.attr(&#8220;transform&#8221;, function(d) { return &#8220;translate(&#8221; + d.y + &#8220;,&#8221; + d.x + &#8220;)&#8221;; })<br \/>\n\/\/\u4e3a\u8282\u70b9\u6dfb\u52a0\u5706\u5f62\u6807\u8bb0<br \/>\nnode.append(&#8220;circle&#8221;)<br \/>\n.attr(&#8220;r&#8221;, 4.5);<br \/>\n\/\/\u4e3a\u8282\u70b9\u6dfb\u52a0\u8bf4\u660e\u6587\u5b57<br \/>\nnode.append(&#8220;text&#8221;)<br \/>\n.attr(&#8220;dx&#8221;, function(d) { return d.children ? -8 : 8; })<br \/>\n.attr(&#8220;dy&#8221;, 3)<br \/>\n.style(&#8220;text-anchor&#8221;, function(d) { return d.children ? &#8220;end&#8221; : &#8220;start&#8221;; })<br \/>\n.text(function(d) { return d.name; });<br \/>\n});<br \/>\n&lt;\/script&gt;<br \/>\n&lt;\/body&gt;<br \/>\n&lt;\/html&gt;<\/p><\/blockquote>\n","protected":false},"excerpt":{"rendered":"<p>\u96c6\u7fa4\u56fe\uff08 Cluster \uff09\u901a\u5e38\u7528\u4e8e\u8868\u793a\u5305\u542b\u4e0e\u88ab\u5305\u542b\u5173\u7cfb\u3002 \u73b0\u5728\u6211\u4eec\u7ed9\u51fa\u6570\u636e\uff0c\u5e76\u5c06\u5176\u53ef\u89c6\u5316\u3002\u6570\u636e\u7684\u5185\u5bb9\u4e3a\uff1a\u4e2d\u56fd&#8230;<\/p>\n","protected":false},"author":2,"featured_media":518,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_kad_post_transparent":"","_kad_post_title":"","_kad_post_layout":"","_kad_post_sidebar_id":"","_kad_post_content_style":"","_kad_post_vertical_padding":"","_kad_post_feature":"","_kad_post_feature_position":"","_kad_post_header":false,"_kad_post_footer":false,"footnotes":""},"categories":[38,56,8],"tags":[55,233],"_links":{"self":[{"href":"http:\/\/www.daliane.com\/category\/jinjiaoyou\/wp-json\/wp\/v2\/posts\/514"}],"collection":[{"href":"http:\/\/www.daliane.com\/category\/jinjiaoyou\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/www.daliane.com\/category\/jinjiaoyou\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/www.daliane.com\/category\/jinjiaoyou\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"http:\/\/www.daliane.com\/category\/jinjiaoyou\/wp-json\/wp\/v2\/comments?post=514"}],"version-history":[{"count":6,"href":"http:\/\/www.daliane.com\/category\/jinjiaoyou\/wp-json\/wp\/v2\/posts\/514\/revisions"}],"predecessor-version":[{"id":521,"href":"http:\/\/www.daliane.com\/category\/jinjiaoyou\/wp-json\/wp\/v2\/posts\/514\/revisions\/521"}],"wp:featuredmedia":[{"embeddable":true,"href":"http:\/\/www.daliane.com\/category\/jinjiaoyou\/wp-json\/wp\/v2\/media\/518"}],"wp:attachment":[{"href":"http:\/\/www.daliane.com\/category\/jinjiaoyou\/wp-json\/wp\/v2\/media?parent=514"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/www.daliane.com\/category\/jinjiaoyou\/wp-json\/wp\/v2\/categories?post=514"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/www.daliane.com\/category\/jinjiaoyou\/wp-json\/wp\/v2\/tags?post=514"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}