下載本文檔
版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第JavaScript實(shí)現(xiàn)流星雨效果的示例代碼目錄演示技術(shù)棧源碼首先建立星星對(duì)象讓星星閃亮起來(lái)創(chuàng)建流星雨對(duì)象讓流星動(dòng)起來(lái)
演示
上一次做了一個(gè)雨滴的動(dòng)畫,順著這種思維正好可以改成流星雨,嘿嘿我真是一個(gè)小機(jī)靈。
技術(shù)棧
還是先建立畫布
body
canvasid="stars"/canvas
/body
畫布標(biāo)簽我昨天講過(guò)了。不知道的小伙伴可以去看看。
源碼
首先建立星星對(duì)象
//創(chuàng)建一個(gè)星星對(duì)象
varStar=function(){
this.x=windowWidth*Math.random();//橫坐標(biāo)
this.y=5000*Math.random();//縱坐標(biāo)
this.text=".";//文本
this.color="white";//顏色
//產(chǎn)生隨機(jī)顏色
this.getColor=function(){
var_r=Math.random();
if(_r0.5){
this.color="#333";
}else{
this.color="white";
//初始化
this.init=function(){
this.getColor();
//繪制
this.draw=function(){
context.fill>
讓星星閃亮起來(lái)
//頁(yè)面加載的時(shí)候
window.onload=function(){
init();
//畫星星
for(vari=0;istarCount;i++){
varstar=newStar();
star.init();
star.draw();
arr.push(star);
//畫流星
for(vari=0;irainCount;i++){
varrain=newMeteorRain();
rain.init();
rain.draw();
rains.push(rain);
drawMoon();//繪制月亮
playStars();//繪制閃動(dòng)的星星
playRains();//繪制流星
//星星閃起來(lái)
functionplayStars(){
for(varn=0;nstarCount;n++){
arr[n].getColor();
arr[n].draw();
setTimeout("playStars()",100);
}
創(chuàng)建流星雨對(duì)象
varMeteorRain=function(){
this.x=-1;
this.y=-1;
this.length=-1;//長(zhǎng)度
this.angle=30;//傾斜角度
this.width=-1;//寬度
this.height=-1;//高度
this.speed=1;//速度
this.offset_x=-1;//橫軸移動(dòng)偏移量
this.offset_y=-1;//縱軸移動(dòng)偏移量
this.alpha=1;//透明度
this.color1="";//流星的色彩
this.color2="";//流星的色彩
/****************初始化函數(shù)********************/
this.init=function()//初始化
this.getPos();
this.alpha=1;//透明度
this.getRandomColor();
//最小長(zhǎng)度,最大長(zhǎng)度
varx=Math.random()*80+150;
this.length=Math.ceil(x);
//x=Math.random()*10+30;
this.angle=30;//流星傾斜角
x=Math.random()+0.5;
this.speed=Math.ceil(x);//流星的速度
varcos=Math.cos(this.angle*3.14/180);
varsin=Math.sin(this.angle*3.14/180);
this.width=this.length*cos;//流星所占寬度
this.height=this.length*sin;//流星所占高度
this.offset_x=this.speed*cos;
this.offset_y=this.speed*sin;
/**************獲取隨機(jī)顏色函數(shù)*****************/
this.getRandomColor=function(){
vara=Math.ceil(255-240*Math.random());
//中段顏色
this.color1="rgba("+a+","+a+","+a+",1)";
//結(jié)束顏色
this.color2="black";
}
讓流星動(dòng)起來(lái)
this.draw=function()//繪制一個(gè)流星的函數(shù)
context.save();
context.beginPath();
context.lineWidth=1;//寬度
context.globalAlpha=this.alpha;//設(shè)置透明度
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2026山東煙臺(tái)萊陽(yáng)市事業(yè)單位招聘?jìng)淇伎荚囋囶}附答案解析
- 縣安全生產(chǎn)值班制度
- 生產(chǎn)裝配工藝管理制度
- 廣東豬肉生產(chǎn)紅線制度
- 安全生產(chǎn)迎檢工作制度
- 2026浙江省社會(huì)主義學(xué)院招聘專職教師3人參考考試題庫(kù)附答案解析
- 財(cái)務(wù)部安全生產(chǎn)制度
- 佛教安全生產(chǎn)制度
- 澆鑄生產(chǎn)管理制度范本
- 生產(chǎn)經(jīng)營(yíng)單位未制度
- 2026中國(guó)電信四川公用信息產(chǎn)業(yè)有限責(zé)任公司社會(huì)成熟人才招聘?jìng)淇碱}庫(kù)(含答案詳解)
- 2026年湖南師大附中雙語(yǔ)實(shí)驗(yàn)學(xué)校(南校區(qū))教師招聘?jìng)淇碱}庫(kù)完整參考答案詳解
- 2026年廣州市黃埔區(qū)穗東街招考編外服務(wù)人員易考易錯(cuò)模擬試題(共500題)試卷后附參考答案
- 2026湖南衡陽(yáng)耒陽(yáng)市公安局招聘75名警務(wù)輔助人員考試參考試題及答案解析
- 黑龍江高職單招語(yǔ)文試題附答案
- 高低壓配電安裝工程施工方案方案
- 2026年中國(guó)煙草專業(yè)知識(shí)考試題含答案
- 2026云南新華書店集團(tuán)限公司公開(kāi)招聘34人易考易錯(cuò)模擬試題(共500題)試卷后附參考答案
- 2026年人教版八年級(jí)語(yǔ)文上冊(cè)期末考試卷含答案
- 造紙業(yè)五年環(huán)保化:2025年竹漿環(huán)保再生紙行業(yè)報(bào)告
- GB/T 17587.2-2025滾珠絲杠副第2部分:公稱直徑、公稱導(dǎo)程、螺母尺寸和安裝螺栓公制系列
評(píng)論
0/150
提交評(píng)論