2012-08-28 14:53:52 +08:00
enum ResolutionPolicy
{
// The entire application is visible in the specified area without trying to preserve the original aspect ratio.
// Distortion can occur, and the application may appear stretched or compressed.
kResolutionExactFit,
// The entire application fills the specified area, without distortion but possibly with some cropping,
// while maintaining the original aspect ratio of the application.
kResolutionNoBorder,
// The entire application is visible in the specified area without distortion while maintaining the original
// aspect ratio of the application. Borders can appear on two sides of the application.
kResolutionShowAll,
kResolutionUnKnown,
};
class CCEGLViewProtocol
{
/**
* Get the frame size of EGL view.
* In general, it returns the screen size since the EGL view is a fullscreen view.
*/
2012-08-29 17:32:47 +08:00
const CCSize& getFrameSize() const;
2012-08-28 14:53:52 +08:00
/**
* Set the frame size of EGL view.
*/
2012-08-29 17:32:47 +08:00
void setFrameSize(float width, float height);
2012-08-28 14:53:52 +08:00
/**
* Get the visible area size of opengl viewport.
*/
2012-08-29 17:32:47 +08:00
CCSize getVisibleSize() const;
2012-08-28 14:53:52 +08:00
/**
* Get the visible origin point of opengl viewport.
*/
2012-08-29 17:32:47 +08:00
CCPoint getVisibleOrigin() const;
2012-08-28 14:53:52 +08:00
/**
* Set the design resolutin size.
* You can't use it with enableRetina together.
* @param width Design resolution width.
* @param height Design resolution height.
* @param resolutionPolicy The resolution policy you need, there are:
2012-10-30 10:35:19 +08:00
* [1] kResolutionExactFit Fill screen, if the design resolution ratio of width and height is different from the screen resolution ratio, your game view will be stretched.
* [2] kResolutionNoBorder Full screen without black border, if the design resolution ratio of width and height is different from the screen resolution ratio, two areas of your game view will be cut.
* [3] kResolutionShowAll Full screen with black border, if the design resolution ratio of width and height is different from the screen resolution ratio, two black border will be shown on the screen;
2012-08-28 14:53:52 +08:00
*/
2012-08-29 17:32:47 +08:00
void setDesignResolutionSize(float width, float height, ResolutionPolicy resolutionPolicy);
2012-10-30 10:35:19 +08:00
/** Get design resolution size.
* Default resolution size is the same as 'getFrameSize'.
*/
virtual const CCSize& getDesignResolutionSize() const;
2012-08-29 17:32:47 +08:00
/** Set touch delegate */
void setTouchDelegate(EGLTouchDelegate * pDelegate);
2012-08-28 14:53:52 +08:00
/**
* Set opengl view port rectangle with points.
*/
2012-08-29 17:32:47 +08:00
void setViewPortInPoints(float x , float y , float w , float h);
/**
* Set Scissor rectangle with points.
*/
void setScissorInPoints(float x , float y , float w , float h);
/**
* Get opengl view port rectangle.
*/
const CCRect& getViewPortRect() const;
/**
* Get the scale factor of horizontal direction.
*
*/
float getScaleX() const;
/**
* Get the scale factor of vertical direction.
*/
float getScaleY() const;
2012-08-28 14:53:52 +08:00
};
2013-03-07 11:55:57 +08:00
class CCEGLView : public CCEGLViewProtocol
{
2013-07-12 13:11:21 +08:00
/** @deprecated Use getInstance() instead */
static CCEGLView* sharedOpenGLView();
static CCEGLView* getInstance();
2013-03-07 11:55:57 +08:00
};