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 ...
随机推荐
- redis 集群搭建碰到的问题
make PREFIX=/usr/local/redis install把编译好的redis 安装到指定目录下. redis.conf文件从源码目录拷贝到/usr/local/redis(安装目录)下 ...
- c# async和await 用法(阻塞与不阻塞)
void PagePaint() { Console.WriteLine("Paint Start"); Paint(); Console.WriteLine("Pain ...
- libGDX开发环境搭建-Android Studio 最新版
http://blog.csdn.net/renwuqiangg/article/details/53088720 —————————————————————————————————————————— ...
- Linux操作系统配置Go语言编程环境
之前一直在windows下写Go,现在工作环境切换至Linux下,因此写下此文,记录安装Go环境的过程. 操作系统:CentOS7.5 一.安装步骤 1,下载Go语言安装包 yum install g ...
- CustomDrawableTextView
public class CustomDrawableTextView extends TextView{ //image width.height private int imageWidth; p ...
- 【2019年04月22日】A股最便宜的股票
太钢不锈(SZ000825) - 当前便宜指数:170.67 - 滚动扣非市盈率PE:4.37 - 滚动市净率PB:0.98 - 动态年化股息收益率:4.79%- 太钢不锈(SZ000825)的历 ...
- 误删除libc.so.6的解决
最近安装一个软件需要glibc-2.17. 使用ldd --version 发现系统的glibc版本为 glibc-2.12,当时没有想到更好的方法,就尝试将系统的glibc版本修改为glibc-2. ...
- SpringMVC工作原理 : HandlerMapping和HandlerAdapter
一.HandlerMapping 作用是根据当前请求的找到对应的 Handler,并将 Handler(执行程序)与一堆 HandlerInterceptor(拦截器)封装到 HandlerExecu ...
- 将ubuntu的home迁移至第二块磁盘
在忍受了一整周的磁盘将满的报警之后,今天终于着手准备将占据64G磁盘中的44G的Home迁移至另外一块磁盘,当然,这也是使用Linux做PC OS的正确使用方式.在Linux的目录管理风格的基础上,这 ...
- Python学习之旅(二十)
Python基础知识(19):面向对象高级编程(Ⅱ) 定制类 形如“__xx__”的变量或函数在Python中是有特殊用途的 1.__str__ 让打印出来的结果更好看 __str__:面向用户:__ ...