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

模态对话框(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. Redis在C#中的使用及Redis的封装

    Redis是一款开源的.高性能的键-值存储(key-value store).它常被称作是一款数据结构服务器(data structure server).Redis的键值可以包括字符串(string ...

  2. redhat 7.5 更换 yum源

    因为 redhat 的 yum 是收费,所以需要换成 Centos 的 yum 才可以 首先,卸载 redhat 的 yum 软件 sudo rpm -qa|grep yum 其次,下载 Centos ...

  3. Kafka基本架构及原理

    本文转载自http://www.cnblogs.com/cyfonly/p/5954614.html  一.为什么需要消息系统 1.解耦: 允许你独立的扩展或修改两边的处理过程,只要确保它们遵守同样的 ...

  4. 【Leetcode】收集

    万事总要有个开头,来吧. 问题原题看情况,如果我能用中文准确地表述出来的话那就用中文说一下.也有可能完全不说… ■ twoSum 问题: 参数是一个数组nums和一个目标数target,寻找nums中 ...

  5. WOW.js和animate.css让页面滚动时显示动画

    官网:http://mynameismatthieu.com/WOW/ bootstrap CDN服务:http://www.bootcdn.cn/wow/ 1.wow.js 实现了在网页滚动时的动画 ...

  6. Direct3D 11 Tutorial 3: Shaders and Effect System_Direct3D 11 教程3:着色器和效果系统

    概述 在上一个教程中,我们设置了一个顶点缓冲区并将一个三角形传递给GPU. 现在,我们将逐步完成图形管道并查看每个阶段的工作原理. 将解释着色器和效果系统的概念. 请注意,本教程与前一个源代码共享相同 ...

  7. 第四百一十五节,python常用排序算法学习

    第四百一十五节,python常用排序算法学习 常用排序 名称 复杂度 说明 备注 冒泡排序Bubble Sort O(N*N) 将待排序的元素看作是竖着排列的“气泡”,较小的元素比较轻,从而要往上浮 ...

  8. 自动化测试工具Katalon简单使用

    前一段时间接触了下Katalon,当时只是简单用了下,今天看到Katalon给发邮件,发现都忘记了,因此重新学习并记录下来 Katalon是在Selemium相同的内核上构建起来的一个自动化测试工具 ...

  9. 使用DDL触发器同步多个数据库结构

    使用DDL触发器同步多个数据库结构 背景:当开发组比较大时,势必会分布到不同的地理位置,若无法在同一个快速网络中工作,就会造成多个开发库并存的局面,这样就需要多个开发库结构的同步,甚至是开发测试数据的 ...

  10. Mac - 如何安全地还原 Mac 的默认字体

    为清理mac系统内存,下载了daisydisk for mac 破解版,然后发现mac所有的字体都被清理了,所有汉子都变成了问号❓和方框.... 在通常情况下,遇到字体显示不正常,甚至乱码时,重置总是 ...