前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >unity3d ugui 图片点击与拖动同存互不影响

unity3d ugui 图片点击与拖动同存互不影响

作者头像
立羽
发布2023-08-24 13:26:59
1720
发布2023-08-24 13:26:59
举报
文章被收录于专栏:Unity3d程序开发

1 功能描述

Ugui下一张图片同时要响应拖动(例如实现下一张功能)和点击(例如实现跳转UI功能),但是两个事件要分开独立互不影响。

2 详细设计

2.1绑定事件

代码语言:javascript
复制
 local callback = function(self, e)
      Debugger.Log("callbackClick")
		  self:onClickDisplayItem(i+1)
	  end	
    local listener = NTGEventTriggerProxy.Get(item.gameObject)
    local callbackBeginDrag = function(self, e)
      self.isClickDisplayItem = false
		  self.posDragBegin = Input.mousePosition
	  end	
    local callbackDrag = function(self, e)
		  self:onDragDisplayItem(i+1,item)
	  end	
    listener.onBeginDrag = listener.onBeginDrag + DelegateFactory.NTGEventTriggerProxy_PointerEventDelegate_Self(self, callbackBeginDrag);
    listener.onEndDrag = listener.onEndDrag + DelegateFactory.NTGEventTriggerProxy_PointerEventDelegate_Self(self, callbackDrag);
listener.onPointerClick = listener.onPointerClick + DelegateFactory.NTGEventTriggerProxy_PointerEventDelegate_Self(self, callback)

onBeginDrag 拖动事件开始时,isClickDisplayItem点击标志位置为false,即使响应了点击事件,也不执行点击处理的函数;并且记录下当前拖动开始点击坐标。如果对这张图片进行拖动操作:unity先响应onBeginDrag,然后是onPointerClick ,最后是onEndDrag。如果只对这张图片进行点击:unity只会响应onPointerClick 

2.2拖动结束事件处理函数

代码语言:javascript
复制
function StoreRecommendCtrl:onDragDisplayItem(idx,item)
  if Input.mousePosition.x < self.posDragBegin.x-10 then
    Debugger.Log("left")
  elseif Input.mousePosition.x > self.posDragBegin.x + 10 then
    Debugger.Log("right")
  self.isClickDisplayItem = true
end

拖动结束时坐标与拖动开始坐标x值比较,得到拖动方向,注意的是结束时要self.isClickDisplayItem = true,重新使能点击标志位。

2.3点击事件处理函数

代码语言:javascript
复制
function StoreRecommendCtrl:onClickDisplayItem(idx)
   if self.isClickDisplayItem == true then
      Debugger.Log("onClickDisplayItem"..idx)
   end
end

当isClickDisplayItem 点击标志位为true,执行函数(跳转ui)。解决拖动时同时会响应点击事件,又不想执行点击函数的问题

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2016-05-28,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1 功能描述
  • 2 详细设计
    • 2.1绑定事件
      • 2.2拖动结束事件处理函数
        • 2.3点击事件处理函数
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档