分享一個插件實現(xiàn)水珠自動下落效果
分享一個水珠自動下落的插件,下載地址:https://github.com/foreverjiangting/rainyday.js
下面來看看如何使用它?添加下面代碼即可運行它。
實現(xiàn)效果如下:

代碼如下:
<!DOCTYPE HTML>
<html>
<head>
<style>
</style>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title></title>
<script type="text/javascript">
function runImage()
{
var image=document.getElementById("img");
image.src="4.jpg";
image.onload=function()
{
//設定一個rain對象
var engine=new RainyDay({image:this,}); //調用rain函數(shù)
engine.rain([[4,6,8000]]);//設定雨滴大小4,6 數(shù)量為8000 ||也可為 engine.rain([[6,8000]]),此時水珠的大小較小
engine.rain([[3,3,0.88],[5,5,0.9],[6,2,1]],100);//設定雨滴重復時間
}
// image.crossOrigin="jt"; 加載跨域圖片
}
</script>
</head>
<body onload="runImage();" >
<div class="rain">
<img src="4.jpg" id="img" alt="點擊圖片">
</div>
<script type="text/javascript" src="rainy.js"></script>
</body>
</html>
下面來研究下rainy.js部分代碼,源代碼見上面的github里面的:
RainyDay.prototype.rain = function(presets, speed) {
// 準備canvas 進行下落映射
if (this.reflection !== this.REFLECTION_NONE) {
this.prepareReflections();
}
this.animateDrops();
// 動畫
this.presets = presets;
this.PRIVATE_GRAVITY_FORCE_FACTOR_Y = (this.options.fps * 0.001) / 25;
this.PRIVATE_GRAVITY_FORCE_FACTOR_X = ((Math.PI / 2) - this.options.gravityAngle) * (this.options.fps * 0.001) / 50;
// 準備下落的模型
if (this.options.enableCollisions) {
// 計算最大的下落水珠圓角
var maxDropRadius = 0;
for (var i = 0; i < presets.length; i++) {
if (presets[i][0] + presets[i][1] > maxDropRadius) {
maxDropRadius = Math.floor(presets[i][0] + presets[i][1]);
}
}
if (maxDropRadius > 0) {
// 初始化下落的模型
var mwi = Math.ceil(this.canvas.width / maxDropRadius);
var mhi = Math.ceil(this.canvas.height / maxDropRadius);
this.matrix = new CollisionMatrix(mwi, mhi, maxDropRadius);
} else {
this.options.enableCollisions = false;
}
}
for (var i = 0; i < presets.length; i++) {
if (!presets[i][3]) {
presets[i][3] = -1;
}
}
var lastExecutionTime = 0;
this.addDropCallback = function() {
var timestamp = new Date().getTime();
if (timestamp - lastExecutionTime < speed) {
return;
}
lastExecutionTime = timestamp;
var context = this.canvas.getContext('2d');
context.clearRect(0, 0, this.canvas.width, this.canvas.height);
context.drawImage(this.background, 0, 0, this.canvas.width, this.canvas.height);
// 選擇匹配的模型
var preset;
for (var i = 0; i < presets.length; i++) {
if (presets[i][2] > 1 || presets[i][3] === -1) {
if (presets[i][3] !== 0) {
presets[i][3]--;
for (var y = 0; y < presets[i][2]; ++y) {
this.putDrop(new Drop(this, Math.random() * this.canvas.width, Math.random() * this.canvas.height, presets[i][0], presets[i][1]));
}
}
} else if (Math.random() < presets[i][2]) {
preset = presets[i];
break;
}
}
if (preset) {
this.putDrop(new Drop(this, Math.random() * this.canvas.width, Math.random() * this.canvas.height, preset[0], preset[1]));
}
context.save();
context.globalAlpha = this.opacity;
context.drawImage(this.glass, 0, 0, this.canvas.width, this.canvas.height);
context.restore();
}
.bind(this);
};
這里我想提到關于跨域資源的問題,image.crossOrigin="jt"; 加載跨域圖片。剛開始我用的是跨域的圖片,但出現(xiàn)問題了,然后我就使用本地的圖片加載,即 src="4.jpg" ,就沒問題了。其實如果你要使用跨域的圖片,只要加上image.crossOrigin="jt"; 這句代碼就可以了。
(前提是服務器開了允許的權限)
這里涉及到CORS的問題,我們來看下: CORS全稱是"跨域資源共享"(Cross-origin resource sharing)。它允許瀏覽器向跨源服務器
發(fā)出xmlhttprequest請求從而克服了AJAX只能同源使用的限制。
我們還用上面的列子來看問題:
<!DOCTYPE HTML>
<html>
<head>
<style>
</style>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title></title>
<script type="text/javascript">
function runImage()
{
var image=document.getElementById("img");
image.onload=function()
{
//設定一個rain對象
var engine=new RainyDay({image:this,});
engine.rain([[4,6,8000]]);//設定雨滴大小4,6 數(shù)量為8000
engine.rain([[3,3,0.88],[5,5,0.9],[6,2,1]],100);//設定雨滴重復時間
}
// image.crossOrigin="jt"; //跨域圖片
image.src="http://img0.imgtn.bdimg.com/it/u=938096994,3074232342&fm=21&gp=0.jpg";
}
</script>
</head>
<body onload="runImage();" >
<div class="rain">
<img src="http://img0.imgtn.bdimg.com/it/u=938096994,3074232342&fm=21&gp=0.jpg" id="img" alt="點擊圖片">
</div>
<script type="text/javascript" src="rainy.js"></script>
</body>
</html>
我們來看下調試控制臺里面的信息:
Accept image/png,image/*;q=0.8,*/*;q=0.5 Accept-Encoding gzip, deflate Accept-Language zh-CN,zh;q=0.8,en-US;q=0.5,en;q=0.3 Connection keep-alive Host img0.imgtn.bdimg.com Origin null ---上面的頭信息中,Origin字段用來說明,本次請求來自哪個源(協(xié)議 + 域名 + 端口)。服務器根據(jù)這個值決定是否同意這次請求.不在許可范圍內。服務器會返回一個正常的HTTP回應。瀏覽器發(fā)現(xiàn),這個回應的頭信息沒有包含Access-Control-Allow-Origin字段(詳見下文),就知道出錯了,從而拋出一個錯誤,被XMLHttpRequest的onerror回調函數(shù)捕獲。注意,這種錯誤無法通過狀態(tài)碼識別,因為HTTP回應的狀態(tài)碼有可能是200。 GET /cors HTTP/1.1 Origin: http://api.bob.com Host: api.alice.com Accept-Language: en-US Connection: keep-alive User-Agent: Mozilla/5.0. User-Agent Mozilla/5.0 (Windows NT 6.1; rv:46.0) Gecko/20100101 Firefox/46.0
如果Origin指定的域名在許可范圍內,服務器返回的響應,會多出幾個頭信息字段。
以上內容是小編給大家分享的一個插件實現(xiàn)水珠自動下落效果 ,希望大家喜歡!
相關文章
js拆分字符串并將分割的數(shù)據(jù)放到數(shù)組中的方法
這篇文章主要介紹了js拆分字符串并將分割的數(shù)據(jù)放到數(shù)組中的方法,涉及javascript中split方法及數(shù)組的操作技巧,需要的朋友可以參考下2015-05-05
js實現(xiàn)文件上傳功能 后臺使用MultipartFile
這篇文章主要為大家詳細介紹了純js實現(xiàn)最簡單的文件上傳功能,后臺使用MultipartFile,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-09-09
一份老外寫的XMLHttpRequest代碼多瀏覽器支持兼容性
一份老外寫的XMLHttpRequest代碼多瀏覽器支持兼容性...2007-01-01
微信小程序中如何實現(xiàn)動態(tài)改變SVG顏色和尺寸
SVG可被非常多的工具讀取和修改SVG與JPEG和GIF圖像比起來,尺寸更小,且可壓縮性更強,下面這篇文章主要給大家介紹了關于微信小程序中如何實現(xiàn)動態(tài)改變SVG顏色和尺寸的相關資料,需要的朋友可以參考下2022-07-07
一個Js文件函數(shù)中調用另一個Js文件函數(shù)的方法演示
這篇文章主要介紹了一個Js文件函數(shù)中調用另一個Js文件函數(shù)的方法,兩個javascript文件中相互調用函數(shù),主要是將引入的Js文件代碼放在</body>下面。具體操作方法可查看下文,需要的朋友可以參考下2017-08-08
使用javascript實現(xiàn)Iframe自適應高度
這篇文章主要介紹了使用javascript實現(xiàn)Iframe自適應高度,需要的朋友可以參考下2014-12-12
JavaScript不使用prototype和new實現(xiàn)繼承機制
這篇文章主要介紹了JavaScript不使用prototype和new實現(xiàn)繼承機制的相關資料,需要的朋友可以參考下2014-12-12

