前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >cocos3.X 惯性滑动

cocos3.X 惯性滑动

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

1 主要思路

实现手指拖动地图后,手指离开地图后,地图距离会向着手指的方向移动一段距离:

1.在滑动中把每个点放入到容器中

2.滑动结束根据最后一个点与倒数第二点的设定x,y方向上的位移

3.根据摩擦系数,依次减小位移,直至小到一定程度

2 详细设计

2.1 给地图精灵绑定触摸监听

代码语言:javascript
复制
auto listener1 = EventListenerTouchOneByOne::create();//创建一个触摸监听
	listener1->setSwallowTouches(true); //设置是否想下传递触摸
	//通过 lambda 表达式 直接实现触摸事件的回掉方法
	listener1->onTouchBegan = [=](Touch* touch, Event* event){
		return onTouchBegan(touch, event);
	};
	listener1->onTouchMoved = [=](Touch* touch, Event* event){
		onTouchMoved(touch, event);
	};
	listener1->onTouchEnded = [=](Touch* touch, Event* event){
		onTouchEnded(touch, event);
	};
	_eventDispatcher->addEventListenerWithSceneGraphPriority(listener1, m_spr);

2.2触摸开始

代码语言:javascript
复制
bool  HelloWorld::onTouchBegan(Touch* touch, Event*  event)
{
	auto target = static_cast<Sprite*>(event->getCurrentTarget());
	m_vecPot.clear();
	Point locationInNode = target->convertToNodeSpace(touch->getLocation());
	Size s = target->getContentSize();
	Rect rect = Rect(0, 0, s.width, s.height);

	if (rect.containsPoint(locationInNode))
	{
		log("sprite began... x = %f, y = %f", locationInNode.x, locationInNode.y);
		target->setOpacity(180);
		return true;
	}
	return false;
}

当按在精灵上时,返回true,表示能继续响应后面的move操作。

2.3触摸移动

代码语言:javascript
复制
void  HelloWorld::onTouchMoved(Touch* touch, Event*  event)
{
	m_bDrag = true;
	auto target = static_cast<Sprite*>(event->getCurrentTarget());
	target->setPosition(target->getPosition() + touch->getDelta());
	Point locationInNode = target->convertToWorldSpace(touch->getLocation());
	m_vecPot.push_back(locationInNode);
}

移动时保存每个移动的点到m_vecPot容器中。

2.4触摸结束

代码语言:javascript
复制
void  HelloWorld::onTouchEnded(Touch* touch, Event*  event)
{
	auto target = static_cast<Sprite*>(event->getCurrentTarget());
	target->setOpacity(255);
	if (m_bDrag == true)
	{
		m_bDrag = false;
		int iVecSize = m_vecPot.size();
		float fXspeed = m_vecPot[iVecSize - 1].x - m_vecPot[iVecSize - 2].x;
		float fYspeed = m_vecPot[iVecSize - 1].y - m_vecPot[iVecSize - 2].y;
		while (abs(fXspeed) > 0.1 || abs(fYspeed) > 0.1)
		{
			Point potNew = ccpAdd(target->getPosition(), Point(fXspeed, fYspeed));
			auto moveBy = MoveBy::create(0.1f, ccp(fXspeed, fYspeed));
			target->runAction(moveBy);
			fXspeed *= GfFriction;
			fYspeed *= GfFriction;
		}
	}
}

判断结束时,最后一个点与倒数第二点的位置差。当位置差绝对值大于一定量时,移动精灵,位置差再乘上摩擦系数,直到位置差小于这个一定量精灵将停止移动。

源码下载

http://download.csdn.net/detail/luoyikun/9119487

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

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

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1 主要思路
  • 2 详细设计
    • 2.1 给地图精灵绑定触摸监听
      • 2.2触摸开始
        • 2.3触摸移动
          • 2.4触摸结束
          相关产品与服务
          容器服务
          腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档