位置: IT常识 - 正文

HTML跳动爱心代码|最近很火的爱心代码你还没收到吗(2021年8月现在还能去武汉吗)

编辑:rootadmin
HTML跳动爱心代码|最近很火的爱心代码你还没收到吗 最近很火的跳动爱心代码HTML实现可DIY

推荐整理分享HTML跳动爱心代码|最近很火的爱心代码你还没收到吗(2021年8月现在还能去武汉吗),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:东芝单卡收录机,东芝单卡收录机,里泽运动足球俱乐部,里泽运动足球俱乐部,html跳动爱心代码加字,东芝单卡收录机,东芝单卡收录机,html跳动爱心代码加字,内容如对您有帮助,希望把文章链接给更多的朋友!

看效果HTML跳动爱心代码|最近很火的爱心代码你还没收到吗(2021年8月现在还能去武汉吗)

QQ录屏20221108115545

点个赞吧,养成好习惯 不想动手的小伙伴可以直接👇👇 阿里云盘直接提取 阿里云盘 DIY版----提取码: f30q

使用说明主体代码来源于网络,让我们为原作者点赞👍我用css3的animate和@keyframes帧动画加了一个跳动效果.heart { animation: heart 1s infinite ease-in-out;}@keyframes heart { 0%, 100% { transform: rotate(-2deg) scale(1); } 50% { transform: rotate(2deg) scale(1.12); }}可自行修改爱心颜色context.fillStyle = "#dc4b61";//自定义爱心颜色修改基础参数var settings = { particles: { length: 520, // 爱心数量 duration: 5, // 数值变大向内收缩 velocity: 100, // 移动速度 effect: 0.75, //正值外发散 size: 60, // 大小 }}DIY输入自定义文字实现

我用了一个简单的输入框和按钮实现input { font-size: 1.375rem; color: #ff437b;/*这里修改文字颜色*/ text-align: center; background: none;}<div class="text_box"> <input type="text" id="text" placeholder="送给你的那个[Ta]️"> <button id="btn" onclick="fn()">❤️</button></div><script> function fn() { var a1 = document.querySelector('#text'); var btn = document.querySelector('#btn'); a1.style.border = 'none'; btn.parentNode.removeChild(btn);//点击爱心后移除元素 }</script>其他效果背景/文字/图片 就看大家自由发挥了源代码部分<!DOCTYPE html><html lang="zh"><head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><title>DIY跳动爱心</title><style>* {padding: 0;margin: 0;}body {height: 600px;padding: 0;margin: 0;background: #000;display: flex;justify-content: center;align-items: center;}.container {width: 500px;height: 500px;position: relative;}canvas {z-index: 99;position: absolute;width: 500px;height: 500px;}.text_box {text-align: center;position: absolute;font-size: 1.125rem;top: 36%;left: 22%;color: #ff437b;z-index: 100;}input {font-size: 1.375rem;color: #ff437b;text-align: center;background: none;}button {font-size: 1.375rem;border: none;border-radius: 4px;}input::input-placeholder {color: #dc4b61;}input::-webkit-input-placeholder {color: #dc4b61;}.heart {animation: heart 1s infinite ease-in-out;}@keyframes heart {0%,100% {transform: rotate(-2deg) scale(1);}50% {transform: rotate(2deg) scale(1.12);}}</style></head><body><div id="jsi-cherry-container" class="container "><!-- 爱心 --><canvas id="pinkboard" class="container heart"> </canvas><!-- 输入你需要的文字 --><div class="text_box"><input type="text" id="text" placeholder="送给你的那个[Ta]️"><button id="btn" onclick="fn()">❤️</button></div></div></body><script src="https://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script><script>function fn() {var a1 = document.querySelector('#text');var btn = document.querySelector('#btn');a1.style.border = 'none';btn.parentNode.removeChild(btn);console.log("点关注不迷路!");}</script><script>/* * Settings */var settings = {particles: {length: 500, // maximum amount of particlesduration: 2, // particle duration in secvelocity: 100, // particle velocity in pixels/seceffect: -0.75, // play with this for a nice effectsize: 30, // particle size in pixels},};(function() {var b = 0;var c = ["ms", "moz", "webkit", "o"];for (var a = 0; a < c.length && !window.requestAnimationFrame; ++a) {window.requestAnimationFrame = window[c[a] + "RequestAnimationFrame"];window.cancelAnimationFrame =window[c[a] + "CancelAnimationFrame"] ||window[c[a] + "CancelRequestAnimationFrame"];}if (!window.requestAnimationFrame) {window.requestAnimationFrame = function(h, e) {var d = new Date().getTime();var f = Math.max(0, 16 - (d - b));var g = window.setTimeout(function() {h(d + f);}, f);b = d + f;return g;};}if (!window.cancelAnimationFrame) {window.cancelAnimationFrame = function(d) {clearTimeout(d);};}})();/* * Point class */var Point = (function() {function Point(x, y) {this.x = typeof x !== "undefined" ? x : 0;this.y = typeof y !== "undefined" ? y : 0;}Point.prototype.clone = function() {return new Point(this.x, this.y);};Point.prototype.length = function(length) {if (typeof length == "undefined")return Math.sqrt(this.x * this.x + this.y * this.y);this.normalize();this.x *= length;this.y *= length;return this;};Point.prototype.normalize = function() {var length = this.length();this.x /= length;this.y /= length;return this;};return Point;})();/* * Particle class */var Particle = (function() {function Particle() {this.position = new Point();this.velocity = new Point();this.acceleration = new Point();this.age = 0;}Particle.prototype.initialize = function(x, y, dx, dy) {this.position.x = x;this.position.y = y;this.velocity.x = dx;this.velocity.y = dy;this.acceleration.x = dx * settings.particles.effect;this.acceleration.y = dy * settings.particles.effect;this.age = 0;};Particle.prototype.update = function(deltaTime) {this.position.x += this.velocity.x * deltaTime;this.position.y += this.velocity.y * deltaTime;this.velocity.x += this.acceleration.x * deltaTime;this.velocity.y += this.acceleration.y * deltaTime;this.age += deltaTime;};Particle.prototype.draw = function(context, image) {function ease(t) {return --t * t * t + 1;}var size = image.width * ease(this.age / settings.particles.duration);context.globalAlpha = 1 - this.age / settings.particles.duration;context.drawImage(image,this.position.x - size / 2,this.position.y - size / 2,size,size);};return Particle;})();/* * ParticlePool class */var ParticlePool = (function() {var particles,firstActive = 0,firstFree = 0,duration = settings.particles.duration;function ParticlePool(length) {// create and populate particle poolparticles = new Array(length);for (var i = 0; i < particles.length; i++)particles[i] = new Particle();}ParticlePool.prototype.add = function(x, y, dx, dy) {particles[firstFree].initialize(x, y, dx, dy);// handle circular queuefirstFree++;if (firstFree == particles.length) firstFree = 0;if (firstActive == firstFree) firstActive++;if (firstActive == particles.length) firstActive = 0;};ParticlePool.prototype.update = function(deltaTime) {var i;// update active particlesif (firstActive < firstFree) {for (i = firstActive; i < firstFree; i++)particles[i].update(deltaTime);}if (firstFree < firstActive) {for (i = firstActive; i < particles.length; i++)particles[i].update(deltaTime);for (i = 0; i < firstFree; i++) particles[i].update(deltaTime);}// remove inactive particleswhile (particles[firstActive].age >= duration &&firstActive != firstFree) {firstActive++;if (firstActive == particles.length) firstActive = 0;}};ParticlePool.prototype.draw = function(context, image) {// draw active particlesif (firstActive < firstFree) {for (i = firstActive; i < firstFree; i++)particles[i].draw(context, image);}if (firstFree < firstActive) {for (i = firstActive; i < particles.length; i++)particles[i].draw(context, image);for (i = 0; i < firstFree; i++) particles[i].draw(context, image);}};return ParticlePool;})();/* * Putting it all together */(function(canvas) {var context = canvas.getContext("2d"),particles = new ParticlePool(settings.particles.length),particleRate =settings.particles.length / settings.particles.duration, // particles/sectime;// get point on heart with -PI <= t <= PIfunction pointOnHeart(t) {return new Point(160 * Math.pow(Math.sin(t), 3),130 * Math.cos(t) -50 * Math.cos(2 * t) -20 * Math.cos(3 * t) -10 * Math.cos(4 * t) +25);}// creating the particle image using a dummy canvasvar image = (function() {var canvas = document.createElement("canvas"),context = canvas.getContext("2d");canvas.width = settings.particles.size;canvas.height = settings.particles.size;// helper function to create the pathfunction to(t) {var point = pointOnHeart(t);point.x =settings.particles.size / 2 +(point.x * settings.particles.size) / 350;point.y =settings.particles.size / 2 -(point.y * settings.particles.size) / 350;return point;}// create the pathcontext.beginPath();var t = -Math.PI;var point = to(t);context.moveTo(point.x, point.y);while (t < Math.PI) {t += 0.01; // baby steps!point = to(t);context.lineTo(point.x, point.y);}context.closePath();// create the fillcontext.fillStyle = "#dc4b61";context.fill();// create the imagevar image = new Image();image.src = canvas.toDataURL();return image;})();// render that thing!function render() {// next animation framerequestAnimationFrame(render);// update timevar newTime = new Date().getTime() / 1000,deltaTime = newTime - (time || newTime);time = newTime;// clear canvascontext.clearRect(0, 0, canvas.width, canvas.height);// create new particlesvar amount = particleRate * deltaTime;for (var i = 0; i < amount; i++) {var pos = pointOnHeart(Math.PI - 2 * Math.PI * Math.random());var dir = pos.clone().length(settings.particles.velocity);particles.add(canvas.width / 2 + pos.x,canvas.height / 2 - pos.y,dir.x,-dir.y);}// update and draw particlesparticles.update(deltaTime);particles.draw(context, image);}// handle (re-)sizing of the canvasfunction onResize() {canvas.width = canvas.clientWidth;canvas.height = canvas.clientHeight;}window.onresize = onResize;// delay rendering bootstrapsetTimeout(function() {onResize();render();}, 10);})(document.getElementById("pinkboard"));</script></html>

分享结束,快去试试吧🎉🎉🎉

本文链接地址:https://www.jiuchutong.com/zhishi/273628.html 转载请保留说明!

上一篇:如何用u盘装系统?UltraISO软件安装win7系统图文教程(如何用u盘装系统知乎)

下一篇:恢复Linux桌面下方面板上显示最小化的图标的方法(linux桌面不见了)

  • wifi重置密码方法(wifi重置密码方法192.168.10.1)

    wifi重置密码方法(wifi重置密码方法192.168.10.1)

  • 鸿蒙怎么把应用变成卡片(鸿蒙怎么把应用移到sd卡)

    鸿蒙怎么把应用变成卡片(鸿蒙怎么把应用移到sd卡)

  • 怎么给蚂蚁庄园小鸡取名字(怎么给蚂蚁庄园的鸡取名)

    怎么给蚂蚁庄园小鸡取名字(怎么给蚂蚁庄园的鸡取名)

  • 淘宝可以微信支付吗(微信小商店怎么上架商品)

    淘宝可以微信支付吗(微信小商店怎么上架商品)

  • 蓝牙网关的作用(蓝牙网关的作用是什么)

    蓝牙网关的作用(蓝牙网关的作用是什么)

  • 华为曲面屏易碎吗(华为曲面手机屏容易破碎吗)

    华为曲面屏易碎吗(华为曲面手机屏容易破碎吗)

  • 苹果xr来电照片怎么设置全屏(苹果xr来电照片怎么换)

    苹果xr来电照片怎么设置全屏(苹果xr来电照片怎么换)

  • 秘乐短视频是什么东西(秘乐短视频什么时候关闭)

    秘乐短视频是什么东西(秘乐短视频什么时候关闭)

  • 高清通话有必要开启吗(高清通话需要开吗)

    高清通话有必要开启吗(高清通话需要开吗)

  • 红魔5G什么时候上市(红魔5g会降价吗)

    红魔5G什么时候上市(红魔5g会降价吗)

  • 红米手机怎么下载不了微信(红米手机怎么下载小说到mp4)

    红米手机怎么下载不了微信(红米手机怎么下载小说到mp4)

  • 一个微信只能申请一个健康码吗(一个人只能注册一个公众号)

    一个微信只能申请一个健康码吗(一个人只能注册一个公众号)

  • 6p和7p的手机壳一样吗(苹果6p和7p手机壳能通用吗?)

    6p和7p的手机壳一样吗(苹果6p和7p手机壳能通用吗?)

  • vivo字体如何变特别大(vivo手机字体怎么变大)

    vivo字体如何变特别大(vivo手机字体怎么变大)

  • 手机距离测量仪怎么用(手机距离测量仪在线)

    手机距离测量仪怎么用(手机距离测量仪在线)

  • 华为mate30pro变焦倍数(华为mate30pro变焦卡住)

    华为mate30pro变焦倍数(华为mate30pro变焦卡住)

  • 索立信儿童电话手表怎么用(索立信儿童电话手表app)

    索立信儿童电话手表怎么用(索立信儿童电话手表app)

  • 唯品会退了货怎么删除(唯品会退货怎么免运费)

    唯品会退了货怎么删除(唯品会退货怎么免运费)

  • 电话卡被暂停服务是什么意思(电话卡被暂停服务怎么恢复)

    电话卡被暂停服务是什么意思(电话卡被暂停服务怎么恢复)

  • 能量球收取失败(能量球不显示还剩多久可收取)

    能量球收取失败(能量球不显示还剩多久可收取)

  • 怎么缩小照片内存容量(怎么缩小照片内存的应用)

    怎么缩小照片内存容量(怎么缩小照片内存的应用)

  • anealoo是什么手机(anole是什么牌子)

    anealoo是什么手机(anole是什么牌子)

  • jkmal00是什么手机(jkmal00什么型号)

    jkmal00是什么手机(jkmal00什么型号)

  • iphone7可以用airpods吗(iphone7可以用airpods二代吗)

    iphone7可以用airpods吗(iphone7可以用airpods二代吗)

  • 华为mate20pro跑马灯设置(华为mate20有跑马灯功能吗)

    华为mate20pro跑马灯设置(华为mate20有跑马灯功能吗)

  • ChatGPT的火爆出圈,你对它有几分了解?

    ChatGPT的火爆出圈,你对它有几分了解?

  • 车辆消费税征税范围是什么
  • 三免三减半如何申报企业所得税
  • 劳务派遣公司简介模板范文
  • 上市公司股价变动谁受益
  • etc充值怎么操作
  • 税务外管证取消了吗
  • 企业销售使用过的固定资产如何开票
  • 公司支付保险公司保费怎么做账
  • 资本公积什么时候做账
  • 承兑贴现给个人怎么做账
  • 公司改变工资结构变相降工资怎么办
  • 买了两个可以退一个吗
  • 其他业务收入的核算内容
  • 给员工缴纳保险
  • 集体土地上的不动产证已经能查询为何房产证拿不到
  • 营改增后增加了什么征税项目
  • 专利申请费用怎么做账
  • 零申报有期限吗
  • 发票勾选可以勾选几次
  • 发票专用章备案需要什么资料
  • 建筑企业员工培训
  • 物业费需不需要物价局审批
  • 吊车租赁费计入什么会计科目
  • 购买的技术服务费需要摊销吗
  • 企业公户转别的公司公户他不给开发票怎么操作?
  • 租车公司的车能租吗
  • 1697509666
  • 去年的发票可以红冲重新开具吗?
  • 测测网络
  • 财政专项补助资金企业所得税申报
  • 研发费中废料收入怎么处理
  • 生产企业出口退税计算
  • 安装adsl modem必须安装什么协议
  • 支付汽车耗材费怎么入账
  • 中秋购物
  • 酒店没有营业执照开业员工有责任吗
  • 赡养老人支出如果有四个子女都要填吗
  • 既征收消费税又征收增值税的是
  • 关于出售使用过的车辆
  • wwwxxx域名选择(www.xxx.com或者.cn)
  • kavsvc.exe - kavsvc是什么进程 有什么作用
  • 哪些费用可以在开办费中列支
  • 免施工许可证
  • 出口流程步骤
  • php请求接口数据
  • php操作json文件
  • python基本功
  • 投资入股的会计处理
  • 增值税进项税加计抵减
  • 机器学习——果蔬分类
  • mysql 触发器
  • 将原生html改成vue
  • 筹建期的收入要交企业所得税吗
  • 临时工工资账务处理该怎么进行
  • 为什么出台农产品质量安全法
  • 其他应付款贷方余额怎么冲平
  • 企业研发费用加计扣除比例
  • 发票票种核定发票种类怎么选
  • 小规模未达起征点申报表怎么填
  • 小规模未开票收入按1%还是3%
  • 应付账款收不回发票该如何调整
  • 行政单位基建账地质灾害评估报告计哪个科目
  • 内含增长率简易公式如何理解
  • 收到利息收入如何做分录
  • 增值税普通发票可以抵扣吗
  • 外汇申报填写什么最简单
  • MySQL ERROR 1045 (28000) 错误的解决办法
  • sql语句训练题及答案
  • xp系统如何配置ip
  • Ubuntu Server 11.04安装GNOME 3的方法
  • 软件无法卸载怎么办,安装的软件卸载不了怎么办
  • win1020th2
  • html中title的作用
  • js时间倒计时定时器怎么弄
  • js内存释放
  • 手游接入
  • opengl配置vc6.0
  • node.js中的http.response.end方法使用说明
  • JavaScript中String.match()方法的使用详解
  • 国家税务总局令第43号公告
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设