亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > JavaScript > 正文

javascript轉換靜態圖片,增加粒子動畫效果

2024-05-06 16:20:57
字體:
來源:轉載
供稿:網友

這篇文章主要介紹了javascript轉換靜態圖片,增加粒子動畫效果,非常的炫酷,需要的朋友可以參考下

使用getImageData接口獲取圖片的像素點,然后基于像素點實現動畫效果,封裝成一個簡單的lib

 

 
  1. <!DOCTYPE html> 
  2. <html> 
  3. <head> 
  4. <title>particle image</title> 
  5. <meta charset="utf-8" /> 
  6. <style> 
  7. #logo { 
  8. margin-left:20px; 
  9. margin-top:20px; 
  10. width:160px; 
  11. height:48px; 
  12. background:url('./images/logo.png'); 
  13. /*border: 1px solid red;*/ 
  14. </style> 
  15. <script type="text/javascript" src="ParticleImage.js"></script> 
  16. <script> 
  17. window.onload = function() { 
  18. ParticleImage.create("logo", "./images/logo.png", "fast"); 
  19. }; 
  20. </script> 
  21. </head> 
  22. <body> 
  23. <div id="logo"></div> 
  24. </body> 
  25. </html> 

ParticleImage.js

 

 
  1. /* 
  2. The MIT License (MIT) 
  3.  
  4. Copyright (c) 2015 arest 
  5.  
  6. Permission is hereby granted, free of charge, to any person obtaining a copy of 
  7. this software and associated documentation files (the "Software"), to deal in 
  8. the Software without restriction, including without limitation the rights to 
  9. use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of 
  10. the Software, and to permit persons to whom the Software is furnished to do so, 
  11. subject to the following conditions: 
  12.  
  13. The above copyright notice and this permission notice shall be included in all 
  14. copies or substantial portions of the Software. 
  15.  
  16. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 
  17. IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS 
  18. FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR 
  19. COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER 
  20. IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN 
  21. CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 
  22. */ 
  23.  
  24. /** 
  25. * Add particle animation for image 
  26. * usage: 
  27. <script type="text/javascript" src="ParticleImage.js"></script> 
  28. <script> 
  29. window.onload = function() { 
  30. // be sure to use image file in your own server (prevent CORS issue) 
  31. ParticleImage.create("logo", "logo_s2.png", "fast"); 
  32. }; 
  33. </script> 
  34. // in html file 
  35. <div id="logo"></div> 
  36. // you can set default background image as usual 
  37. #logo { 
  38. margin-left:20px; 
  39. margin-top:20px; 
  40. width:160px; 
  41. height:48px; 
  42. background:url('logo_s2.png'); 
  43. } 
  44. * 
  45. * @author tianx.qin (rushi_wowen@163.com) 
  46. * @file ParticleImage.js 
  47. * @version 0.9 
  48. */ 
  49. var ParticleImage = (function(window) { 
  50. var container = null, canvas = null
  51. var ctx = null, _spirit = [], timer = null
  52. cw = 0, ch = 0, // container width/height 
  53. iw = 0, ih = 0, // image width/height 
  54. mx = 0, my = 0, // mouse position 
  55. bMove = true
  56. MOVE_SPAN = 4, DEFAULT_ALPHA = 100, 
  57. speed = 100, S = {"fast":10, "mid":100, "low":300}, 
  58. ALPHA = 255 * 255; 
  59.  
  60. // spirit class 
  61. var Spirit = function(data) { 
  62. this.orginal = { 
  63. pos: data.pos, 
  64. x : data.x, y : data.y, 
  65. r : data.r, g : data.g, b : data.b, a : data.a 
  66. }; 
  67. // change state, for animation 
  68. this.current = { 
  69. x : data.x, 
  70. y : data.y, 
  71. a : data.a 
  72. }; 
  73. }; 
  74.  
  75. /** 
  76. * move spirit to original position 
  77. */ 
  78. Spirit.prototype.move = function() { 
  79. var cur = this.current, orig = this.orginal; 
  80. if ((cur.x === orig.x) && (cur.y === orig.y)) { 
  81. //console.log("don't move:" + cur.y); 
  82. return false
  83. //console.log("move:" + cur.y); 
  84. var rand = 1 + Math.round(MOVE_SPAN * Math.random()); 
  85. var offsetX = cur.x - orig.x, 
  86. offsetY = cur.y - orig.y; 
  87. var rad = offsetX == 0 ? 0 : offsetY / offsetX; 
  88. var xSpan = cur.x < orig.x ? rand : cur.x > orig.x ? -rand : 0; 
  89. cur.x += xSpan; 
  90. var tempY = xSpan == 0 ? Math.abs(rand) : Math.abs(Math.round(rad * xSpan)); 
  91. var ySpan = offsetY < 0 ? tempY : offsetY > 0 ? -tempY : 0; 
  92. cur.y += ySpan; 
  93. cur.a = ((cur.x === orig.x) && (cur.y === orig.y)) ? orig.a : DEFAULT_ALPHA; 
  94. return true
  95. }; 
  96.  
  97. /** 
  98. * set random position 
  99. */ 
  100. Spirit.prototype.random = function(width, height) { 
  101. var cur = this.current; 
  102. cur.x = width + Math.round(width * 2 * Math.random()); 
  103. this.current.y = height + Math.round(height * 2 * Math.random()); 
  104. }; 
  105.  
  106. /** 
  107. * set random positions for all spirits 
  108. */ 
  109. var _disorder = function() { 
  110. var len = _spirit.length; 
  111. for (var i = 0; i < len; i++) { 
  112. _spirit[i].random(cw, ch); 
  113. }; 
  114.  
  115. /** 
  116. * start to move spirit 
  117. */ 
  118. var _move = function() { 
  119. var sprt = _spirit; 
  120. var len = sprt.length; 
  121. var isMove = false// whether need to move 
  122. for (var i = 0; i < len; i++) { 
  123. if (sprt[i].move()) { 
  124. isMove = true
  125. isMove ? _redraw() : _stopTimer(); 
  126. }; 
  127.  
  128. /** 
  129. * redraw all spirits while animating 
  130. */ 
  131. var _redraw = function() { 
  132. var imgDataObj = ctx.createImageData(iw, ih); 
  133. var imgData = imgDataObj.data; 
  134. var sprt = _spirit; 
  135. var len = sprt.length; 
  136. //console.log("redraw image : " + len); 
  137. for (var i = 0; i < len; i++) { 
  138. var temp = sprt[i]; 
  139. //console.log("item : " + JSON.stringify(temp)); 
  140. var orig = temp.orginal; 
  141. var cur = temp.current; 
  142. var pos = (cur.y * iw + cur.x) * 4; 
  143. imgData[pos] = orig.r; 
  144. imgData[pos + 1] = orig.g; 
  145. imgData[pos + 2] = orig.b; 
  146. imgData[pos + 3] = cur.a; 
  147. ctx.putImageData(imgDataObj, 0, 0); 
  148. }; 
  149.  
  150. /** 
  151. * add mousemove/mouseclick event 
  152. */ 
  153. var _addMouseEvent = function(c) { 
  154. c.addEventListener("mouseenter"function(e) { 
  155. //console.log("e.y:" + e.clientY + ", " + container.offsetTop); 
  156. _startTimer(); 
  157. }); 
  158. c.addEventListener("click"function() { 
  159. // disorder all spirits and start animation 
  160. _startTimer(); 
  161. }); 
  162. }; 
  163.  
  164. /** 
  165. * calculate all pixels of the logo image 
  166. */ 
  167. var _checkImage = function(imgUrl, callback) { 
  168. // var tempCanvas = document.getElementById("temp"); 
  169. //canvas.width = width; 
  170. //canvas.height = height; 
  171.  
  172. var proc = function(image) { 
  173. var w = image.width, h = image.height; 
  174. iw = w, ih = h; 
  175. //console.log("proc image " + image + "," + w + "," + h); 
  176. canvas = _createCanvas(); 
  177. // hide container background 
  178. container.style.backgroundPosition = (-w) + "px"
  179. container.style.backgroundRepeat = "no-repeat"
  180. ctx.drawImage(image, 0, 0); 
  181. // this may cause security error for CORS issue 
  182. try { 
  183. var imgData = ctx.getImageData(0, 0, w, h); 
  184. var arrData = imgData.data; 
  185. for (var i = 0; i < arrData.length; i += 4) { 
  186. var r = arrData[i], g = arrData[i + 1], b = arrData[i + 2], a = arrData[i + 3]; 
  187. if (r > 0 || g > 0 || b > 0 || a > 0) { 
  188. var pos = i / 4; 
  189. _spirit.push(new Spirit({ 
  190. x : pos % w, y : Math.floor(pos / w),  
  191. r : r, g : g, b : b, a : a 
  192. })); 
  193. return true
  194. catch (e) { 
  195. // do nothing 
  196. return false
  197. //return out; 
  198. }; 
  199.  
  200. var img = new Image(); 
  201. img.src = imgUrl; 
  202. if (img.complete || img.complete === undefined) { 
  203. proc(img) && callback && callback(); 
  204. else { 
  205. img.onload = function() { 
  206. proc(img) && callback && callback(); 
  207. }; 
  208. }; 
  209.  
  210. // use "requestAnimationFrame" to create a timer, need browser support 
  211. var _timer = function(func, dur) { 
  212. //console.log("speed is " + dur); 
  213. var timeLast = null
  214. var bStop = false
  215. var bRunning = false// prevent running more than once 
  216. var _start = function() { 
  217. if (func) { 
  218. if (! timeLast) { 
  219. timeLast = Date.now(); 
  220. func(); 
  221. else { 
  222. var current = Date.now(); 
  223. if (current - timeLast >= dur) { 
  224. timeLast = current; 
  225. func(); 
  226.  
  227. if (bStop) { 
  228. return
  229. requestAnimationFrame(_start); 
  230. }; 
  231.  
  232. var _stop = function() { 
  233. bStop = true
  234. }; 
  235.  
  236. return { 
  237. start : function() { 
  238. if (bRunning) { 
  239. //console.log("already running.."); 
  240. return
  241. //console.log("start running.."); 
  242. bRunning = true
  243. bStop = false
  244. _disorder(); 
  245. _start(); 
  246. }, 
  247. stop : function() { 
  248. _stop(); 
  249. bRunning = false
  250. }; 
  251. }; 
  252.  
  253. var _startTimer = function() { 
  254. if (! timer) { 
  255. timer = _timer(function() { 
  256. bMove && _move(); 
  257. }, speed); 
  258. timer.start(); 
  259. }; 
  260.  
  261. var _stopTimer = function() { 
  262. timer && timer.stop(); 
  263. }; 
  264.  
  265. /** 
  266. * start process 
  267. */ 
  268. var _create = function(imgUrl) { 
  269. _checkImage(imgUrl, function() { 
  270. //_createSpirits(); 
  271. _addMouseEvent(canvas); 
  272. //_startTimer(); 
  273. }); 
  274. }; 
  275.  
  276. var _setSpeed = function(s) { 
  277. S[s] && (speed = S[s]); 
  278. }; 
  279.  
  280. /** 
  281. * check whether browser supports canvas 
  282. */ 
  283. var _support = function() { 
  284. try { 
  285. document.createElement("canvas").getContext("2d"); 
  286. return true
  287. catch (e) { 
  288. return false
  289. }; 
  290.  
  291. /** 
  292. * create a canvas element 
  293. */ 
  294. var _createCanvas = function() { 
  295. var cav = document.createElement("canvas"); 
  296. cav.width = iw; 
  297. cav.height = ih; 
  298. container.appendChild(cav); 
  299. ctx = cav.getContext("2d"); 
  300. return cav; 
  301. }; 
  302.  
  303. /** 
  304. * initialize container params 
  305. */ 
  306. var _init = function(c, s) { 
  307. if ((! c) || (! _support())) { // DIV id doesn't exist 
  308. return false
  309. container = c; 
  310. cw = c.clientWidth; 
  311. ch = c.clientHeight; 
  312. s && _setSpeed(s); 
  313. return true
  314. }; 
  315.  
  316. /** 
  317. * export 
  318. */ 
  319. return { 
  320. "create" : function(cId, imgUrl, s) { // user can set move speed by 's'['fast','mid','low'] 
  321. _init(document.getElementById(cId), s) && _create(imgUrl); 
  322. }; 
  323. })(window); 

以上所述就是本文的全部內容了,希望大家能夠喜歡。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩在线视频中文字幕| 欧美性猛交xxxx黑人| 日韩影视在线观看| 久久成人综合视频| 欧美日韩在线视频观看| 中文字幕欧美精品在线| 欧美性精品220| 中文字幕日韩欧美| 国产福利成人在线| 国产成+人+综合+亚洲欧美丁香花| 日韩欧美国产一区二区| 色999日韩欧美国产| 亚洲欧美激情另类校园| 亚洲精品视频网上网址在线观看| 国产成人精品一区二区三区| 国产精品久久久久久久天堂| 中文字幕在线国产精品| 日本精品久久电影| 欧美日韩福利在线观看| 亚洲人成伊人成综合网久久久| 亚洲老板91色精品久久| 狠狠色噜噜狠狠狠狠97| 国产欧洲精品视频| 欧洲午夜精品久久久| 亚洲成人精品久久久| 国产成人精品一区二区| 国产日韩欧美在线观看| 欧美成人免费一级人片100| 日本久久久久久久久久久| 亚洲视频视频在线| 色哟哟入口国产精品| 色妞一区二区三区| 国产精品国产福利国产秒拍| 久久久视频在线| 日韩欧美国产激情| 国产精品夜色7777狼人| 欧美成人精品三级在线观看| 欧美又大又粗又长| 欧美亚洲视频在线观看| 色爱精品视频一区| 日韩黄色高清视频| 5566成人精品视频免费| 亚洲bt欧美bt日本bt| 色偷偷av亚洲男人的天堂| 亚洲国语精品自产拍在线观看| 日韩成人在线视频网站| 亚洲精品国产综合区久久久久久久| 久久久www成人免费精品张筱雨| 全亚洲最色的网站在线观看| 亚洲男人的天堂在线| 成人黄色生活片| 亚洲国产私拍精品国模在线观看| 亚洲乱码av中文一区二区| 亚洲精品第一国产综合精品| 亚洲午夜性刺激影院| 美女视频黄免费的亚洲男人天堂| 中文字幕日韩欧美| 亚洲欧美精品中文字幕在线| 日韩中文在线观看| 精品国产鲁一鲁一区二区张丽| 裸体女人亚洲精品一区| 欧美在线亚洲在线| 国产女人精品视频| 日韩**中文字幕毛片| 国产69精品久久久| 欧美电影院免费观看| 欧美日韩亚洲成人| 国产精品一区久久| 欧美丰满老妇厨房牲生活| 久久亚洲精品一区| 亚洲va男人天堂| 久久久精品在线观看| 欧美亚洲午夜视频在线观看| 一区二区三区无码高清视频| 国产精品r级在线| 亚洲高清福利视频| 国产精品日韩在线一区| 中文字幕亚洲在线| 性亚洲最疯狂xxxx高清| 亚洲免费视频在线观看| 日韩av快播网址| 欧美日韩另类字幕中文| 亚洲天堂av在线免费| 成人妇女淫片aaaa视频| 91av视频导航| 欧美在线观看日本一区| 欧美激情一区二区三区在线视频观看| 日本久久精品视频| 一区二区日韩精品| 欧美另类精品xxxx孕妇| 欧美性受xxxx黑人猛交| 久久精品99久久久香蕉| 中文字幕亚洲一区| 国产精品户外野外| 色偷偷av一区二区三区乱| 国产精品视频区| 亚洲精品自拍第一页| 全色精品综合影院| 成人午夜小视频| 国产成人jvid在线播放| 91成品人片a无限观看| 久久男人资源视频| 国产一区欧美二区三区| xxx欧美精品| 国产精品mp4| 69**夜色精品国产69乱| 国产精品视频网址| 亚洲欧美日本伦理| 亚洲新中文字幕| 国产成人精品免高潮在线观看| 久久久在线观看| 麻豆精品精华液| 日韩欧美国产免费播放| 欧美人在线视频| 久久理论片午夜琪琪电影网| 国产精品视频自在线| 国产精品国产亚洲伊人久久| 亚洲bt天天射| 亚洲国产精品国自产拍av秋霞| www.日韩不卡电影av| 久久久久免费视频| 91日韩在线播放| 久久91亚洲人成电影网站| 国产精品日韩专区| 91精品视频在线免费观看| 中日韩午夜理伦电影免费| 亚洲va男人天堂| 中文字幕无线精品亚洲乱码一区| 日韩不卡在线观看| 人人澡人人澡人人看欧美| 欧美精品生活片| 国内精品久久久久影院优| 中文字幕精品网| 亚洲精品乱码久久久久久按摩观| 亚洲欧美综合区自拍另类| 欧美日韩成人在线视频| 亚洲精品视频免费在线观看| 久久99久国产精品黄毛片入口| 日产精品久久久一区二区福利| 欧日韩在线观看| 欧美日韩免费观看中文| 91香蕉嫩草神马影院在线观看| 欧美日韩福利视频| 黑人精品xxx一区一二区| 97香蕉超级碰碰久久免费软件| 久久综合伊人77777蜜臀| 日韩精品一区二区视频| 91色精品视频在线| 精品福利视频导航| 日韩在线观看免费高清| 国产精品久久激情| 国产精品成人aaaaa网站| 亚洲aaaaaa| 国产免费一区二区三区在线能观看| 色综合视频一区中文字幕| 尤物yw午夜国产精品视频| 亚洲欧洲美洲在线综合| 久久av在线看| 日韩精品一区二区视频| 欧美性猛交xxxxx免费看| 国产日韩欧美91| 欧美亚洲视频在线看网址| 国产精品美女999| 亚洲欧美综合精品久久成人|