js碰撞效果怎样实现?js碰撞测试代码详解
Admin 2021-05-22 群英技术资讯 1064 次浏览
怎样使用js实现碰撞检测?碰撞效果在很多游戏中都会使用到,下面给大家分享一个js实现碰撞的简单测试。当小物体碰撞大物体,大物体颜色改变,效果如下。
代码:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> </head> <style> div { position: absolute; top: 0px; right: 0px; bottom: 0px; left: 0px; margin: auto; width: 300px; height: 300px; background-color: green; } span { position: absolute; top: 0px; left: 0px; display: block; width: 100px; height: 100px; background-color: rgb(10, 151, 233); } </style> <body> <div></div> <span></span> <script> var div = document.getElementsByTagName('div')[0]; var span = document.getElementsByTagName('span')[0]; span.onmousedown = function(e) { // 事件对象兼容 e = window.event || e; // 添加全局捕获 if (span.setCapture) { span.setCapture(); } // 鼠标按下获取鼠标距离页面左侧和顶部距离 var x = e.clientX; var y = e.clientY; // 元素距离页面左侧和顶部距离 var elex = span.offsetLeft; var eley = span.offsetTop; // 鼠标距离元素距离 =鼠标距离页面距离 -元素距离页面距离 var X = x - elex; var Y = y - eley; document.onmousemove = function(e) { // 鼠标移动 获取鼠标距离页面距离 // 事件对象兼容 e = window.event || e; var movex = e.clientX; var movey = e.clientY; // 元素的left和top值 =鼠标距离页面距离 -鼠标距离元素距离 var leftx = movex - X; var lefty = movey - Y; /*----------------------------------------------------------*/ // 碰撞检测 // 1.左侧安全距离 =大盒子距离页面左侧距离 -小盒子占位宽 var safeleft = div.offsetLeft - span.offsetWidth; // 2.右侧安全距离 大盒子距离页面左侧距离 +大盒子占位宽 var saferight = div.offsetLeft + div.offsetWidth; // 3.上侧安全距离 =大盒子距离页面顶部距离 -小盒子占位高 var safetop = div.offsetTop - span.offsetHeight; // 4. 下侧安全距离 = 大盒子距离页面顶部距离 + 大盒子占位高 var safebottom = div.offsetTop + div.offsetHeight; if (leftx < safeleft || leftx > saferight || lefty < safetop || lefty > safebottom) { div.style.background = 'green'; } else { div.style.background = 'red'; } /*----------------------------------------------------------*/ // 边界值 // 左 if (leftx <= 0) { leftx = 0; } // 上 if (lefty <= 0) { lefty = 0; } // 右 var rightx = document.documentElement.clientWidth - span.offsetWidth; if (leftx >= rightx) leftx = rightx; // 下 var righty = document.documentElement.clientHeight - span.offsetHeight; if (lefty >= righty) { lefty = righty; } span.style.left = leftx + 'px'; span.style.top = lefty + 'px'; } document.onmouseup = function() { document.onmousemove = null; if (span.releaseCapture) { span.releaseCapture(); } } // 阻止默认事件 return false; } </script> </body> </html>
以上就是JS实现简单的碰撞测试的代码,感兴趣的朋友可以参考,想要更好的视觉效果,可以参考代码实现,希望本文对大家有帮助。
文本转载自脚本之家
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
本篇文章给大家带来了关于JavaScript的相关知识,reduce是数组原型对象上的一个方法,可以帮助我们操作数组。本文将和大家分享4个关于JavaScript中数组reduce的用法,希望对大家有所帮助。
什么是树在现实生活中,相信每个人对树都很熟悉,不管是柳树、杨树还是桃树,可以说树在我们生活中随处可见;在计算机世界,树是一种分层结构的抽象模型,如下图所示:树结构的应用有很多
在开发过程中,经常遇到组件数据无法更新,本文主要介绍了react纯函数组件setState更新页面不刷新的解决,感兴趣的可以了解一下
node如何下载文件?用 axios 就行啦!简单版如下:constaxios=require('axios')constfs=require('fs')functionformatHeaders(headers){returnObject.keys(headers).reduce((header,name)=>{heade
这篇文章主要介绍了uni-app 的自定义组件,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008