首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Touch事件实现View拖动

Touch监听事件可以监听手指在屏幕上的行为,例如按下、滑动。抬起。根据这些事件,可以做出View任意推动的效果。...注意: onTouch和onClick事件冲突问题:   当同时实现了Touch和Click事件时,会发生冲突,如何避免?在我们的onTouchListener的监听方法会返回一个boolean。...当它为false时,就会触发Click事件,当它为true时,便不会触发。我们希望在点击的时候触发点击事件,在拖动的时候实现移动效果的Touch事件。   ...这样做会出现很难触发点击事件拖动事件太容易触发。所以我们需要加点限制。在ACTION_MOVE中我们获得X、Y移动的距离。那么我们判断当期中一个的移动距离大于1的时,才执行key=true。...正确的姿势是在touch时间或者click事件触发的时候调用。 View获取的位置的参照物是它的父控件:   对于view来说,他的上下左右位置参照物是它的父控件,无论父控件在屏幕的哪个位置。

1.5K10

javascript对点击事件拖动事件的区分

由于是悬浮的,那么就会考虑用户会出现哪几种可能的操作,一个是直接点击,另外一种就是在屏幕上先拖动几下,然后再点击。 那么为了完美的实现这个需求,那么该怎么办呢?...最重要的就是要区分点击事件拖动事件。 我们都知道,点击事件是被点击的对象可看做是静止不动的,而拖动事件的对象很明显是移动的。...那么思路就应该是先判断事件对象是否有移动的现象, 但是由于不管是在点击事件拖动事件,其都有一个鼠标按下的一个过程和一个松开的过程,只不过拖动事件多了一个拖动动作。...那么完整的思路应是这样的: 第一:先写出鼠标按下的函数; 第二:编写对象是否被拖动的函数; 第三:判断对象是否相对原先位置产生了位移; 第四:编写鼠标松开之后的代码; 完整代码如下: var timmerHandle...自己整理了一份2018最全面前端学习资料,从最基础的HTML+CSS+JS到移动端HTML5到各种框架都有整理,送给每一位前端小伙伴,这里是小白聚集地,欢迎初学和进阶中的小伙伴!

5.2K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【Android 事件分发】ItemTouchHelper 实现拖动排序

    事件传递机制 七 ) 【Android 事件分发】ItemTouchHelper 简介 ( 拖动/滑动事件 | ItemTouchHelper.Callback 回调 ) 【Android 事件分发...实现拖动排序 ( 设置滑动方向 | 启启用长按拖动功能 | 拖动距离判定 | 设置拖动触发操作 ) ---- 文章目录 Android 事件分发 系列文章目录 一、ItemTouchHelper.Callback...此处设置上下拖动事件 int dragFlags = ItemTouchHelper.UP | ItemTouchHelper.DOWN; // 设置滑动方向, 此处设置左右侧滑事件..., 此处设置上下拖动事件 int dragFlags = ItemTouchHelper.UP | ItemTouchHelper.DOWN; // 设置滑动方向, 此处设置左右侧滑事件..., 此处设置上下拖动事件 int dragFlags = ItemTouchHelper.UP | ItemTouchHelper.DOWN; // 设置滑动方向, 此处设置左右侧滑事件

    2.2K10

    js实现拖动组件移动效果

    2015-04-15 14:06:09 今天我来给大家介绍一种js特效,这种特效是当你用鼠标点击组件移动到其他地方后,这个组件就定在了那个地方,这种效果通常用来做视图化排版的。...p>column3 item4 这段代码是html代码,主要是大体的div布局,我们在这里的组件用的是div,通过下面的js...代码来实现组件的移动 <script type="text/javascript...= this//不能跟<em>拖动</em>元素自己比较 否则不能在本列向下移动 && top < findPosY(this.column.childNodes[i])){//从上到下找到第一个比<em>拖动</em>元素的上边距大的元素...CCCCCC;background:#CCCCCC;color:white;cursor:move;} 这样就可以实现组件的移动了,在上面这段代码中需要引入Drag.<em>js</em>

    10K20

    自学HarmonyOS应用开发(59)- 处理拖动事件

    地图软件的一个常用功能就是地图拖动功能,本文介绍它是如何实现的。...实现DraggedListener 在Harmony应用中通过实现Component.DraggedListener接口处理拖动事件,这个接口的方法一共有6个,这里我们只是用其中的3个: onDragPreAccept...用于判断是否接受某个拖动操作,这里我们一律返回true,表示接受所有的拖动操作。...,系统会调用onDragStart方法,在这个方法里我们可以记录一些拖动的开始信息,例如触摸位置和显示中心的经纬度信息; 在整个拖动过程中,系统会不断调用onDragUpdate方法。...动作效果 以下是用单指拖动地图时的显示效果: 参考代码 完整代码可以从以下链接下载: https://github.com/xueweiguo/Harmony/tree/master/StopWatch

    53730

    js事件

    中的值类型:String,Number,Boolean,Null,Object,Function 8.JS中的字符型转换成数值型:parseInt(),parseFloat() 9.JS中的数字转换成字符型...:(""+变量)10.JS中的取字符串长度是:(length) 11.JS中的字符与字符相连接使用+号. 12.JS中的比较操作符有:==等于,!...=不等于,>,>=,<.<= 13.JS中声明变量使用:var来进行声明 14.JS中的判断语句结构:if(condition){}else{} 15.JS中的循环结构:for([initial expression...HTML: 51.当超链和ONCLICK事件都有时,则老版本的浏览器转向a.html,否则转向b.html.例:<a href="a.html" onclick......的多重继续. 73.JS中的self指的是当前的窗口 74.JS中状态栏显示内容:window.status="内容" 75.JS中的top指的是框架集中最顶层的框架 76.JS中关闭当前的窗口:

    10.8K110

    移动端touch拖动事件和click事件冲突问题解决

    实现效果 类似微信里的悬浮窗效果,苹果手机的悬浮球功能效果 可以点击拖动,然后吸附在窗口边缘 点击悬浮球,可以跳转界面,或者更改悬浮球的形态 准备 移动端使用 touch事件类型: touchstart...实现 通过设置悬浮球定位样式,拖动的时候计算坐标,然后动态的修改悬浮球的定位偏移量,结合transtion过渡效果,实现平滑的过渡 代码比较简单,就不贴了。...问题 当给元素添加了touch事件之后,click事件就不会出发了,那么怎么模拟点击效果呢?...有可能拖动了一圈又回到初始位置 结合计算触摸时长和触摸元素起始位置两种方式,逻辑比较复杂 下面看我是怎么做的: 首先应该了解触摸行为的事件响应机制: 如果有拖动行为,事件执行次序为:touchstart...-> touchmove-> touchend 没有拖动行为,事件执行次序为:touchstart-> touchend 从上面的分析来看,我们可以从touchmove 入手,继续往下看 解决

    2.3K20

    js动画事件_JavaScript事件

    js之动画事件 首先,动画事件主要包括以下三个animationstart,animationiteration和animationend事件,下面做简单分别介绍。...animationstart 该事件在css动画开始播放时触发 animationiteration 该事件在css动画重新播放时触发 animationend 该事件在css动画结束播放时触发 我们知道...animation:name duration timing-function delay iteration-count direction; 分别是:动画名称 动画持续事件 动画运行速度曲线 动画开始时的运行时间...this.innerHTML="动画正在运行"; x.style.background="pink"; } function myanimationiterration() //动画再次运行触发,同样也是通过事件监听...this.innerHTML="动画重新运行"; x.style.background="greenyellow"; } function myanimationend() //动画运行结束时触发,同样也是通过事件监听事件

    18.4K10

    Js 事件委托(事件代理)

    一、概述 事件委托,又叫事件代理。事件委托就是利用事件冒泡,只指定一个事件处理程序,就可以管理某一类型的所有事件。 例子:有三个同事预计会在周一收到快递。...二、为什么是使用事件委托 一般来说,dom需要有事件处理程序,我们都会直接给它设事件处理程序就好了,那如果是很多的dom需要添加事件处理呢?...,这就是为什么性能优化的主要思想之一就是减少DOM操作的原因;如果要用事件委托,就会将所有的操作放到js程序里面,与dom的操作就只需要交互一次,这样就能大大的减少与dom的交互次数,提高性能; 每个函数都是一个对象...三、事件委托原理 事件委托利用的是事件冒泡原理,将事件绑定到父级元素上,当点击子元素时,通过事件冒泡将事件传递到父级元素。  四、总结: 那什么样的事件可以用事件委托,什么样的事件不可以用呢?...适合用事件委托的事件:click,mousedown,mouseup,keydown,keyup,keypress。

    11.4K30

    【Android 事件分发】ItemTouchHelper 简介 ( 拖动滑动事件 | ItemTouchHelper.Callback 回调 )

    事件传递机制 七 ) 【Android 事件分发】ItemTouchHelper 简介 ( 拖动/滑动事件 | ItemTouchHelper.Callback 回调 ) 【Android 事件分发...实现拖动排序 ( 设置滑动方向 | 启启用长按拖动功能 | 拖动距离判定 | 设置拖动触发操作 ) ---- 文章目录 Android 事件分发 系列文章目录 一、ItemTouchHandler 简介...四、博客资源 一、ItemTouchHandler 简介 ---- ItemTouchHandler 是 Google 提供的一个工具类 , 主要针对 RecyclerView 的上下左右拖动事件 进行处理..., 左右拉动 , 没有效果 , 也无法进行拖动交换条目操作 ; 调用 ItemTouchHandler 的 attachToRecyclerView 方法 , 传入想要添加上下左右拖动事件的 RecyclerView...对象 , 即可为该 RecyclerView 添加拖动事件 ; 添加后 , 该 RecyclerView 自动可以进行上下左右拖动操作 , 用户可以自行添加相关的回调 ItemTouchHelper.Callback

    1.8K10

    js事件大全

    一般事件 事件 浏览器支持 描述 onClick IE3|N2|O3 鼠标点击事件,多用在某个对象控制的范围内的鼠标点击 onDblClick IE4|N4|O 鼠标双击事件 onMouseDown...onStop IE5|N|O 浏览器的停止按钮被按下时触发的事件或者正在下载的文件被中断 onUnload IE3|N2|O3 当前页面将被改变时触发的事件 表单相关事件 事件 浏览器支持 描述...O 当某个对象被拖动时触发的事件 [活动事件] onDragDrop IE|N4|O 一个外部对象被鼠标拖进当前窗口或者帧 onDragEnd IE5|N|O 当鼠标拖动结束时触发的事件,即鼠标的按钮被释放了...onDragEnter IE5|N|O 当对象被鼠标拖动的对象进入其容器范围内时触发的事件 onDragLeave IE5|N|O 当对象被鼠标拖动的对象离开其容器范围内时触发的事件 onDragOver...IE5|N|O 当某被拖动的对象在另一对象容器范围内拖动时触发的事件 onDragStart IE4|N|O 当某对象将被拖动时触发的事件 onDrop IE5|N|O 在一个拖动过程中,释放鼠标键时触发的事件

    3.8K10

    JS 事件循环

    ,脚本执行,事件处理等 其包含的线程有:GUI 渲染线程(负责渲染页面,解析 HTML,CSS 构成 DOM 树)、JS 引擎线程、事件触发线程、定时器触发线程、http 请求线程等主要线程 关于执行中的线程...: 主线程:也就是 js 引擎执行的线程,这个线程只有一个,页面渲染、函数处理都在这个主线程上执行。...工作线程:也称幕后线程,这个线程可能存在于浏览器或js引擎内,与主线程是分开的,处理文件读取、网络请求等异步事件。...上述过程的不断重复就是我们说的 Event Loop (事件循环)。...宏任务主要包含:script( 整体代码)、setTimeout、setInterval、I/O、UI 交互事件、setImmediate(Node.js 环境) 微任务主要包含:Promise、MutaionObserver

    15.4K10

    js --- 事件

    1.事件流   事件发生时会在元素节点与根节点之间按照特定的顺序传播,路径所经过的所有节点都会收到该事件,这个传播过程即DOM事件流。...2.两种事件流模型   1.冒泡型事件流:事件的传播是从最特定的事件目标到最不特定的事件目标。即从DOM树的叶子到根   2.捕获型事件流:事件的传播是从最不特定的事件目标到最特定的事件目标。...即从DOM树的根到叶子 3.绑定事件的方法   1.普通浏览器 绑定事件:addEventListener(type,name,bool);     删除事件:removeEventListener...()   2.ie 低版本 绑定事件:attachEvent()     删除事件:detachEvent() 4.参数说明 type 事件类型 例如:click load   name...事件执行函数   bool true 为事件捕获 && false 为事件冒泡 5.阻止事件冒泡和 事件捕获 1.阻止事件冒泡 不 阻止默认行为     event.stopPropagation

    7.6K30
    领券