This article shares the specific code of JS to implement the brick-breaking pinball game for your reference. The specific content is as follows Written in native JS, there are still some flaws. The code can be used directly by copying it into HTML The speed is random because it involves horizontal and vertical speeds, so the speed value of the ball displayed is their sum (cube and square root). <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>document</title> <style> .container{ width: 500px; height: 500px; border:1px solid #000; margin:auto; position:relative; } .brickBox{ width: 500px; height: 300px; /* background-color: yellowgreen; */ position:absolute; left: 0; top: 0; } .ball{ width: 15px; height: 15px; background-color:purple; border-radius:50%; position:absolute; bottom:30px; left:235px; /* margin-left:-15px; */ } .slider{ width: 150px; height: 30px; background-color: #00f; position:absolute; /* left:50%; */ left:175px; /* margin-left:-75px; */ bottom:0; } </style> </head> <body> <div class="container"> <div class="brickBox"></div> <div class="ball"></div> <div class="slider"></div> </div> <div style="margin-left: 40%;font-size: 25px;">Current speed: <span id="speed"></span> </div> <div style="margin-left: 40% ;font-size: 25px;">Current number of blocks destroyed: <span id="count"></span> </div> </body> <script> // Get all current tags var container = document.querySelector('.container') var brickBox = container.querySelector('.brickBox') var ball = container.querySelector('.ball') var slider = container.querySelector('.slider') // Dynamically create bricks // Define brick size var brickWidth = 50; var brickHeight = 15; // Calculate the number of bricks var brickNum = brickBox.clientWidth * brickBox.clientHeight / (brickWidth * brickHeight) // console.log(brickNum); var brickColNum = brickBox.clientWidth / brickWidth // Create according to quantity for(var i=0;i<brickNum;i++){ var div = document.createElement('div') setStyle(div,{ width:brickWidth + "px", height:brickHeight + "px", backgroundColor:getColor(true), position:'absolute', top:parseInt(i/brickColNum)*brickHeight + 'px', left:(i%brickColNum)*brickWidth + 'px' }) brickBox.appendChild(div) } // Click the slider to make the ball start moving // Define the horizontal and vertical movement values var speedX = getRandom(1,8); var speedY = getRandom(1,8); document.querySelector("#speed").innerHTML = Math.sqrt(Math.pow(speedX,2)+Math.pow(speedY,2)) var timer; //Click to move slider.onclick = move; //Enter key starts the pop-up function move(){ var count=0; clearInterval(timer) timer = setInterval(function(){ // Start moving // Get the left and top of the ball let left = ball.offsetLeft; let top = ball.offsetTop; // Let left and top increase speed // The ball collides with the slider if (boom (slider, ball)) { speedY = -speedY } // The small ball collides with the big box if(left<=0 || left>=container.clientWidth - ball.offsetWidth){ speedX = -speedX } if(top<=0){ speedY = -speedY } // Check if all bricks and balls collide for(let i=0;i<brickBox.children.length;i++){ if(boom(brickBox.children[i],ball)){ speedY = -speedY brickBox.removeChild(brickBox.children[i]); count++; } } console.log(count) document.querySelector("#count").innerHTML=count // GAME OVER if(top>=container.clientHeight-ball.offsetHeight){ clearInterval(timer) if(confirm("GAME OVER, whether to play again")){ location.reload(); }else{alert('your final score'+count)} } left += speedX top += speedY // Set the left and top of the ball ball.style.left = left + "px" ball.style.top = top + "px" },20) } // Let the slider follow the mouse movement slider.onmouseover = function(){ document.onmousemove = function(e){ var e = e || window.event; var x = e.pageX; var l = x - container.offsetLeft - 1 - slider.offsetWidth / 2 if(l<0){ l = 0 } if (l > container.clientWidth - slider.offsetWidth) { l = container.clientWidth - slider.offsetWidth } slider.style.left = l + "px" } } //Let the slider move with the left and right keyboards window.onload = function(){ document.onkeydown = e=>{ var e = e || window.event; var keycode = e.keyCode || e.which; var keyword = String.fromCharCode(keycode).toLowerCase(); if(keycode==13){ move(); } if(keyword=='a'){ console.log("1111") slider.style.left = slider.offsetLeft-15+"px" }else if(keyword=='d'){ console.log("222") slider.style.left=slider.offsetLeft+15+"px" } console.log(slider.offsetLeft) } } // Encapsulate the collision detection function function boom(node1,node2){ // There are only 4 possibilities for not colliding if(node1.offsetLeft+node1.offsetWidth<node2.offsetLeft || node1.offsetTop+node1.offsetHeight<node2.offsetTop || node2.offsetLeft+node2.offsetWidth<node1.offsetLeft || node2.offsetTop+node2.offsetHeight<node1.offsetTop){ return false; }else{ return true; } } // Encapsulate the function of getting random color function getColor(hex=true){ if(hex){ var color = '#' for(var i=0;i<3;i++){ var rgb = getRandom(256).toString(16); rgb = rgb.length===1?'0'+rgb:rgb; color += rgb } return color; } return `rgb(${getRandom(256)},${getRandom(256)},${getRandom(256)})` } // Encapsulate the function of setting style function setStyle(ele,styleObj){ for(var attr in styleObj){ ele.style[attr] = styleObj[attr] } } // Encapsulate the function of getting random numbers function getRandom(a,b=0){ var max = Math.max(a,b); var min = Math.min(a,b) return Math.floor(Math.random() * (max-min)) + min } </script> </html> The effect diagram is shown in the figure The style is a little ugly without the plug-in. The above is the full content of this article. I hope it will be helpful for everyone’s study. I also hope that everyone will support 123WORDPRESS.COM. You may also be interested in:
|
<<: Detailed steps for Python script self-start and scheduled start under Linux
>>: Unzipped version of MYSQL installation and encountered errors and solutions
Special symbols Named Entities Decimal encoding S...
Preface Let's get straight to the point. The ...
Front-end is a tough job, not only because techno...
Table of contents 2 solutions for file upload Bas...
Preface: I reinstalled win10 and organized the fi...
1. Introduction By enabling the slow query log, M...
I started learning MySQL recently. The installati...
Preface The mv command is the abbreviation of mov...
Tip: The following operations are all performed u...
Pessimistic Lock Pessimistic lock, considers the ...
Table of contents 1. Introduction 2. Aggregation ...
This article example shares the specific code of ...
The future of CSS is so exciting: on the one hand,...
Required effect: After clicking to send the verif...
1. Introduction Our real servers should not be di...