JavaScript动画-磁性吸附

Posted 老板丶鱼丸粗面

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaScript动画-磁性吸附相关的知识,希望对你有一定的参考价值。

▓▓▓▓▓▓ 大致介绍

  磁性吸附是以模拟拖拽为基础添加一个拖拽时范围的限定而来的一个效果,如果对模拟拖拽有疑问的同学请移步模拟拖拽

  源代码、效果:点这里

 

▓▓▓▓▓▓ 范围限定(可视区)

  先来看一个在可视区范围内的模拟拖拽,我们先要搞清楚可视区的范围。

  可视区就是用户可以看到的区域,有上、下、左、右四个范围

  上:T = 0

  下:B = document.documentElement.clientHeight

  左:L = 0

  右:R = document.documentElement.clientWidth

  

  我们控制div在可视区范围内拖拽就是设置div的left和top值,从下图我们可以看到left和top应设置的值

  代码中用L和R记录方块的坐标值

  代码如下:

 1                 if(L < 0){
 2                     // 左侧范围
 3                     L = 0;
 4                 }else if(L > document.documentElement.clientWidth - obj.offsetWidth){
 5                     // 右侧范围
 6                     L = document.documentElement.clientWidth - obj.offsetWidth;
 7                 }
 8                 if(T < 0){
 9                     // 上侧范围
10                     T = 0;
11                 }else if(T > document.documentElement.clientHeight - obj.offsetHeight){
12                     // 下侧范围
13                     T = document.documentElement.clientHeight - obj.offsetHeight;
14                 }

  

▓▓▓▓▓▓ 磁性吸附

  磁性吸附就是在范围限定的基础上改进得来的

  如图:

  我们把方块拖到距离可视区边界30px的位置,放快就自动的吸附到边框上。

  代码:

 1                 if(L < 50){
 2                     // 左侧范围
 3                     L = 0;
 4                 }else if(L > document.documentElement.clientWidth - obj.offsetWidth - 50){
 5                     // 右侧范围
 6                     L = document.documentElement.clientWidth - obj.offsetWidth;
 7                 }
 8                 if(T < 50){
 9                     // 上侧范围
10                     T = 0;
11                 }else if(T > document.documentElement.clientHeight - obj.offsetHeight - 50){
12                     // 下侧范围
13                     T = document.documentElement.clientHeight - obj.offsetHeight;
14                 }

 

  

 

以上是关于JavaScript动画-磁性吸附的主要内容,如果未能解决你的问题,请参考以下文章

JavaScript动画-碰撞检测

javascript动画系列第三篇——碰撞检测

限制范围拖拽,磁性吸附。

音频处理Melodyne 选择工具使用 ( 主工具简介 | 修改音高 | 自动吸附 | 音符长度修改 | 长度自动吸附 | 设置音符分离线 | 设置片段分离线 )

可缩放时间轴和录像片段选择器的实现

JavaScript-Tool-lhgDialog:动画示例