mind-map/dist/js/chunk-2d2254a4.js
街角小林 06c4809b7b update
2023-12-07 09:45:22 +08:00

1 line
6.7 KiB
JavaScript
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.

(window["webpackJsonp"]=window["webpackJsonp"]||[]).push([["chunk-2d2254a4"],{e487:function(s,n,a){"use strict";a.r(n);var t=function(){var s=this;s._self._c;return s._m(0)},i=[function(){var s=this,n=s._self._c;return n("div",[n("h1",[s._v("如何渲染一个小地图")]),n("blockquote",[n("p",[s._v("要使用小地图需要注册小地图插件")])]),n("p",[s._v("小地图可以方便看到当前画布可视区域在思维导图树的哪个部分。")]),n("p",[s._v("虽然小地图需要你自行开发,不过"),n("code",[s._v("simple-mind-map")]),s._v("提供了一些方法来帮你快速的完成这一工作。")]),n("p",[s._v("小地图由两部分组成,一个是当前的画布内容,一个是视口框,当缩放、移动、元素过多时画布上可能只显示了思维导图的部分内容,可以通过视口框来查看当前视口所在位置,以及可以通过在小地图上拖动来快速定位。")]),n("p",[s._v("当注册了小地图插件后可以通过"),n("code",[s._v("mindMap.miniMap")]),s._v("获取到插件实例,然后通过"),n("code",[s._v("mindMap.miniMap.calculationMiniMap")]),s._v("方法即可获取小地图渲染需要的数据,返回的数据结构如下:")]),n("pre",{staticClass:"hljs"},[n("code",[s._v("{\n getImgUrl,"),n("span",{staticClass:"hljs-comment"},[s._v("// v0.8.0+一个异步函数你可以调用该函数传递一个回调函数回调函数可以接收一个参数代表图片类型的小地图你可以通过img标签进行渲染")]),s._v("\n svgHTML, "),n("span",{staticClass:"hljs-comment"},[s._v("// 小地图html")]),s._v("\n viewBoxStyle, "),n("span",{staticClass:"hljs-comment"},[s._v("// 视图框的位置信息")]),s._v("\n miniMapBoxScale, "),n("span",{staticClass:"hljs-comment"},[s._v("// 视图框的缩放值")]),s._v("\n miniMapBoxLeft, "),n("span",{staticClass:"hljs-comment"},[s._v("// 视图框的left值")]),s._v("\n miniMapBoxTop, "),n("span",{staticClass:"hljs-comment"},[s._v("// 视图框的top值")]),s._v("\n}\n")])]),n("p",[s._v("完整实现思路如下:")]),n("p",[s._v("1.准备一个宽高不为0的容器元素container定位不为static")]),n("p",[s._v("2.在container内创建一个小地图容器元素miniMapContainer绝对定位设置变换中心点为"),n("code",[s._v("left top")]),s._v("")]),n("pre",{staticClass:"hljs"},[n("code",[n("span",{staticClass:"hljs-attribute"},[s._v("transform-origin")]),s._v(": left top;\n")])]),n("p",[s._v("3.在container内创建一个视口框元素viewBoxContainer绝对定位设置边框样式过渡属性可选")]),n("p",[s._v("4.监听data_change和view_data_change事件最好也监听一下node_tree_render_end事件防止初次渲染完毕后小地图没有刷新在该事件内调用calculationMiniMap方法获取计算数据然后将返回数据中的svgHTML渲染到miniMapContainer元素内")]),n("pre",{staticClass:"hljs"},[n("code",[s._v("miniMapContainer.innerHTML = svgHTML\n")])]),n("p",[s._v("并且给miniMapContainer元素设置或更新如下样式")]),n("pre",{staticClass:"hljs"},[n("code",[s._v("{\n "),n("span",{staticClass:"hljs-attr"},[s._v("transform")]),s._v(": "),n("span",{staticClass:"hljs-string"},[s._v("`scale("),n("span",{staticClass:"hljs-subst"},[s._v("${miniMapBoxScale}")]),s._v(")`")]),s._v(",\n "),n("span",{staticClass:"hljs-attr"},[s._v("left")]),s._v(": miniMapBoxLeft + "),n("span",{staticClass:"hljs-string"},[s._v("'px'")]),s._v(",\n "),n("span",{staticClass:"hljs-attr"},[s._v("top")]),s._v(": miniMapBoxTop + "),n("span",{staticClass:"hljs-string"},[s._v("'px'")]),s._v(",\n}\n")])]),n("p",[s._v("5.将viewBoxStyle对象设置为viewBoxContainer元素的样式")]),n("p",[s._v("到这一步,当画布上的思维导图变化了,小地图也会实时更新,并且视口框元素会实时反映视口在思维导图图形上的位置")]),n("p",[s._v("6.监听container元素的mousedown、mousemove、mouseup事件分别调用小地图插件实例的三个方法即可实现鼠标拖动时画布上的思维导图也随之拖动的效果")]),n("p",[s._v("插件的完整信息可以参考"),n("a",{attrs:{href:"https://wanglin2.github.io/mind-map/#/doc/zh/miniMap"}},[s._v("miniMap")]),s._v("。")]),n("p",[s._v("在"),n("code",[s._v("v0.8.0+")]),s._v("版本之后,"),n("code",[s._v("calculationMiniMap")]),s._v("方法会返回"),n("code",[s._v("getImgUrl")]),s._v("属性,这是一个异步函数,你可以调用它并传递一个回调函数,回调函数可以接收一个参数,代表小地图图片数据,然后可以通过"),n("code",[s._v("img")]),s._v("标签进行渲染,替代前面的"),n("code",[s._v("svgHTML")]),s._v(",这样可以减少页面上的节点数量,能优化一定的性能:")]),n("pre",{staticClass:"hljs"},[n("code",[s._v("getImgUrl("),n("span",{staticClass:"hljs-function"},[n("span",{staticClass:"hljs-params"},[s._v("img")]),s._v(" =>")]),s._v(" {\n img.src = img\n})\n")])]),n("h2",[s._v("完整示例")]),n("iframe",{staticStyle:{width:"100%",height:"455px",border:"none"},attrs:{src:"https://wanglin2.github.io/playground/#eNrFVt2O20QUfpWRASULWSfbUgQhW5UCEkgNQqUSF0yVeu1J4sqesTzjJFWUm4oLhEBcIH6LBFyBhBStEBdsJXgaki1vwTn2jD12stpy1ZU28sz3nZ85c35m6byRJO4sY07fGUg/DRNFJFNZcp3yME5EqsiSpGzcIYIPRcYVCzpETr0oEvPbbExWZJyKmLRAQ6uUGIY8GHpJAVFHwnbEDmPYPYy9hDqUE0J5xBTBPWQeE55FEeWUd7tkc/rF5ofTzaO/N+uzzXe/nn//8Wb917+/fUu5L7hUBH6VF3KWfhgGagqyR73eDvYOCydTBeA1wHK120d/bL8+LZUbCXAhBBfeNIIgAudtoz8HhjML2fymWHygHkRM48tViWoNSPC9knC0B7/FxugSwr098B2BkaijWRJ4ikFEwyGC7QNyfJ0sMYJwpCfrn8/X35RH2n51uv18jRjGFuQ8kNAhdrUZF1z0s8hTIVxosdWuB7TTDCL4klvb/vn79scvN5/YMSQ78XNnXpQxN+Qof2d4C1xAT1w5m+ASRexwFnRDshFLuQltndwA63wM9UV0xOpsiPxFZIAoX2EOFReS14FkgZhzvA9WXUgz0hYTaPuUxGKGFp9CCTIvUJLleXG5iiypFJTF3LYSyipGNjdF3M4hQljUJ4Hws5hx5U6Yejti+HnzwbtBu6UlyxxoHXQKKYxlv9COf9TBDepYW8W2YguF29TZ/nT25NOH5w/PijaBfyutDIn+NIyClHEkf1TpaKjba6Vp6Z/Hn50//qVprG5wj9G7FWbznpEH5lPvGTm4eXVbCPWeCNj7QoZY7SDZiiDzWx3S8uHq4Jru5vTVwetFR65SR/B2C48w8qcenzAQsftQ3hBsKpbt6H/wObg1UiljIzhTwNIR/O7KYIcddIuhBOMIForBJAEKrAgZBOGM+JEn5TF1tPa3oFCok8OaEAYVWuYnUAZdQG2iiaTRWDbB6mZuxKaeAbeq2zCoKhhYrBUDV01GllR4piciIdodqmoOWT41ey11bBYMjr0ci9KX2FmB1chLlXpcjkUa98k9ic20/fyy0V5XB/dqSYlDZqz6zen2Emkli1aDqURiE3HOFbyysBVVq8pTHYgc0V/2fTXuXg8NOyrlOWsDpXHr5bf5GnStBINlriRn3NAvG+q43eI5o9ujy2Ts+lJSp6wh7LsmF039z3Gw9vGh8kLOIyQpqzJlOI1nLAfygsb/55o5a1RVgt6JFFGmCkFzHT29ykNuFrvmp/lk75OXe71kYSzvt/uisRx76SQEu0Zr4gVByCdmo3TdLUvnKX0+Mj5ot6115Xm5ZVy/ZnleRb7+lrvMfpn3hyIN88OhR+hFQ3Mzxy7VfCJSaGx9ciVZEADCgKSTk/aVq692yCuv4X/RdLULRkcUkZ57VRrj0P3yFHQ6TpGA+H5270vB4bmee0A1AAlYDhvI+gySHSeM24VPN4VRH8YMc/XwJBVzCa+0+yChq3TPC72Q3c10lNK+rZzVf9RSHZw="}})])}],e={},v=e,p=a("2877"),l=Object(p["a"])(v,t,i,!1,null,null,null);n["default"]=l.exports}}]);