加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Cocos2d-x开发之第二篇《设置模拟器大小及实际分辨率》

发布时间:2020-12-14 19:19:05 所属栏目:百科 来源:网络整理
导读:接上一篇《创建工程》 1、在 D:cocos2d-x-2.2.5projectsMyGameproj.win32 中有 main.cpp 文件,内容如下: 650) this.width=650;" src="http://img.jb51.cc/vcimg/static/loading.png" alt="" src="http://img.blog.csdn.net/20141101175131537"> 其中的

接上一篇《创建工程》


1、在D:cocos2d-x-2.2.5projectsMyGameproj.win32中有main.cpp文件,内容如下:

其中的eglView->setFrameSize(480,320)是设置模拟器大小的(相当于是手机的实际尺寸),大家可以根据实际情况进行设置。

2、在D:cocos2d-x-2.2.5projectsMyGameClasses中的AppDelegate.cpp是整个游戏的代理文件。由于考虑到Android手机各种屏幕分辨率问题,所以需要在这里设置统一的分辨率。如下:

正是那句CCEGLView::sharedOpenGLView()->setDesignResolutionSize这个函数。

第一个参数是:分辨率宽;

第二个参数是:分辨率高;

第三个参数是:图片适应屏幕分辨率的属性,如:kResolutionExactFitkResolutionNoBorderkResolutionShowAll等等,主要用的是这三个。

3、下面分别对kResolutionExactFit、kResolutionNoBorder、kResolutionShowAll属性做图文讲解。假设我们有一张540X960的png图,然后把模拟器大小设置成480X320(对应实际手机屏幕尺寸),而分辨率设置成520X800(对应实际手机屏幕分辨率)通过如下函数设置:

CCEGLView::sharedOpenGLView()->setDesignResolutionSize(520,800,属性);

540X960的图如下:

当属性为kResolutionExactFit时,如下结果:

由上得到的结论是:

背景图片为了填充整个屏幕而挤压变形了,还影响到了其它元素的显示效果,比如:文本元素HelloWorld,右下角的按钮,都变了形。

当属性为kResolutionNoBorder时,如下结果:

背景图片为以原图片大小居中显示,只截取了中间的一部分,不会影响其它元素的显示效果(通常都用这个属性,反正我是用这个属性的),要注意的是这里和图片的setPosition有关系,这里是setPosition屏幕中间的。

特别提醒:以kResolutionNoBorder属性时,场景中的精灵位置需要加上CCPoint origin = CCDirector::sharedDirector()->getVisibleOrigin();的坐标,否则会出现位置偏移的情况。

当属性为kResolutionShowAll时,如下结果:

背景图片等比例缩小,直到原始图片高度与屏幕分辨率高相等,会影响其它元素的显示,比如:文本元素和按钮,显示的位置会以大背景图的显示区域为基准。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读