Skip to content

Instantly share code, notes, and snippets.

@512jay
Forked from jrue/index.html
Last active February 10, 2023 20:45
Show Gist options
  • Save 512jay/c822c69271d4d8c68aafe43a690ad0ca to your computer and use it in GitHub Desktop.
Save 512jay/c822c69271d4d8c68aafe43a690ad0ca to your computer and use it in GitHub Desktop.
HTML & CSS Wheel Of Fortune / Bingo Game
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Regina's Fun Interview Questions</title>
<!--
MIT License
Copyright (c) 2017 Jeremy Rue
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
-->
<style type="text/css">
body {
background-color: #DCD6F7;
}
h1 {
color: #424874;
font-weight: bold;
font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
padding: 50;
margin: 50;
-webkit-transform: translate(0, -50%);
transform: translate(0, -50%);
}
text {
font-family: Helvetica, Arial, sans-serif;
font-weight: bold;
font-size: 20px;
pointer-events: none;
}
#chart {
position: absolute;
width: 1200px;
height: 1200;
top: 0;
left: 0;
}
#question {
position: absolute;
width: 400px;
height: 500px;
top: 0;
left: 520px;
}
#question h1 {
color: #424874;
font-size: 50px;
font-weight: bold;
font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
position: absolute;
padding: 0;
margin: 0;
top: 50%;
-webkit-transform: translate(0, -50%);
transform: translate(0, -50%);
}
</style>
</head>
<body>
<h1 style="text-align:center">Regina's Corner Interview Wheel</h1>
<br>
<div id="chart"></div>
<div id="question">
<h1></h1>
</div>
<script src="https://d3js.org/d3.v3.min.js" charset="utf-8"></script>
<script type="text/javascript" charset="utf-8">
var padding = { top: 120, right: 40, bottom: 0, left: 20 },
w = 500 - padding.left - padding.right,
h = 500 - padding.top - padding.bottom,
r = Math.min(w, h) / 2,
rotation = 0,
oldrotation = 0,
picked = 100000,
oldpick = [],
color = d3.scale.category20();//category20c()
//randomNumbers = getRandomNumbers();
//http://osric.com/bingo-card-generator/?title=HTML+and+CSS+BINGO!&words=padding%2Cfont-family%2Ccolor%2Cfont-weight%2Cfont-size%2Cbackground-color%2Cnesting%2Cbottom%2Csans-serif%2Cperiod%2Cpound+sign%2C%EF%B9%A4body%EF%B9%A5%2C%EF%B9%A4ul%EF%B9%A5%2C%EF%B9%A4h1%EF%B9%A5%2Cmargin%2C%3C++%3E%2C{+}%2C%EF%B9%A4p%EF%B9%A5%2C%EF%B9%A4!DOCTYPE+html%EF%B9%A5%2C%EF%B9%A4head%EF%B9%A5%2Ccolon%2C%EF%B9%A4style%EF%B9%A5%2C.html%2CHTML%2CCSS%2CJavaScript%2Cborder&freespace=true&freespaceValue=Web+Design+Master&freespaceRandom=false&width=5&height=5&number=35#results
var data = [
{ "label": "Fantasy", "value": 1, "question": "If you could trade places with any fictional character for a day, who would it be and why?" },
{ "label": "Childhood", "value": 1, "question": "What's your favorite childhood memory?" },
{ "label": "Travel", "value": 1, "question": "If you could travel anywhere in the world tomorrow, where would you go?" },
{ "label": "Pets", "value": 1, "question": "What's the funniest or most interesting pet you've ever had?" },
{ "label": "Food", "value": 1, "question": "What's your favorite dish to cook?" },
{ "label": "Music", "value": 1, "question": "What kind of music do you like to listen to?" },
{ "label": "Movies", "value": 1, "question": "What's your favorite movie?" },
{ "label": "Sports", "value": 1, "question": "Do you have any favorite sports teams or players?" },
{ "label": "Books", "value": 1, "question": "What's your favorite book?" },
{ "label": "Hobbies", "value": 1, "question": "What do you like to do in your free time?" },
{ "label": "TV Shows", "value": 1, "question": "What's your favorite TV show?" },
{ "label": "Technology", "value": 1, "question": "What's your favorite piece of technology or gadget?" },
{ "label": "Superheroes", "value": 1, "question": "Who's your favorite superhero and why?" },
{ "label": "Dreams", "value": 1, "question": "What's the most interesting dream you've ever had?" },
{ "label": "Career", "value": 1, "question": "What was your first job, and what did you learn from it?" },
{ "label": "Talents", "value": 1, "question": "What are you good at, and what do you like to do?" },
{ "label": "Fears", "value": 1, "question": "What are you afraid of?" },
{ "label": "Accomplish", "value": 1, "question": "What are you most proud of?" },
{ "label": "Goals", "value": 1, "question": "What are your goals for the future?" },
{ "label": "Funny", "value": 1, "question": "What's the funniest story you can tell us?" },
{ "label": "Hero", "value": 1, "question": "Who's someone you admire or look up to?" },
{ "label": "Surprises", "value": 1, "question": "What's the biggest surprise you've ever had?" },
{ "label": "Memorable ", "value": 1, "question": "What's the most memorable moment of your life so far?" },
{ "label": "Embarrassing ", "value": 1, "question": "What's the most embarrassing moment of your life so far?" },
{ "label": "Regrets", "value": 1, "question": "What's something you wish you could go back and do differently?" },
]
var svg = d3.select('#chart')
.append("svg")
.data([data])
.attr("width", w + padding.left + padding.right)
.attr("height", h + padding.top + padding.bottom);
var container = svg.append("g")
.attr("class", "chartholder")
.attr("transform", "translate(" + (w / 2 + padding.left) + "," + (h / 2 + padding.top) + ")");
var vis = container
.append("g");
var pie = d3.layout.pie().sort(null).value(function (d) { return 1; });
// declare an arc generator function
var arc = d3.svg.arc().outerRadius(r);
// select paths, use arc generator to draw
var arcs = vis.selectAll("g.slice")
.data(pie)
.enter()
.append("g")
.attr("class", "slice");
arcs.append("path")
.attr("fill", function (d, i) { return color(i); })
.attr("d", function (d) { return arc(d); });
// add the text
arcs.append("text").attr("transform", function (d) {
d.innerRadius = 0;
d.outerRadius = r;
d.angle = (d.startAngle + d.endAngle) / 2;
return "rotate(" + (d.angle * 180 / Math.PI - 90) + ")translate(" + (d.outerRadius - 10) + ")";
})
.attr("text-anchor", "end")
.text(function (d, i) {
return data[i].label;
});
container.on("click", spin);
function spin(d) {
container.on("click", null);
//all slices have been seen, all done
console.log("OldPick: " + oldpick.length, "Data length: " + data.length);
if (oldpick.length == data.length) {
console.log("done");
container.on("click", null);
return;
}
var ps = 360 / data.length,
pieslice = Math.round(1440 / data.length),
rng = Math.floor((Math.random() * 1440) + 360);
rotation = (Math.round(rng / ps) * ps);
picked = Math.round(data.length - (rotation % 360) / ps);
picked = picked >= data.length ? (picked % data.length) : picked;
if (oldpick.indexOf(picked) !== -1) {
d3.select(this).call(spin);
return;
} else {
oldpick.push(picked);
}
rotation += 90 - Math.round(ps / 2);
vis.transition()
.duration(3000)
.attrTween("transform", rotTween)
.each("end", function () {
//mark question as seen
d3.select(".slice:nth-child(" + (picked + 1) + ") path")
.attr("fill", "#111");
//populate question
d3.select("#question h1")
.text(data[picked].label + ": " + data[picked].question);
oldrotation = rotation;
container.on("click", spin);
});
}
//make arrow
svg.append("g")
.attr("transform", "translate(" + (w + padding.left + padding.right) + "," + ((h / 2) + padding.top) + ")")
.append("path")
.attr("d", "M-" + (r * .15) + ",0L0," + (r * .05) + "L0,-" + (r * .05) + "Z")
.style({ "fill": "black" });
//draw spin circle
container.append("circle")
.attr("cx", 0)
.attr("cy", 0)
.attr("r", 60)
.style({ "fill": "white", "cursor": "pointer" });
//spin text
container.append("text")
.attr("x", 0)
.attr("y", 15)
.attr("text-anchor", "middle")
.text("SPIN")
.style({ "font-weight": "bold", "font-size": "30px" });
function rotTween(to) {
var i = d3.interpolate(oldrotation % 360, rotation);
return function (t) {
return "rotate(" + i(t) + ")";
};
}
function getRandomNumbers() {
var array = new Uint16Array(1000);
var scale = d3.scale.linear().range([360, 1440]).domain([0, 100000]);
if (window.hasOwnProperty("crypto") && typeof window.crypto.getRandomValues === "function") {
window.crypto.getRandomValues(array);
console.log("works");
} else {
//no support for crypto, get crappy random numbers
for (var i = 0; i < 1000; i++) {
array[i] = Math.floor(Math.random() * 100000) + 1;
}
}
return array;
}
</script>
</body>
</html>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment