-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcolorgame.js
101 lines (96 loc) · 2.26 KB
/
colorgame.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
var noo=6;
var colors=[];
var pickedcolor;
var squares=document.getElementsByClassName("square");
var dmessage=document.getElementById("dmessage");
var message=document.getElementById("message");
var head=document.querySelector("h1");
var resetbtn=document.querySelector("#reset");
var level=document.querySelectorAll(".level");
var selected=document.querySelector("#selected");
dmessage.textContent=pickedcolor;
init();
function setlvl(){
for(var i=0;i<level.length;i++)
{
level[i].addEventListener("click",function(){
level[0].classList.remove("selected");
level[1].classList.remove("selected");
this.classList.add("selected");
if(this.textContent==="Easy")
noo=3;
else
noo=6;
reset();
});
}
}
function setblocks(){
for(var i=0;i<squares.length;i++)
{
squares[i].style.backgroundColor=colors[i];
squares[i].addEventListener("click",function(){
var clickedcolor=this.style.backgroundColor;
if(clickedcolor===pickedcolor)
{
message.textContent="correct";
changecolor(pickedcolor);
head.style.backgroundColor=clickedcolor;
resetbtn.textContent="Play Again?";
}
else{
this.style.backgroundColor="#232323";
message.textContent="try again";
}
});
}
}
function init(){
setlvl();
setblocks();
reset();
}
function reset()
{
colors=generatecolors(noo);
pickedcolor=pickcolor();
dmessage.textContent=pickedcolor;
resetbtn.textContent="New Colors";
head.style.backgroundColor="steelblue";
message.textContent="";
for(var i=0;i<6;i++)
{
if(colors[i])
{
squares[i].style.display="block";
squares[i].style.backgroundColor=colors[i];
}
else
{
squares[i].style.display="none";
}
}
}
resetbtn.addEventListener("click",reset);
function changecolor(color)
{
for(var i=0;i<squares.length;i++)
squares[i].style.backgroundColor=color;
}
function pickcolor(){
var random=Math.floor(Math.random()*colors.length);
return colors[random];
}
function generatecolors(num)
{
var arr=[];
for(var i=0;i<num;i++)
{
var x=Math.floor(Math.random()*256);
var y=Math.floor(Math.random()*256);
var z=Math.floor(Math.random()*256);
var current="rgb("+x+", "+y+", "+z+")";
arr.push(current);
}
return arr;
}