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

首頁 > 網站 > WEB開發 > 正文

視覺盛宴之INTERCATIVE DHTML

2024-04-27 15:11:46
字體:
來源:轉載
供稿:網友
準備一張圖片:images.gif 比如我用的,圖片效果之一如下:

圖片

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> <html> <head> <title>INTERCATIVE DHTML</title> <meta http-equiv="imagetoolbar" content="no"> <style type="text/CSS"> html { overflow: hidden; } body { position: absolute; margin: 0px; padding: 0px; background: #fff; width: 100%; height: 100%; } #screen { position: absolute; left: 10%; top: 10%; width: 80%; height: 80%; background: #fff; } #screen img { position: absolute; cursor: pointer; width: 0px; height: 0px; -ms-interpolation-mode:nearest-neighbor; } #bankImages { visibility: hidden; } #FPS { position: absolute; right: 5px; bottom: 5px; font-size: 10px; color: #666; font-family: verdana; } </style> <script type="text/javascript"> /* ==== Easing function ==== */ var Library = {}; Library.ease = function () { this.target = 0; this.position = 0; this.move = function (target, speed) { this.position += (target - this.position) * speed; } } var tv = { /* ==== variables ==== */ O : [], fps : 0, screen : {}, angle : { x : new Library.ease(), y : new Library.ease() }, camera : { x    : new Library.ease(), y    : new Library.ease() }, create3DHTML : function (i, x, y, z, sw, sh) { /* ==== create HTML image element ==== */ var o = document.createElement('img'); o.src = i.src; tv.screen.obj.appendChild(o); /* ==== 3D coordinates ==== */ o.point3D = { x  : x, y  : y, z  : new Library.ease(), sw : sw, sh : sh, w  : i.width, h  : i.height }; o.point3D.z.target = z; /* ==== push object ==== */ o.point2D = {}; tv.O.push(o); /* ==== on mouse over event ==== */ o.onmouSEOver = function () { if (this != tv.o) { this.point3D.z.target = tv.mouseZ; tv.camera.x.target = this.point3D.x; tv.camera.y.target = this.point3D.y; if (tv.o) tv.o.point3D.z.target = 0; tv.o = this; } return false; } /* ==== on mousedown event ==== */ o.onmousedown = function () { if (this == tv.o) { if (this.point3D.z.target == tv.mouseZ) this.point3D.z.target = 0; else { tv.o = false; this.onmouseover(); } } } /* ==== main 3D function ==== */ o.animate = function () { /* ==== 3D coordinates ==== */ var x = this.point3D.x - tv.camera.x.position; var y = this.point3D.y - tv.camera.y.position; this.point3D.z.move(this.point3D.z.target, this.point3D.z.target ? .15 : .08); /* ==== rotations ==== */ var xy = tv.angle.cx * y  - tv.angle.sx * this.point3D.z.position; var xz = tv.angle.sx * y  + tv.angle.cx * this.point3D.z.position; var yz = tv.angle.cy * xz - tv.angle.sy * x; var yx = tv.angle.sy * xz + tv.angle.cy * x; /* ==== 2D transform ==== */ var scale = tv.camera.focalLength / (tv.camera.focalLength + yz); x = yx * scale; y = xy * scale; var w = Math.round(Math.max(0, this.point3D.w * scale * this.point3D.sw)); var h = Math.round(Math.max(0, this.point3D.h * scale * this.point3D.sh)); /* ==== HTML rendering ==== */ var o    = this.style; o.left  = Math.round(x + tv.screen.w - w * .5) + 'px'; o.top    = Math.round(y + tv.screen.h - h * .5) + 'px'; o.width  = w + 'px'; o.height = h + 'px'; o.zIndex = 10000 + Math.round(scale * 1000); } }, /* ==== init script ==== */ init : function (structure, FL, mouseZ, rx, ry) { this.screen.obj = document.getElementById('screen'); this.screen.obj.onselectstart = function () { return false; } this.screen.obj.ondrag        = function () { return false; } this.mouseZ = mouseZ; this.camera.focalLength = FL; this.angle.rx = rx; this.angle.ry = ry; /* ==== create objects ==== */ var i = 0, o; while( o = structure[i++] ) this.create3DHTML(o.img, o.x, o.y, o.z, o.sw, o.sh); /* ==== start script ==== */ this.resize(); mouse.y = this.screen.y + this.screen.h; mouse.x = this.screen.x + this.screen.w; /* ==== loop ==== */ setInterval(tv.run, 16); setInterval(tv.dFPS, 1000); }, /* ==== resize window ==== */ resize : function () { var o = tv.screen.obj; if (o) { tv.screen.w = o.offsetWidth / 2; tv.screen.h = o.offsetHeight / 2; for (tv.screen.x = 0, tv.screen.y = 0; o != null; o = o.offsetParent) { tv.screen.x += o.offsetLeft; tv.screen.y += o.offsetTop; } } }, /* ==== main loop ==== */ run : function () { tv.fps++; /* ==== motion ease ==== */ tv.angle.x.move(-(mouse.y - tv.screen.h - tv.screen.y) * tv.angle.rx, .1); tv.angle.y.move( (mouse.x - tv.screen.w - tv.screen.x) * tv.angle.ry, .1); tv.camera.x.move(tv.camera.x.target, .025); tv.camera.y.move(tv.camera.y.target, .025); /* ==== angles sin and cos ==== */ tv.angle.cx = Math.cos(tv.angle.x.position); tv.angle.sx = Math.sin(tv.angle.x.position); tv.angle.cy = Math.cos(tv.angle.y.position); tv.angle.sy = Math.sin(tv.angle.y.position); /* ==== loop through images ==== */ var i = 0, o; while( o = tv.O[i++] ) o.animate(); }, /* ==== trace frames per seconds ==== */ dFPS : function () { document.getElementById('FPS').innerHTML = tv.fps + ' FPS'; tv.fps = 0; } } /* ==== global mouse position ==== */ var mouse = { x : 0, y : 0 } document.onmousemove = function(e) { if (window.event) e = window.event; mouse.x = e.clientX; mouse.y = e.clientY; return false; } /* ==== starting script ==== */ onload = function() { onresize = tv.resize; /* ==== build grid ==== */ var img = document.getElementById('bankImages').getElementsByTagName('img'); var structure = []; for (var i = -300; i <= 300; i += 120) for (var j = -300; j <= 300; j += 120) structure.push({ img:img[0], x:i, y:j, z:0, sw:.5, sh:.5 }); /* ==== let's go ==== */ tv.init(structure, 350, -200, .005, .0025); } </script> </head> <body> <div id="screen"> </div> <div id="bankImages"> <img alt="DHTML" src="images.gif"> </div> <div id="FPS"></div> </body> </html> 


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美激情啊啊啊| 亚洲视频欧美视频| 国产亚洲精品91在线| 国产成人福利视频| 亚洲伊人久久综合| 一道本无吗dⅴd在线播放一区| 亚洲精品成a人在线观看| 亚洲福利在线视频| 伊人成人开心激情综合网| 亚洲日韩第一页| 91精品国产综合久久香蕉922| 久久夜色精品国产亚洲aⅴ| 欧美在线影院在线视频| 国产精品热视频| 欧美激情在线狂野欧美精品| 91精品在线国产| 亚洲欧美制服丝袜| 亚洲资源在线看| 国产一区二区香蕉| 亚洲精品免费一区二区三区| 日韩视频欧美视频| 狠狠做深爱婷婷久久综合一区| 亚洲天堂精品在线| 欧美精品午夜视频| 国产精品99久久久久久人| 国产精品视频免费在线观看| 国内外成人免费激情在线视频网站| 成人激情视频在线| 亚洲精品美女视频| 欧美成人精品xxx| 91在线免费看网站| 亚洲欧洲一区二区三区久久| 91九色单男在线观看| www国产精品com| 亚洲欧美日韩国产中文| 亚洲精品电影在线观看| 欧美亚洲伦理www| 亚洲成人激情在线| 欧美丰满少妇xxxx| 欧美成人精品在线| 91精品国产高清久久久久久91| 日韩av中文在线| 欲色天天网综合久久| 久久久久久中文| 亚洲精品永久免费精品| 伊人久久大香线蕉av一区二区| 538国产精品一区二区在线| 亚洲精品美女在线| 韩国三级电影久久久久久| 国产精品视频免费在线| 欧美电影免费播放| 欧美大片网站在线观看| 高清欧美电影在线| www.欧美精品| 国产精品wwwwww| 久久五月天综合| 国产精品一区久久| 亚洲欧美综合图区| 国产精品高精视频免费| 亚洲夜晚福利在线观看| 欧亚精品中文字幕| 国产精品女人网站| 在线观看日韩专区| 国产精品爽爽ⅴa在线观看| 精品美女久久久久久免费| 久久男人的天堂| 亚洲精品短视频| 国产91精品网站| 欧美性黄网官网| 全球成人中文在线| 91精品视频在线播放| 97成人精品视频在线观看| 欧美交受高潮1| 精品国产一区二区三区在线观看| 亚洲97在线观看| 91成人国产在线观看| 久久久久亚洲精品| 日韩精品久久久久久福利| 国产视频亚洲视频| 日韩欧美国产中文字幕| 欧美性猛交xxxx乱大交| 欧美大片第1页| 国产成人精品一区二区在线| 日韩欧美a级成人黄色| 国产v综合v亚洲欧美久久| 亚洲国产成人一区| 欧美成人黑人xx视频免费观看| 久久久久久网址| 国产精品亚洲视频在线观看| 亚洲高清久久久久久| 国产成人一区二区三区小说| 国产精品久久电影观看| 欧美最猛黑人xxxx黑人猛叫黄| 欧美日韩另类字幕中文| 欧美多人爱爱视频网站| 国产精品久久久久久久久久99| 久久久噜久噜久久综合| 久久精品色欧美aⅴ一区二区| 色樱桃影院亚洲精品影院| 久久人人看视频| 97精品视频在线观看| 91精品美女在线| 亚洲欧美日韩国产成人| 狠狠躁夜夜躁人人爽超碰91| 中文字幕精品久久久久| 国产精品视频午夜| 国模精品视频一区二区三区| 日韩欧美在线免费观看| 少妇高潮久久77777| 久久久国产影院| 国产视频亚洲精品| 国产成人极品视频| 国产九九精品视频| 亚洲一级黄色av| 日韩精品极品在线观看播放免费视频| 欧美俄罗斯乱妇| 国产成人精品免高潮费视频| 一级做a爰片久久毛片美女图片| 成人欧美在线观看| 伦伦影院午夜日韩欧美限制| 中文字幕av一区二区三区谷原希美| 国产精品视频yy9099| 国产精品久久中文| 91在线精品播放| 午夜精品一区二区三区在线视频| 91视频国产高清| 精品偷拍一区二区三区在线看| 午夜精品99久久免费| 欧美日韩国产成人在线观看| 亚洲精品美女久久久| 92福利视频午夜1000合集在线观看| 97在线观看免费高清| 亚洲福利视频网| 欧美另类69精品久久久久9999| 久久久久一本一区二区青青蜜月| 亚洲电影在线观看| 欧美精品在线免费播放| 国产精品吊钟奶在线| 亚洲第一页中文字幕| 日韩视频亚洲视频| 最好看的2019年中文视频| 97色在线观看| 综合网日日天干夜夜久久| 午夜美女久久久久爽久久| 精品国产乱码久久久久久婷婷| 98精品国产高清在线xxxx天堂| 亚洲综合精品一区二区| 国产亚洲精品日韩| 国产啪精品视频网站| 911国产网站尤物在线观看| 久久99国产精品久久久久久久久| 91精品国产777在线观看| 精品成人在线视频| 亚洲最大福利视频网站| 久久久这里只有精品视频| 色777狠狠综合秋免鲁丝| 亚洲人成网站色ww在线| 中文字幕在线国产精品| 久久影院资源站| 97视频在线观看免费| 亚洲综合视频1区| 中文字幕欧美精品日韩中文字幕| 在线观看欧美成人| 久久夜精品香蕉|