展会信息港展会大全

关于cocos2d-x屏幕适配
来源:互联网   发布日期:2015-09-28 14:43:11   浏览:2698次  

导读: 关于cocos2d-x屏幕适配关于屏幕适配文章很多,看了好多还是很费解。实际cocos2d-x 源码已经非常清楚的说明了各种情形。一、前提概念:屏幕分辨率 :确定屏幕上显示多少信息的设置,以水平...

关于cocos2d-x屏幕适配关于屏幕适配文章很多,看了好多还是很费解。实际cocos2d-x 源码已经非常清楚的说明了各种情形。一、前提概念:屏幕分辨率 :确定屏幕上显示多少信息的设置,以水平和垂直像素来衡量,网上很多,可自行参考。设计分辨率:开发时候,为制定的参考大小,比如常见的480*800,在初期就要定好,美术、程序按照这个标准来安排布局物件。很大原因是物理屏幕分辨率太多,不能兼顾,只能自行设计个参考大校二、目的 把设计分辨率 投放 映射到 屏幕分辨率。三、思路:首先用 屏幕分辨率和设计分辨率 求出x,y轴缩放因子;然后根据各种缩放策略 修正缩放因子;最后在算出viewPort大小(可理解为显示视窗大小,或者叫视窗分辨率);若视窗大于屏幕大小,则会发生裁剪现象,部分会显示不出来;若视窗小于屏幕大小,则会有黑边。下面一起来看代码。四、代码分析

在开发中,该函数是我们在外经常用到的,在新版中他调用updateDesignResolutionSize来设置分辨率。

void GLView::setDesignResolutionSize(float width,float height,ResolutionPolicy resolutionPolicy)

{

CCASSERT(resolutionPolicy!=ResolutionPolicy::UNKNOWN,"should set resolutionPolicy");

if(width==0.0f||height==0.0f)

{

return;

}

_designResolutionSize.setSize(width,height);

_resolutionPolicy=resolutionPolicy;

updateDesignResolutionSize();

}

void GLView::updateDesignResolutionSize()

{

if (_screenSize.width > 0 && _screenSize.height > 0

&& _designResolutionSize.width > 0 && _designResolutionSize.height > 0)

{

//关键点 用屏幕分辨率 和设计分辨率 求出x轴和y轴缩放因子

_scaleX = (float)_screenSize.width / _designResolutionSize.width;

_scaleY = (float)_screenSize.height / _designResolutionSize.height;

//NO_BORDER 模式,就是用最大缩放因子,显然此类情形 使得小(窄)边 超出实际,所以会导致裁剪

if (_resolutionPolicy == ResolutionPolicy::NO_BORDER)

{

_scaleX = _scaleY = MAX(_scaleX, _scaleY);

}

//SHOW_ALL模式 ,用的是最小因子;显然视窗会小于屏幕,所以会有黑边

else if (_resolutionPolicy == ResolutionPolicy::SHOW_ALL)

{

_scaleX = _scaleY = MIN(_scaleX, _scaleY);

}

//固定高度,是指统一用y轴缩放因子。显然x轴会受影响,x轴实际是按照y因子进行缩放,

//同时根据实际物理屏幕分辨率 修正 设计分辨率,目的保持视窗和物理屏幕大小一致。

//此类情形会铺满整个屏幕,但x轴方向也会发生裁剪或者黑边,这主要是设计分辨率的x轴会根据物理屏幕实际大小

//动态发生变化。应用程序中,若绘制布局的物件位置 大于设计分辨率x轴,则会裁剪;若没x轴方向没有被绘制部分,

//则会黑边,如x轴被缩放过大时候。

//总之此类情形,若完美满足匹配,要求我们在程序中,宽度(x轴向)要用相对坐标,不要用绝度坐标,

//常需要getVisualeSize配合

else if ( _resolutionPolicy == ResolutionPolicy::FIXED_HEIGHT) {

_scaleX = _scaleY;

_designResolutionSize.width = ceilf(_screenSize.width/_scaleX);

}

//分析同上

else if ( _resolutionPolicy == ResolutionPolicy::FIXED_WIDTH) {

_scaleY = _scaleX;

_designResolutionSize.height = ceilf(_screenSize.height/_scaleY);

}

//默认情形是EXACT_FIT,分别按照x,y各自缩放;视窗和屏幕大小一致;但会有拉伸现象,不建议使用。

// calculate the rect of viewport。 计算出视窗大校

float viewPortW = _designResolutionSize.width * _scaleX;

float viewPortH = _designResolutionSize.height * _scaleY;

_viewPortRect.setRect((_screenSize.width - viewPortW) / 2, (_screenSize.height - viewPortH) / 2, viewPortW, viewPortH);

// reset director's member variables to fit visible rect

auto director = Director::getInstance();

director->_winSizeInPoints = getDesignResolutionSize();

director->createStatsLabel();

director->setGLDefaultValues();

}

}

http://www.bkjia.com/Androidjc/936942.htmlwww.bkjia.comtruehttp://www.bkjia.com/Androidjc/936942.htmlTechArticle关于cocos2d-x屏幕适配 关于屏幕适配文章很多,看了好多还是很费解。实际cocos2d-x 源码已经非常清楚的说明了各种情形。 一、前提概念:...

赞助本站

人工智能实验室

相关热词: android开发 应用开发

AiLab云推荐
展开

热门栏目HotCates

Copyright © 2010-2024 AiLab Team. 人工智能实验室 版权所有    关于我们 | 联系我们 | 广告服务 | 公司动态 | 免责声明 | 隐私条款 | 工作机会 | 展会港