<!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>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<style>
body{margin:0;padding:0;}
div{width:100px;height:100px;background:red;position:absolute;left:0;top:30px;}
</style>
<script>
var ispeedX = 0;
var ispeedY = 0;
window.onload = function(){
var oBtn = document.getElementsByTagName('input')[0];
var oDiv = document.getElementsByTagName('div')[0]; oBtn.onclick = function(){
elasticStartMove(oDiv);
};
var lastX = 0; /*拖的快就快碰撞,拖的慢就慢碰撞*/
var lastY = 0;
oDiv.onmousedown = function(ev){
var ev = ev || event;
var disX = ev.clientX-this.offsetLeft;
var disY = ev.clientY-this.offsetTop; document.onmouseover = function(ev){
var oEvent = ev || event;
var l = oEvent.clientX-disX;
var t = oEvent.clientY-disY;
ispeedX = l-lastX;
ispeedY = t-lastY;
lastX = l;
lastY = t;
oDiv.style.left = l+'px';
oDiv.style.top = t+'px'; }; document.onmouseup = function(){
document.onmouseover = document.onmouseup = null;
elasticStartMove(oDiv);
};
};
}; function elasticStartMove(obj){
clearInterval(obj.timer);
obj.timer = setInterval(function(){
ispeedY += 3; /*受重力因素,越来越快,加上重力摩擦会变得越来越小*/
var t = obj.offsetTop+ispeedY;
var l= obj.offsetLeft+ispeedX;
// alert("obj.offsetTop:"+obj.offsetTop+"ispeedY:"+ispeedY+"t:"+t);
if(t >= document.documentElement.clientHeight - obj.offsetHeight){
ispeedY *= -0.8;/*重力因素,让速度越来越小,高度不会变*/
ispeedX *= 0.8;
t = document.documentElement.clientHeight - obj.offsetHeight;
}else if(t<=0){
ispeedY *= -0.8;
t = 0;
}
if(l >= document.documentElement.clientWidth - obj.offsetWidth){
ispeedX *= -0.8;
l = document.documentElement.clientWidth - obj.offsetWidth; //避免超出范围碰撞,出现滚动条
}else if(l<=0){
ispeedX *= -0.8;
l = 0
}
/*如果isped为小数,会往回跑,300.3-300 299.5->299*/
if(Math.abs(ispeedX) <1){
ispeedX = 0;
}
if(Math.abs(ispeedY) <1){
ispeedY = 0;
}
if(ispeedX ==0 && ispeedY == 0 && t == document.documentElement.clientHeight - obj.offsetHeight ){
clearInterval(obj.timer); }else{
obj.style.top = t+'px';
obj.style.left = l+'px'; } },30); }
</script>
</head> <body>
<input type='button' value='开始运动'/>
<div></div>
</body>
</html>

js 碰撞+拖拽的更多相关文章

  1. Js元素拖拽功能实现

    Js元素拖拽功能实现 需要解决的问题 最近项目遇到了一个问题,就是用户某个操作需要弹出一个自定义的内容输入框,但是有个缺点,当浏览太大的时候没办法点击确认和取消按钮,应为这个弹出框是采用绝对定位的,取 ...

  2. js之拖拽事件

    js之拖拽事件 api:https://www.runoob.com/jsref/event-ondrag.html 拖拽事件是js原生的事件,使用时在div上添加 draggable="t ...

  3. JS—实现拖拽

    JS中的拖拽示例:    1)实现拖拽思路:当鼠标按下和拖拽过程中,鼠标与拖拽物体之间的相对距离保持不变    2)实现拖拽遇到的问题:        问题1:当鼠标按下移动过快时,离开了拖拽的物体时 ...

  4. js鼠标拖拽

    html <div id="box"> </div> css ;;} #box{width:200px;height:200px;background:cy ...

  5. 原生Js实现拖拽(适用于pc和移动端)

    效果: HTML和CSS部分 <!DOCTYPE html> <html lang="en"> <head> <meta charset= ...

  6. js 利用jquery.gridly.js实现拖拽并且排序

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  7. js 实现拖拽排序

    <!DOCTYPE> <html lang="zh-cn"> <head> <meta http-equiv="Content- ...

  8. jquery.dragsort.js 实现拖拽过程遇到的问题

    .在IE下第一次拖动的时候,被拖动的li元素会不显示,查了很多资料发现是因为在IE中定位出了问题,li标签还在,只是位置计算出错.解决的办法是在li的css样式中position设置为relative ...

  9. JS实现拖拽功能

    本文代码地址(第一节):https://github.com/dirstart/js-exam/blob/master/%E6%8B%96%E6%8B%BDdiv1.html 第二节:https:// ...

随机推荐

  1. python循环删除list中的元素

    直接上例子: a = [1,2,3,4,5,6] for i in a: a.remove(i) print(a) 返回:[2, 4, 6] 循环a,想删除a的所有元素,但实际确有数据保留了下来,这是 ...

  2. 吴裕雄--天生自然python学习笔记:Python3 面向对象

    Python从设计之初就已经是一门面向对象的语言,正因为如此,在Python中创建一个类和对象是很容易的. 面向对象技术简介 类(Class): 用来描述具有相同的属性和方法的对象的集合.它定义了该集 ...

  3. php 依赖注入 和 控制反转 php设计模式

    https://blog.csdn.net/zyddj123/article/details/82753650 什么是依赖注入?IOC:英文全称:Inversion of Control,中文名称:控 ...

  4. PHP生成word文档的三种实现方式

    PHP生成word原理 利用windows下面的 com组件 利用PHP将内容写入doc文件之中 具体实现: 利用windows下面的 com组件 原理:com作为PHP的一个扩展类,安装过offic ...

  5. 高效能Windows人士的N个习惯之一:启动篇

    接触电脑十多年,经历了各种折腾阶段,这几年开始沉静下来,不再追求花哨的界面与应用,只注重工作的效率,逐渐养成了一套自己的操作习惯,感觉不错,特撰文分享.标题借用了一下<高效能人士的七个习惯> ...

  6. kNN算法 Demo

    项目链接: https://github.com/WES6/kNN

  7. 教你win7关闭开机动画,大幅度加快开机时间

    Win7系统如何关闭开机动画 Win7系统开机动画关闭教程,以前我们说过很多种帮助Win7开机加速的方法,比如减少Win7开机启动的程序.服务或计划任务等.不过这些都优化都是针对已经进入Win7系统后 ...

  8. 产品需求说明书PRD模版

    <软件自动化测试开发>出版了 XXX产品需求说明书 [版本号:V+数字]                 编  制: 日  期: 评  审: 日  期: 批  准: 日  期:       ...

  9. Microsoft Translator:消除面对面交流的语言障碍

    ​ Translator:消除面对面交流的语言障碍" title="Microsoft Translator:消除面对面交流的语言障碍"> ​ James Simm ...

  10. 能源科技,苹果和Google的新圣战?

    细心的果粉可能会注意到,最新版本的IOS软体中,增加了一个不起眼的按钮,它是一款署名为"家庭"的App,之所以说它不起眼,是因为它好像真得没什么用,活跃率恐怕不及Wechat的万分 ...