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 ...
随机推荐
- iOS中UITextField输入判断小数点后两位
在输入金额的UITextField中,要给予三个规则的判断 1. 只能输入数字(可以通过设置键盘类型为Decimal Pad) 2. 小数点只能有一个 3. 小数点后最多有两位数字 (可以通过正则表达 ...
- C语言 · 滑动解锁
题目:滑动解锁 滑动解锁是智能手机一项常用的功能.你需要在3x3的点阵上,从任意一个点开始,反复移动到一个尚未经过的"相邻"的点.这些划过的点所组成的有向折线,如果与预设的折线在图 ...
- poi操作Excel的封装类
这是一个简单的对poi的封装,只能简单的取值,设值,拷贝行,插入行等. 针对读取Excel模板后,填值再保存的应用,比较方便. poi版本:3.13 贴代码: package cn.com.gtmc. ...
- halcon 特征测量
Features 1. line_orientation 功能:计算线的方位. 2. line_position 功能:计算一条线的重心.长度和方位. 3. partition_lines ...
- awd入门教程
(转自:awk入门教程 - 阮一峰) 以下为正文 ———————————————————— awk是处理文本文件的一个应用程序,几乎所有 Linux 系统都自带这个程序. 它依次处理文件的每一行,并读 ...
- 使用git命令push到自己的仓库,显示Unknown且没有贡献记录的解决方案
一.问题的起因 今天用公司电脑在github上push时出现了以下问题: 用户名为unknown: 贡献记录为0: 二.解决方案 1,检查一遍自己的账号密码是否正确,如果正确,执行第二步骤操作: 2, ...
- 框架源码系列八:Spring源码学习之Spring核心工作原理(很重要)
目录:一.搞清楚ApplicationContext实例化Bean的过程二.搞清楚这个过程中涉及的核心类三.搞清楚IOC容器提供的扩展点有哪些,学会扩展四.学会IOC容器这里使用的设计模式五.搞清楚不 ...
- NuGet Packages are missing,This project references NuGet package(s) that are missing on this computer. Use NuGet Package Restore to download them.
错误内容 This project references NuGet package(s) that are missing on this computer. Use NuGet Package R ...
- Flask学习笔记(3)--路由
0x01 参数传递 传递参数的语法是: /<参数名>/,然后在视图函数中,也要定义同名的参数. 参数的数据类型: 1.如果没有指定具体的数据类型,那么默认就是使用string 数据类型. ...
- 114、drawable和mipmap 目录下图片的区别
android 在 API level 17 加入了 mipmap 技术,对 bitmap 图片的渲染支持 mipmap 技术,来提高渲染的速度和质量.mipmap 是一种很早就有的技术了,翻译过来就 ...