电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

js模擬實(shí)現(xiàn)煙花特效

瀏覽:97日期:2024-05-19 17:39:32

本文實(shí)例為大家分享了js實(shí)現(xiàn)煙花特效的具體代碼,供大家參考,具體內(nèi)容如下

如下圖

js模擬實(shí)現(xiàn)煙花特效

首先描繪圓周運(yùn)動(dòng)

// d1/*css*/div{ height: 4px; width: 4px; background: red; position: absolute;}//jsvar div = document.getElementById(’div’); // 畫(huà)運(yùn)動(dòng)點(diǎn)document.getElementsByTagName(’body’)[0].appendChild(tdiv); // 添加節(jié)點(diǎn)var deg = 0; // 運(yùn)動(dòng)角度var r = 100; // 半徑var center = [300, 300] // 圓心var dd = Math.PI/180; // PI和角度之間的轉(zhuǎn)換setInterval(function(){ deg++; div.style.left = center[0] + Math.cos(deg * dd) * r + ’px’; div.style.top = center[1] + Math.sin(deg * dd) * r + ’px’;},16);

以上代碼運(yùn)行后可以看到一個(gè)圓周運(yùn)動(dòng)紅色方塊 完成上述步驟后,有什么用呢? 煙花的綻放,想象一下,可以當(dāng)成很多方塊從一個(gè)從圓心開(kāi)始向四周擴(kuò)算的一種運(yùn)動(dòng)方式。 一束煙花,有10個(gè)綻放點(diǎn),那就是每隔360 / 10 = 36度,就有一條運(yùn)動(dòng)軌跡。 這樣就好辦了

// d2var divs = []; // 保存煙花節(jié)點(diǎn)var len = 10; // 煙花節(jié)點(diǎn)個(gè)數(shù)var temp = 360 / len; // 運(yùn)動(dòng)軌跡所隔角度f(wàn)or(var i = 0; i < len; i++){ var tdiv = document.createElement(’div’); var tr1 = r; // 半徑 var deg = i * temp; // 當(dāng)前軌跡所在的角度值 var left = center[0] + Math.cos(deg * dd) * tr1 var topLen = center[1] + Math.sin(deg * dd) * tr1 tdiv.style.left = left +’px’; tdiv.style.top = topLen +’px’; tdiv.data = { // 存放節(jié)點(diǎn)的位置信息 deg : deg, r : tr1, left : left, top : topLen }; document.getElementsByTagName(’body’)[0].appendChild(tdiv); divs.push(tdiv);}

上述代碼運(yùn)行后可以看到

js模擬實(shí)現(xiàn)煙花特效

看起來(lái)是有點(diǎn)煙花的意思了,但是煙花的運(yùn)動(dòng)軌跡可沒(méi)這么工整,同一個(gè)地點(diǎn)出發(fā),同一個(gè)地點(diǎn)結(jié)束。 而這個(gè)結(jié)束點(diǎn)就是半徑的長(zhǎng)度值,所以只需將半徑進(jìn)行變化就可打亂。

// d3function getRanR(a,b){ // 隨機(jī)得到a-b的值 return Math.floor(Math.random()*(b-a+1)+a);}

將for循環(huán)里的 tr1 改為 getRanR(0,200); 就可看到下圖

js模擬實(shí)現(xiàn)煙花特效

看著很亂,完全沒(méi)點(diǎn)煙花的樣子。沒(méi)關(guān)系,讓它運(yùn)動(dòng)起來(lái)就可以看出來(lái)了。 為了讓這個(gè)動(dòng)起來(lái)就要讓上面 d2 的js代碼進(jìn)行修改。讓各個(gè)節(jié)點(diǎn)的起始位置為圓心。同時(shí)為了省點(diǎn)力,用css3進(jìn)行運(yùn)動(dòng)。

/*css*/div{ height: 4px; width: 4px; background: red; position: absolute; transition: 1s all; // 就添加這一句}// jstdiv.style.left = center[0] +’px’;tdiv.style.top = center[1] +’px’;

運(yùn)動(dòng)軌跡從 d2 可以看出來(lái)已經(jīng)全部存放到了節(jié)點(diǎn)里。用divs可以拿到各個(gè)節(jié)點(diǎn)。所以只需操作divs就可以了

document.onclick = function () { for(var i = 0; i < divs.length; i++){ divMove(divs[i]) }}function divMove(div){ var data = div.data; div.style.left = data.left + ’px’; div.style.top = data.top + ’px’;}

運(yùn)動(dòng)如下圖:

js模擬實(shí)現(xiàn)煙花特效

這樣就可以看到一個(gè)簡(jiǎn)易的煙花效果。就這么一個(gè)簡(jiǎn)易的煙花連續(xù)起來(lái)就可達(dá)到圖1的效果。 所以首先要對(duì)這個(gè)簡(jiǎn)易的煙花效果進(jìn)行封裝。 動(dòng)畫(huà)方面為了方便操作,所以引入jquery。 以下為html + css

<html><head> <meta charset='utf-8'> <style> *{ padding: 0; margin: 0; } div.boom-div{ height: 4px; width: 4px; background: orange; position: absolute; border-radius: 50%; } #container{ width: 100%; height: 100%; position: relative; } .input-container{ position: absolute; z-index: 1; } </style></head><body> <div class='input-container'> <input type='button' value='重繪'> <input type='button' value='清零'> <input type='button' value='保存'> </div> <div id='container'></div></body></html>

JS部分

var boom = { init: function (center, len, container, type) { this.len = len || 20; // 煙花節(jié)點(diǎn)個(gè)數(shù) this.maxR = 100; // 最大半徑 this.speed = 1500; // 速度 this.divs = []; // 存放煙花節(jié)點(diǎn) this.center = center; // 圓心 this.type = type; // 類(lèi)型 this.container = container; // 容器 this.paint(); }, getRanR: function (a, b) { // 得到隨機(jī)數(shù) return Math.floor(Math.random() * (b - a + 1 )+ a); }, // 畫(huà)出煙花節(jié)點(diǎn)所在點(diǎn),以及保存去往點(diǎn)信息 // 圓心, 半徑, 容器, 類(lèi)型 paint: function () { var that = this; var center = that.center.slice(), len = that.len, container = that.container, type = that.type, dd = Math.PI / 180, temp = 360 / len; for (var i= 0; i < len; i++) { var div = document.createElement(’div’); var deg = i * temp; // 當(dāng)前軌跡所在的角度值 var cc = []; // 節(jié)點(diǎn)的結(jié)束點(diǎn) var tr = that.getRanR(0, that.maxR); // 半徑 var left = 0; // 煙花節(jié)點(diǎn)所在的位置 var topLen = 0; // 煙花節(jié)點(diǎn)所在的位置 var xCenter = center[0], yCenter = center[1]; if (type) { // 當(dāng)類(lèi)型為真時(shí),整個(gè)煙花效果就是向外擴(kuò)張 left = xCenter; // 為假時(shí)則是向內(nèi)收縮,本質(zhì)一樣都是拿到開(kāi)始點(diǎn)和結(jié)束點(diǎn) topLen = yCenter; // 只是將開(kāi)始和結(jié)束換了個(gè)位置 cc = [xCenter + Math.cos(deg * dd) * tr, yCenter + Math.sin(deg * dd) * tr]; } else { left = xCenter + Math.cos(deg * dd) * tr; topLen = yCenter + Math.sin(deg * dd) * tr; cc = [xCenter, yCenter]; } div.className = ’boom-div’; div.style.left = left + ’px’; div.style.top = topLen + ’px’; div.data = { left: cc[0], // 節(jié)點(diǎn)的結(jié)束點(diǎn) top: cc[1], // 節(jié)點(diǎn)的結(jié)束點(diǎn) } that.divs.push(div); container.appendChild(div); } // 使節(jié)點(diǎn)運(yùn)動(dòng)起來(lái) that.move(); }, // 運(yùn)動(dòng) move: function () { var that = this; var len = that.len, container = that.container, divLen = that.divs.length; for (var i = 0; i < divLen; i++) { var div = that.divs[i]; $(div).animate({ left: div.data.left, top: div.data.top, opacity: 0, }, that.speed, 'linear', function() { // 運(yùn)動(dòng)完結(jié)后刪除節(jié)點(diǎn) this.parentNode.removeChild(this); }); } }}

控制特效

var container = $(’#container’)[0];var arr = []; // 存放鼠標(biāo)點(diǎn)擊位置var iCount = -1;$(container).on(’mousedown’, function(e) { iCount++; e = e || window.event; boom.init([e.clientX, e.clientY], 20,container, 1) arr[iCount] = []; // 每點(diǎn)擊一次,增加一個(gè)二位數(shù)組 $(container).on(’mousemove’, function(e) { e = e || window.event; boom.init([e.clientX, e.clientY], 20, container, 1) arr[iCount].push([e.clientX, e.clientY]) // 鼠標(biāo)每移動(dòng)一次,添加鼠標(biāo)位置 }) $(container).on(’mouseup’, function() { $(container).off(’mousemove’) })});// 重繪$(’#repaint’).click(function() { // console.log(arr) if( !arr.length ){ return; } var tempArr= []; // 將所有點(diǎn)取出來(lái),轉(zhuǎn)換為二維數(shù)組 for(var i = 0; i < arr.length; i++){ for(var j = 0; j< arr[i].length; j++){ tempArr.push(arr[i][j]) } } var count = 0; var timmer = setInterval(function(){ if( ++ count >= tempArr.length){ clearInterval(timmer) } boom.init(tempArr[count],20,container,1) },16)});$(’#zero’).click(function(){ iCount=-1; arr=[]});

煙花節(jié)點(diǎn)可以用背景圖代替,比如用小愛(ài)心或者五角星啥的,只是大小得適當(dāng)調(diào)整。

更多JavaScript精彩特效分享給大家:

Javascript菜單特效大全

javascript仿QQ特效匯總

JavaScript時(shí)鐘特效匯總

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 传动滚筒,改向滚筒-淄博建凯机械科技有限公司 | 北京律师事务所_房屋拆迁律师_24小时免费法律咨询_云合专业律师网 | 高压包-点火器-高压发生器-点火变压器-江苏天网 | 芝麻黑-芝麻黑石材厂家-永峰石业 | 台湾阳明固态继电器-奥托尼克斯光电传感器-接近开关-温控器-光纤传感器-编码器一级代理商江苏用之宜电气 | 济南画室培训-美术高考培训-山东艺霖艺术培训画室 | 振动筛-交叉筛-螺旋筛-滚轴筛-正弦筛-方形摇摆筛「新乡振动筛厂家」 | 耐驰泵阀管件制造-耐驰泵阀科技(天津)有限公司 | 盐城网络公司_盐城网站优化_盐城网站建设_盐城市启晨网络科技有限公司 | 浙江自考_浙江自学考试网 | 污水处理设备维修_污水处理工程改造_机械格栅_过滤设备_气浮设备_刮吸泥机_污泥浓缩罐_污水处理设备_污水处理工程-北京龙泉新禹科技有限公司 | 上海电子秤厂家,电子秤厂家价格,上海吊秤厂家,吊秤供应价格-上海佳宜电子科技有限公司 | TTCMS自助建站_网站建设_自助建站_免费网站_免费建站_天天向上旗下品牌 | 玻纤土工格栅_钢塑格栅_PP焊接_单双向塑料土工格栅_复合防裂布厂家_山东大庚工程材料科技有限公司 | 考勤系统_人事考勤管理系统_本地部署BS考勤系统_考勤软件_天时考勤管理专家 | 液压油缸-液压站生产厂家-洛阳泰诺液压科技有限公司 | 外贸资讯网 - 洞悉全球贸易,把握市场先机 | 拖鞋定制厂家-品牌拖鞋代加工厂-振扬实业中国高端拖鞋大型制造商 | 烟雾净化器-滤筒除尘器-防爆除尘器-除尘器厂家-东莞执信环保科技有限公司 | 气体热式流量计-定量控制流量计(空气流量计厂家)-湖北南控仪表科技有限公司 | 武汉EPS线条_EPS装饰线条_EPS构件_湖北博欧EPS线条厂家 | 喷播机厂家_二手喷播机租赁_水泥浆洒布机-河南青山绿水机电设备有限公司 | 艺术涂料_进口艺术涂料_艺术涂料加盟_艺术涂料十大品牌 -英国蒙太奇艺术涂料 | 无线遥控更衣吊篮_IC卡更衣吊篮_电动更衣吊篮配件_煤矿更衣吊篮-力得电子 | 澳洁干洗店加盟-洗衣店干洗连锁「澳洁干洗免费一对一贴心服务」 干洗加盟网-洗衣店品牌排行-干洗设备价格-干洗连锁加盟指南 | 安徽千住锡膏_安徽阿尔法锡膏锡条_安徽唯特偶锡膏_卡夫特胶水-芜湖荣亮电子科技有限公司 | 上海橡胶接头_弹簧减震器_金属软接头厂家-上海淞江集团 | 精密五金冲压件_深圳五金冲压厂_钣金加工厂_五金模具加工-诚瑞丰科技股份有限公司 | 退火炉,燃气退火炉,燃气热处理炉生产厂家-丹阳市丰泰工业炉有限公司 | 挤塑板-XPS挤塑板-挤塑板设备厂家[襄阳欧格] | 技德应用| 锂电混合机-新能源混合机-正极材料混料机-高镍,三元材料混料机-负极,包覆混合机-贝尔专业混合混料搅拌机械系统设备厂家 | 澳洁干洗店加盟-洗衣店干洗连锁「澳洁干洗免费一对一贴心服务」 干洗加盟网-洗衣店品牌排行-干洗设备价格-干洗连锁加盟指南 | 手术室净化厂家_成都实验室装修公司_无尘车间施工单位_洁净室工程建设团队-四川华锐16年行业经验 | 搜活动房网—活动房_集装箱活动房_集成房屋_活动房屋 | 山东风淋室_201/304不锈钢风淋室净化设备厂家-盛之源风淋室厂家 翻斗式矿车|固定式矿车|曲轨侧卸式矿车|梭式矿车|矿车配件-山东卓力矿车生产厂家 | 酒精检测棒,数显温湿度计,酒安酒精测试仪,酒精检测仪,呼气式酒精检测仪-郑州欧诺仪器有限公司 | 鑫达滑石-辽宁鑫达滑石集团| 橡胶弹簧|复合弹簧|橡胶球|振动筛配件-新乡市永鑫橡胶厂 | 档案密集架,移动密集架,手摇式密集架,吉林档案密集架-厂家直销★价格公道★质量保证 | 液晶拼接屏厂家_拼接屏品牌_拼接屏价格_监控大屏—北京维康 |