亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

分享一個(gè)插件實(shí)現(xiàn)水珠自動(dòng)下落效果

 更新時(shí)間:2016年06月01日 15:16:30   作者:姜婷  
本篇文章給大家分享一個(gè)插件制作水珠自動(dòng)下落效果,效果非常逼真,感興趣的朋友可以添加下面代碼運(yùn)行看看效果哦

分享一個(gè)水珠自動(dòng)下落的插件,下載地址:https://github.com/foreverjiangting/rainyday.js

下面來看看如何使用它?添加下面代碼即可運(yùn)行它。

實(shí)現(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()
{
//設(shè)定一個(gè)rain對(duì)象
var engine=new RainyDay({image:this,}); //調(diào)用rain函數(shù)
engine.rain([[4,6,8000]]);//設(shè)定雨滴大小4,6 數(shù)量為8000 ||也可為 engine.rain([[6,8000]]),此時(shí)水珠的大小較小
engine.rain([[3,3,0.88],[5,5,0.9],[6,2,1]],100);//設(shè)定雨滴重復(fù)時(shí)間
}
// image.crossOrigin="jt"; 加載跨域圖片 
}
</script>
</head>
<body onload="runImage();" >
<div class="rain">
<img src="4.jpg" id="img" alt="點(diǎn)擊圖片">
</div>
<script type="text/javascript" src="rainy.js"></script> 
</body>
</html> 

下面來研究下rainy.js部分代碼,源代碼見上面的github里面的:

RainyDay.prototype.rain = function(presets, speed) {
// 準(zhǔn)備canvas 進(jìn)行下落映射
if (this.reflection !== this.REFLECTION_NONE) {
this.prepareReflections();
}
this.animateDrops();
// 動(dòng)畫
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;
// 準(zhǔn)備下落的模型
if (this.options.enableCollisions) {
// 計(jì)算最大的下落水珠圓角
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);
}; 

這里我想提到關(guān)于跨域資源的問題,image.crossOrigin="jt"; 加載跨域圖片。剛開始我用的是跨域的圖片,但出現(xiàn)問題了,然后我就使用本地的圖片加載,即 src="4.jpg" ,就沒問題了。其實(shí)如果你要使用跨域的圖片,只要加上image.crossOrigin="jt"; 這句代碼就可以了。

(前提是服務(wù)器開了允許的權(quán)限)

這里涉及到CORS的問題,我們來看下: CORS全稱是"跨域資源共享"(Cross-origin resource sharing)。它允許瀏覽器向跨源服務(wù)器

發(fā)出xmlhttprequest請(qǐng)求從而克服了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()
{
//設(shè)定一個(gè)rain對(duì)象
var engine=new RainyDay({image:this,});
engine.rain([[4,6,8000]]);//設(shè)定雨滴大小4,6 數(shù)量為8000
engine.rain([[3,3,0.88],[5,5,0.9],[6,2,1]],100);//設(shè)定雨滴重復(fù)時(shí)間
}
// 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="點(diǎn)擊圖片">
</div>
<script type="text/javascript" src="rainy.js"></script>
</body>
</html> 

我們來看下調(diào)試控制臺(tái)里面的信息:

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字段用來說明,本次請(qǐng)求來自哪個(gè)源(協(xié)議 + 域名 + 端口)。服務(wù)器根據(jù)這個(gè)值決定是否同意這次請(qǐng)求.不在許可范圍內(nèi)。服務(wù)器會(huì)返回一個(gè)正常的HTTP回應(yīng)。瀏覽器發(fā)現(xiàn),這個(gè)回應(yīng)的頭信息沒有包含Access-Control-Allow-Origin字段(詳見下文),就知道出錯(cuò)了,從而拋出一個(gè)錯(cuò)誤,被XMLHttpRequest的onerror回調(diào)函數(shù)捕獲。注意,這種錯(cuò)誤無法通過狀態(tài)碼識(shí)別,因?yàn)镠TTP回應(yīng)的狀態(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指定的域名在許可范圍內(nèi),服務(wù)器返回的響應(yīng),會(huì)多出幾個(gè)頭信息字段。

以上內(nèi)容是小編給大家分享的一個(gè)插件實(shí)現(xiàn)水珠自動(dòng)下落效果 ,希望大家喜歡!

相關(guān)文章

  • 如何將php數(shù)組或者對(duì)象傳遞給javascript

    如何將php數(shù)組或者對(duì)象傳遞給javascript

    這篇文章主要介紹了將php數(shù)組或者對(duì)象傳遞給javascript的方法,需要的朋友可以參考下
    2014-03-03
  • 腳本分析、壓縮、混淆工具 JSA新版本發(fā)布,壓縮效率提高大約10%

    腳本分析、壓縮、混淆工具 JSA新版本發(fā)布,壓縮效率提高大約10%

    腳本分析、壓縮、混淆工具 JSA新版本發(fā)布,壓縮效率提高大約10%...
    2007-05-05
  • JS+HTML5 canvas繪制驗(yàn)證碼示例

    JS+HTML5 canvas繪制驗(yàn)證碼示例

    這篇文章主要介紹了JS+HTML5 canvas繪制驗(yàn)證碼,結(jié)合實(shí)例形式分析了HTML5 canvas圖形繪制相關(guān)操作技巧,需要的朋友可以參考下
    2018-12-12
  • 微信小程序基于ColorUI構(gòu)建皮皮蝦短視頻去水印組件

    微信小程序基于ColorUI構(gòu)建皮皮蝦短視頻去水印組件

    這篇文章主要介紹了微信小程序-基于ColorUI構(gòu)建皮皮蝦短視頻去水印組件,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2020-11-11
  • JS實(shí)現(xiàn)網(wǎng)站吸頂條

    JS實(shí)現(xiàn)網(wǎng)站吸頂條

    這篇文章主要為大家詳細(xì)介紹了JS制作網(wǎng)站吸頂條,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-01-01
  • JS幻想 讀取二進(jìn)制文件

    JS幻想 讀取二進(jìn)制文件

    如果說讓JavaScript讀取站點(diǎn)上一文本文件,那不過是個(gè)再簡(jiǎn)單不了的事了;但若說要換成一個(gè)二進(jìn)制的文件,并且是完全靜態(tài)的讀取,那似乎有點(diǎn)天方夜譚了。
    2009-04-04
  • V8實(shí)現(xiàn)字符串拼接

    V8實(shí)現(xiàn)字符串拼接

    本文主要介紹了V8實(shí)現(xiàn)字符串拼接,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • 搭建Bootstrap離線文檔的方法

    搭建Bootstrap離線文檔的方法

    雖然現(xiàn)在不聯(lián)網(wǎng)的情況很少,但在本機(jī)上搭建一份Bootstrap離線文檔以備不時(shí)之需也是很有必要的。下面就給大家分享下搭建Bootstrap離線文檔的方法,感興趣的朋友一起看看吧
    2016-12-12
  • 完美實(shí)現(xiàn)js焦點(diǎn)輪播效果(二)(圖片可滾動(dòng))

    完美實(shí)現(xiàn)js焦點(diǎn)輪播效果(二)(圖片可滾動(dòng))

    這篇文章主要為大家詳細(xì)介紹了完美實(shí)現(xiàn)js焦點(diǎn)輪播效果的相關(guān)代碼,采用輔助圖片實(shí)現(xiàn)圖片無限滾動(dòng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • JS不同運(yùn)算符下隱式類型轉(zhuǎn)換的實(shí)現(xiàn)示例

    JS不同運(yùn)算符下隱式類型轉(zhuǎn)換的實(shí)現(xiàn)示例

    隱式轉(zhuǎn)換就是自動(dòng)轉(zhuǎn)換,通常發(fā)生在一些數(shù)學(xué)運(yùn)算中,本文就來介紹一下JS不同運(yùn)算符下隱式類型轉(zhuǎn)換的實(shí)現(xiàn)示例,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-12-12

最新評(píng)論