游戏中,新手引导经常要用到。这次是基于3.5版本。
思路:创建遮罩,显示区触摸,下层响应。
让引导层继承widget
local Guide = class("Guide",function () return ccui.Widget:create() end)
把guide设置描点为self:setAnchorPoint(cc.p(0,0))。这样方便坐标计算。
这样可以方便处理触摸区域的响应。通过点击的落点是否在显示区域,然后设置self.listener:setSwallowtouches(true),可以向下层穿透,响应事件;
function OperationalView:onTouchBegan(touch_,event_) print(" OperationalView:onTouchBegan began") local pos = touch_:getLocation() self._touchPos = cc.p(pos.x,pos.y) if self._blackBg then else self._listener:setSwallowtouches(false) end if rectIntersectsPoint(self._stencil:getBoundingBox(),cc.p(pos.x,pos.y)) then self._listener:setSwallowtouches(false) end return true end
遮罩可以使用cc.LayerColor:create(cc.c4b(0,0))来创建
实现镂空
self._clippingNode = cc.ClippingNode:create() self._clippingNode:addChild(self._stencil) self._clippingNode:setStencil(self._stencil) self._clippingNode:setInverted(true)
self._stencil可以是图片资源,也可以使用cc.DrawNode:create()来创建;
对于下层的响应,设计框架时,按钮的监听事件都通过统一回调处理。或者把widget封装多一层。响应按钮事件后通知guide,下层响应完毕。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。