cocos2d-Js 各类碰撞检测
这里总结一下点、圆、矩形之间的简单碰撞检测算法(矩形不包括旋转状态)
点和圆的碰撞检测:
1.计算点和圆心的距离
2.判断点与圆心的距离是否小于圆的半径
isCollision: function(point, circle)
{
//点与圆心的距离
var distance = Math.sqrt(Math.pow(point.x - circle.x, 2) + Math.pow(point.y - circle.y, 2)); //圆的半径
var radius = circle.getContentSize().width / 2; //如果点与圆心距离小于圆的半径,返回true
if(radius > distance)
{
return true;
}
else
{
return false;
}
}
点和矩形的碰撞检测:
1.获取矩形的左上角坐标p1和右下角坐标p2
2.判断点p的x坐标是否在p1和p2的x坐标之间,并且p的y坐标是否在p1和p2的y坐标之间
isCollision: function(point, rect)
{
//获得矩形的左上角坐标p1和右下角坐标p2
var p1 = cc.p(rect.x - rect.width/2, rect.y + rect.height/2);
var p2 = cc.p(rect.x + rect.width/2, rect.y - rect.height/2); //判断点p的x坐标是否大于p1的x坐标,并且小于p2的x坐标,并且p的y坐标大于p2的y坐标,并且小于p2的y坐标
if(point.x > p1.x && point.x < p2.x && point.y > p2.y && point.y < p1.y)
{
return true;
}
else
{
return false;
}
}
圆和圆的碰撞检测:
1.计算两圆的圆心距
2.判断圆心距是否小于两圆的半径之和
isCollision: function(circle1, circle2)
{
//圆心与圆心的距离
var distance = Math.sqrt(Math.pow(circle1.x - circle2.x, 2) + Math.pow(circle1.y - circle2.y, 2)); //圆心半径
var r1 = circle1.getContentSize().width / 2;
var r2 = circle2.getContentSize().width / 2; //如果圆心与圆心距离小于两圆的半径,返回true
if(r1 + r2 > distance)
{
return true;
}
else
{
return false;
}
}
矩形和矩形的碰撞检测:
1.在水平方向上,判断两个矩形中点x坐标的距离是否小于两个矩形宽度的一半之和
2.在垂直方向上,判断两个矩形中点y坐标的距离是否小于两个矩形高度的一半之和
isCollision: function(rect1, rect2)
{
//获取矩形1的宽高
var width1 = rect1.width;
var height1 = rect1.height; //获取矩形2的宽高
var width2 = rect2.width;
var height2 = rect2.height; var flag;
if(rect1.x >= rect2.x && rect2.x <= rect1.x - width1/2 - width2/2)
{
flag = false;
}
else if(rect1.x <= rect2.x && rect2.x >= rect1.x + width1/2 + width2/2)
{
flag = false;
}
else if(rect1.y >= rect2.y && rect2.y <= rect1.y - height1/2 - height2/2)
{
flag = false;
}
else if(rect1.y <= rect2.y && rect2.y >= rect1.y + height1/2 + height2/2)
{
flag = false;
}
else
{
flag = true;
}
}
圆和矩形的碰撞检测:
isCollision: function(circle, rect)
{
//圆的半径
var radius = circle.width / 2; //圆形中心与矩形中心的相对坐标
var x = circle.x - rect.x;
var y = circle.y - rect.y; var minX = Math.min(x, rect.width/2);
var maxX = Math.max(minX, -rect.width/2);
var minY = Math.min(y, rect.height/2);
var maxY = Math.max(minY, -rect.height/2); if((maxX - x) * (maxX - x) + (maxY - y) * (maxY - y) <= radius * radius)
{
return true;
}
else
{
return false;
}
}
cocos2d-Js 各类碰撞检测的更多相关文章
- cocos2d js jsb XMLHttpRequest 中文乱码
1.首先讲下怎样使用XMLHttpRequest 下面所说的是在cocos2d-x 2.2.2 或者 2.3 版本号中. 首先要明确cocos2d js事实上分两个版本号,一个是html5的版本号,另 ...
- cocos2d js的一些tip
cocos2d-js-v3.2-rc0 cc.director.end();//退出app cc.Application.getInstance().openURL("http://www. ...
- cocos2d js ClippingNode 制作标题闪亮特效
1.效果图: 之前在<Android 高仿 IOS7 IPhone 解锁 Slide To Unlock>中制作了文字上闪亮移动的效果,这次我们来看下怎样在cocos2d js 中做出类似 ...
- cocos2d-x JS 各类点、圆、矩形之间的简单碰撞检测
这里总结了一下点.圆.矩形之间的简单碰撞检测算法 (ps:矩形不包括旋转状态) 点和圆的碰撞检测: 1.计算点和圆心的距离 2.判断点与圆心的距离是否小于圆的半 isCollision: functi ...
- Cocos2d Box2D之碰撞检测
| 版权声明:本文为博主原创文章,未经博主允许不得转载. 在Box2D中碰撞事件由b2ContactListener类函数实现,b2ContactListener是Box2D提供的抽象类,它的抽象 ...
- js各类共用方法
function GetParameterValueByName(parametername) { var reg = new RegExp("(^|&)" + param ...
- cocos2d.js
1.节点是Cocos2d最基础的东西 2.坐标与普通数学坐标一致 3.children属性表示节点的孩子,父节点位置变化,它包含的子节点也会跟着变化,以整体的形势移动 4.层(layer), 新建层: ...
- cocos2d JS 源生js实现each方法
javascript笔记——源生js实现each方法 出处:http://www.lovejavascript.com/#!zone/blog/content.html?id=48 jquery里 ...
- cocos2d JS 错误异常抛出捕获和崩溃拦截
Error对象 一旦代码解析或运行时发生错误,JavaScript引擎就会自动产生并抛出一个Error对象的实例,然后整个程序就中断在发生错误的地方. Error对象的实例有三个最基本的属性: nam ...
- cocos2d JS 在 JavaScript 中,怎样把一个对象转化成 JSON 字符串?
为什么今天要做这样子的操作,原因很简单,因为cocos JS 的本地缓存储存不了对象,所以当我通过本地缓存的 key和value来取值的时候就取不出来来,json的消息数据是一个对象来的,然而在做牌局 ...
随机推荐
- 2D KD-Tree实现
KD-tree 1.使用背景 在项目中遇到一个问题: 如何算一个点到一段折线的最近距离~折线的折点可能有上千个, 而需要检索的点可能出现上万的数据量, 的确是个值得思考的问题~ 2.暴力解法 有个比较 ...
- 企业级低代码平台,通用代码生成平台,Java开源项目(附源码)
项目介绍 Jeecg-Boot 是一款基于代码生成器的智能开发平台!采用前后端分离架构:SpringBoot,Mybatis,Shiro,JWT,Vue&Ant Design.强大的代码生成器 ...
- 使用antd-mobile遇到的坑
在使用antd-mobile中的组件的时候,遇到了一些比较棘手的问题,经过查找相关资料和网上的帮助,在此整理出了问题以及解决办法: 在引入antd-mobile的时候,根据官网提供的文档: 1,首先安 ...
- GORM自定义Gorm.Model实现自动添加时间戳
废话不说直接开始 官网(http://gorm.io)有给出一套默认的gorm.Model模型,定义如下 package gorm import "time" // Model b ...
- Seata AT和XA模式
一.分布式事务产生得原因: 1.1.数据库分库分表 当数据库单表一年产生的数据超过1000W,那么就要考虑分库分表,具体分库分表的原理在此不做解释,以后有空详细说,简单的说就是原来的一个数据库变成了多 ...
- Linux第二次周总结
第三章 用户管理 3.1 用户/组概览 Linux系统是多用户.多任务的分时操作系统,系统上每一个进程都有一个特定的文件,每个文件都被一个特定的用户所拥有.每个用户都属于一个用户组或者多个组,系统可以 ...
- 13. 用Rust手把手编写一个wmproxy(代理,内网穿透等), HTTP中的压缩gzip,deflate,brotli算法
用Rust手把手编写一个wmproxy(代理,内网穿透等), HTTP中的压缩gzip,deflate,brotli算法 项目 ++wmproxy++ gite: https://gitee.com/ ...
- python加解密小工具
1.地址 https://github.com/Doneone/RSA_GUI 2.用法 python3 rsa_gui.py 创建密钥对 3.思考 为什么要写rsa小工具呐,因为单纯想实现一个简单的 ...
- Redis 7.0 源码环境搭建与阅读技巧
天下武功,无坚不摧,唯快不破!我的名字叫 Redis,全称是 Remote Dictionary Server. 有人说,组 CP,除了要了解她外,还要给机会让她了解你. 那么,作为开发工程师的你,是 ...
- RLChina理论三:强化学习基础
强化学习基础 马尔可夫决策过程就是在,环境自发做出转变,是个随波逐流的过程,At是智能体的行动,在St环境状态下加入At动作,c才进入下个状态S(t+1),即环境有自己的变化,也加入了智能体的决策. ...