• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >html5 > canvas 像素级碰撞

canvas 像素级碰撞

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-03

本文主要包含HTML5教程,HTML5中国,canvas 像素级碰撞,admin,html5资料,html5文章,html5内容,h等相关知识,匿名希望在学习及工作中可以帮助到您
demo地址http://06wjin.sinaapp.com/html5/hitTest/ 用鼠标拖动

1首先先判断两个图片的矩形区域有无碰撞

判断两个矩形的中心距离即可

2如果矩形区域有碰撞则检测上图红色矩形区域的像素,这里有两种方法
a 直接判断,循环检测两位图在红色矩形内是否有一点像素的alpha点都不为0,如果有则说明碰撞

  • context.drawImage(img1, x1, y1);//画第一张位图
  • var data1 = context.getImageData(minx, miny, maxx - minx, maxy - miny).data;//获取第一张位图红色矩形内像素
  • context.clearRect(x1, y1,img1.width,img1.height);//清除第一张位图
  • context.drawImage(img2, x2, y2);//画第二张位图
  • var data2 = context.getImageData(minx, miny, maxx - minx, maxy - miny).data;//获取第二章位图红色矩形内像素

  • for(var i = 3; i < data1.length; i += 4)
  • {
  • if(data1 > 0 && data2 > 0) return true;//循环判断alpha值,这里可以设置透明阙值,比如把0改为0.2,意味着透明度为0.2时就认为不碰撞了
  • }
  • return false;




b将绘图模式改为xor(xor是指相交部分透明,具体见站长上篇教程),也可以判断
  • context.drawImage(img1, x1,y1);//画第一张位图
  • context.globalCompositeOperation = 'xor';//改绘图模式为xor
  • context.drawImage(img2, x2,y2);//画第二张位图
  • var data = context.getImageData(minx, miny, maxx - minx, maxy - miny).data;//获取位图红色矩形内像素
  • context.globalCompositeOperation = 'source-over';//把绘图模式改回去

  • for(var i = 3; i < data.length; i += 4)
  • {

  • if(data == 0 ) return true;//若有透明像素,则碰撞
  • }
  • return false;



下面是一个2d精灵类,碰撞直接用sprite1.hitTest(sprite2)就好
  • function Sprite(x, y, img, width, height)
  • {
  • this.x = x;
  • this.y = y;
  • this.img = document.getElementById(img);
  • this.width = width;
  • this.height = height;
  • this.halfWidth = this.width/2;
  • this.halfHeight = this.height/2;
  • this.angle = 0;角度
  • this.scaleX = 1;//水平缩放
  • this.scaleY = 1;//竖直缩放
  • this.alpha = 1;//透明度
  • this.isDrug = false;//是否拖到
  • }

  • Sprite.prototype.draw = function()
  • {
  • context.save();
  • context.translate(this.x + this.halfWidth, this.y + this.halfHeight);
  • context.globalAlpha = this.alpha;//修改透明度
  • context.rotate(this.angle);//旋转角度
  • context.scale(this.scaleX, this.scaleY);//缩放
  • context.drawImage(this.img, -this.halfWidth, -this.halfHeight);
  • context.restore();
  • }

  • Sprite.prototype.hitTest = function(sprite)
  • {
  • var minx = this.x > sprite.x ? this.x :sprite.x;
  • var maxx = this.x + this.width < sprite.x + sprite.width ? this.x + this.width : sprite.x + sprite.width ;
  • var miny = this.y > sprite.y ? this.y : sprite.y;
  • var maxy = this.y + this.width < sprite.y + sprite.width ? this.y + this.width : sprite.y + sprite.width;

  • if (minx >= maxx || miny >= maxy) {return false;}

  • var canvas = document.createElement('canvas');
  • canvas.setAttribute('width', 550);
  • canvas.setAttribute('height', 400);
  • var context = canvas.getContext('2d');


  • /*第一种方法*/
  • context.drawImage(this.img, this.x, this.y);
  • var data1 = context.getImageData(minx, miny, maxx - minx, maxy - miny).data;
  • context.clearRect(0, 0, 550, 400);
  • context.drawImage(sprite.img, sprite.x, sprite.y);
  • var data2 = context.getImageData(minx, miny, maxx - minx, maxy - miny).data;

  • for(var i = 3; i < data1.length; i += 4)
  • {
  • if(data1 > 0 && data2 > 0) return true;
  • }
  • return false;

  • /*第二种方法
  • context.drawImage(this.img, this.x, this.y);
  • context.globalCompositeOperation = 'xor';
  • context.drawImage(sprite.img, sprite.x, sprite.y);
  • var data = context.getImageData(minx, miny, maxx - minx, maxy - miny).data;
  • context.globalCompositeOperation = 'source-over';

  • for(var i = 3; i < data.length; i += 4)
  • {

  • if(data == 0 ) return true;
  • }
  • return false;*/
  • }



您可能想查找下面的文章:

  • 一款利用html5和css3动画排列人物头像的实例演示
  • html5教程调用绘图api画简单的圆形代码分享
  • html5教程画矩形代码分享
  • html5教程制作简单画板代码分享
  • html5基础教程常用技巧整理
  • html5教程-Canvas入门
  • html5教程画矩形代码分享
  • HTML5晃动DeviceMotionEvent事件
  • HTML5教程之html 5 本地数据库(Web Sql Database)
  • HTML5中对contenteditable属性的解释与规定

相关文章

  • 2018-12-03举例详解HTML5中使用JSON格式提交表单_html5教程技巧
  • 2018-12-03HTML5 对各个标签的定义与解释:noscript
  • 2018-12-03web前端菜鸟,好迷茫?
  • 2018-12-03实现卡片3D翻转效果
  • 2018-12-03Html5拖放的实现方法
  • 2018-12-03分享移动端网页宽度值实例代码
  • 2018-12-03如何让IE9以下版本(ie6/7/8)认识html5元素_html5教程技巧
  • 2018-12-03HTML5实践-灰色图片画廊实现的方法
  • 2018-12-03请问如何从头开始学习制作一款HTML5 小游戏?
  • 2018-12-03通过手机浏览器打开APP或者跳转到下载页面的实现

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • html5拍照功能实现代码(htm5上传文件)_html5教程技巧
    • HTML5之WebGL 3D概述(上)—WebGL原生开发开启网页3D渲染新时代_html5教程技巧
    • 移动端html5 meta标签的神奇功效
    • HTML5游戏开发 之 循环的控制(3)
    • 纯HTML5+CSS3制作生日蛋糕(代码易懂)
    • 在HTML中 root和body?
    • 用HTML5来开发一款android本地化App游戏-宝石碰碰
    • HTML5 Canvas 颜色选择器
    • html5指南-6.如何创建离线web应用程序实现离线访问_html5教程技巧
    • spring mvc+localResizeIMG实现H5端图片压缩上传

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有