基于javascript实现按圆形排列DIV元素(三)


Posted in Javascript onDecember 02, 2016

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

效果图:

基于javascript实现按圆形排列DIV元素(三)

分析图:

基于javascript实现按圆形排列DIV元素(三)

上图中:

黑色:是外层容器;

黄色:是需要按椭圆运动的图片

橙色:每个图片元素距离容器顶部的距离

紫色:长半径或短半径;

蓝色:图片距离容器顶部最大的距离

绿色:坐标轴;

白色:椭圆运动轨迹;

一、原理分析:

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;

因为这个比例值是根据橙色线段的长度得来的。(蓝色线段的值,是固定的,橙色线段的值,是在运动中变化的),所以用它去乘以宽、高、透明度就是可以实现,运动中“相同长度的橙色线段的图片,应该具有相同的宽度、高度、透明度。”

因为最小值可能是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元素(二)》谢谢对三水点靠木的支持!

Javascript 相关文章推荐
JavaScript与函数式编程解释
Apr 27 Javascript
有趣的javascript数组定义方法
Sep 10 Javascript
自写的一个jQuery圆角插件
Oct 26 Javascript
JS获取当前网址、主机地址项目根路径
Nov 19 Javascript
jquery css 设置table的奇偶行背景色示例
Jun 03 Javascript
JS JQUERY实现滚动条自动滚到底的方法
Jan 09 Javascript
5个数组Array方法: indexOf、filter、forEach、map、reduce使用实例
Jan 29 Javascript
jquery插件EasyUI中form表单提交实例分享
Jan 11 Javascript
微信小程序 Button 组件详解及简单实例
Jan 10 Javascript
微信小程序显示下拉列表功能【附源码下载】
Dec 12 Javascript
Vue精简版风格概述
Jan 30 Javascript
vue路由结构可设一层方便动态添加路由操作
Aug 31 Javascript
js中动态创建json,动态为json添加属性、属性值的实例
Dec 02 #Javascript
bootstrap模态框跳转到当前模板页面 框消失了而背景存在问题的解决方法
Nov 30 #Javascript
js 动态生成json对象、时时更新json对象的方法
Dec 02 #Javascript
详解JavaScript中数组的reduce方法
Dec 02 #Javascript
基于javascript实现按圆形排列DIV元素(二)
Dec 02 #Javascript
微信公众平台开发教程(六)获取个性二维码的实例
Dec 02 #Javascript
Bootstrap Modal对话框如何在关闭时触发事件
Dec 02 #Javascript
You might like
php面向对象全攻略 (九)访问类型
2009/09/30 PHP
php实现多张图片上传加水印技巧
2013/04/18 PHP
php for 循环使用的简单实例
2016/06/02 PHP
JavaScript DOM 学习第五章 表单简介
2010/02/19 Javascript
javascript 四则运算精度修正函数代码
2010/05/31 Javascript
基于jquery的$.ajax async使用
2011/10/19 Javascript
Javascript跨域请求的4种解决方式
2013/03/17 Javascript
jsp js鼠标移动到指定区域显示选项卡离开时隐藏示例
2013/06/14 Javascript
js调用浏览器打印模块实现点击按钮触发自定义函数
2014/03/21 Javascript
个人总结的一些JavaScript技巧、实用函数、简洁方法、编程细节
2015/06/10 Javascript
使用jspdf生成pdf报表
2015/07/03 Javascript
如何用js 实现依赖注入的思想,后端框架思想搬到前端来
2015/08/03 Javascript
JS实现放大、缩小及拖拽图片的方法【可兼容IE、火狐】
2016/08/23 Javascript
AngularJs表单验证实例代码解析
2016/11/29 Javascript
Bootstrap笔记之缩略图、警告框实例详解
2017/03/09 Javascript
基于vue.js中事件修饰符.self的用法(详解)
2018/02/23 Javascript
vue draggable resizable 实现可拖拽缩放的组件功能
2019/07/15 Javascript
layer.js之回调销毁对话框的例子
2019/09/11 Javascript
layui table单元格事件修改值的方法
2019/09/24 Javascript
vue 解决数组赋值无法渲染在页面的问题
2019/10/28 Javascript
Vue中jsx不完全应用指南小结
2019/11/01 Javascript
Node.js API详解之 timer模块用法实例分析
2020/05/07 Javascript
python 实现堆排序算法代码
2012/06/05 Python
python3+PyQt5实现柱状图
2018/04/24 Python
给大家整理了19个pythonic的编程习惯(小结)
2019/09/25 Python
python 中的命名空间,你真的了解吗?
2020/08/19 Python
迪拜航空官方网站:flydubai
2017/04/20 全球购物
Clarria化妆品官方网站:购买天然和有机化妆品系列
2018/04/08 全球购物
SKECHERS斯凯奇中国官网:来自美国的运动休闲品牌
2018/11/14 全球购物
伯克斯奥特莱斯:Burkes Outlet
2019/03/30 全球购物
Madewell澳大利亚官方网站:美国休闲服饰品牌
2019/07/18 全球购物
学年末自我鉴定
2014/01/21 职场文书
小学家长学校培训材料
2014/08/24 职场文书
交通事故委托书范本精选
2014/10/04 职场文书
服装店员工管理制度
2015/08/07 职场文书
妇产科护理心得体会
2016/01/22 职场文书