$(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,那么图片的宽度就应该是小于正常图片的大小。
如何得到这个比例值"htmlcode">
2.3 索引值 视觉上距离我们最近的图片,应该是在最上层,即绝对定位的z-index应该是最大,反之而最小,因为这个值也是随图片运动而变化的,所以我们就用到上面的allpers比例值,这个值是0-1之间的,所以我们再用一个函数处理一下: Math.ceil(allpers*10),让其值在1-10之间 (因为我们这里正好是十个图片,如果多了,这个公式需要变化一下) 三、完整代码 弄清原理后,代码量其实很少!~~ 以上就是本文的全部内容,希望对大家有所帮助,有兴趣的朋友可以看下《基于javascript实现按圆形排列DIV元素(一)》和《基于javascript实现按圆形排列DIV元素(二)》谢谢对的支持!
var wpers = Math.max(0.1,allpers);
var hpers = Math.max(0.1,allpers);
$(this).css({
"width":wpers*wid,
"height":hpers*hei,
"opacity":allpers
});
$(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".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);
})
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]