重庆分公司,新征程启航

为企业提供网站建设、域名注册、服务器等服务

cocos2dx[3.2](6)——屏幕适配-创新互联

【唠叨】

成都创新互联公司是一家企业级云计算解决方案提供商,超15年IDC数据中心运营经验。主营GPU显卡服务器,站群服务器,德阳电信服务器托管,海外高防服务器,机柜大带宽、租用·托管,动态拨号VPS,海外云手机,海外云服务器,海外服务器租用托管等。

    手机的屏幕大小千差万别,如现在流行的安卓手机屏幕大部分长宽比例为16:9。而iPhone 5S的长宽比例为71:40(接近16:9),也有预测说iPhone 6S的长宽比例也将会是主流的16:9。另外还有一些平板电脑为4:3、16:10、5:4等等。当然还有一些其他的牌子可能屏幕比例也不一样。

    要想让你的程序在各种手机上都能很好的呈现游戏画面,就需要进行屏幕适配

【致谢】

    http://gl.paea.cn/contents/10adab2de4f4bf1c.html

【小知识】

    分辨率:是指屏幕图像的精密度,即显示器所能显示的像素有多少。

    如:分辨率480×320的意思是水平方向含有像素数为480个,垂直方向像素数320个。

    屏幕尺寸一样的情况下,分辨率越高,显示效果就越精细和细腻。

    同时分辨率也反映了屏幕长宽比例(如15:10)。


【屏幕适配】

1、两个分辨率

   1.1、窗口分辨率

    在AppDelegate.cpp中有个设置窗口分辨率的函数。该函数是设置了我们预想设备的屏幕大小,也就是应用程序窗口的大小。

//
	glView->setFrameSize(480, 320);
//

    1.2、设计分辨率(可视区域)

    在AppDelegate.cpp中也有个设置设计分辨率的函数。该函数是设置了我们游戏设计时候的分辨率,也就是可视区域的大小,也就是说设计者初衷的游戏可视区域的分辨率屏幕大小。

    但是对于每个用户来说,他们使用的设备不一定是(480/320)的,比如手机有大有小。

    而后面的ResolutionPolicy::SHOW_ALL,意思是按照原比例(480/320)进行放缩以适配实际屏幕大小。

//
	glview->setDesignResolutionSize(480, 320, ResolutionPolicy::SHOW_ALL);
//

    以下贴了三张对比图,加深理解。

   (1)这是原图片大小,窗口大小为480 * 320。

cocos2dx[3.2](6) ——屏幕适配

    (2)若设置窗口大小为setFrameSize(960, 640),而不设置设计分辨率ResolutionPolicy::SHOW_ALL 的情况下,图片不放缩,原图还是480 * 320。

cocos2dx[3.2](6) ——屏幕适配

    (3)设置了 ResolutionPolicy::SHOW_ALL 之后,图片放缩到适配整个屏幕960 * 640 了。

cocos2dx[3.2](6) ——屏幕适配

2、五种适配模式

    从上面的讲解我们可以了解到,setFrameSize()是设置了窗口大小(即屏幕的实际大小),而这个参数只是为了我们开发时作为模拟参照,在实际手机上运行时,手机的屏幕大小是我们无法设置的。

    而屏幕适配的关键在于setDesignResolutionSize(),通过它来设置可视区域的分辨率以及屏幕适配模式。该函数的前两个参数为分辨率(即屏幕长宽比例),而最后一个参数则是适配的模式。

    2.1、适配模式

  (1)ResolutionPolicy::EXACT_FIT:拉伸变形,使铺满屏幕。

    (2)ResolutionPolicy::NO_BORDER:按比例放缩,全屏展示不留黑边。

                                             (长宽中小的铺满屏幕,大的超出屏幕)

    (3)ResolutionPolicy::SHOW_ALL:按比例放缩,全部展示不裁剪。

                                             (长宽中大的铺满屏幕,小的留有黑边)

    (4)ResolutionPolicy::FIXED_WIDTH:按比例放缩,宽度铺满屏幕。

    (5)ResolutionPolicy::FIXED_HEIGHT:按比例放缩,高度铺满屏幕。

    2.2、计算方法

   假设:屏幕分辨率(fWidth,fHeight) ; 设计分辨率(dWidth,dHeight)。

   放缩因子:k1 = fWidth/dWidth ; k2 = fHeight/dHeight。

    则适配后的分辨率大小如下:

    (1)EXACT_FIT:( dWidth * k1     , dHeight * k2     )

    (2)NO_BORDER:( dWidth * max(k1,k2) , dHeight * max(k1,k2) )

    (3)SHOW_ALL:( dWidth * min(k1,k2) , dHeight * min(k1,k2) )

    (4)FIXED_WIDTH:( dWidth * k1     , dHeight * k1     )

    (5)FIXED_HEIGHT:( dWidth * k2     , dHeight * k2     )

    2.3、有图有真相

        屏幕大小:400 X 400 。

        可视区域大小:480 X 320 。

        根据上面的计算方法,自己慢慢琢磨吧。cocos2dx[3.2](6) ——屏幕适配

cocos2dx[3.2](6) ——屏幕适配        cocos2dx[3.2](6) ——屏幕适配

cocos2dx[3.2](6) ——屏幕适配        cocos2dx[3.2](6) ——屏幕适配

cocos2dx[3.2](6) ——屏幕适配        cocos2dx[3.2](6) ——屏幕适配

3、横竖换屏

   cocos2dx开发的游戏,在手机上运行的时候,默认是横屏的

   3.1、Android

    AndroidManifest.xml文件中

    (1)android:screenOrientation = "landscape"   //横屏显示(默认)

    (2)android:screenOrientation = "portrait"   //竖屏显示

cocos2dx[3.2](6) ——屏幕适配

    3.2、IOS

//
	- (NSUInteger) supportedInterfaceOrientations{
		//横屏显示
		//return UIInterfaceOrientationMaskLandscape;
		
		//竖屏显示
		return UIInterfaceOrientationMaskPortrait;
	}
//

4、屏幕大小及坐标

    (1)WinSize:屏幕大小

    (2)VisibleSize:可视区域大小

    (3)VisibleOrigin:可视区域的左下角坐标

//
	Director::getInstance()->getWinSize()
	Director::getInstance()->getVisibleSize();
	Director::getInstance()->getVisibleOrigin();
//

    图解:

cocos2dx[3.2](6) ——屏幕适配

另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


分享名称:cocos2dx[3.2](6)——屏幕适配-创新互联
网址分享:http://cqcxhl.com/article/gihip.html

其他资讯

在线咨询
服务热线
服务热线:028-86922220
TOP