游戏官网作业html,html游戏

3 月,跳不动了?>>>

6c1555302777729326ca3efa0910d9ec.png

开发工具:Visual Studio Code

游戏介绍:已知3个一组的方块,前面2个方块涂有相近的两种颜色,你根据这两种颜色序列的递减情况,猜测第三个方块的颜色是什么,并从下面的方块中选择你认为最接近的颜色。

程序设计步骤:

1.编写html代码

2.编写js代码

html代码编写

设置css文件

import url('https://fonts.googleapis.com/css?family=Pacifico');

html, body {

background: #9cf;

margin: 0;

padding: 0;

}

h1, h2 {

text-align: center;

color: white;

font-size: 5vmin;

text-shadow: 0 1px 3px rgba(0,0,0,0.25);

font-family: Pacifico, arial, serif;

font-weight: normal;

}

h2 {

font-size: 3.5vmin;

margin-top: 5vmin;

}

#points {

font-family: Pacifico, Verdana, sans-serif;

color: white;

font-size: 5vmin;

text-shadow: 0 1px 3px rgba(0,0,0,0.25);

position: absolute;

top: 1vmin;

right: 2vmin;

}

.center {

position: absolute;

top: 50%;

left: 50%;

transform: translate(-50%, -50%);

}

.boxes {

margin: auto auto;

text-align: center;

white-space: nowrap;

}

.color-box {

display: inline-block;

background: red;

box-sizing: border-box;

border: 1.25vmin solid white;

border-radius: 2px;

width: 20vmin;

height: 20vmin;

margin-right: 5vmin;

box-shadow: 0 1rem 0.75rem -0.75rem rgba(0,0,0,0.25);

position: relative;

}

.boxes.mini .color-box {

width: 15vmin;

height: 15vmin;

margin-right: 3vmin;

cursor: pointer;

}

.color-box.right {

border-color: green;

}

.color-box.wrong {

border-color: #e81222;

}

#box-3 {

margin-right: 0;

background: #ccc;

overflow: hidden;

}

#color-3 {

margin-right: 0;

}

#box-3::before {

content: "?";

position: absolute;

top: 50%;

left: 50%;

transform: translate(-50%, -50%);

font-family: Pacifico, Verdana, sans-serif;

font-size: 6vmin;

color: rgba(0,0,0,0.5);

}

#scrim {

position: fixed;

top: 0;

left: 0;

width: 100%;

height: 100%;

background: rgba(0,0,0,0);

display: none;

}

#scrim.correct,

#scrim.incorrect {

display: block;

}

#scrim > div {

padding: 3vmin;

border-radius: 3px;

background: white;

box-shadow: 0 0.5rem 1.5rem -0rem rgba(0,0,0,0.25);

}

#scrim h2 {

color: #444;

margin-top: 0;

display: none;

}

#scrim.correct #correct,

#scrim.incorrect #incorrect {

display: block;

}

#scrim button {

width: 100%;

text-align: center;

font-size: 2vmin;

padding: 1.5vmin;

border-radius: 3px;

border: 0;

background: #396;

color: white;

box-shadow: 0 1rem 0.75rem -0.75rem rgba(0,0,0,0.25);

cursor: pointer;

}

#correct-color,

#picked-color {

position: absolute;

width: 100%;

height: 60%;

z-index: 2;

}

#picked-color {

top: 50%;

}

界面

根据渐变序列猜颜色游戏

js编写

导入js代码

const game = {

color: {

red: 0,

green: 0,

blue: 0

},

variation: {

red: 0,

green: 0,

blue: 0

},

right: 0,

total: 0,

possibilities: [

[0,0,16], [0,16,0], [0,16,16], [16,0,0], [16,0,16], [16,16,0], [16,16,16],

[0,0,-16], [0,-16,0], [0,-16,-16], [-16,0,0], [-16,0,-16], [-16,-16,0], [-16,-16,-16],

[0,16,-16], [0,-16,16], [16,0,-16], [-16,0,16], [16,-16,0], [-16,16,0],

[16,16,-16], [16,-16,16], [16,-16,-16], [-16,16,16], [-16,16,-16], [-16,-16,16]

],

min: 50,

correct: 0,

initialize: function() {

// associate the event handlers to the buttons

const boxes = document.querySelectorAll(".boxes.mini .color-box");

for (let x = 0; x < boxes.length; x++) {

boxes[x].addEventListener("click", function() {

if (this.dataset.value == game.correct) {

document.querySelector("#scrim").classList.add("correct");

this.classList.add("right");

game.right++;

} else {

document.querySelector("#scrim").classList.add("incorrect");

this.classList.add("wrong");

document.querySelector(`[data-value='${game.correct}']`).classList.add("right");

}

game.total++;

document.querySelector("#total").textContent = game.total;

document.querySelector("#guessed").textContent = game.right;

document.querySelector("#correct-color").style.backgroundColor = document.querySelector(`[data-value='${game.correct}']`).style.backgroundColor;

document.querySelector("#picked-color").style.backgroundColor = this.style.backgroundColor;

});

}

// associate event to the button

document.querySelector("#scrim button").addEventListener("click", function() {

const scrim = document.querySelector("#scrim");

scrim.classList.remove("correct");

scrim.classList.remove("incorrect");

game.generateGame();

});

// generate a new round

this.generateGame();

},

generateGame: function() {

// remove rights and wrongs

var dright = document.querySelector(".right");

if (dright) dright.classList.remove("right");

var dwrong = document.querySelector(".wrong");

if (dwrong) dwrong.classList.remove("wrong");

document.querySelector("#correct-color").style.backgroundColor = "rgba(0,0,0,0)";

document.querySelector("#picked-color").style.backgroundColor = "rgba(0,0,0,0)";

// generate the sequence

this.color.red = this.min + Math.floor(Math.random() * (255 - this.min * 2));

this.color.green = this.min + Math.floor(Math.random() * (255 - this.min * 2));

this.color.blue = this.min + Math.floor(Math.random() * (255 - this.min * 2));

this.variation.red = Math.floor((Math.random() * this.min) / 2);

this.variation.green = Math.floor((Math.random() * this.min) / 2);

this.variation.blue = Math.floor((Math.random() * this.min) / 2);

document.querySelector("#box-1").style.backgroundColor = `rgb(${this.color.red},${this.color.green},${this.color.blue})`;

document.querySelector("#box-2").style.backgroundColor = `rgb(${this.color.red+this.variation.red},${this.color.green+this.variation.green},${this.color.blue+this.variation.blue})`;

// set up the correct one

this.correct = Math.floor(Math.random()*4);

document.querySelector("#color-" + this.correct).style.backgroundColor = `rgb(${this.color.red+this.variation.red*2},${this.color.green+this.variation.green*2},${this.color.blue+this.variation.blue*2})`;

// generate the incorrect colors

for (let x = 0; x < 4; x++) {

if (x != this.correct) {

var change = Math.floor(Math.random() * this.possibilities.length);

document.querySelector("#color-" + x).style.backgroundColor = `rgb(${this.color.red+this.variation.red+this.possibilities[change][0]},${this.color.green+this.variation.green+this.possibilities[change][1]},${this.color.blue+this.variation.blue+this.possibilities[change][2]})`;

}

}

}

}

game.initialize()

游戏截图

6c1555302777729326ca3efa0910d9ec.png

6c1555302777729326ca3efa0910d9ec.png

6c1555302777729326ca3efa0910d9ec.png

来源:oschina

链接:https://my.oschina.net/u/4460087/blog/3208248

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值