Cocos2d-js3.3 模态对话框的实现
首先,先了解一下什么是模态对话框,百度百科的给出了下面一个定义:
模态对话框(Modal Dialogue Box,又叫做模式对话框),是指在用户想要对对话框以外的应用程序进行操作时,必须首先对该对话框进行响应。如单击【确定】或【取消】按钮等将该对话框关闭。
游戏中经常会出现很多模态对话框,例如登陆框、提示框等等。
下面来看下效果图:
有几点值得关注的:
1.当对话框出现后,对话框外不响应触摸。
这就需要用到setSwallowTouches(),设置为true时,并且onTouchBegan返回true,就会吞没事件,不再向下传递
2.当对话框出现后,背景变暗
这里用到LayerColor的两个方法,设置颜色setColor()和设置透明度setOpacity()
下面,请看代码:
- var ModalDialogueBox = cc.LayerColor.extend({
- _listener: null,
- ctor: function() {
- this._super(cc.color.BLACK);
- this.ignoreAnchorPointForPosition(false); //忽略锚点设置为false,默认为true,锚点(0, 0)
- this.setOpacity(128); //透明度
- //初始化对话框
- this._initDialog();
- return true;
- },
- onEnter: function()
- {
- this._super();
- //监听器
- this._listener = new cc.EventListener.create({
- event: cc.EventListener.TOUCH_ONE_BY_ONE,
- swallowTouches: false,
- onTouchBegan: function(touch, event)
- {
- return true;
- }
- });
- //添加触摸监听
- cc.eventManager.addListener(this._listener, this);
- },
- //初始化对话框
- _initDialog: function()
- {
- var winSize = cc.winSize;
- //背景
- var bg = new cc.Sprite(res.dialog_png);
- bg.setPosition(cc.p(winSize.width / 2, winSize.height / 2));
- this.addChild(bg, 0, 101);
- //OK按钮
- var OKLabel = new cc.LabelTTF("OK", "Arial", 36);
- var OKMenuItem = new cc.MenuItemLabel(OKLabel, this._onCallback, this);
- OKMenuItem.setPosition(cc.p(100, 50));
- //Cancel按钮
- var cancelLabel = new cc.LabelTTF("Cancel", "Arial", 36);
- var cancelMenuItem = new cc.MenuItemLabel(cancelLabel, this._onCallback, this);
- cancelMenuItem.setPosition(cc.p(250, 50));
- //菜单
- var menu = new cc.Menu(OKMenuItem, cancelMenuItem);
- menu.setPosition(cc.p(0, 0));
- bg.addChild(menu); //注意是添加到背景里面
- this.setVisible(false); //默认设置为不可见
- },
- _onCallback: function()
- {
- this.hidden();
- },
- //弹出
- popup: function()
- {
- this.setVisible(true);
- this._listener.setSwallowTouches(true);
- var bg = this.getChildByTag(101);
- bg.setScale(0);
- var scaleTo = new cc.ScaleTo(2.0, 1);
- var rotateBy = new cc.RotateBy(2.0, 360, 0);
- var spawn = new cc.Spawn(scaleTo, rotateBy);
- bg.runAction(spawn);
- },
- //隐藏
- hidden: function()
- {
- this.setVisible(false);
- this._listener.setSwallowTouches(false);
- },
- onExit: function()
- {
- this._super();
- //移除触摸监听
- cc.eventManager.removeListeners(cc.EventListener.TOUCH_ONE_BY_ONE, true);
- }
- });
源码下载:点击打开链接
Cocos2d-js3.3 模态对话框的实现的更多相关文章
- cocos2d-x 模态对话框的实现
心情不好,恩.不扯淡了.直接讲. ================================== 在泰然看了一篇实现模态对话框的文章,写的还不错,然后在其基础上加了我简单加了一层灰色透明背景,这 ...
- cocos2dx & cocostudio 实现模态对话框
用cocos2dx实现模态对话框 http://www.cnblogs.com/mrblue/(转自于) ui部分使用了cocoStudio,注意这里没有实现怎么屏蔽其他的输入事件,其他的文档已经太多 ...
- MFC编程 | 非模态对话框的定义
因为课程需要,会用到MFC编程,所以讲一些经验总结下,以便日后使用查询. // 非模态对话框的定义 // 通过单文档菜单调用一个非模态窗口 1.首先在工程里插入一个对话框(如:IDD_DLG_TEST ...
- bootstrap dialog 使用模态对话框
bootstrap3-dialog 使用模态对话框 <div class="modal fade"> <div class="modal-dialog& ...
- 【原创】WinForm 模态对话框
今天解决的一个问题,记录下,以备后用. 问题描述:WinForm程序有超时自动退出功能,但是有些模态对话框不关掉的话会退出失败,原因(猜测): 程序倒计时用的System.Windows.Forms. ...
- 关于easyUI的模态对话框
本文版权归博客园和作者吴双本人共同所有,转载和爬虫请注明原文地址.博客园蜗牛cnblogs.com/tdws 会用easyUI的模态对话框会是我们的开发更加简洁,只需下载这个插件,把需要的文件拖到项目 ...
- 自定义AlertView实现模态对话框
在Windows应用程序中,经常使用模态(Model)对话框来和用户进行简单的交互,比如登录框.在IOS应用程序中,有时我们也希望做同样的事情.但IOS的UI库中,没有模态对话框,最接近那个样子的应该 ...
- MFC编程入门之十二(对话框:非模态对话框的创建及显示)
上一节讲了模态对话框及其弹出过程,本节接着讲另一种对话框--非模态对话框的创建及显示. 非模态对话框显示后,程序其他窗口仍然能正常运行,可以响应用户输入,还可以相互切换.上一讲中创建的Tip模态对话框 ...
- MFC编程入门之十一(对话框:模态对话框及其弹出过程)
加法计算器对话框程序大家照着做一遍后,相信对基于对话框的程序有了些解了,有个好的开始对于以后的学习大有裨益.趁热打铁,这一节讲讲什么是对话框和非模态对话框,以及模态对话框怎样弹出. 一.模态对话框和非 ...
- MFC学习笔记(一)向模态对话框传递数据
声明构造函数为2个参数,具有默认参数的参数须放在后面. CDialogDimmer::CDialogDimmer(CString name,CWnd* pParent /*=NULL*/) : CDi ...
随机推荐
- 【iCore1S 双核心板_ARM】例程十八:SD_IAP_FPGA实验——更新升级FPGA
实验现象及操作说明: 1.烧写程序成功,绿色ARM·LED灯点亮,三色FPGA·LED灯循环点亮,烧写失败,如果挂载SD卡失败,红灯快闪,如果打开文件失败,蓝灯快闪,读取文件指针移动失败,白灯点亮,升 ...
- 重新粗推了一下Master Theorem
主定理一般形式是T(n) = a T(n / b) + f(n), a >= 1, b > 1.递归项可以理解为一个高度为 logbn 的 a 叉树, 这样 total operation ...
- Vue+Vue-router微信分享功能
在使用vue和vue-router路由框架已经开发过好几个项目了,其中也遇到不少坑,有些坑各种搜也没有找到非常理想的答案. vue学习相对来说还是比较简单,官方文档说明非常清楚(https://cn. ...
- rpm命令如何打印调试信息?
问题描述: 今天在做rpm相关操作的时候,发现报错,并且还不知道如何入手来解决问题,就左查右查的问题还是没有解决,后来就想,rpm能否打印debug信息,然后也百度了,也没有找到,后来想我为啥不看看r ...
- nginx default_server的作用
用来处理没有成功匹配server_name的请求 https://www.oschina.net/question/12_3565 https://segmentfault.com/a/1190000 ...
- chrome自动填表会遮挡input中背景图的问题解决方法
在做某项目登录界面时,发现用户密码框在Chrome自动填充时,input中的背景框会被遮住.网上也搜了一下,没有一个有效的解决方法. 来看csdn的登录界面,也有这个问题. 后来在浏览网页时,无意中发 ...
- 新Windows本地提权漏洞学习(CVE-2019-0841)
1.这是一个啥漏洞? 睁眼一看,妈呀本地提权,快加入本地提权漏洞利用包里,速度加入.github连接我就不发了.担心被认为是传播黑客工具,咱们在这里单纯学习一下漏洞的原理和部分源代码. 2.文件读写权 ...
- 【谈谈IO】BIO、NIO和AIO
BIO: BIO是阻塞IO,体现在一个线程调用IO的时候,会挂起等待,然后Thread会进入blocked状态:这样线程资源就会被闲置,造成资源浪费,通常一个系统线程数是有限的,而且,Thread进入 ...
- 【C++/实验三】类和对象
1.定义一个矩形类,有长,宽两个属性,有成员函数计算矩形的面积. 在该矩形类中,我做了5个主要的测试. 构造函数带默认值参数,利用默认值参数计算矩形面积:rectangle(double x=2.0, ...
- C++打开剪切板,获取剪切板数据
if (::OpenClipboard(NULL) && ::IsClipboardFormatAvailable(CF_HDROP)) { HDROP hDrop = (HDROP) ...