首先,先了解一下什么是模态对话框,百度百科的给出了下面一个定义:

模态对话框(Modal Dialogue Box,又叫做模式对话框),是指在用户想要对对话框以外的应用程序进行操作时,必须首先对该对话框进行响应。如单击【确定】或【取消】按钮等将该对话框关闭。

游戏中经常会出现很多模态对话框,例如登陆框、提示框等等。

下面来看下效果图:

有几点值得关注的:

1.当对话框出现后,对话框外不响应触摸。

这就需要用到setSwallowTouches(),设置为true时,并且onTouchBegan返回true,就会吞没事件,不再向下传递

2.当对话框出现后,背景变暗

这里用到LayerColor的两个方法,设置颜色setColor()和设置透明度setOpacity()

下面,请看代码:

  1. var ModalDialogueBox = cc.LayerColor.extend({
  2. _listener: null,
  3. ctor: function() {
  4. this._super(cc.color.BLACK);
  5. this.ignoreAnchorPointForPosition(false);   //忽略锚点设置为false,默认为true,锚点(0, 0)
  6. this.setOpacity(128);       //透明度
  7. //初始化对话框
  8. this._initDialog();
  9. return true;
  10. },
  11. onEnter: function()
  12. {
  13. this._super();
  14. //监听器
  15. this._listener = new cc.EventListener.create({
  16. event: cc.EventListener.TOUCH_ONE_BY_ONE,
  17. swallowTouches: false,
  18. onTouchBegan: function(touch, event)
  19. {
  20. return true;
  21. }
  22. });
  23. //添加触摸监听
  24. cc.eventManager.addListener(this._listener, this);
  25. },
  26. //初始化对话框
  27. _initDialog: function()
  28. {
  29. var winSize = cc.winSize;
  30. //背景
  31. var bg = new cc.Sprite(res.dialog_png);
  32. bg.setPosition(cc.p(winSize.width / 2, winSize.height / 2));
  33. this.addChild(bg, 0, 101);
  34. //OK按钮
  35. var OKLabel = new cc.LabelTTF("OK", "Arial", 36);
  36. var OKMenuItem = new cc.MenuItemLabel(OKLabel, this._onCallback, this);
  37. OKMenuItem.setPosition(cc.p(100, 50));
  38. //Cancel按钮
  39. var cancelLabel = new cc.LabelTTF("Cancel", "Arial", 36);
  40. var cancelMenuItem = new cc.MenuItemLabel(cancelLabel, this._onCallback, this);
  41. cancelMenuItem.setPosition(cc.p(250, 50));
  42. //菜单
  43. var menu = new cc.Menu(OKMenuItem, cancelMenuItem);
  44. menu.setPosition(cc.p(0, 0));
  45. bg.addChild(menu);      //注意是添加到背景里面
  46. this.setVisible(false);     //默认设置为不可见
  47. },
  48. _onCallback: function()
  49. {
  50. this.hidden();
  51. },
  52. //弹出
  53. popup: function()
  54. {
  55. this.setVisible(true);
  56. this._listener.setSwallowTouches(true);
  57. var bg = this.getChildByTag(101);
  58. bg.setScale(0);
  59. var scaleTo = new cc.ScaleTo(2.0, 1);
  60. var rotateBy = new cc.RotateBy(2.0, 360, 0);
  61. var spawn = new cc.Spawn(scaleTo, rotateBy);
  62. bg.runAction(spawn);
  63. },
  64. //隐藏
  65. hidden: function()
  66. {
  67. this.setVisible(false);
  68. this._listener.setSwallowTouches(false);
  69. },
  70. onExit: function()
  71. {
  72. this._super();
  73. //移除触摸监听
  74. cc.eventManager.removeListeners(cc.EventListener.TOUCH_ONE_BY_ONE, true);
  75. }
  76. });

源码下载:点击打开链接

Cocos2d-js3.3 模态对话框的实现的更多相关文章

  1. cocos2d-x 模态对话框的实现

    心情不好,恩.不扯淡了.直接讲. ================================== 在泰然看了一篇实现模态对话框的文章,写的还不错,然后在其基础上加了我简单加了一层灰色透明背景,这 ...

  2. cocos2dx & cocostudio 实现模态对话框

    用cocos2dx实现模态对话框 http://www.cnblogs.com/mrblue/(转自于) ui部分使用了cocoStudio,注意这里没有实现怎么屏蔽其他的输入事件,其他的文档已经太多 ...

  3. MFC编程 | 非模态对话框的定义

    因为课程需要,会用到MFC编程,所以讲一些经验总结下,以便日后使用查询. // 非模态对话框的定义 // 通过单文档菜单调用一个非模态窗口 1.首先在工程里插入一个对话框(如:IDD_DLG_TEST ...

  4. bootstrap dialog 使用模态对话框

    bootstrap3-dialog 使用模态对话框 <div class="modal fade"> <div class="modal-dialog& ...

  5. 【原创】WinForm 模态对话框

    今天解决的一个问题,记录下,以备后用. 问题描述:WinForm程序有超时自动退出功能,但是有些模态对话框不关掉的话会退出失败,原因(猜测): 程序倒计时用的System.Windows.Forms. ...

  6. 关于easyUI的模态对话框

    本文版权归博客园和作者吴双本人共同所有,转载和爬虫请注明原文地址.博客园蜗牛cnblogs.com/tdws 会用easyUI的模态对话框会是我们的开发更加简洁,只需下载这个插件,把需要的文件拖到项目 ...

  7. 自定义AlertView实现模态对话框

    在Windows应用程序中,经常使用模态(Model)对话框来和用户进行简单的交互,比如登录框.在IOS应用程序中,有时我们也希望做同样的事情.但IOS的UI库中,没有模态对话框,最接近那个样子的应该 ...

  8. MFC编程入门之十二(对话框:非模态对话框的创建及显示)

    上一节讲了模态对话框及其弹出过程,本节接着讲另一种对话框--非模态对话框的创建及显示. 非模态对话框显示后,程序其他窗口仍然能正常运行,可以响应用户输入,还可以相互切换.上一讲中创建的Tip模态对话框 ...

  9. MFC编程入门之十一(对话框:模态对话框及其弹出过程)

    加法计算器对话框程序大家照着做一遍后,相信对基于对话框的程序有了些解了,有个好的开始对于以后的学习大有裨益.趁热打铁,这一节讲讲什么是对话框和非模态对话框,以及模态对话框怎样弹出. 一.模态对话框和非 ...

  10. MFC学习笔记(一)向模态对话框传递数据

    声明构造函数为2个参数,具有默认参数的参数须放在后面. CDialogDimmer::CDialogDimmer(CString name,CWnd* pParent /*=NULL*/) : CDi ...

随机推荐

  1. list add对象踩的坑

    list 添加对象时,没有把new object写到循环体里,导致最后添加了相同的一个对象: public List<goods> find(String goodsname) { Lis ...

  2. 基于Gradle的spring boot 项目构建

    今天听只是分享,听到不用maven而使用Gradle构建,就尝试了下 Java三大构建工具:Ant.Maven和Gradle Gradle是一个基于Apache Ant和Apache Maven概念的 ...

  3. PHP memcached memcache 扩展安装

    好久没配置环境今天安装PHP 开发环境, 项目比较老,一开始以为项目用的是memcache 装完后发现 项目用的是memcached 所以正好两个都装了. 碰到些坑希望能帮助到百度到这篇文章的伙伴 . ...

  4. 使用npm安装webpack失败时,可能被墙要为cmd命令行设置代理

    一.搜索到的相关概念: Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境. npm是 Node packaged Modules(node的包管理工具).本身用n ...

  5. ux.form.field.Year 只能选年的时间扩展

    效果如图,亲测6.2.1版本可用,用法同时间选择控件 //只选择年的控件 Ext.define('ux.picker.Year', { extend: 'Ext.Component', alias: ...

  6. 漏洞预警:Linux内核9年高龄的“脏牛”0day漏洞

    这个名叫Dirty COW,也就是脏牛的漏洞,存在Linux内核中已经有长达9年的时间,也就说2007年发布的Linux内核版本中就已经存在此漏洞.Linux kernel团队已经对此进行了修复. 漏 ...

  7. 启动Mysql数据库报错误:-bash: ./start.sh: Permission denied

    linux下安装好Mysql数据库后,输入启动命令: cd /home/homework/mysql && ./start.sh 回车后报如下错误: 原因是:该文件未有相关执行权限 解 ...

  8. C++对windows控制面板的操作

    经常碰到程序无法卸载, 就老是骂微软搞的什么安装方式,安装好了不能卸载. 后来就打算研究一下windows是如何卸载程序的,一个程序安装完后留下了什么信息用于后面的卸载. 研究对象win7 64位, ...

  9. 删除或修改本地Git保存的账号密码

    win10 系统下进入 控制面板 > 用户帐户 > 管理你的凭据 选择 [Windows 凭据] git 保存的用户信息在普通凭据列表里 >>编辑>>>完成

  10. array_rand

    array_rand — 从数组中随机取出一个或多个单元 mixed array_rand ( array $array [, int $num = 1 ] ) 从数组中取出一个或多个随机的单元,并返 ...