分享一個水珠自動下落的插件,下載地址:https://github.com/foreverjiangting/rainyday.js
下面來看看如何使用它?添加下面代碼即可運行它。
實現效果如下:
代碼如下:
<!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函數engine.rain([[4,6,8000]]);//設定雨滴大小4,6 數量為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><img src="4.jpg" id="img"></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"; 加載跨域圖片。剛開始我用的是跨域的圖片,但出現問題了,然後我就使用本地的圖片加載,即src="4.jpg" ,就沒問題了。其實如果你要使用跨域的圖片,只要加上image.crossOrigin="jt"; 這句代碼就可以了。
(前提是服務器開了允許的權限)
這裡涉及到CORS的問題,我們來看下: CORS全稱是"跨域資源共享"(Cross-origin resource sharing)。它允許瀏覽器向跨源服務器
發出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 數量為8000engine.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><img src="http://img0.imgtn.bdimg.com/it/u=938096994,3074232342&fm=21&gp=0.jpg" id="img"></div><script type="text/javascript" src="rainy.js"></script></body></html>我們來看下調試控制台裡面的信息:
Accept image/png,image/*;q=0.8,*/*;q=0.5Accept-Encoding gzip, deflateAccept-Language zh-CN,zh;q=0.8,en-US;q=0.5,en;q=0.3Connection keep-aliveHost img0.imgtn.bdimg.comOrigin null ---上面的頭信息中,Origin字段用來說明,本次請求來自哪個源(協議+ 域名+ 端口)。服務器根據這個值決定是否同意這次請求.不在許可範圍內。服務器會返回一個正常的HTTP回應。瀏覽器發現,這個回應的頭信息沒有包含Access-Control-Allow-Origin字段(詳見下文),就知道出錯了,從而拋出一個錯誤,被XMLHttpRequest的onerror回調函數捕獲。注意,這種錯誤無法通過狀態碼識別,因為HTTP回應的狀態碼有可能是200。 GET /cors HTTP/1.1Origin: http://api.bob.comHost: api.alice.comAccept-Language: en-USConnection: keep-aliveUser-Agent: Mozilla/5.0. User-Agent Mozilla/5.0 (Windows NT 6.1; rv:46.0) Gecko/20100101 Firefox/46.0
如果Origin指定的域名在許可範圍內,服務器返回的響應,會多出幾個頭信息字段。
以上內容是小編給大家分享的一個插件實現水珠自動下落效果,希望大家喜歡!