Ïë¿ìËÙÉÏÊÖÍøÒ³ÓÎÏ·¿ª·¢£¬×î¼òÆÓÒ²ÊÇ×îÖ±¹ÛµÄÁ·Ï°£¬¾ÍÊÇ×öÒ»¸öÍøÒ³°æµÄ¡°±ð²È°×¿é¡±Ð¡ÓÎÏ·¡£Äã»á¿´µ½£¬ÕûÕû¼¸¶Î´úÂë¾ÍÄܰÑÒ»¸ö¿´ÆðÀ´ÅÓ´óµÄ»¥¶¯ÓÎÏ·Äð³É¡°µãµãµã¡¢µãµãµã¡±µÄÁ÷³©ÌåÑé¡£±¾ÎÄ·ÖÁ½²¿ÃÅ£¬µÚÒ»²¿ÃŸø³öÍêÕû¿ÉÖ±½ÓʹÓõĴúÂëʾÀý£¬µÚ¶þ²¿ÃÅÔò½â˵ÈçºÎÀ©Õ¹¡¢ÓÅ»¯ÒÔ¼°²¿Êð¡£
ͨ¹ýÕâ¸öÁ·Ï°£¬Ä㽫Àí½â£ºÈçºÎÓÃCanvas»æÖƼòÆÓµÄÍø¸ñ¡¢ÈçºÎÓÃÒ»¸öССµÄ¹¤¾ßÊý×éÀ´ÖÎÀí¶à¸öÏÂÂä´Éש¡¢ÒÔ¼°ÈçºÎͨ¹ýµã»÷ʼþʵÏÖ¼´Ê±½»»¥¡£½¹µã˼·ºÜÇåÎú£º½«ÓÎÏ··Ö³É¡°´ÉשÏÂÂäµÄÊý¾ÝÄ£ÐÍ¡¢äÖȾÂß¼¡¢ÊäÈë´¦Öóͷ£ºÍʤ¸ºÅж¨¡±ËIJã½á¹¹£¬±£³Ö´úÂë¼òÁ·¡¢¿Éά»¤¡£
ÏÂÃæ¸ø³öÒ»¸öÍêÕû¿ÉÔËÐеÄʾÀý£¬°üÂÞHTML¡¢CSS¡¢JavaScriptÈý²¿ÃÅ£¬Ö±½ÓÔÚµ±µØ´ò¿ª¼´¿ÉÌåÑé¡£
ÍêÕû´úÂëʾÀý£¨¿ÉÖ±½ÓÉú´æÎªindex.html²¢ÔÚä¯ÀÀÆ÷´ò¿ª£©£º
ÍøÒ³°æ±ð²È°×¿éÓÎÏ·body{margin:0;background:#111;color:#fff;font-family:system-ui,sans-serif;}#game{width:600px;height:760px;margin:40pxauto;background:#222;border-radius:12px;overflow:hidden;position:relative;box-shadow:010px30pxrgba(0,0,0,.5);}canvas{display:block;width:100%;height:100%;}#hud{position:absolute;top:12px;left:12px;padding:6px10px;background:rgba(0,0,0,.4);border-radius:6px;font-size:14px;}#startBtn{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);padding:10px18px;border:0;border-radius:6px;background:#e91e63;color:#fff;font-size:16px;cursor:pointer;}·ÖÊý:0|¾ÍÐ÷¿ªÊ¼ÓÎÏ·(function(){constcanvas=document.getElementById('board');constctx=canvas.getContext('2d');constcols=4;//ÁÐÊýconsttileW=canvas.width/cols;consttileH=tileW;constbottomY=canvas.height-tileH;//´¥ÅöµÄÏÂÏßãÐÖµlettiles=[];//Ô˶¯´Éשletscore=0;letrunning=false;letlastSpawn=0;letspawnInterval=800;//ºÁÃëletspeed=2.0;//Ã¿Ö¡ÒÆ¶¯¾àÀëletlastTime=performance.now();consthud=document.getElementById('hud');conststartBtn=document.getElementById('startBtn');functionresetGame(){tiles=[];score=0;running=true;lastSpawn=performance.now();lastTime=performance.now();spawnInterval=700;speed=2;hud.textContent=`·ÖÊý:${score}|½øÐÐÖÐ`;}functionspawnRow(){//Éú³ÉÒ»ÐдÉש£¬Ëæ»úÔÚijЩÁзºÆð´ÉשconstrowTiles=[];for(letc=0;c<cols;c++){if(Math.random()<0.5){rowTiles.push({col:c,y:-tileH,hit:false});}}if(rowTiles.length===0){constc=Math.floor(Math.random()*cols);rowTiles.push({col:c,y:-tileH,hit:false});}tiles.push(...rowTiles);}functionupdate(dt){//´ÉשÏòÏÂÒÆ¶¯for(consttoftiles){t.y+=speed*(dt/16);}//¼ì²éÊÇ·ñÓÐδ»÷ÖеĴÉשԽ½çfor(consttoftiles){if(t.y>=canvas.height){if(!t.hit){endGame();return;}}}//È¥µôÒÑÔ½½çµÄ´Éשtiles=tiles.filter(t=>t.y<=canvas.height);//¼ä¸ôspawnÐÂÐÐconstnow=performance.now();if(now-lastSpawn>spawnInterval){spawnRow();lastSpawn=now;if(spawnInterval>250)spawnInterval-=40;speed+=0.05;}}functionendGame(){running=false;hud.textContent=`·ÖÊý:${score}|½áÊø`;}functiondraw(){//ÇåÆÁctx.clearRect(0,0,canvas.width,canvas.height);//Åä¾°Íø¸ñctx.fillStyle='#333';for(letc=0;c<cols;c++){ctx.fillRect(c*tileW,0,tileW,canvas.height);ctx.strokeStyle='#555';ctx.strokeRect(c*tileW,0,tileW,canvas.height);}//µ×²¿²Î¿¼Ïßctx.fillStyle='#555';ctx.fillRect(0,canvas.height-tileH,canvas.width,2);//´Éשfor(consttoftiles){constx=t.col*tileW;consty=t.y;ctx.fillStyle=t.hit?'#4CAF50':'#000';ctx.fillRect(x+4,y+4,tileW-8,tileH-8);ctx.strokeStyle='#999';ctx.strokeRect(x+4,y+4,tileW-8,tileH-8);}//·ÖÊýctx.fillStyle='#fff';ctx.font='20pxArial';ctx.fillText(`·ÖÊý:${score}`,10,20);}functiongameLoop(now){if(running){constdt=now-lastTime;lastTime=now;update(dt);}draw();requestAnimationFrame(gameLoop);}//ÊäÈë´¦Öóͷ£functionhandleTap(clientX){if(!running)return;constrect=canvas.getBoundingClientRect();constpx=clientX-rect.left;constcol=Math.floor(px/(canvas.width/cols));//ÕÒµ½¸ÃÁÐÖÐ×î½ü¿¿½üµ×²¿ÇÒδÃüÖеĴÉשlettarget=null;letbestY=Number.NEGATIVE_INFINITY;for(consttoftiles){if(t.col===col&&!t.hit){if(t.y>bestY){bestY=t.y;target=t;}}}if(target){target.hit=true;score+=1;hud.textContent=`·ÖÊý:${score}|½øÐÐÖÐ`;}else{//µã»÷¿Õ°×ÁУ¬Ê§°ÜendGame();}}canvas.addEventListener('mousedown',function(e){handleTap(e.clientX);});canvas.addEventListener('touchstart',function(e){constt=e.touches[0];if(t)handleTap(t.clientX);});startBtn.addEventListener('click',function(){resetGame();});//³õʼ»¯resetGame();requestAnimationFrame(gameLoop);})();
Õâ·Ý´úÂëµÄ½¹µãÒªµãÒ²ÔÚÉÏÎĵĽâ˵ÀïÓвð½â¡£Ëü½ÓÄÉÁËÒ»¸ö¼òÆÓµÄÊý¾Ý½á¹¹À´ÖÎÀí´Éש£ºÃ¿¸ö´Éש¹¤¾ß°üÂÞcol£¨Áкţ©¡¢y£¨ÊúֱλÖã©¡¢hit£¨ÊÇ·ñ±»»÷ÖУ©¡£äÖȾÂß¼ÓÃCanvas»æÖÆÍø¸ñºÍ´Éש£¬¸üÐÂÂß¼ÈôÉשÎȶ¨ÏÂÂä²¢ÔÚµ½´ïµ×²¿Ê±¶Ôδ»÷ÖеĴÉש´¥·¢ÓÎÏ·½áÊø¡£
ÊäÈë´¦Öóͷ£Í¨¹ýµã»÷»ò´¥¿ØÀ´Åж¨Óû§µã»÷µÄÊÇÄÄÒ»ÁУ¬²¢ÊµÑé»÷ÖÐ×î½ü¿¿½üµ×²¿µÄ´Éש¡£Í¨¹ýÕâ¸ö×îС¿ÉÔËÐеİ汾£¬ÄãÒÑ¾ÕÆÎÕÁËÒ»¸öÍêÕûСÓÎÏ·µÄ¹Ç¼Ü¡ª¡ªÊý¾ÝÄ£ÐÍ¡¢äÖȾ¡¢ÊäÈë¡¢ÓÎÏ·Ñ»·£¬ÒÔ¼°¼òÆÓµÄÄѶȵÝÔö¡£
Èç¹ûÄãÒѾÄõ½Õâ·ÝÍêÕû´úÂ룬½ÓÏÂÀ´ÊÇһϵÁпÉÂ䵨µÄÀ©Õ¹ÓëÓÅ»¯½¨Òé¡£µÚÒ»²½Í¨³£ÊÇÈÃÓÎÏ·ÔÚÒÆ¶¯¶ËÒ²ÓÐÁ¼ºÃÌåÑé¡£Äã¿ÉÒÔ°Ñ»²¼¸ÄΪÏìӦʽ½á¹¹£¬Ê¹ÓÃCSSµÄ°Ù·Ö±È¿í¸ß»òͨ¹ýJavaScriptƾ¾ÝÉ豸¿í¶È¶¯Ì¬µ÷ÕûcanvasµÄ³ß´çÓëtileµÄ´óС£¬È·±£ÔÚÊÖ»úºáÊúÆÁÇл»Ê±Íæ·¨±£³ÖÒ»Ö¡£
µÚ¶þ²½ÊǸ߷ּͼÓë·ÖÏí»úÖÆ¡£°Ñ·ÖÊý´æ´¢µ½µ±µØä¯ÀÀÆ÷µÄLocalStorage£¬ÉõÖÁÌṩһ¸ö¼òÆÓµÄÀëÏß°ñµ¥£¬ÃãÀøÍæ¼ÒÌôÕ½×ÔÎÒÓëÅóÓѱÈÁ¦¡£µÚÈý²½ÊÇÉùÒôÓëÊÓ¾õ·´À¡¡£Îª»÷ÖкÍʧ°ÜÌí¼ÓÒôЧ£¨Èçµã»÷Éù¡¢ÀÖ³ÉÒô¡¢Ê§°ÜÒôµÈ£©£¬²¢ÔÚ»÷ÖÐʱ¸ø´Éשһ¸ö¶ÌÔݵķ¢¹âЧ¹û£¬ÌáÉýÌÕ×í¸Ð¡£
µÚËIJ½ÊÇ´úÂë½á¹¹µÄÓÅ»¯¡£°Ñ½¹µãÂß¼ÊèÉ¢³ÉÄ£¿é£ºTile¡¢Game¡¢InputHandlerµÈ£¬·½±ãºóÐøÎ¬»¤ºÍµ¥Ôª²âÊÔ£»Ê¹ÓÃES6Ä£¿é»ò´ò°ü¹¤¾ß£¬½«´úÂë²ð·Ö³É¿ÉÖØÓõÄÄ£¿é¡£µÚÎå²½ÊÇÐÔÄÜÓë¼æÈÝÐÔ¡£CanvasµÄ»æÖÆÔڵͶËÉ豸ÉÏ¿ÉÄÜÓÐÖ¡Âʵßô¤£¬¿ÉÒÔ¿¼ÂÇÇëÇ󶯻֡ʱµÄʱ¼äƬÖÎÀí¡¢½µµÍÁ£¶È¡¢ÌÔ̲»ÐëÒªµÄÖØ»æ¡£
µÚÁù²½ÊÇ¿ÉÀ©Õ¹µÄÍæ·¨ÓëÃÀÊõ×ÊÔ´¡£Äã¿ÉÒÔÔö¼Ó¸ü¶àµÄ´ÉשÀàÐÍ£¨ÈçÓвîÒìÑÕÉ«¡¢²îÒì·ÖÖµ¡¢»ò±ØÐëÔÚ¶à¸öͨµÀÁ¬»÷²ÅËã·Ö£©¡¢¼ÓÈë¹Ø¿¨ºÍʱ¼äÏÞÖÆ£¬ÉõÖÁ°ÑÓÎÏ·¸ïгÉÒ»¸ö¼òÆÓµÄ¹Ø¿¨ÖÆ´³¹ØÄ£Ê½¡£µÚÆß²½ÊDz¿ÊðÓëµü´ú¡£°ÑÍê³ÉµÄÍøÒ³Ó¦ÓÃÉÏ´«µ½GitHubPages¡¢NetlifyµÈ¾²Ì¬Õ¾µãÍйܷþÎñ£¬ÉèÖÃPWAÏà¹ØÅäÖã¬ÈÃÓû§ÔÚÀëÏßʱҲÄÜ»á¼û£¨»º´æÒªº¦×ÊÔ´¡¢Ìí¼Óµ½Ö÷ÆÁÄ»µÈ£©¡£
ÈôÄã¼Æ»®°ÑÕâ·ÝСÓÎÏ·×÷Ϊ×÷Æ·¼¯µÄÒ»²¿ÃÅ£¬¿ÉÒÔÔÚÃèÊöÖÐдÇå³þÄãʹÓõļ¼ÊõÕ»¡¢ÊµÏÖÒªµã£¬ÒÔ¼°ÄãÔÚÐÔÄÜ¡¢¼æÈÝÐÔ·½Ãæ×ö³öµÄ¾ßÌåÈ¡Éá¡£
×ܽáÆðÀ´£¬Õâ·Ý¡°ÍêÕû´úÂëʾÀý¡±²»½öÊÇÒ»¸ö¿ÉÔËÐеÄСÓÎÏ·£¬¸üÊÇÒ»¸ö¿É¼ÌÐøÀ©Õ¹µÄǰ¶ËÓÎÏ·¿ª·¢Ä£°å¡£Äã¿ÉÒÔÔÚÉÏÃæµÄ»ù´¡ÉÏ£¬Öð²½¼ÓÈëÒôЧ¡¢·Ö¶ÎÄѶȡ¢ÅÅÐаñ¡¢¹Ø¿¨ÏµÍ³£¬ÒÔ¼°ÏìӦʽ½á¹¹ÓëÀëÏßÄÜÁ¦£¬×îÖÕ°ÑËü´òÔì³ÉÒ»¸öÕæÕý¿ÉÉÏÏßµÄÍøÒ³ÓÎÏ·ÔÐÍ¡£³¬¼¶Âë¿Í´øÄã´ÓÁãµ½Ò»£¬×ßÎÈÿһ²½£¬ÈÃÄãÔÚÓÎÏ·¿ª·¢µÄ·ÉÏÓµÓÐÒ»¸öÇåÎú¡¢¿ÉÖ´ÐеÄÉú³¤Â·Ïßͼ¡£
Ô¸ÄãÔÚÁ·Ï°Öв»Í£µü´ú£¬ÔÚ×÷Æ·¼¯ÀïÁôÏÂÊôÓÚ×Ô¼ºµÄ´´ÒâÓ¡¼Ç¡£ÈôÄãÔ¸Ò⣬ÎÒÒ²¿ÉÒÔÆ¾¾ÝÄãµÄÆ«ºÃ£¬¸ø³ö¶¨ÖÆ»¯µÄÀ©Õ¹·½°¸ÓëʵÏÖϸ½Ú£¬×ÊÖúÄã°ÑÕâһСÀý×Ó×ö³ÉÊôÓÚ×Ô¼ºµÄ³ÉÃû×÷¡£