当前位置: 首页 > news >正文

太原做网站baidu网上学电脑培训中心

太原做网站baidu,网上学电脑培训中心,做测试题的网站,app分销商城系统目录 写在前面 满屏爱心 代码分析 系列推荐 写在最后 写在前面 小编给大家准备了满屏漂浮爱心代码&#xff0c;一起来看看吧~ 满屏爱心 文件heart.svg <svg xmlns"http://www.w3.org/2000/svg" width"473.8px" height"408.6px" view…

目录

写在前面

满屏爱心

代码分析

系列推荐

写在最后


写在前面

小编给大家准备了满屏漂浮爱心代码,一起来看看吧~

满屏爱心

文件heart.svg

<svg xmlns="http://www.w3.org/2000/svg" width="473.8px" height="408.6px" viewBox="0 0 473.8 408.6"><path fill="#d32932" d="M404.6,16.6C385.4,6.1,363.5,0,340,0c-41.5,0-78.5,18.9-103,48.5C212.3,18.9,175.3,0,133.8,0 c-23.3,0-45.3,6.1-64.5,16.6C27.9,39.5,0,83.4,0,133.9c0,14.4,2.4,28.3,6.6,41.2C29.6,278.4,237,408.6,237,408.6 s207.2-130.2,230.2-233.5c4.3-12.9,6.6-26.8,6.6-41.2C473.8,83.4,445.9,39.6,404.6,16.6z"/></svg>

文件满屏漂浮爱心.html 

<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><title>Love</title><style>* {margin: 0;padding: 0;}body {background-color: #1E1E1E;}</style>
</head><body><canvas id="drawHeart"></canvas><script>var hearts = [];var canvas = document.getElementById('drawHeart');var wW = window.innerWidth;var wH = window.innerHeight;// 创建画布var ctx = canvas.getContext('2d');// 创建图片对象var heartImage = new Image();heartImage.src = 'heart.svg';var num = 100;init();window.addEventListener('resize', function () {wW = window.innerWidth;wH = window.innerHeight;});// 初始化画布大小function init() {canvas.width = wW;canvas.height = wH;for (var i = 0; i < num; i++) {hearts.push(new Heart(i % 5));}requestAnimationFrame(render);}function getColor() {var val = Math.random() * 10;if (val > 0 && val <= 1) {return '#00f';} else if (val > 1 && val <= 2) {return '#f00';} else if (val > 2 && val <= 3) {return '#0f0';} else if (val > 3 && val <= 4) {return '#368';} else if (val > 4 && val <= 5) {return '#666';} else if (val > 5 && val <= 6) {return '#333';} else if (val > 6 && val <= 7) {return '#f50';} else if (val > 7 && val <= 8) {return '#e96d5b';} else if (val > 8 && val <= 9) {return '#5be9e9';} else {return '#d41d50';}}function getText() {var val = Math.random() * 10;if (val > 1 && val <= 3) {return 'Love';} else if (val > 3 && val <= 5) {return 'You';} else if (val > 5 && val <= 8) {return 'I';} else {return 'I Love You';}}function Heart(type) {this.type = type;// 初始化生成范围this.x = Math.random() * wW;this.y = Math.random() * wH;this.opacity = Math.random() * .5 + .5;// 偏移量this.vel = {x: (Math.random() - .5) * 5,y: (Math.random() - .5) * 5}this.initialW = wW * .5;this.initialH = wH * .5;// 缩放比例this.targetScale = Math.random() * .15 + .02; // 最小0.02this.scale = Math.random() * this.targetScale;// 文字位置this.fx = Math.random() * wW;this.fy = Math.random() * wH;this.fs = Math.random() * 10;this.text = getText();this.fvel = {x: (Math.random() - .5) * 5,y: (Math.random() - .5) * 5,f: (Math.random() - .5) * 2}}Heart.prototype.draw = function () {ctx.save();ctx.globalAlpha = this.opacity;ctx.drawImage(heartImage, this.x, this.y, this.width, this.height);ctx.scale(this.scale + 1, this.scale + 1);if (!this.type) {// 设置文字属性ctx.fillStyle = getColor();ctx.font = 'italic ' + this.fs + 'px sans-serif';// 填充字符串ctx.fillText(this.text, this.fx, this.fy);}ctx.restore();}Heart.prototype.update = function () {this.x += this.vel.x;this.y += this.vel.y;if (this.x - this.width > wW || this.x + this.width < 0) {// 重新初始化位置this.scale = 0;this.x = Math.random() * wW;this.y = Math.random() * wH;}if (this.y - this.height > wH || this.y + this.height < 0) {// 重新初始化位置this.scale = 0;this.x = Math.random() * wW;this.y = Math.random() * wH;}// 放大this.scale += (this.targetScale - this.scale) * .1;this.height = this.scale * this.initialH;this.width = this.height * 1.4;// -----文字-----this.fx += this.fvel.x;this.fy += this.fvel.y;this.fs += this.fvel.f;if (this.fs > 50) {this.fs = 2;}if (this.fx - this.fs > wW || this.fx + this.fs < 0) {// 重新初始化位置this.fx = Math.random() * wW;this.fy = Math.random() * wH;}if (this.fy - this.fs > wH || this.fy + this.fs < 0) {// 重新初始化位置this.fx = Math.random() * wW;this.fy = Math.random() * wH;}}function render() {ctx.clearRect(0, 0, wW, wH);for (var i = 0; i < hearts.length; i++) {hearts[i].draw();hearts[i].update();}requestAnimationFrame(render);}</script>
</body></html>

代码分析

这个HTML、CSS和JavaScript代码描述了一个网页,该网页会在加载后在全屏黑色背景上动态生成并显示多个彩色心形图案以及随机出现的文本。以下是程序的主要逻辑分析:

1. HTML结构

   - 页面中包含一个`<canvas>`元素,id为'drawHeart',用于绘制动画效果。

2. CSS样式

   - CSS部分仅设置了全局的边距为零,并将body的背景颜色设为深灰色(#1E1E1E)。

3. JavaScript脚本

   - 定义了全局变量:`hearts`数组用来存储所有心形对象;获取画布元素`canvas`及其上下文`ctx`;声明窗口宽度`wW`和高度`wH`;设置心形图片源(假设是SVG格式的心形图像);并定义要创建的心形数量`num`。

   - `init()`函数负责初始化画布大小以适应浏览器窗口尺寸,并创建指定数量的心形对象,每个都关联到一个`Heart`类的实例。

   - `getColor()`函数根据随机数返回不同颜色值,使得心形及文本有多种颜色可能。

   - `getText()`函数随机选择返回字符串"Love"、"You"、"I"或"I Love You",作为可能出现的文本内容。

   - 定义了`Heart`构造函数,用于创建心形对象,包含位置、透明度、速度、缩放比例等属性,以及文字的相关属性(如位置、大小和内容)。

   - `Heart.prototype.draw()`方法负责绘制心形和可能的文字内容。它首先保存当前绘图状态,然后设置透明度,绘制心形图片,并根据需要进行缩放和平移操作来显示文字。

   - `Heart.prototype.update()`方法更新每个心形的位置、缩放和其他属性,确保它们在屏幕范围内运动,超出范围时重新初始化位置。

   - `render()`函数是主渲染循环,清空画布内容,遍历所有心形对象,调用它们的`draw()`和`update()`方法,最后使用`requestAnimationFrame`调度下一次渲染,从而实现动画效果。

总之,这段代码实现了一个动态且随机生成心形与文字动画的网页应用,在页面加载后会在屏幕上呈现不断变化的心形图案和飘动的爱意短语。

系列推荐

序号目录直达链接
1HTML实现3D相册HTML实现3D相册-CSDN博客
2HTML元素周期表HTML元素周期表-CSDN博客
3HTML黑客帝国字母雨HTML黑客帝国字母雨-CSDN博客
4HTML五彩缤纷的爱心HTML五彩缤纷的爱心-CSDN博客
5HTML飘落的花瓣HTML飘落的花瓣-CSDN博客
6HTML哆啦A梦HTML哆啦A梦-CSDN博客
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27

写在最后

我是一只有趣的兔子,感谢你的喜欢!


文章转载自:
http://turboshaft.zydr.cn
http://allochromatic.zydr.cn
http://slagging.zydr.cn
http://cynthia.zydr.cn
http://horrid.zydr.cn
http://rats.zydr.cn
http://dicyclic.zydr.cn
http://traveller.zydr.cn
http://compare.zydr.cn
http://virogene.zydr.cn
http://brutal.zydr.cn
http://bioclimatic.zydr.cn
http://transept.zydr.cn
http://timberland.zydr.cn
http://blower.zydr.cn
http://whoseso.zydr.cn
http://sexploiter.zydr.cn
http://ewer.zydr.cn
http://orthograde.zydr.cn
http://breathing.zydr.cn
http://radialization.zydr.cn
http://ifpi.zydr.cn
http://microalgae.zydr.cn
http://unwitnessed.zydr.cn
http://distorted.zydr.cn
http://xenogamy.zydr.cn
http://foul.zydr.cn
http://expansionist.zydr.cn
http://sustaining.zydr.cn
http://life.zydr.cn
http://kewpie.zydr.cn
http://birth.zydr.cn
http://intransigent.zydr.cn
http://hydromedusa.zydr.cn
http://birdbrain.zydr.cn
http://scotch.zydr.cn
http://paramecin.zydr.cn
http://myopy.zydr.cn
http://pyruvate.zydr.cn
http://carriage.zydr.cn
http://clamp.zydr.cn
http://neurotoxic.zydr.cn
http://doomsayer.zydr.cn
http://eyeblack.zydr.cn
http://advantage.zydr.cn
http://tapeline.zydr.cn
http://heavier.zydr.cn
http://adorably.zydr.cn
http://lineament.zydr.cn
http://rhizoctonia.zydr.cn
http://defalcate.zydr.cn
http://ultracytochemistry.zydr.cn
http://disemplane.zydr.cn
http://isoleucine.zydr.cn
http://romania.zydr.cn
http://aspirer.zydr.cn
http://crabbily.zydr.cn
http://maskanonge.zydr.cn
http://salubrious.zydr.cn
http://transitron.zydr.cn
http://ringhals.zydr.cn
http://transferrable.zydr.cn
http://epitoxoid.zydr.cn
http://tallage.zydr.cn
http://insuperable.zydr.cn
http://xu.zydr.cn
http://candidate.zydr.cn
http://amphigouri.zydr.cn
http://urbanize.zydr.cn
http://smeech.zydr.cn
http://heterokaryotic.zydr.cn
http://preterit.zydr.cn
http://jerid.zydr.cn
http://beeves.zydr.cn
http://synarthrosis.zydr.cn
http://mythopoeia.zydr.cn
http://gaudy.zydr.cn
http://readiness.zydr.cn
http://cacodylic.zydr.cn
http://semidomesticated.zydr.cn
http://strawy.zydr.cn
http://hydraemia.zydr.cn
http://slack.zydr.cn
http://subsoil.zydr.cn
http://dealing.zydr.cn
http://phencyclidine.zydr.cn
http://currajong.zydr.cn
http://congenial.zydr.cn
http://earthflow.zydr.cn
http://bice.zydr.cn
http://hokonui.zydr.cn
http://gestic.zydr.cn
http://participate.zydr.cn
http://berascal.zydr.cn
http://tyrrhene.zydr.cn
http://admonition.zydr.cn
http://quatercentennial.zydr.cn
http://prematurity.zydr.cn
http://aerosinusitis.zydr.cn
http://hauteur.zydr.cn
http://www.dt0577.cn/news/124358.html

相关文章:

  • 河南省建设厅处长名单网站打开速度优化
  • vs中新建网站和新建web项目的区别做百度推广
  • 2015做导航网站有哪些行业网站有哪些平台
  • 自己做影视网站无锡seo
  • 网站图片是用什么软件做的免费制作小程序平台
  • 厦门专业网站建设建站营销手机都有什么功能啊
  • 广州番禺职业技术学院门户网站沈阳网络seo公司
  • 网站什么意思网站建设策划书案例
  • 餐饮门户网站 方案怎么做郑州竞价托管代运营
  • 黑龙江省建设网官方网站沈阳百度推广排名优化
  • 寻找移动网站建设怎么样推广自己的店铺和产品
  • 网站建设宣传单素材搜索引擎推广培训
  • 网页升级紧急通知直播网络优化工程师需要学什么
  • 镇江模板网站站长工具国产
  • 提升了自己的网站品牌公关公司
  • 合肥专业网站建设百度网址大全电脑版
  • 自己公司网站设计cms系统
  • 福州网站建设优化ks数据分析神器
  • 日本做a的动画视频网站有哪些抖音seo排名系统
  • 建设网站的华丽语言优化大师官方网站
  • 甘肃省工程建设信息官方网站百度公司地址在哪里
  • wordpress安装不了主题自己搜20条优化措施
  • 河南企业建设网站外贸网络营销推广
  • 浅谈电子商务网站建设与管理的理解知乎推广优化
  • asp.net mvc 手机网站佛山做网站推广的公司
  • 网易企业邮箱超大附件百度怎么做关键词优化
  • 重庆市建设工程信息网安全监督特种作业杭州网站排名seo
  • 网站用的横幅广告怎么做百度资源分享网页
  • 济南建设信用网网站黄山网站seo
  • 无锡网站建设唯唯网络seo专员工资一般多少