js push box tutoriel d'implémentation du jeu
Cet article vous expliquera les étapes et les points clés de la création d'un jeu push box avec JS grâce à l'analyse de code. Les amis qui en ont besoin peuvent s'y référer et l'apprendre. J'espère que cela pourra aider tout le monde.
Démo :
Analyse des étapes :
Le code de cet article a été placé sur github, et beaucoup de du travail a été effectué. Les commentaires détaillés du code peuvent être copiés et exécutés localement pour y jeter un œil.
1. Carte de rendu
Structure HTML :
La structure HTML est très simple, il suffit de faire un tas de p pour placez-les La classe map est suffisante. J'ai initialisé 12*9 p ici, et la carte a un maximum de neuf lignes de hauteur.
Ces p ont tous la même taille, et la seule différence dans le rendu de la carte est la couleur.
Fonction de carte :
var box=$('.box p'); //地图使用的p集合 function create(){ //创建地图函数 box.each(function(index){ //index的数量是固定的,是box p下面p的数量 // 每次创建地图初始化p box.eq(index).removeClass(); }); box.each(function(index,element){ //循环整个p的数量 二维数组里数量不够的 默认为空白 //level为关卡数 根据关卡渲染地图 builder为二维数组,为地图关卡 if(builder[level][index]){ //过滤0 box.eq(index).addClass('type'+builder[level][index]); } }); box.eq(origin[level]).addClass("pusher"); //推箱人 皮卡丘位置 } //第一关的地图长这样(下面只是栗子,不是代码),0代表不可抵达区域,1代表目标(要被推到的地方), //2代表普通路径(可以走的),3代表墙,4代表箱子 [0,0,0,0,3,3,3,0,0,0,0,0, 0,0,0,0,3,1,3,0,0,0,0,0, 0,0,0,0,3,2,3,3,3,3,0,0, 0,0,3,3,3,4,2,4,1,3,0,0, 0,0,3,1,2,4,2,3,3,3,0,0, 0,0,3,3,3,3,4,3,0,0,0,0, 0,0,0,0,0,3,1,3,0,0,0,0, 0,0,0,0,0,3,3,3,0,0,0,0]
2. Capturez les événements du clavier pour déterminer s'il peut être déplacé.
Utilisez $(document).keydown( )événement jqery, capture les événements du clavier.
Capturez les événements du clavier, haut, bas, gauche et wsad.
$(document).keydown(function (e) { var key=e.which; switch(key){ //col 的值为12,上下移动要12个p为一个周期 //方向键上或者w case 87: case 38: move(-col);//判断移动函数 break; //方向键下或者s case 83: case 40: move(col); break; //方向键左或者a case 65: case 37: move(-1); break; //方向键右或者d case 68: case 39: move(1); break; } setTimeout(win,500); //按键之后调判断是否过关 });
Déterminez s'il peut être déplacé.
Il est divisé en deux conditions de jugement : l'une consiste à pousser la boîte, et l'autre est de se déplacer naturellement sans pousser la boîte, sinon Pikachu ne bougera pas.
function move(step){ //是否移动判断 // 分为两个判断条件一个是推箱子,一个是不推箱子 自然移动。 否则不移动皮卡丘 //step 上下是12个p一个周期,左右是1个p positin是皮卡丘的原来位置 var pikaqiu1=box.eq(position);//皮卡丘现在的地方 var pikaqiu2=box.eq(position+step);//皮卡丘要去的下一个地方 var pushBox=box.eq(position+step*2);//箱子要去的下一个地方 if(!pikaqiu2.hasClass('type4')&&( pikaqiu2.hasClass('type1')||pikaqiu2.hasClass('type2'))){ //自然移动 //判断:如果下一个p的class不包含type4(箱子),并且 下一个p含有type1(目标位置),或者type2(普通路径) //这一步和下一步判断是否有type4的原因是普通路径会变成有type4的路径,这时候就会出现问题 pikaqiu1.removeClass("pusher"); //移除当前皮卡丘 pikaqiu2.addClass("pusher");//移动皮卡丘到下一个位置 position=position+step;//增加position值 } else if((pikaqiu2.hasClass('type4'))&&(!pushBox.hasClass('type4'))&&(pushBox.hasClass('type1')|| pushBox.hasClass('type2')) ) { //推箱子 //如果下一个p的class包含type4(箱子)并且 不包含重叠type4(箱子) 并且 包含class type1(目标位置)或者 包含type2(空路) pikaqiu2.removeClass('type4');//移除当前箱子 pikaqiu1.removeClass("pusher");//移除当前皮卡丘 pushBox.addClass('type4');//移动箱子到下一个位置 pikaqiu2.addClass("pusher").addClass("type2");// //本来是type4 移除之后,这里没有class了,要变成普通路径 position=position+step;//增加position值 } }
3. Jugement de victoire :
Ce jugement de victoire doit être appelé à chaque fois que vous bougez.
function win(){ //胜利条件判断 if($(".type1.type4").length===goal){ //推的箱子与关卡设置通过箱子的数量对比 if(level<9) { alert("666,挑战下一关吧--OBKoro1"); level++; //关卡+1 goal = goalList[level]; position = origin[level]; create(); }else { alert("厉害啊 大佬 通关了都"); } } }
Recommandations associées :
[Développement de jeux HTML5] Sokoban classique
JavaScript écrire des compétences de push box game_javascript
php pour implémenter le jeu de saut WeChat
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment utiliser WebSocket et JavaScript pour mettre en œuvre un système de reconnaissance vocale en ligne Introduction : Avec le développement continu de la technologie, la technologie de reconnaissance vocale est devenue une partie importante du domaine de l'intelligence artificielle. Le système de reconnaissance vocale en ligne basé sur WebSocket et JavaScript présente les caractéristiques d'une faible latence, d'un temps réel et d'une multiplateforme, et est devenu une solution largement utilisée. Cet article explique comment utiliser WebSocket et JavaScript pour implémenter un système de reconnaissance vocale en ligne.

WebSocket et JavaScript : technologies clés pour réaliser des systèmes de surveillance en temps réel Introduction : Avec le développement rapide de la technologie Internet, les systèmes de surveillance en temps réel ont été largement utilisés dans divers domaines. L'une des technologies clés pour réaliser une surveillance en temps réel est la combinaison de WebSocket et de JavaScript. Cet article présentera l'application de WebSocket et JavaScript dans les systèmes de surveillance en temps réel, donnera des exemples de code et expliquera leurs principes de mise en œuvre en détail. 1. Technologie WebSocket

Lorsque nous utilisons le système d'exploitation win10, nous voulons savoir si le jeu Démineur intégré de l'ancienne version est toujours enregistré après la mise à jour win10. À la connaissance de l'éditeur, nous pouvons le télécharger et l'installer dans le magasin, à condition que ce soit le cas. tel qu'il est dans le magasin, recherchez simplement Microsoft Minesweeper. Jetons un coup d'œil aux étapes spécifiques avec l'éditeur ~ Existe-t-il un jeu Démineur pour Windows 10 ? 1. Tout d'abord, ouvrez le menu Démarrer de Win10 et cliquez. Recherchez ensuite et cliquez sur Rechercher. 2. Cliquez sur le premier. 3. Ensuite, vous devrez peut-être saisir un compte Microsoft, c'est-à-dire un compte Microsoft. Si vous n'avez pas de compte Microsoft, vous pouvez l'installer et être invité à vous inscrire. Entrez le mot de passe du compte et cliquez sur Suivant. 4. Ensuite, lancez le téléchargement

Comment utiliser WebSocket et JavaScript pour mettre en œuvre un système de réservation en ligne. À l'ère numérique d'aujourd'hui, de plus en plus d'entreprises et de services doivent fournir des fonctions de réservation en ligne. Il est crucial de mettre en place un système de réservation en ligne efficace et en temps réel. Cet article explique comment utiliser WebSocket et JavaScript pour implémenter un système de réservation en ligne et fournit des exemples de code spécifiques. 1. Qu'est-ce que WebSocket ? WebSocket est une méthode full-duplex sur une seule connexion TCP.

Introduction à l'utilisation de JavaScript et de WebSocket pour mettre en œuvre un système de commande en ligne en temps réel : avec la popularité d'Internet et les progrès de la technologie, de plus en plus de restaurants ont commencé à proposer des services de commande en ligne. Afin de mettre en œuvre un système de commande en ligne en temps réel, nous pouvons utiliser les technologies JavaScript et WebSocket. WebSocket est un protocole de communication full-duplex basé sur le protocole TCP, qui peut réaliser une communication bidirectionnelle en temps réel entre le client et le serveur. Dans le système de commande en ligne en temps réel, lorsque l'utilisateur sélectionne des plats et passe une commande

Comment jouer à des mini-jeux sur Google Chrome ? Google Chrome possède de nombreuses fonctionnalités conçues avec un soin humaniste et vous pouvez y profiter de nombreuses activités diverses. Dans Google Chrome, il existe un jeu d'œufs de Pâques très intéressant, à savoir le jeu Little Dinosaur. De nombreux amis aiment beaucoup ce jeu, mais ils ne savent pas comment le déclencher. L'éditeur vous le présentera ci-dessous. le mini-jeu entre dans le tutoriel. Comment jouer à des mini-jeux sur Google Chrome Méthode 1 : [Ordinateur déconnecté du réseau] Si votre ordinateur utilise un réseau filaire, veuillez débrancher le câble réseau. Si votre ordinateur utilise un réseau sans fil, veuillez cliquer sur la connexion réseau sans fil pour vous déconnecter ; dans le coin inférieur droit de l'ordinateur. ② Lorsque votre ordinateur est déconnecté d'Internet, ouvrez Google Chrome et Google Browse apparaîtra.

JavaScript et WebSocket : Construire un système efficace de prévisions météorologiques en temps réel Introduction : Aujourd'hui, la précision des prévisions météorologiques revêt une grande importance pour la vie quotidienne et la prise de décision. À mesure que la technologie évolue, nous pouvons fournir des prévisions météorologiques plus précises et plus fiables en obtenant des données météorologiques en temps réel. Dans cet article, nous apprendrons comment utiliser la technologie JavaScript et WebSocket pour créer un système efficace de prévisions météorologiques en temps réel. Cet article démontrera le processus de mise en œuvre à travers des exemples de code spécifiques. Nous

Tutoriel JavaScript : Comment obtenir le code d'état HTTP, des exemples de code spécifiques sont requis Préface : Dans le développement Web, l'interaction des données avec le serveur est souvent impliquée. Lors de la communication avec le serveur, nous devons souvent obtenir le code d'état HTTP renvoyé pour déterminer si l'opération a réussi et effectuer le traitement correspondant en fonction de différents codes d'état. Cet article vous apprendra comment utiliser JavaScript pour obtenir des codes d'état HTTP et fournira quelques exemples de codes pratiques. Utilisation de XMLHttpRequest
