文章地址:https://www.cnblogs.com/sandraryan/

碰撞检测这个东西写小游戏挺有用der~~~

注释写的还挺全,所以就不多说了,看注释

这是页面结构。wrap存放生成的小球

box是用来检测的元素

<div class="wrap">
<!-- 用于做碰撞检测的一个元素 -->
<div class="box"></div>
</div>

css:

 body {
margin:;
padding:;
} .wrap {
width: 100vw;
height: 100vh;
background-color: rgb(228, 243, 248);
} .box {
width: 70px;
height: 70px;
background-color: green;
border-radius: 50%;
position: fixed;
top:;
left:;
} .wrap .item {
position: fixed;
border-radius: 50%;
}

js

let wrap = document.querySelector('.wrap');
let box = document.querySelector('.box');
// 随机数函数
function rn(a, b) {
return Math.round(Math.random() * (a - b) + b);
}
// 创建其他小球的函数
function create() {
// 创建div
let el = document.createElement('div');
// 从20-100之间随机一个数作为小球的宽高(要是圆形,所以宽高相同)
let w = rn(20, 80);
el.style.width = w + 'px';
el.style.height = w + 'px';
// 设置top left值 该元素css有固定定位
//可以选择把最大值设置为当前屏幕/父级宽高,然后减去元素最大随即宽度(80)
el.style.top = rn(0, 500) + 'px';
el.style.left = rn(0, 1200) + 'px';
// 追加item作为类名
el.className = 'item';
// 获取0-1之间的随机数并取小数点后一位
let opa = Math.random().toFixed(1);
// 设置随机颜色
// 不能先给一个变量随机0-254,然后拼接变量,拼接出来red green blue颜色都一样
el.color = 'rgba(' + rn(0, 254) + ',' + rn(0, 254) + ',' + rn(0, 254) + ',' + opa + ')';
el.style.background = el.color;
// 元素追加给wrap
wrap.appendChild(el);
}
// 利用循环创建20个小球
function balls() {
for (let i = 0; i < 20; i++) {
create();
}
}
balls();
// box半径(理论上写一个就好,是个正方形画出来的圆嘛~)
let r1 = box.offsetWidth / 2;
// 获取创建的小球们
let item = document.querySelectorAll('.item');
// console.log(item);
// 文档注册鼠标移动事件
document.onmousemove = function (ev) {
let e = ev || event;
// 获取浏览器宽度/高度,减去要检测的盒子宽高一半
let x = e.clientX - r1;
let y = e.clientY - r1;
// 设为要拿去做检测的盒子左边,上边
// 鼠标移动的时候改变要拿去做碰撞检测的元素的top left值(改变位置,让他动起来,动的范围是整个可视页面-自己宽高,不会卡一半在外面)
box.style.left = x + 'px';
box.style.top = y + 'px';
for (let i = 0; i < item.length; i++) {
// item的半径
let r2 = item[i].offsetHeight / 2;
// 生成的小球的左边+半径,减用来检测的元素的左边+半径(两个球圆心距)
let leftC = item[i].offsetLeft + r2 - (box.offsetLeft + r1);
// 生成的小球上边加半径-检测小球的上边加半径
let topC = item[i].offsetTop + r2 - (box.offsetTop + r1);
// pow() 方法可返回 x 的 y 次幂的值。
// sqrt() 方法可返回一个数的平方根。
// 水平方向圆心距的2次幂 + 垂直方向的圆心距2次幂,的平方根(勾股定理?)
let dis = Math.sqrt(Math.pow(leftC, 2) + Math.pow(topC, 2));
// 求出来的值小于检测的两个球的半径的和,碰撞上了,生成的小球变色
if (dis < r1 + r2) {
item[i].style.background = 'red';
} else {
item[i].style.background = item[i].color;
}
}
};

over

js实现圆形的碰撞检测的更多相关文章

  1. js绘制圆形时钟

    纯js制作圆形时钟 <!DOCTYPE html> <html lang="en"> <head> <meta charset=" ...

  2. js实现方块的碰撞检测

    文章地址:https://www.cnblogs.com/sandraryan/ 个人感觉.方块的碰撞检测比圆形麻烦~~ <!DOCTYPE html> <html lang=&qu ...

  3. 写一些封装part1 (事件绑定移除,圆形矩形碰撞检测)

    var EventHandle = { addEvent:function(ele,type,handle){ if (ele.addEventListener) { ele.addEventList ...

  4. 28-THREE.JS 扇形圆形

    <!DOCTYPE html> <html> <head> <title></title> <script src="htt ...

  5. 用HTML、CSS、JS制作圆形进度条(无动画效果)

    逻辑 1.首先有一个圆:蓝色的纯净的圆,效果: 2.再来两个半圆,左边一个,右边一个将此蓝色的圆盖住,效果: 此时将右半圆旋转60°,就会漏出底圆,效果:   然后我们再用一个比底圆小的圆去覆盖这个大 ...

  6. cocos2dx - JS - 碰撞检测

    碰撞检测是游戏的一个重要组成部分,我们这里使用一种最简单的方法,就是获取精灵的矩形碰撞框.当然圆形的碰撞检测也比较简单,其他形状就复杂多了.首先是如何获取矩形碰撞框:var hBox=this.her ...

  7. Canvas动画基础之碰撞检测

    在Canvas中进行碰撞检测,大家往往直接采用游戏引擎(Cocos2d-JS.Egret)或物理引擎(Box2D)内置的碰撞检测功能,好奇的你有思考过它们的内部运行机制吗?下面将针对基本的碰撞检测技术 ...

  8. Html5 Canvas动画基础碰撞检测的实现

    在Canvas中进行碰撞检测,大家往往直接采用游戏引擎(Cocos2d-JS.Egret)或物理引擎(Box2D)内置的碰撞检测功能,好奇的你有思考过它们的内部运行机制吗?下面将针对基本的碰撞检测技术 ...

  9. 【读书笔记《Android游戏编程之从零开始》】18.游戏开发基础(碰撞检测)

    1.矩形碰撞 所谓矩形碰撞,就是利用两个矩形之间的位置关系来进行判断,如果矩形的像素在另外一个矩形之中,或者之上都可以认为这两个矩形发生了碰撞. 如果单纯的去考虑哪些情况会判定两个矩形发生碰撞,倒不如 ...

随机推荐

  1. js对象属性方法大总结

    数组(Array):系列元素的有序集合: 详细演示请看:[js入门系列演示·数组 ] http://www.cnblogs.com/thcjp/archive/2006/08/04/467761.ht ...

  2. 杨柳絮-Info:菏泽多措并举治理杨柳絮 5年内实现“有絮不成灾”

    ylbtech-杨柳絮-Info:菏泽多措并举治理杨柳絮 5年内实现“有絮不成灾” 1.返回顶部 1. 菏泽多措并举治理杨柳絮 5年内实现“有絮不成灾” 2019年04月09日 11:44  来源:大 ...

  3. 手把手教你如何玩转消息中间件(ActiveMQ) https://blog.csdn.net/cs_hnu_scw/article/details/81040834

    #情景引入小白:起床起床起床起床....快起床~我:怎么了又,大惊小怪,吓到我了.小白:我有事有事想找你,十万火急呢~~我:你能有什么事?反正我不信..那你说说看~~小白:就是我有两个小表弟,叫大白和 ...

  4. 微信小程序之上拉加载更多

    loadmore 加载更多(分页加载) 当用户打开一个页面时,假设后台数据量庞大时,一次性地返回所有数据给客户端,页面的打开速度就会有所下降,而且用户只看上面的内容而不需要看后面的内容时,也浪费用户流 ...

  5. 蚁群算法MATLAB解TSP问题

    Excel表exp12_3_1.xls中数据为: clc clear all [xdata,textdata]=xlsread('exp12_3_1.xls'); %加载20个城市的数据,数据按照表格 ...

  6. css中用一张背景图做页面的技术有什么优势?

    css中用一张背景图做页面的技术有什么优势? 简单介绍一下 CSS Sprites 的优点: 当用户往U盘中拷200张图片,会等很久.但是如果弄成一个文件,再拷贝就会快很多. CSS Sprites ...

  7. 当inline-block和text-indent遇到IE6,IE7

    在实际应用中,考虑到seo,很多button,icon都要用到inline-block和text-indent来处理,例如: <a href="#" class=" ...

  8. StatusBar用法

    一.StatusBar组件介绍 StatusBar 是 React Native 0.20 起新增的跨平台组件,它可以用来设置并动态改变设备的状态栏显示特性. StatusBar 组件可以同时加载多个 ...

  9. bzoj3899 弦论

    好久没有更blog了啊... 对于一个给定长度为N的字符串,求它的第K小子串是什么. 这是一个SAM的模板题. 我好弱啊这个时候才开始学SAM,才会用指针. 要维护3个东西:每个状态right集合的大 ...

  10. qt获取本机用户名

    //获取用户名 QString getUserName() { #if 1 QStringList envVariables; envVariables << "USERNAME ...