上周需要做一个把页面左侧列表内容拖拽到右侧区域,并且绘制成关系树的功能。
看了设计图,第一反应是用canvas绘制关系线。
吭哧吭哧搞定这个功能后,发现用canvas绘图,有一个很严重的缺陷。那就是如果左侧关系特别多,需要绘制成百上千条时,而canvas画布的宽高在写dom的时候就已声明。关系很多的情况下,无法使用canvas。
不过还是记录一下研究成果。
下面是设计图:
做出效果如下:
html、css代码就不贴了。 js主要用到了拖拽、canvas绘制。
function startDrag(ev) { ev.dataTransfer.setData("Text",ev.target.innerText); } function allowDrop(ev) { ev.preventDefault(); } function decideDrop(ev) { ev.preventDefault(); var length = $('.main-target').length; if(length == 0){ dropToMain(ev); }else { dropToRelate(ev); } } function dropToMain(ev) { var data=ev.dataTransfer.getData("Text"); var _html = '<div class="main-target">' + data + '</div>'; $('.main-target-wrap').width('auto').append(_html); } function dropToRelate(ev) { //画关系线 drawLineOne(document.getElementById('canvasOne'), 'begin'); drawLineOne(document.getElementById('canvasTwo'), 'end'); //插入图片 以及图片初始化点击事件 var _img = $('<img src="inner.png">'); $('.imgBox').append(_img); _img.click(showRelationBox); //写入数据 var data = ev.dataTransfer.getData('Text'); var _html = '<div class="item-text">' + data + '</div>'; $('.relation-text-box').append(_html); }
以上是拖拽的方法,我也是一边看菜鸟教程,一边写出的拖拽方法。
function drawLineOne(canvas, flag) { var context = canvas.getContext('2d'); var position = {}; if(flag == "begin"){ position = getCanvasOnePosition(); }else { position = getCanvasTwoPosition(); } context.beginPath(); context.moveTo(position.beginX, position.beginY); context.lineTo(position.endX, position.endY); if(position.endX2 && position.endY2){ context.lineTo(position.endX2, position.endY2); } context.strokeStyle = "#333"; context.stroke(); } /** * 左侧关系线 * @returns {{beginX: *, beginY: *, endX: *, endY: *}} */ function getCanvasOnePosition() { var imgLength = $('.imgBox img').length; var beginX = (imgLength == 0) ? 0 : 77, beginY = (imgLength == 0) ? 15 : (15 + 60 * (imgLength-1)), endX = (imgLength == 0) ? 155 : 77, endY = 60*imgLength + 15; var position = {beginX: beginX, beginY: beginY, endX: endX, endY: endY}; if(imgLength > 0){ position.endX2 = 155; position.endY2 = endY; } return position; } function getCanvasTwoPosition() { var imgLength = $('.imgBox img').length; var endY = 15 + 60*imgLength return {beginX: 0, beginY: endY, endX: 155, endY: endY} }
以上是canvas画线的方法,代码没什么难点,主要就是分析线的起始坐标麻烦一些。希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
无争山庄资源网 Copyright www.whwtcm.com
暂无“html5利用canvas绘画二级树形结构图的示例”评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2025年01月04日
2025年01月04日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]