三月,和她一起看一次樱花吧(vue实现樱花漫天效果)

news/2024/12/2 18:59:45/

目录

      • 1 前言
      • 2 樱花雨实现
        • 2.1 环境
        • 2.2 效果
        • 2.3 源码与源图
        • 2.4 踩坑

1 前言

去年三月

她的长发在风中随樱花起舞

难以忘怀的不止是樱花
更是她的笑靥

此时此刻

恰如彼时彼刻;

希望各位能与命中注定的他或她,在樱花雨中来一场邂逅;

2 樱花雨实现

2.1 环境

  • 开发工具:vscode;

  • 开发框架:vue;

  • 语言:JavaScript+html

2.2 效果

效果如图所示:

在这里插入图片描述

2.3 源码与源图

代码如下所示:

sakura.vue:

<template><div id="page"><canvas ref="canvas_sakura" id="canvas_sakura" class="bg-sakura"></canvas></div>
</template>
<script>
import { Sakura, SakuraList } from "./sakura.js";export default {data() {return {sakuraNum: 100, //页面樱花数量 (添加)limitTimes: -1, //樱花坠落循环次数limitArray: []};},created() {this.initParams();},mounted() {// 初始化页面参数与对象this.initSakura();this.initSakuraList();// 页面开始坠落樱花this.startSakura();},methods: {// 初始化循环数组initParams() {for (let index = 0; index < this.sakuraNum; index++) {this.limitArray[index] = this.limitTimes;}},initSakura() {const img = new Image();img.src = require("./imgs/sakura.png"); //图片路径使用require才能获取// 绘制樱花const _this = this;Sakura.prototype.draw = function(cxt) {cxt.save();const xc = (40 * this.s) / 4;cxt.translate(this.x, this.y);cxt.rotate(this.r);cxt.drawImage(img, 0, 0, 100 * this.s, 100 * this.s); //context.drawImage(img,x,y,width,height);cxt.restore();};// 修改樱花位置,模拟飘落.Sakura.prototype.update = function() {this.x = this.fn.x(this.x, this.y);this.y = this.fn.y(this.y, this.y);this.r = this.fn.r(this.r);// 如果樱花越界, 重新调整位置if (this.x > window.innerWidth ||this.x < 0 ||this.y > window.innerHeight ||this.y < 0) {// 如果樱花不做限制if (_this.limitArray[this.idx] == -1) {this.r = _this.getRandom("fnr");if (Math.random() > 0.4) {this.x = _this.getRandom("x");this.y = 0;this.s = _this.getRandom("s");this.r = _this.getRandom("r");} else {this.x = window.innerWidth;this.y = _this.getRandom("y");this.s = _this.getRandom("s");this.r = _this.getRandom("r");}}// 否则樱花有限制else {if (_this.limitArray[this.idx] > 0) {this.r = _this.getRandom("fnr");if (Math.random() > 0.4) {this.x = _this.getRandom("x");this.y = 0;this.s = _this.getRandom("s");this.r = _this.getRandom("r");} else {this.x = window.innerWidth;this.y = _this.getRandom("y");this.s = _this.getRandom("s");this.r = _this.getRandom("r");}// 该越界的樱花限制数减一_this.limitArray[this.idx]--;}}}};},initSakuraList() {SakuraList.prototype.push = function(sakura) {this.list.push(sakura);};// list update 方法SakuraList.prototype.update = function() {for (let i = 0, len = this.list.length; i < len; i++) {this.list[i].update();}};// list draw 方法SakuraList.prototype.draw = function(cxt) {for (let i = 0, len = this.list.length; i < len; i++) {this.list[i].draw(cxt);}};SakuraList.prototype.get = function(i) {return this.list[i];};SakuraList.prototype.size = function() {return this.list.length;};},// 位置随机策略getRandom(option) {let ret, random;switch (option) {case "x":ret = Math.random() * window.innerWidth;break;case "y":ret = Math.random() * window.innerHeight;break;case "s":ret = Math.random();break;case "r":ret = Math.random() * 6;break;case "fnx":random = Math.random() - 0.3;ret = function(x, y) {return x + 0.5 * random - 1.7;};break;case "fny":random = 5 + Math.random() * 0.7;ret = function(x, y) {return y + random;};break;case "fnr":random = Math.random() * 0.03;ret = function(r) {return r + random;};break;}return ret;},// 樱花入口startSakura() {const requestAnimationFrame =window.requestAnimationFrame ||window.mozRequestAnimationFrame ||window.webkitRequestAnimationFrame ||window.msRequestAnimationFrame ||window.oRequestAnimationFrame;const canvas = this.$refs.canvas_sakura;canvas.height = window.innerHeight;canvas.width = window.innerWidth;const cxt = canvas.getContext("2d");const sakuraList = new SakuraList();// sakuraNum 樱花个数for (let i = 0; i < this.sakuraNum; i++) {const randomX = this.getRandom("x");const randomY = this.getRandom("y");const randomR = this.getRandom("r");const randomS = this.getRandom("s");const randomFnx = this.getRandom("fnx"); //x轴移动速度const randomFny = this.getRandom("fny"); //y轴移动速度const randomFnR = this.getRandom("fnr"); //转动速度const sakura = new Sakura(randomX,randomY,randomS,randomR,{x: randomFnx,y: randomFny,r: randomFnR},i);sakura.draw(cxt);sakuraList.push(sakura);}let stop = requestAnimationFrame(function f() {// console.log("111");cxt.clearRect(0, 0, canvas.width, canvas.height);// 修改樱花位置逻辑sakuraList.update();// 画出修改后的樱花sakuraList.draw(cxt);// 递归 修改位置, 画出修改后的樱花stop = requestAnimationFrame(f);});}}
};
</script>
<style scoped>
.bg-sakura {background-image: url("../../../assets/images/sakuraTree01.jpeg");background-size: 100%;
}
</style>

sakura.js:

// 定义樱花, idx 是修改添加的
export const Sakura = function(x, y, s, r, fn, idx) {this.x = x;this.y = y;this.s = s;this.r = r;this.fn = fn;this.idx = idx;
};export const SakuraList = function() {this.list = [];
};

代码中用到的源图:樱花漫天特效源图

2.4 踩坑

  1. vue中对象this作用域以及对this重命名;
  2. 画布大小需要进行动态设置;
  3. vue中使用图片对象时,需要使用require读取图片路径才可生效;

http://www.ppmy.cn/news/399779.html

相关文章

樱花树(2)

Hi~ o(*&#xffe3;▽&#xffe3;*)ブ大家好今天我又来分享代码啦&#xff01;还是老样子不喜勿喷mua 原码如下&#xff1a; from turtle import * from random import * from math import * def tree(n,l): pd()#下笔 #阴影效果 t cos(radians(heading()45)…

酷炫樱花飞舞

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <HTML><HEAD><TITLE>樱花飞舞</TITLE><META NAME"Generator" CONTENT"EditPlus"><META NAME"Author" CONTENT""&…

樱花樱花想见你:关于不一样的爱

樱花樱花想见你 歌曲起源 编辑 作者高野健一的创作灵感来源于 西加奈子写的小说《樱》 [2] &#xff0c;该小说讲诉了一条叫“樱”的小狗与其主人一家的感人故事。高野健一据此在歌词中构造一个失去女儿 [3] 的父亲的形象&#xff0c;并以此展开后续歌词创作。 本系列歌曲共有三…

P1833 樱花

文章目录 R e s u l t Result Result H y p e r l i n k Hyperlink Hyperlink D e s c r i p t i o n Description Description S o l u t i o n Solution Solution C o d e 1 Code1 Code1 C o d e 2 Code2 Code2 R e s u l t Result Result H y p e r l i n k Hyperlink Hyper…

樱花

美丽的樱花~ 求不定方程&#xff1a; 1 x 1 y 1 n ! \frac{1}{x}\frac{1}{y}\frac{1}{n!} x1​y1​n!1​ 的正整数解 (x,y) 的数目。 Input 一个整数 n。 Output 一个整数&#xff0c;表示有多少对 (x,y) 满足题意。答案对 1097 取模。 Example 样例输入 2 样例输出 3…

IE不兼容ES6箭头函数的解决方法

第一种&#xff1a; npm install babel-polyfill --save 页面中引用"polyfill.js" 和 "browser.min.js" JS代码script标签加上 type"text/babel" <script type"text/babel"></script> polyfill为什么可以&#xff1f; va…

樱花何处有?动态樱花飘落图

用言辞表达爱就如用一台有故障的发报机发送密码情报&#xff0c;总是不确定怎样才能被收到。——阿兰德波顿《爱情笔记》 掏心话&#xff1a;以前丢失的东西&#xff0c;到最后或许都得慢慢找回来。 前几天武大的云赏樱甚是好看&#xff0c;可惜本人没有亲自去看过 **花语&a…

漫天樱花表白小程序:“樱花将灿,冬尽风暖“一樱花和你我都想念~(内含多份源码)

&#x1f338;​樱花和你一一一一我都想念樱花&#x1f338; 导语 古人云“人间四月芳菲尽&#xff0c;山寺桃花始盛开”。 ​ 双十一剁手之后很快就要进入双十二剁脚节了吗&#xff1f; 不管是因为太冷才跺脚的还是因为......你知道的&#xff0c;我还不想变成人肉丸子啊啊…