js实现直播点击飘心效果
(编辑:jimmy 日期: 2024/11/25 浏览:3 次 )
本文实例为大家分享了js实现直播点击飘心效果的具体代码,供大家参考,具体内容如下
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>直播点击飘心效果</title> <style type="text/css"> html, body { height: 100%; position: relative; width: 100%; } canvas { display: block; position: absolute; bottom: 100px; right: -24px; z-index: 20; cursor: pointer; -webkit-tap-highlight-color: rgba(0, 0, 0, 0); } .journal-reward { position: absolute; bottom: 70px; right: 20px; height: 60px; width: 60px; display: block; z-index: 21; cursor: pointer; } </style> </head> <body> <img src="/UploadFiles/2021-04-02/reward.png">flutter-hearts-zmt.js
! function(t, e) { "object" == typeof exports && "undefined" != typeof module "function" == typeof define && define.amd "use strict"; function t(t, n, r) { var i = e.uniformDiscrete(89, 91) / 100, o = 1 - i, u = (e.uniformDiscrete(45, 60) + e.uniformDiscrete(45, 60)) / 100, a = function(t) { return t > i "Cannot call a class as a function") }, r = function() { function t(t, e) { for(var n = 0; n < e.length; n++) { var r = e[n]; r.enumerable = r.enumerable || !1, r.configurable = !0, "value" in r && (r.writable = !0), Object.defineProperty(t, r.key, r) } } return function(e, n, r) { return n && t(e.prototype, n), r && t(e, r), e } }(), i = window.requestAnimationFrame || window.webkitRequestAnimationFrame || function(t) { return setTimeout(t, 16) }, o = function() { function o() { n(this, o); var t = this.canvas = document.createElement("canvas"), e = this.context = t.getContext("2d"), r = this._children = [], u = function n() { i(n), e.clearRect(0, 0, t.width, t.height); for(var o = 0, u = r.length; o < u;) { var a = r[o]; a.render.call(null, (a.timestamp + a.duration - new Date) / a.duration) "bubble", value: function(n) { var r = arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : e.uniformDiscrete(2400, 3600), i = arguments.length > 2 && void 0 !== arguments[2] ? arguments[2] : t(n, this.canvas, this.context); return this._children.push({ render: i, duration: r, timestamp: +new Date }), this } }]), o }(); return o }); // 图片地址在此处更换 可换成你的图片 var assets = [ 'img/1.png', 'img/2.png', 'img/3.png', 'img/4.png', 'img/5.png', ]; assets.forEach(function(src, index) { assets[index] = new Promise(function(resolve) { var img = new Image; img.onload = resolve.bind(null, img); img.src = src; }); }); Promise.all(assets).then(function(images) { var random = { uniform: function(min, max) { return min + (max - min) * Math.random(); }, uniformDiscrete: function(i, j) { return i + Math.floor((j - i + 1) * random.uniform(0, 1)); }, }; var stage = new BubbleHearts(); var canvas = stage.canvas; canvas.width = 170; canvas.height = 300; canvas.style['width'] = '170px'; canvas.style['height'] = '300px'; document.body.appendChild(canvas); //journal-reward 为赏桃的按钮 document.getElementsByClassName('journal-reward')[0].addEventListener('click', function() { //随机飘动 stage.bubble(images[random.uniformDiscrete(0, images.length - 1)]); }, false); });以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
下一篇:js实现鼠标点击飘爱心效果