您现在的位置是:网站首页> 编程资料编程资料
Canvas 文字碰撞检测并抽稀的方法Html5 Canvas动画基础碰撞检测的实现
2021-09-01
1059人已围观
简介 一般在做地图相关的需求是才会用到文字抽稀,这篇文章主要介绍了Canvas 文字碰撞检测并抽稀的方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
需求背景
一般在做地图相关的需求是才会用到文字抽稀,我也是在为公司的地图引擎实现一个功能时才实现了该方法,在这里将其简化了,就在普通的 Canvas 上进行操作,并没有引入地图概念
效果

碰撞检测
计算文字在 canvas 中所占据的范围
// 计算文字所需的宽度 var p = { x: 10, y: 10, name: "测试文字" }; var measure = ctx.measureText(p.name); // 求出文字在 canvas 画板中占据的最大 y 坐标 var maxX = measure.width + p.x; // 求出文字在 canvas 画板中占据的最大 y 坐标 // canvas 只能计算文字的宽度,并不能计算出文字的高度。所以就利用文字的宽度除以文字个数计算个大概 var maxY = measure.width / p.name.length + p.y; var min = { x: p.x, y: p.y }; var max = { x: maxX, y: maxY }; // bounds 为该文字在 canvas 中所占据的范围。 // 在取点位坐标作为最小范围时,textAlign、textBaseline 按照以下方式设置会比较准确。 // 如设置在不同的位置展示,范围最大、最小点也需进行调整 // ctx.textAlign = "left"; // ctx.textBaseline = "top"; var bounds = new Bounds(min, max); Bounds 范围对象
/** * 定义范围对象 */ function Bounds(min, max) { this.min = min; this.max = max; } /** * 判断范围是否与另外一个范围有交集 */ Bounds.prototype.intersects = function(bounds) { var min = this.min, max = this.max, min2 = bounds.min, max2 = bounds.max, xIntersects = max2.x >= min.x && min2.x <= max.x, yIntersects = max2.y >= min.y && min2.y <= max.y; return xIntersects && yIntersects; }; 检测
// 每次绘制之前先与已绘制的文字进行范围交叉检测 // 如发现有交叉,则放弃绘制当前文字,否则绘制并存入已绘制文字列表 for (var index in _textBounds) { // 循环所有已绘制的文字范围,检测是否和当前文字范围有交集,如果有交集说明会碰撞,则跳过该文字 var pointBounds = _textBounds[index]; if (pointBounds.intersects(bounds)) { return; } } _textBounds.push(bounds); ctx.fillStyle = "red"; ctx.textAlign = "left"; ctx.textBaseline = "top"; ctx.fillText(p.name, p.x, p.y); 示例、代码地址
示例地址:示例
具体可查看完整代码:Github 地址
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
相关内容
- socket.io 和canvas 实现的共享画板功能JavaScript+Canvas实现自定义画板的示例代码几何画板怎么利用弧绘制三角形折叠?几何画板怎么制作旋转的正六边形课件?几何画板怎么一只飞舞的蝴蝶动画?手把手教你实现一个canvas智绘画板的方法ai怎么设置画板属性? ai画板设置属性的教程金排物理画板 V2019 中文免费安装版
- Html5内唤醒百度、高德APP的实现示例html5唤醒APP小记
- 鲜为人知的HTML5语音合成功能HTML5实时语音通话聊天MP3压缩传输3KB每秒使用Html5多媒体实现微信语音功能基于Html5实现的语音搜索功能HTML5为输入框添加语音输入功能的实现方法Jquery+html5可设置闹钟并且会语音提醒的时钟特效源码用html5实现语音搜索框的方法HTML5语音识别标签写法附图html5的新玩法——语音搜索HTML5 语音搜索只需一句代码HTML5 语音搜索(淘宝店语音搜素)
- Html5实现单张、多张图片上传功能
- html5中监听canvas内部元素点击事件的三种方法如何在Canvas上的图形/图像绑定事件监听的实现如何在Canvas中添加事件的方法示例详解Canvas事件绑定HTML5 Canvas的事件处理介绍一个不错的HTML5 Canvas多层点击事件监听实例HTML5 Canvas鼠标与键盘事件demo示例详解如何在Canvas中添加事件的方法
- HTML5网页录音和上传到服务器支持PC、Android,支持IOS微信功能html5录音功能实战示例详解HTML5 录音的踩坑之旅HTML5录音实践总结(Preact)
- canvas画布实现手写签名效果的示例代码html5 利用canvas手写签名并保存的实现方法如何用canvas实现在线签名的示例代码Html5基于canvas实现电子签名并生成PDF文档
- 5分钟弄清楚html5的drag and drop(小结)HTML5 拖放(Drag 和 Drop)详解与实例代码详解HTML5中的拖放事件(Drag 和 drop)HTML5+CSS3实现拖放(Drag and Drop)示例突袭HTML5之Javascript API扩展4—拖拽(Drag/Drop)概述HTML5 drag和drop具体使用详解
- 详解如何用canvas画一个微笑的表情canvas绘制表情包的示例代码
- 使用HTML5原生对话框元素并轻松创建模态框组件html5实现点击弹出图片功能html5 录制mp3音频支持采样率和比特率设置html5表单的required属性使用html5调用摄像头实例代码HTML5页面音频自动播放的实现方式Html5大屏数据可视化开发的实现html实现弹窗的实例HTML5来实现本地文件读取和写入的实现方法HTML 罗盘式时钟的实现HTML5简单实现添加背景音乐的几种方法
