1、项目文件
2、使用HTML及css进行页面布局
HTML部分
<div class="container">
<h1 class="score">0</h1>
<div class="progress"></div>
<div id="start">
<h2>锅打灰太狼</h2>
<button class="start">开始游戏</button></div>
<div class="rules">游戏规则</div>
<div class="rule">
<p>游戏规则:</p>
<p>1.游戏时间:60s</p>
<p>2.拼手速,殴打灰太狼+10分</p>
<p>3.殴打小灰灰-10分</p>
<a href="#" class="close">[关闭]</a>
</div>
<div class="mask">
<h1>GAME OVER</h1>
<button class="reStart">重新开始</button>
<button class="finish">结束游戏</button>
</div>
<div id="finish">
<h2>锅打灰太狼</h2>
<h3>得分:<span class="scoreEnd"></span> </h3>
</div>
</div>
css部分
* {
margin: 0;
padding: 0;
}
.container {
width: 320px;
height: 480px;
background: url("./images/game_bg.jpg") no-repeat 0 0;
margin: 50px auto;
position: relative;
}
.container>h1 {
margin-left: 60px;
}
.container>.progress {
width: 180px;
height: 16px;
background: url("./images/progress.png") no-repeat 0 0;
position: absolute;
top: 66px;
left: 63px;
}
.container>#start>h2 {
margin-top: 180px;
color: white;
text-align: center;
}
.container>#start>.start {
width: 150px;
line-height: 35px;
text-align: center;
color: white;
background: linear-gradient(#E55C3D, #C50000);
border-radius: 20px;
border: none;
font-size: 20px;
position: absolute;
top: 320px;
left: 50%;
margin-left: -75px;
}
.container>.rules {
width: 100%;
height: 20px;
background: #ccc;
position: absolute;
left: 0;
bottom: 0;
text-align: center;
}
.container>.rule {
width: 100%;
height: 100%;
background: rgba(0, 0, 0, 0.5);
position: absolute;
left: 0;
top: 0;
padding-top: 100px;
box-sizing: border-box;
text-align: center;
display: none;
}
.rule>p {
line-height: 50px;
color: white;
}
.rule>a {
color: red;
}
.container>.mask {
width: 100%;
height: 100%;
background: rgba(0, 0, 0, 0.5);
position: absolute;
left: 0;
top: 0;
padding-top: 200px;
box-sizing: border-box;
text-align: center;
display: none;
}
.mask>h1 {
color: #ff4500;
text-shadow: 3px 3px 0 #fff;
font-size: 40px;
}
.mask>button {
width: 100px;
line-height: 35px;
text-align: center;
color: white;
background: linear-gradient(#74ACCF, #007DDC);
border-radius: 20px;
border: none;
font-size: 20px;
position: absolute;
top: 320px;
left: 30%;
}
.mask>.reStart {
margin-left: -50px;
}
.mask>.finish {
margin-left: 80px;
float: right;
}
#finish {
color: white;
text-align: center;
display: none;
margin-top: 100px;
}
#finish h2 {
padding: 25px;
}
3、使用JavaScript来实现效果
var begin = document.querySelector('#start');
var h = begin.querySelector('h2');
var start = document.querySelector('.start');
var mask = document.querySelector('.mask');
var rules = document.querySelector('.rules');
var rule = document.querySelector('.rule');
var reStart = document.querySelector('.reStart');
var close = document.querySelector('.close');
var progress = document.querySelector('.progress');
var container = document.querySelector('.container');
var score = document.querySelector('.score');
var finishBtn = document.querySelector('.finish');
var finish = document.querySelector('#finish');
var scoreEnd = document.querySelector('.scoreEnd');
start.onclick = function() {
finish.style.display = 'none';
var fadIndex = this.parentNode;
fadIndex.style.display = 'none';
var progressWidth = 180;
progressHandler(progressWidth);
var timer;
startAnimation();
};
rules.onclick = function() {
console.log('点击游戏规则');
rule.style.display = 'block';
};
close.onclick = function() {
console.log('关闭');
rule.style.display = 'none';
};
reStart.onclick = function() {
score.innerHTML = 0;
mask.style.display = 'none';
var progressWidth = 180;
progress.style.width = '180px';
progressHandler(progressWidth);
startAnimation();
};
finishBtn.onclick = function() {
mask.style.display = 'none';
finish.style.display = 'block';
scoreEnd.innerHTML += score.innerHTML;
begin.style.display = 'block';
h.style.display = 'none';
progress.style.width = 180 + 'px';
}
function progressHandler(index) {
var setProgress = setInterval(function() {
index--;
progress.style.width = index + "px";
if (index <= 0) {
clearInterval(setProgress);
mask.style.display = 'block';
stopAnimation();
}
}, 100);
}
function startAnimation() {
var imgArr = ['./images/h0.png', './images/h1.png', './images/h2.png',
'./images/h3.png', './images/h4.png', './images/h5.png', './images/h6.png',
'./images/h7.png', './images/h8.png', './images/h9.png'
];
var imgArr2 = ['./images/x0.png', './images/x1.png', './images/x2.png',
'./images/x3.png', './images/x4.png', './images/x5.png', './images/x6.png',
'./images/x7.png', './images/x8.png', './images/x9.png'
];
var arrPos = [{
left: "98px",
top: "115px"
}, {
left: "17px",
top: "160px"
}, {
left: "15px",
top: "220px"
}, {
left: "30px",
top: "293px"
}, {
left: "122px",
top: "273px"
}, {
left: "207px",
top: "295px"
}, {
left: "200px",
top: "211px"
}, {
left: "187px",
top: "141px"
}, {
left: "100px",
top: "185px"
}];
var imgs = document.createElement('img');
imgs.setAttribute('class', 'wolfImages');
var posIndex = Math.round(Math.random() * 8);
imgs.style.position = 'absolute';
imgs.style.left = arrPos[posIndex].left;
imgs.style.top = arrPos[posIndex].top;
var imgType = Math.round(Math.random()) == 0 ? imgArr : imgArr2;
window.index = 0;
window.indexEnd = 5;
timer = setInterval(() => {
if (index > indexEnd) {
imgs.remove();
clearInterval(timer);
startAnimation();
}
imgs.setAttribute('src', imgType[index]);
index++;
}, 400);
container.appendChild(imgs);
scoreEverySum(imgs);
}
function scoreEverySum(e) {
e.onclick = function() {
window.index = 5;
window.indexEnd = 9;
var src = this.getAttribute('src');
if (src.indexOf("h") >= 0) {
score.innerHTML = parseInt(score.innerHTML) + 10;
} else {
score.innerHTML = parseInt(score.innerHTML) - 10;
}
e.onclick = null
}
}
function stopAnimation() {
var img = document.querySelector('.wolfImages');
console.log(img);
img.remove();
clearInterval(timer);
}
4、效果图
开始界面 结束界面
|