Skip to content

Instantly share code, notes, and snippets.

@hipi
Created June 30, 2019 08:04
Show Gist options
  • Save hipi/0ce0b28df70bd877471ca19291f2b88b to your computer and use it in GitHub Desktop.
Save hipi/0ce0b28df70bd877471ca19291f2b88b to your computer and use it in GitHub Desktop.
点击心型
(function(window, document) {
window.requestAnimationFrame =
window.requestAnimationFrame ||
window.webkitRequestAnimationFrame ||
window.mozRequestAnimationFrame ||
window.oRequestAnimationFrame ||
window.msRequestAnimationFrame ||
function(callback) {
setTimeout(callback, 1000 / 60);
};
var hearts = [];
function css(css) {
var style = document.createElement("style");
style.type = "text/css";
try {
style.appendChild(document.createTextNode(css));
} catch (ex) {
style.styleSheet.cssText = css;
}
document.getElementsByTagName("head")[0].appendChild(style);
}
function randomColor() {
return (
"rgb(" +
~~(Math.random() * 255) +
"," +
~~(Math.random() * 255) +
"," +
~~(Math.random() * 255) +
")"
);
}
function gameloop() {
for (var i = 0; i < hearts.length; i++) {
if (hearts[i].alpha <= 0) {
document.body.removeChild(hearts[i].el);
hearts.splice(i, 1);
continue;
}
hearts[i].y--;
hearts[i].scale += 0.004;
hearts[i].alpha -= 0.013;
hearts[i].el.style.cssText =
"left:" +
hearts[i].x +
"px;top:" +
hearts[i].y +
"px;opacity:" +
hearts[i].alpha +
";transform:scale(" +
hearts[i].scale +
"," +
hearts[i].scale +
") rotate(45deg);background:" +
hearts[i].color;
}
requestAnimationFrame(gameloop);
}
function createHeart(event) {
var d = document.createElement("div");
d.className = "heart";
hearts.push({
el: d,
x: event.clientX - 5,
y: event.clientY - 5,
scale: 1,
alpha: 1,
color: randomColor()
});
document.body.appendChild(d);
}
function init() {
css(
".heart{width: 10px;height: 10px;position: fixed;background: #f00;transform: rotate(45deg);-webkit-transform: rotate(45deg);-moz-transform: rotate(45deg);}.heart:after,.heart:before{content: '';width: inherit;height: inherit;background: inherit;border-radius: 50%;-webkit-border-radius: 50%;-moz-border-radius: 50%;position: absolute;}.heart:after{top: -5px;}.heart:before{left: -5px;}"
);
window.addEventListener("click", function(event) {
createHeart(event);
});
gameloop();
}
init();
})(window, document);
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment