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

首頁 > 編程 > JavaScript > 正文

基于javascript實現按圓形排列DIV元素(三)

2019-11-19 18:42:57
字體:
來源:轉載
供稿:網友

$(this).css({"left":Math.sin((ahd*index+ainhd))*radius+dotLeft,"top":Math.cos((ahd*index+ainhd))*radius+dotTop});

效果圖:

分析圖:

上圖中:

黑色:是外層容器;

黃色:是需要按橢圓運動的圖片

橙色:每個圖片元素距離容器頂部的距離

紫色:長半徑或短半徑;

藍色:圖片距離容器頂部最大的距離

綠色:坐標軸;

白色:橢圓運動軌跡;

一、原理分析:

  1.1按橢圓運運

  前面兩個隨筆分析了“圓形排列”和“按圓形運動”,知道了“排列”和“運動”這兩個以后,再來看這個實例應該就有基礎了。

  根據前面一篇隨筆的分析,圓形運去的公式如下:

$(this).css({"left":Math.sin((ahd*index+ainhd))*radius+dotLeft,"top":Math.cos((ahd*index+ainhd))*radius+dotTop});

(如果不清楚這個公式,可以看前面寫的一篇“運動”);

  現在我們是要按橢圓運運,還能不能套用上面的公式呢??

  可以,但……需要有點點變化.

  橢圓和圓形的區別是什么?

  是半徑;圓只有一個半徑,而橢圓有兩個,一個長半徑,一個短半徑,如上圖中的OA和OB,紫色線段;

  所以公式里面半徑需要替換成,長半徑和短半徑;其它都無變化,如下:

$(this).css({"left":Math.sin((ahd*index+ainhd))*OB+dotLeft,"top":Math.cos((ahd*index+ainhd))*OA+dotTop});

  2.2 排列時寬度和透明度的變化

  橢圓里排列的圖片,寬度和透明度的變化有什么規律,或者說是特點?

  是距離容器頂部的距離;如上圖中,橙色的線段長度。通過觀察發現,在運運過程中,具有相同長度的橙色線段的圖片,應該具有相同的寬度、高度、透明度。

  那么我們就通過這個橙色線段的,來設定圖片的寬、高、透明度;

  這里的寬、高、透明度的變化是一個比例的變化,所以我們需要一個比例值,這個比例值為1的時候,去乘以圖片的寬和高,就是圖片原始的大小,如果比例值小于1,那么圖片的寬度就應該是小于正常圖片的大小。

  如何得到這個比例值?

  用橙色線段的長度,去除以藍色線段的長度; 因為藍色線段的長度是橙色線段的最大長度;,所以這個比例值,是在0-1之間的數;同時也滿足上面提到的,相同橙色的線段長度,應該有相同的寬、高、透明度;

  如下公式是求出每一個圖片的距離頂部的值,即上圖中橙色線估的長度;

(Math.cos((ahd*index+ainhd))*b+dotTop)

如下公式是求出這個關鍵的比例值allpers,而這個totpop是上圖中藍色線的長度,也就是橙色的最大長度值

var allpers = (Math.cos((ahd*index+ainhd))*b+dotTop)/totTop;

因為這個比例值是根據橙色線段的長度得來的。(藍色線段的值,是固定的,橙色線段的值,是在運動中變化的),所以用它去乘以寬、高、透明度就是可以實現,運動中“相同長度的橙色線段的圖片,應該具有相同的寬度、高度、透明度?!?/p>

因為最小值可能是0.000幾,所以要用一個函數處理下:

var wpers = Math.max(0.1,allpers);var hpers = Math.max(0.1,allpers);

 $(this).css({     "width":wpers*wid,     "height":hpers*hei,     "opacity":allpers    });

  2.3 索引值

  視覺上距離我們最近的圖片,應該是在最上層,即絕對定位的z-index應該是最大,反之而最小,因為這個值也是隨圖片運動而變化的,所以我們就用到上面的allpers比例值,這個值是0-1之間的,所以我們再用一個函數處理一下:

  Math.ceil(allpers*10),讓其值在1-10之間

  (因為我們這里正好是十個圖片,如果多了,這個公式需要變化一下)

三、完整代碼

  $(function(){  //中心點橫坐標  var dotLeft = ($(".container").width()-$(".dot").width())/2-100;  //中心點縱坐標  var dotTop = ($(".container").height()-$(".dot").height())/2-100;  //橢圓長邊  a = 460;  //橢圓短邊  b = 120;  //起始角度  var stard = 0;  //每一個BOX對應的角度;  var avd = 360/$(".container img").length;  //每一個BOX對應的弧度;  var ahd = avd*Math.PI/180;  //運動的速度  var speed = 2;  //圖片的寬高  var wid = $(".container img").width();  var hei = $(".container img").height();  //總的TOP值  var totTop = dotTop+100;  //設置圓的中心點的位置  $(".dot").css({"left":dotLeft,"top":dotTop});  //運動函數  var fun_animat = function(){    speed = speed<360?speed:2;   //運運的速度   speed+=2;   //運動距離,即運動的弧度數;   var ainhd = speed*Math.PI/180;    //按速度來定位DIV元素   $(".container img").each(function(index, element){    var allpers = (Math.cos((ahd*index+ainhd))*b+dotTop)/totTop;    var wpers = Math.max(0.1,allpers);    var hpers = Math.max(0.1,allpers);    $(this).css({     "left":Math.sin((ahd*index+ainhd))*a+dotLeft,     "top":Math.cos((ahd*index+ainhd))*b+dotTop,     "z-index":Math.ceil(allpers*10),     "width":wpers*wid,     "height":hpers*hei,     "opacity":allpers    });    });  }  //定時調用運動函數  var setAnimate = setInterval(fun_animat,100); })

    弄清原理后,代碼量其實很少!~~

以上就是本文的全部內容,希望對大家有所幫助,有興趣的朋友可以看下《基于javascript實現按圓形排列DIV元素(一)》《基于javascript實現按圓形排列DIV元素(二)》謝謝對武林網的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
精品一区二区三区四区在线| 亚洲最大av在线| 国产成+人+综合+亚洲欧美丁香花| 成人网中文字幕| 欧美性xxxxhd| 亚洲第一区第一页| 富二代精品短视频| 欧美国产日韩二区| 欧美日产国产成人免费图片| 欧美一区第一页| 欧美激情精品久久久久久黑人| 亚洲自拍偷拍第一页| 久久网福利资源网站| 国产一区二区三区视频免费| 神马久久久久久| 国产成人精品免高潮费视频| 成人av资源在线播放| 国产欧美精品在线| 欧美精品电影免费在线观看| 亚洲国产日韩欧美在线99| 丝袜亚洲欧美日韩综合| 欧美精品精品精品精品免费| 久久久av一区| 亚洲国产精彩中文乱码av| 久久久久国产精品免费网站| 亚洲va欧美va国产综合久久| 日韩精品极品视频| 亚洲情综合五月天| 国产成人在线播放| 日韩av免费一区| 日韩中文理论片| 国产精品亚洲自拍| 5566成人精品视频免费| 欧洲午夜精品久久久| 欧美性资源免费| 国产极品精品在线观看| 久久精品视频va| 自拍偷拍亚洲区| 久久久久久久久久国产| 亚洲精品综合久久中文字幕| 精品一区二区三区四区在线| 亚洲国产精品资源| 日韩成人中文字幕在线观看| xxxxxxxxx欧美| 国产精品旅馆在线| 欧美美最猛性xxxxxx| 成人精品视频久久久久| 在线日韩av观看| 欧美性xxxx极品hd欧美风情| 国产精品白丝jk喷水视频一区| 欧美猛男性生活免费| 亚洲精品一区久久久久久| 成人av色在线观看| 日本精品久久久久影院| 欧美精品久久久久久久久久| 国产精品老女人精品视频| 亚洲福利视频专区| 日本欧美爱爱爱| 欧美老女人bb| 国产欧美日韩精品在线观看| 国产一区二区三区毛片| 欧美日韩加勒比精品一区| 国产精品人成电影在线观看| 91社影院在线观看| 欧美黄色www| 成人网在线免费观看| 91国语精品自产拍在线观看性色| 亚洲性夜色噜噜噜7777| 亚洲免费中文字幕| 国产精品第100页| 国产精品福利在线观看| 色综合天天狠天天透天天伊人| 亚洲激情在线观看| 81精品国产乱码久久久久久| 亚洲国产91色在线| 亚洲999一在线观看www| 日韩精品在线视频美女| 午夜精品一区二区三区在线| 中文字幕一区二区精品| 久久久成人av| 久久6免费高清热精品| 久久精品国产一区二区电影| 91久久综合亚洲鲁鲁五月天| 午夜精品一区二区三区在线视| 亚洲va久久久噜噜噜| 精品福利在线观看| 亚洲免费一级电影| 91精品国产网站| 国产亚洲精品综合一区91| 亚洲毛片一区二区| 欧美日韩一区二区在线播放| 亚洲精品一区久久久久久| 久久久www成人免费精品张筱雨| www.日本久久久久com.| 国产高清视频一区三区| 日本国产欧美一区二区三区| 91国产视频在线播放| 国产精品国产福利国产秒拍| 国产精品777| 久久男人的天堂| 国产精品女人久久久久久| 精品久久久久久久久中文字幕| 欧美肥老妇视频| 久久久久久这里只有精品| 欧美另类69精品久久久久9999| 欧美午夜影院在线视频| 亚洲欧美制服中文字幕| 在线播放日韩精品| 日韩精品中文字幕在线播放| 国产mv免费观看入口亚洲| 国产精品吊钟奶在线| 日韩国产一区三区| 日本人成精品视频在线| 午夜精品久久久久久久白皮肤| 亚洲精品午夜精品| 日韩电影在线观看中文字幕| 久久久999精品| 久久99精品久久久久久噜噜| 日韩69视频在线观看| 国产精品69久久久久| 午夜免费日韩视频| 国产精品久久久久久久久| 一本色道久久88综合亚洲精品ⅰ| 国产精品黄页免费高清在线观看| 国产97在线视频| 91伊人影院在线播放| 久久综合免费视频| 国产精品视频免费在线| 91九色视频在线| 欧美疯狂性受xxxxx另类| 成人www视频在线观看| 久久久精品影院| 精品亚洲永久免费精品| 日韩中文字幕在线免费观看| 日韩在线视频线视频免费网站| 国产精品视频最多的网站| 欧美三级xxx| 九九热这里只有精品免费看| 日本在线观看天堂男亚洲| 91久久精品日日躁夜夜躁国产| 91黑丝在线观看| 国产精品白丝jk喷水视频一区| 成人激情在线观看| 2021久久精品国产99国产精品| 久久久噜久噜久久综合| 欧美中文字幕视频在线观看| 国产成人精品在线| 亚洲免费av网址| 色噜噜狠狠狠综合曰曰曰88av| 亚洲黄色在线看| 91精品久久久久久久久久入口| 国产精品激情av在线播放| 亚洲成人av片在线观看| 久久亚洲精品国产亚洲老地址| 97国产suv精品一区二区62| 日韩不卡在线观看| 日本最新高清不卡中文字幕| 97在线视频免费观看| 另类少妇人与禽zozz0性伦| 成人夜晚看av| 欧美日韩在线免费观看| 日韩免费视频在线观看| 免费91麻豆精品国产自产在线观看| 亚洲综合小说区|