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
- {
- 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
- {
- 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
- var miny = this.y > sprite.y ? this.y : sprite.y;
- var maxy = this.y + this.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
- {
- 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
- {
- if(data == 0 ) return true;
- }
- return false;*/
- }

HTML5是構建現代網頁的關鍵技術,提供了許多新元素和功能。 1.HTML5引入了語義化元素如、、等,增強了網頁結構和SEO。 2.支持多媒體元素和,無需插件即可嵌入媒體。 3.表單增強了新輸入類型和驗證屬性,簡化了驗證過程。 4.提供了離線和本地存儲功能,提升了網頁性能和用戶體驗。

H5代碼的最佳實踐包括:1.使用正確的DOCTYPE聲明和字符編碼;2.採用語義化標籤;3.減少HTTP請求;4.使用異步加載;5.優化圖像。這些實踐能提升網頁的效率、可維護性和用戶體驗。

Web标准和技术从HTML4、CSS2和简单的JavaScript演变至今,经历了显著的发展。1)HTML5引入了Canvas、WebStorage等API,增强了Web应用的复杂性和互动性。2)CSS3增加了动画和过渡功能,使页面效果更加丰富。3)JavaScript通过Node.js和ES6的现代化语法,如箭头函数和类,提升了开发效率和代码可读性,这些变化推动了Web应用的性能优化和最佳实践的发展。

H5不僅僅是HTML5的簡稱,它代表了一個更廣泛的現代網頁開發技術生態:1.H5包括HTML5、CSS3、JavaScript及相關API和技術;2.它提供更豐富、互動、流暢的用戶體驗,能在多設備上無縫運行;3.使用H5技術棧可以創建響應式網頁和復雜交互功能。

H5與HTML5指的是同一個東西,即HTML5。 HTML5是HTML的第五個版本,帶來了語義化標籤、多媒體支持、畫布與圖形、離線存儲與本地存儲等新功能,提升了網頁的表現力和交互性。

H5referstoHTML5,apivotaltechnologyinwebdevelopment.1)HTML5introducesnewelementsandAPIsforrich,dynamicwebapplications.2)Itsupportsmultimediawithoutplugins,enhancinguserexperienceacrossdevices.3)SemanticelementsimprovecontentstructureandSEO.4)H5'srespo

H5開發需要掌握的工具和框架包括Vue.js、React和Webpack。 1.Vue.js適用於構建用戶界面,支持組件化開發。 2.React通過虛擬DOM優化頁面渲染,適合複雜應用。 3.Webpack用於模塊打包,優化資源加載。

HTML5hassignificantlytransformedwebdevelopmentbyintroducingsemanticelements,enhancingmultimediasupport,andimprovingperformance.1)ItmadewebsitesmoreaccessibleandSEO-friendlywithsemanticelementslike,,and.2)HTML5introducednativeandtags,eliminatingthenee


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

禪工作室 13.0.1
強大的PHP整合開發環境

記事本++7.3.1
好用且免費的程式碼編輯器

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

WebStorm Mac版
好用的JavaScript開發工具

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),