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>
<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 碰撞+拖拽的更多相关文章
- Js元素拖拽功能实现
Js元素拖拽功能实现 需要解决的问题 最近项目遇到了一个问题,就是用户某个操作需要弹出一个自定义的内容输入框,但是有个缺点,当浏览太大的时候没办法点击确认和取消按钮,应为这个弹出框是采用绝对定位的,取 ...
- js之拖拽事件
js之拖拽事件 api:https://www.runoob.com/jsref/event-ondrag.html 拖拽事件是js原生的事件,使用时在div上添加 draggable="t ...
- JS—实现拖拽
JS中的拖拽示例: 1)实现拖拽思路:当鼠标按下和拖拽过程中,鼠标与拖拽物体之间的相对距离保持不变 2)实现拖拽遇到的问题: 问题1:当鼠标按下移动过快时,离开了拖拽的物体时 ...
- js鼠标拖拽
html <div id="box"> </div> css ;;} #box{width:200px;height:200px;background:cy ...
- 原生Js实现拖拽(适用于pc和移动端)
效果: HTML和CSS部分 <!DOCTYPE html> <html lang="en"> <head> <meta charset= ...
- js 利用jquery.gridly.js实现拖拽并且排序
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- js 实现拖拽排序
<!DOCTYPE> <html lang="zh-cn"> <head> <meta http-equiv="Content- ...
- jquery.dragsort.js 实现拖拽过程遇到的问题
.在IE下第一次拖动的时候,被拖动的li元素会不显示,查了很多资料发现是因为在IE中定位出了问题,li标签还在,只是位置计算出错.解决的办法是在li的css样式中position设置为relative ...
- JS实现拖拽功能
本文代码地址(第一节):https://github.com/dirstart/js-exam/blob/master/%E6%8B%96%E6%8B%BDdiv1.html 第二节:https:// ...
随机推荐
- python循环删除list中的元素
直接上例子: a = [1,2,3,4,5,6] for i in a: a.remove(i) print(a) 返回:[2, 4, 6] 循环a,想删除a的所有元素,但实际确有数据保留了下来,这是 ...
- 吴裕雄--天生自然python学习笔记:Python3 面向对象
Python从设计之初就已经是一门面向对象的语言,正因为如此,在Python中创建一个类和对象是很容易的. 面向对象技术简介 类(Class): 用来描述具有相同的属性和方法的对象的集合.它定义了该集 ...
- php 依赖注入 和 控制反转 php设计模式
https://blog.csdn.net/zyddj123/article/details/82753650 什么是依赖注入?IOC:英文全称:Inversion of Control,中文名称:控 ...
- PHP生成word文档的三种实现方式
PHP生成word原理 利用windows下面的 com组件 利用PHP将内容写入doc文件之中 具体实现: 利用windows下面的 com组件 原理:com作为PHP的一个扩展类,安装过offic ...
- 高效能Windows人士的N个习惯之一:启动篇
接触电脑十多年,经历了各种折腾阶段,这几年开始沉静下来,不再追求花哨的界面与应用,只注重工作的效率,逐渐养成了一套自己的操作习惯,感觉不错,特撰文分享.标题借用了一下<高效能人士的七个习惯> ...
- kNN算法 Demo
项目链接: https://github.com/WES6/kNN
- 教你win7关闭开机动画,大幅度加快开机时间
Win7系统如何关闭开机动画 Win7系统开机动画关闭教程,以前我们说过很多种帮助Win7开机加速的方法,比如减少Win7开机启动的程序.服务或计划任务等.不过这些都优化都是针对已经进入Win7系统后 ...
- 产品需求说明书PRD模版
<软件自动化测试开发>出版了 XXX产品需求说明书 [版本号:V+数字] 编 制: 日 期: 评 审: 日 期: 批 准: 日 期: ...
- Microsoft Translator:消除面对面交流的语言障碍
Translator:消除面对面交流的语言障碍" title="Microsoft Translator:消除面对面交流的语言障碍"> James Simm ...
- 能源科技,苹果和Google的新圣战?
细心的果粉可能会注意到,最新版本的IOS软体中,增加了一个不起眼的按钮,它是一款署名为"家庭"的App,之所以说它不起眼,是因为它好像真得没什么用,活跃率恐怕不及Wechat的万分 ...