在网上看到一个flash实现椭圆运动轨迹,效果不错,试着用js实现,功能实现不是很完善,希望对学习js的朋友有所帮助。

查看演示

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
    <title></title>
    <style type="text/css">
    .object{}{
        position:absolute; width:89px; height:89px
    }
    </style>
</head>
<body>
</body>
<script type="text/javascript">
        function Move(x,y,a,b)//自定义移动类
        {
            this.uid="move_"+Math.random();
            this.uid = this.uid.replace(".","");
            eval(this.uid+"=this;");
            this._x=x;
            this._y=y;
            this._a=a;
            this._b=b;
            this.items=[];
            this.dxrad=0.05;
        }
        Move.prototype.setPostion=function(obj,rad)//设置对象位置
        {
            obj.style.left=this._a*Math.cos(rad)+this._x+"px";
            obj.style.top=this._b*Math.sin(rad)+this._y+"px";
            if(Math.sin(rad)>0) obj.style.zIndex=3; 
            else obj.style.zIndex=2;
        }
        Move.prototype.setAlpha=function(obj,rad){//设定透明度
            
            var p =(Math.sin(rad) < 0) ? 2*this._a-Math.abs(this._a*Math.cos(rad)) :this._a*Math.abs(Math.cos(rad)); 
            p =100-40*p/this._a+20;
            obj.style.filter='alpha(opacity='+p+')';
            obj.style.opacity=p/100;
        }
        Move.prototype.play=function(n)//根据轨迹运动
        {
            for(var i=0;i<this.items.length;i++){
                this.setPostion(this.items[i],2*Math.PI*i/n+this.dxrad);
                this.setAlpha(this.items[i],2*Math.PI*i/n+this.dxrad);
            }
            this.dxrad=this.dxrad+0.03;
            if(this.dxrad>=Math.PI) this.dxrad=this.dxrad-Math.PI;
           window.setTimeout(this.uid+".play("+n+")",120);
        }
        Move.prototype.init=function(n)
        {
            for(var i=1;i<=n;i++)
            {
                var img = new Image();
                img.src = "https://p-blog.csdn.net/images/p_blog_csdn_net/ghtyan/object.jpg";
                img.className="object";
                this.items[i-1]=img;
                this.setPostion(img,2*Math.PI*i/n);
                this.setAlpha(img,2*Math.PI*i/n);
                document.body.appendChild(img);
                //img.οnclick=function(){alert(this.style.zIndex)};
            }
            this.play(n);
        }
        var move = new Move(450,300,300,80);
        move.init(8);
    </script>
</html>

转载于:https://www.cnblogs.com/ghtyan/archive/2007/08/13/js.html

js实现椭圆运动轨迹相关推荐

  1. Unity物体绕圆运动-轨迹

    using UnityEngine; using System.Collections;public class zhuan : MonoBehaviour {public Transform sun ...

  2. javascript-按圆形排列DIV元素(三)实例---- 图片按椭圆形转动

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

  3. C4D搭配动画效果(二)

    上一章讲述了如何利用C4D图切割制作闪光效果.本章将讲述如何在上章文章描述的效果基础上加入椭圆动态效果以及闪动控制. 如下图所示,椭圆运动主要分成两部分:外圈运动.内圈运动.其中内圈运动看似一个椭圆, ...

  4. 百度地图 js 在安卓端手指缩放无效_利用百度地图绘制3D轨迹演示

    简介 百度地图很强大,也为开发者提供很好的开发接口.今天用3D地图上路线轨迹可视化的小功能. 使用 第一步:申请ak ak申请介绍 创建的时候选择浏览器端~ 第二步:填写ak 有了 ak 后,复制下面 ...

  5. 基于Leaflet实现路径轨迹回放功能

    效果图: 说明: 1.该功能是在这篇博客基础上完成的:ArcGIS JS API 实现路径轨迹回放  但是里面有点小问题:首先,小车并不是匀速运动的,而是每一段的运行时间固定,所以在该博客上进行了修改 ...

  6. 极验第四代滑块验证码破解(三):滑块轨迹构造

    极验第四代滑块验证码破解(三):滑块轨迹构造 声明 一.极验滑动轨迹分析 1. 生成滑动轨迹的js入口 2. 滑动轨迹的python实现 二.结语 *本期文章结束啦,如果对您有帮助,记得收藏加关注哦, ...

  7. LUA中测试鱼死亡动作、炸弹轨迹、炸弹爆炸动作

    Fish.lua: --[[ ------------------------------------ 一条鱼 ------------------------------------ Ivan_ha ...

  8. Vue对高德地图2.0的封装使用

    在Vue项目里使用高德地图,网上有几个比较好用的,例如 AMap-Vue ,文档很好,但不开源 vue-amap ,文档让人流泪 懒人和需求不复杂的,可以直接使用上面的.上面两开源的已经不太活跃了,用 ...

  9. 经纬度坐标转换高斯-克吕格平面坐标

    文章目录 前言 主要代码 使用示例 参考链接 原作者链接:https://blog.csdn.net/jianyi7659/article/details/7583339 前言 支持将地理坐标(经纬度 ...

最新文章

  1. java 类的访问权限_什么是Java类的访问权限?
  2. 【城市沙龙】LiveVideoStack Meet|合肥:在“霸都”邂逅音视频技术
  3. 在VB应用程序中调用Excel2000
  4. 华为云TaurusDB性能挑战赛-java赛题mvn编译时报错:不支持 diamond 运算符
  5. Java编程中忽略这些细节,Bug肯定找上你
  6. 小偷写给失主的一封信 雷人啊!!
  7. Fiddler中文乱码解决方法
  8. 软考初级程序员常见类型题,错题个人笔记
  9. Inno Setup 6.0.3+ 简体中文语言包
  10. git diffmerge tool 配置
  11. python中输出编码问题,pyspark、spark.show、
  12. Defect Detection论文合集、代码和数据集
  13. [data engineering] (一)数据工程师的工作内容以及需要的软硬实力
  14. 快手开店怎么引流?快手小店自上线以来就吸引众多的商家入驻
  15. SecureCRT 乱码问题
  16. Android10.0修改默认usb为MTP模式
  17. python replace函数 成功 失败_解决python replace函数替换无效问题
  18. java爬虫爬取互联网上的各大影视网站---360影视(附源码下载)
  19. 预推免-BUAA软院
  20. Dreamweaver连接MySQL总是出现不知名错误的解决办法【适合新手】

热门文章

  1. 第十一届蓝桥杯——JAVA组真题
  2. 朱松纯 | 人工智能的现状、任务、构架与统一(上)
  3. 前端向--BLOB文件处理及常用输入校验
  4. Ubuntu编译ijkplayer so库并播放本地raw/assets文件
  5. 关于Ansi版Delphi剪切板中文乱码的问题
  6. Unity Render Texture 的使用
  7. struts2 拦截器和过滤器理解
  8. asp.net中GridView排序的手动实现
  9. 计算机的大管家教学反思,第二课 计算机的“大管家”.doc
  10. 易语言如何引用模块和模块中的类