2019-11-23 20:27:39 +08:00
|
|
|
/****************************************************************************
|
|
|
|
Copyright (c) 2008-2010 Ricardo Quesada
|
|
|
|
Copyright (c) 2010-2013 cocos2d-x.org
|
|
|
|
Copyright (c) 2011 Zynga Inc.
|
|
|
|
Copyright (c) 2013-2016 Chukong Technologies Inc.
|
|
|
|
Copyright (c) 2017-2019 Xiamen Yaji Software Co., Ltd.
|
2023-12-08 00:13:39 +08:00
|
|
|
Copyright (c) 2019-present Axmol Engine contributors (see AUTHORS.md).
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2022-10-01 16:24:52 +08:00
|
|
|
https://axmolengine.github.io/
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
of this software and associated documentation files (the "Software"), to deal
|
|
|
|
in the Software without restriction, including without limitation the rights
|
|
|
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
copies of the Software, and to permit persons to whom the Software is
|
|
|
|
furnished to do so, subject to the following conditions:
|
|
|
|
|
|
|
|
The above copyright notice and this permission notice shall be included in
|
|
|
|
all copies or substantial portions of the Software.
|
|
|
|
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
|
|
THE SOFTWARE.
|
|
|
|
****************************************************************************/
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <stack>
|
|
|
|
#include <thread>
|
|
|
|
#include <chrono>
|
|
|
|
|
2023-06-11 13:08:08 +08:00
|
|
|
#include "platform/PlatformMacros.h"
|
|
|
|
#include "base/Ref.h"
|
|
|
|
#include "base/Vector.h"
|
|
|
|
#include "2d/Scene.h"
|
|
|
|
#include "math/Math.h"
|
|
|
|
#include "platform/GLView.h"
|
2023-06-25 01:17:29 +08:00
|
|
|
#if defined(AX_PLATFORM_PC)
|
|
|
|
# include "concurrentqueue/concurrentqueue.h"
|
|
|
|
#endif
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2022-07-11 17:50:21 +08:00
|
|
|
NS_AX_BEGIN
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @addtogroup base
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* Forward declarations. */
|
|
|
|
class LabelAtlas;
|
2021-12-25 10:04:45 +08:00
|
|
|
// class GLView;
|
2019-11-23 20:27:39 +08:00
|
|
|
class DirectorDelegate;
|
|
|
|
class Node;
|
|
|
|
class Scheduler;
|
|
|
|
class ActionManager;
|
|
|
|
class EventDispatcher;
|
|
|
|
class EventCustom;
|
|
|
|
class EventListenerCustom;
|
|
|
|
class TextureCache;
|
|
|
|
class Renderer;
|
|
|
|
class Camera;
|
|
|
|
|
|
|
|
class Console;
|
|
|
|
|
|
|
|
/**
|
|
|
|
@brief Class that creates and handles the main Window and manages how
|
|
|
|
and when to execute the Scenes.
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
The Director is also responsible for:
|
|
|
|
- initializing the OpenGL context
|
|
|
|
- setting the OpenGL buffer depth (default one is 0-bit)
|
|
|
|
- setting the projection (default one is 3D)
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
Since the Director is a singleton, the standard way to use it is by calling:
|
|
|
|
_ Director::getInstance()->methodName();
|
|
|
|
*/
|
2024-01-29 22:30:14 +08:00
|
|
|
class AX_DLL Director
|
2019-11-23 20:27:39 +08:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
/** Director will trigger an event before set next scene. */
|
|
|
|
static const char* EVENT_BEFORE_SET_NEXT_SCENE;
|
|
|
|
/** Director will trigger an event after set next scene. */
|
|
|
|
static const char* EVENT_AFTER_SET_NEXT_SCENE;
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/** Director will trigger an event when projection type is changed. */
|
|
|
|
static const char* EVENT_PROJECTION_CHANGED;
|
|
|
|
/** Director will trigger an event before Schedule::update() is invoked. */
|
|
|
|
static const char* EVENT_BEFORE_UPDATE;
|
|
|
|
/** Director will trigger an event after Schedule::update() is invoked. */
|
|
|
|
static const char* EVENT_AFTER_UPDATE;
|
|
|
|
/** Director will trigger an event while resetting Director */
|
|
|
|
static const char* EVENT_RESET;
|
|
|
|
/** Director will trigger an event after Scene::render() is invoked. */
|
|
|
|
static const char* EVENT_AFTER_VISIT;
|
|
|
|
/** Director will trigger an event after a scene is drawn, the data is sent to GPU. */
|
|
|
|
static const char* EVENT_AFTER_DRAW;
|
|
|
|
/** Director will trigger an event before a scene is drawn, right after clear. */
|
|
|
|
static const char* EVENT_BEFORE_DRAW;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Possible OpenGL projections used by director
|
|
|
|
*/
|
|
|
|
enum class Projection
|
|
|
|
{
|
|
|
|
/// Sets a 2D projection (orthogonal projection).
|
|
|
|
_2D,
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/// Sets a 3D projection with a fovy=60, znear=0.5f and zfar=1500.
|
|
|
|
_3D,
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/// It calls "updateProjection" on the projection delegate.
|
|
|
|
CUSTOM,
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/// Default projection is 3D projection.
|
|
|
|
DEFAULT = _3D,
|
|
|
|
};
|
2021-12-25 10:04:45 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns a shared instance of the director.
|
2019-11-23 20:27:39 +08:00
|
|
|
* @js _getInstance
|
|
|
|
*/
|
|
|
|
static Director* getInstance();
|
2024-01-29 22:30:14 +08:00
|
|
|
static void destroyInstance();
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @js ctor
|
|
|
|
*/
|
|
|
|
Director();
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/**
|
|
|
|
* @js NA
|
|
|
|
* @lua NA
|
|
|
|
*/
|
|
|
|
~Director();
|
|
|
|
bool init();
|
|
|
|
|
|
|
|
// attribute
|
|
|
|
|
2022-07-01 12:17:08 +08:00
|
|
|
/** Gets the current running Scene. Director can only run one Scene at a time. */
|
2019-11-23 20:27:39 +08:00
|
|
|
Scene* getRunningScene() { return _runningScene; }
|
|
|
|
|
2023-09-07 21:57:41 +08:00
|
|
|
/** Gets the top(next) scene which will going to running state. */
|
|
|
|
Scene* getNextScene() { return _nextScene; }
|
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/** Gets the FPS value. */
|
|
|
|
float getAnimationInterval() { return _animationInterval; }
|
|
|
|
/** Sets the FPS value. FPS = 1/interval. */
|
|
|
|
void setAnimationInterval(float interval);
|
|
|
|
|
2022-07-05 00:39:20 +08:00
|
|
|
/** Whether the FPS on the bottom-left corner of the screen is displayed or not. */
|
2022-07-06 13:44:55 +08:00
|
|
|
bool isStatsDisplay() { return _statsDisplay; }
|
2019-11-23 20:27:39 +08:00
|
|
|
/** Display the FPS on the bottom-left corner of the screen. */
|
2022-07-06 13:44:55 +08:00
|
|
|
void setStatsDisplay(bool displayStats) { _statsDisplay = displayStats; }
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2022-07-01 12:17:08 +08:00
|
|
|
/** Gets the seconds per frame. */
|
2019-11-23 20:27:39 +08:00
|
|
|
float getSecondsPerFrame() { return _secondsPerFrame; }
|
|
|
|
|
2022-07-05 00:39:20 +08:00
|
|
|
/** Sets the stats corner displayed on screen if display stats is enabled. */
|
|
|
|
void setStatsAnchor(AnchorPreset anchor = (AnchorPreset)0);
|
|
|
|
|
|
|
|
/** Sets the FPS value. */
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
/**
|
2019-11-23 20:27:39 +08:00
|
|
|
* Get the GLView.
|
|
|
|
* @lua NA
|
|
|
|
*/
|
2023-12-01 09:04:51 +08:00
|
|
|
GLView* getGLView() { return _glView; }
|
2021-12-25 10:04:45 +08:00
|
|
|
/**
|
|
|
|
* Sets the GLView.
|
2019-11-23 20:27:39 +08:00
|
|
|
* @lua NA
|
|
|
|
*/
|
2023-12-01 09:04:51 +08:00
|
|
|
void setGLView(GLView* glView);
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Gets singleton of TextureCache.
|
|
|
|
* @js NA
|
|
|
|
*/
|
|
|
|
TextureCache* getTextureCache() const;
|
|
|
|
|
|
|
|
/** Whether or not `_nextDeltaTimeZero` is set to 0. */
|
|
|
|
bool isNextDeltaTimeZero() { return _nextDeltaTimeZero; }
|
2021-12-25 10:04:45 +08:00
|
|
|
/**
|
2019-11-23 20:27:39 +08:00
|
|
|
* Sets the delta time between current frame and next frame is 0.
|
2021-12-25 10:04:45 +08:00
|
|
|
* This value will be used in Schedule, and will affect all functions that are using frame delta time, such as
|
|
|
|
* Actions. This value will take effect only one time.
|
2019-11-23 20:27:39 +08:00
|
|
|
*/
|
|
|
|
void setNextDeltaTimeZero(bool nextDeltaTimeZero);
|
|
|
|
|
|
|
|
/** Whether or not the Director is paused. */
|
|
|
|
bool isPaused() { return _paused; }
|
|
|
|
|
|
|
|
/** How many frames were called since the director started */
|
|
|
|
unsigned int getTotalFrames() { return _totalFrames; }
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/** Gets an OpenGL projection.
|
|
|
|
* @since v0.8.2
|
|
|
|
* @lua NA
|
|
|
|
*/
|
|
|
|
Projection getProjection() { return _projection; }
|
|
|
|
/** Sets OpenGL projection. */
|
|
|
|
void setProjection(Projection projection);
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/** Sets the glViewport.*/
|
|
|
|
void setViewport();
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/** Whether or not the replaced scene will receive the cleanup message.
|
|
|
|
* If the new scene is pushed, then the old scene won't receive the "cleanup" message.
|
|
|
|
* If the new scene replaces the old one, the it will receive the "cleanup" message.
|
|
|
|
* @since v0.99.0
|
|
|
|
*/
|
|
|
|
bool isSendCleanupToScene() { return _sendCleanupToScene; }
|
|
|
|
|
|
|
|
/** This object will be visited after the main scene is visited.
|
|
|
|
* This object MUST implement the "visit" function.
|
|
|
|
* Useful to hook a notification object, like Notifications (http://github.com/manucorporat/CCNotifications)
|
|
|
|
* @since v0.99.5
|
|
|
|
*/
|
|
|
|
Node* getNotificationNode() const { return _notificationNode; }
|
2021-12-25 10:04:45 +08:00
|
|
|
/**
|
2019-11-23 20:27:39 +08:00
|
|
|
* Sets the notification node.
|
|
|
|
* @see Director::getNotificationNode()
|
|
|
|
*/
|
2021-12-25 10:04:45 +08:00
|
|
|
void setNotificationNode(Node* node);
|
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
// window size
|
|
|
|
|
|
|
|
/** Returns the size of the OpenGL view in points. */
|
2021-10-23 23:27:14 +08:00
|
|
|
const Vec2& getWinSize() const;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
/** Returns the size of the OpenGL view in pixels. */
|
2021-10-23 23:27:14 +08:00
|
|
|
Vec2 getWinSizeInPixels() const;
|
2021-12-25 10:04:45 +08:00
|
|
|
|
|
|
|
/**
|
2019-11-23 20:27:39 +08:00
|
|
|
* Returns visible size of the OpenGL view in points.
|
|
|
|
* The value is equal to `Director::getWinSize()` if don't invoke `GLView::setDesignResolutionSize()`.
|
|
|
|
*/
|
2021-10-23 23:27:14 +08:00
|
|
|
Vec2 getVisibleSize() const;
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/** Returns visible origin coordinate of the OpenGL view in points. */
|
|
|
|
Vec2 getVisibleOrigin() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns safe area rectangle of the OpenGL view in points.
|
|
|
|
*/
|
|
|
|
Rect getSafeAreaRect() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Converts a screen coordinate to an OpenGL coordinate.
|
|
|
|
* Useful to convert (multi) touch coordinates to the current layout (portrait or landscape).
|
|
|
|
*/
|
|
|
|
Vec2 convertToGL(const Vec2& point);
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
/**
|
2019-11-23 20:27:39 +08:00
|
|
|
* Converts an OpenGL coordinate to a screen coordinate.
|
|
|
|
* Useful to convert node points to window points for calls such as glScissor.
|
|
|
|
*/
|
|
|
|
Vec2 convertToUI(const Vec2& point);
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
/**
|
2019-11-23 20:27:39 +08:00
|
|
|
* Gets the distance between camera and near clipping frame.
|
|
|
|
* It is correct for default camera that near clipping frame is same as the screen.
|
|
|
|
*/
|
|
|
|
float getZEye() const;
|
|
|
|
|
|
|
|
// Scene Management
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
/**
|
2019-11-23 20:27:39 +08:00
|
|
|
* Enters the Director's main loop with the given Scene.
|
|
|
|
* Call it to run only your FIRST scene.
|
|
|
|
* Don't call it if there is already a running scene.
|
|
|
|
*
|
|
|
|
* It will call pushScene: and then it will call startAnimation
|
|
|
|
* @js NA
|
|
|
|
*/
|
2021-12-25 10:04:45 +08:00
|
|
|
void runWithScene(Scene* scene);
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
/**
|
2019-11-23 20:27:39 +08:00
|
|
|
* Suspends the execution of the running scene, pushing it on the stack of suspended scenes.
|
|
|
|
* The new scene will be executed.
|
2021-12-25 10:04:45 +08:00
|
|
|
* Try to avoid big stacks of pushed scenes to reduce memory allocation.
|
2019-11-23 20:27:39 +08:00
|
|
|
* ONLY call it if there is a running scene.
|
|
|
|
*/
|
2021-12-25 10:04:45 +08:00
|
|
|
void pushScene(Scene* scene);
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
/**
|
2019-11-23 20:27:39 +08:00
|
|
|
* Pops out a scene from the stack.
|
|
|
|
* This scene will replace the running one.
|
|
|
|
* The running scene will be deleted. If there are no more scenes in the stack the execution is terminated.
|
|
|
|
* ONLY call it if there is a running scene.
|
|
|
|
*/
|
|
|
|
void popScene();
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
/**
|
2019-11-23 20:27:39 +08:00
|
|
|
* Pops out all scenes from the stack until the root scene in the queue.
|
|
|
|
* This scene will replace the running one.
|
|
|
|
* Internally it will call `popToSceneStackLevel(1)`.
|
|
|
|
*/
|
|
|
|
void popToRootScene();
|
|
|
|
|
|
|
|
/** Pops out all scenes from the stack until it reaches `level`.
|
|
|
|
If level is 0, it will end the director.
|
|
|
|
If level is 1, it will pop all scenes until it reaches to root scene.
|
|
|
|
If level is <= than the current stack level, it won't do anything.
|
|
|
|
*/
|
2021-12-25 10:04:45 +08:00
|
|
|
void popToSceneStackLevel(int level);
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
/** Replaces the running scene with a new one. The running scene is terminated.
|
|
|
|
* ONLY call it if there is a running scene.
|
|
|
|
* @js NA
|
|
|
|
*/
|
2021-12-25 10:04:45 +08:00
|
|
|
void replaceScene(Scene* scene);
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
/** Ends the execution, releases the running scene.
|
|
|
|
* @lua endToLua
|
|
|
|
*/
|
|
|
|
void end();
|
|
|
|
|
|
|
|
/** Pauses the running scene.
|
|
|
|
* The running scene will be _drawed_ but all scheduled timers will be paused.
|
|
|
|
* While paused, the draw rate will be 4 FPS to reduce CPU consumption.
|
|
|
|
*/
|
|
|
|
void pause();
|
|
|
|
|
|
|
|
/** Resumes the paused scene.
|
|
|
|
* The scheduled timers will be activated again.
|
|
|
|
* The "delta time" will be 0 (as if the game wasn't paused).
|
|
|
|
*/
|
|
|
|
void resume();
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/*
|
2021-12-25 10:04:45 +08:00
|
|
|
* Restart the director.
|
2019-11-23 20:27:39 +08:00
|
|
|
* @js NA
|
|
|
|
*/
|
|
|
|
void restart();
|
|
|
|
|
|
|
|
/** Stops the animation. Nothing will be drawn. The main loop won't be triggered anymore.
|
|
|
|
* If you don't want to pause your animation call [pause] instead.
|
|
|
|
*/
|
|
|
|
void stopAnimation();
|
|
|
|
|
|
|
|
/** The main loop is triggered again.
|
|
|
|
* Call this function only if [stopAnimation] was called earlier.
|
|
|
|
* @warning Don't call this function to start the main loop. To run the main loop call runWithScene.
|
|
|
|
*/
|
|
|
|
void startAnimation();
|
|
|
|
|
|
|
|
/** Draw the scene.
|
|
|
|
* This method is called every frame. Don't call it manually.
|
|
|
|
*/
|
|
|
|
void drawScene();
|
|
|
|
|
|
|
|
// Memory Helper
|
|
|
|
|
|
|
|
/** Removes all cocos2d cached data.
|
|
|
|
* It will purge the TextureCache, SpriteFrameCache, LabelBMFont cache
|
|
|
|
* @since v0.99.3
|
|
|
|
*/
|
|
|
|
void purgeCachedData();
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
/** Sets the default values based on the Configuration info. */
|
2019-11-23 20:27:39 +08:00
|
|
|
void setDefaultValues();
|
|
|
|
|
|
|
|
// OpenGL Helper
|
|
|
|
|
|
|
|
/** Sets the OpenGL default values.
|
|
|
|
* It will enable alpha blending, disable depth test.
|
|
|
|
* @js NA
|
|
|
|
*/
|
|
|
|
void setGLDefaultValues();
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/** Sets clear values for the color buffers,
|
|
|
|
* value range of each element is [0.0, 1.0].
|
|
|
|
* @js NA
|
|
|
|
*/
|
|
|
|
void setClearColor(const Color4F& clearColor);
|
|
|
|
|
|
|
|
void mainLoop();
|
|
|
|
/** Invoke main loop with delta time. Then `calculateDeltaTime` can just use the delta time directly.
|
|
|
|
* The delta time paseed may include vsync time. See issue #17806
|
|
|
|
* @since 3.16
|
|
|
|
*/
|
|
|
|
void mainLoop(float dt);
|
|
|
|
|
|
|
|
/** The size in pixels of the surface. It could be different than the screen size.
|
|
|
|
* High-res devices might have a higher surface size than the screen size.
|
|
|
|
* Only available when compiled using SDK >= 4.0.
|
|
|
|
* @since v0.99.4
|
|
|
|
*/
|
|
|
|
void setContentScaleFactor(float scaleFactor);
|
|
|
|
/**
|
|
|
|
* Gets content scale factor.
|
|
|
|
* @see Director::setContentScaleFactor()
|
|
|
|
*/
|
|
|
|
float getContentScaleFactor() const { return _contentScaleFactor; }
|
|
|
|
|
|
|
|
/** Gets the Scheduler associated with this director.
|
|
|
|
* @since v2.0
|
|
|
|
*/
|
|
|
|
Scheduler* getScheduler() const { return _scheduler; }
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/** Sets the Scheduler associated with this director.
|
|
|
|
* @since v2.0
|
|
|
|
*/
|
|
|
|
void setScheduler(Scheduler* scheduler);
|
|
|
|
|
|
|
|
/** Gets the ActionManager associated with this director.
|
|
|
|
* @since v2.0
|
|
|
|
*/
|
|
|
|
ActionManager* getActionManager() const { return _actionManager; }
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/** Sets the ActionManager associated with this director.
|
|
|
|
* @since v2.0
|
|
|
|
*/
|
|
|
|
void setActionManager(ActionManager* actionManager);
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/** Gets the EventDispatcher associated with this director.
|
|
|
|
* @since v3.0
|
|
|
|
* @js NA
|
|
|
|
*/
|
|
|
|
EventDispatcher* getEventDispatcher() const { return _eventDispatcher; }
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/** Sets the EventDispatcher associated with this director.
|
|
|
|
* @since v3.0
|
|
|
|
* @js NA
|
|
|
|
*/
|
|
|
|
void setEventDispatcher(EventDispatcher* dispatcher);
|
|
|
|
|
|
|
|
/** Returns the Renderer associated with this director.
|
|
|
|
* @since v3.0
|
|
|
|
*/
|
|
|
|
Renderer* getRenderer() const { return _renderer; }
|
|
|
|
|
|
|
|
/** Returns the Console associated with this director.
|
|
|
|
* @since v3.0
|
|
|
|
* @js NA
|
|
|
|
*/
|
|
|
|
Console* getConsole() const { return _console; }
|
|
|
|
|
|
|
|
/* Gets delta time since last tick to main loop. */
|
2021-12-25 10:04:45 +08:00
|
|
|
float getDeltaTime() const;
|
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/**
|
|
|
|
* Gets Frame Rate.
|
|
|
|
* @js NA
|
|
|
|
*/
|
|
|
|
float getFrameRate() const { return _frameRate; }
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
/**
|
2019-11-23 20:27:39 +08:00
|
|
|
* Clones a specified type matrix and put it to the top of specified type of matrix stack.
|
|
|
|
* @js NA
|
|
|
|
*/
|
|
|
|
void pushMatrix(MATRIX_STACK_TYPE type);
|
|
|
|
|
|
|
|
/** Pops the top matrix of the specified type of matrix stack.
|
|
|
|
* @js NA
|
|
|
|
*/
|
|
|
|
void popMatrix(MATRIX_STACK_TYPE type);
|
|
|
|
|
|
|
|
/** Adds an identity matrix to the top of specified type of matrix stack.
|
|
|
|
* @js NA
|
|
|
|
*/
|
|
|
|
void loadIdentityMatrix(MATRIX_STACK_TYPE type);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Adds a matrix to the top of specified type of matrix stack.
|
2021-12-25 10:04:45 +08:00
|
|
|
*
|
2019-11-23 20:27:39 +08:00
|
|
|
* @param type Matrix type.
|
|
|
|
* @param mat The matrix that to be added.
|
|
|
|
* @js NA
|
|
|
|
*/
|
|
|
|
void loadMatrix(MATRIX_STACK_TYPE type, const Mat4& mat);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Multiplies a matrix to the top of specified type of matrix stack.
|
|
|
|
*
|
|
|
|
* @param type Matrix type.
|
|
|
|
* @param mat The matrix that to be multiplied.
|
|
|
|
* @js NA
|
|
|
|
*/
|
|
|
|
void multiplyMatrix(MATRIX_STACK_TYPE type, const Mat4& mat);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the top matrix of specified type of matrix stack.
|
|
|
|
* @js NA
|
|
|
|
*/
|
|
|
|
const Mat4& getMatrix(MATRIX_STACK_TYPE type) const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Clear all types of matrix stack, and add identity matrix to these matrix stacks.
|
|
|
|
* @js NA
|
|
|
|
*/
|
|
|
|
void resetMatrixStack();
|
|
|
|
|
|
|
|
/**
|
2022-10-12 07:04:36 +08:00
|
|
|
* returns the axmol thread id.
|
|
|
|
Useful to know if certain code is already running on the axmol thread
|
2019-11-23 20:27:39 +08:00
|
|
|
*/
|
2023-10-25 09:44:08 +08:00
|
|
|
const std::thread::id& getCocos2dThreadId() const { return getAxmolThreadId(); }
|
2022-10-12 07:04:36 +08:00
|
|
|
const std::thread::id& getAxmolThreadId() const { return _axmol_thread_id; }
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2021-11-09 12:15:28 +08:00
|
|
|
/** Enable node tree children indexer map, the concept is like database INDEX
|
2021-12-25 10:04:45 +08:00
|
|
|
* Notes:
|
2021-11-09 12:15:28 +08:00
|
|
|
* If enable is true: will cost more memory to speed up getChildByTag & getChildByName
|
|
|
|
*/
|
|
|
|
void setChildrenIndexerEnabled(bool enable) { _childrenIndexerEnabled = enable; }
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
/**
|
2021-11-09 12:15:28 +08:00
|
|
|
* returns whether or not node tree children indexer map enabled
|
|
|
|
*/
|
|
|
|
bool isChildrenIndexerEnabled() const { return _childrenIndexerEnabled; }
|
|
|
|
|
2023-06-25 01:17:29 +08:00
|
|
|
/** since Axmol-1.0
|
|
|
|
* queue a priority operation in render thread, even through app in background
|
|
|
|
*/
|
|
|
|
void queueOperation(AsyncOperation op, void* param = nullptr);
|
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/**
|
|
|
|
* returns whether or not the Director is in a valid state
|
|
|
|
*/
|
|
|
|
bool isValid() const { return !_invalid; }
|
|
|
|
|
|
|
|
protected:
|
|
|
|
void reset();
|
|
|
|
|
2023-06-25 01:17:29 +08:00
|
|
|
#if defined(AX_PLATFORM_PC)
|
|
|
|
void processOperations();
|
|
|
|
#endif
|
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
virtual void startAnimation(SetIntervalReason reason);
|
|
|
|
virtual void setAnimationInterval(float interval, SetIntervalReason reason);
|
|
|
|
|
2024-01-29 22:30:14 +08:00
|
|
|
void cleanupDirector();
|
|
|
|
bool _cleanupDirectorInNextLoop = false; // this flag will be set to true in end()
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
void restartDirector();
|
2021-12-25 10:04:45 +08:00
|
|
|
bool _restartDirectorInNextLoop = false; // this flag will be set to true in restart()
|
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
void setNextScene();
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
void updateFrameRate();
|
2022-07-16 10:43:05 +08:00
|
|
|
#if !AX_STRIP_FPS
|
2019-11-23 20:27:39 +08:00
|
|
|
void showStats();
|
|
|
|
void createStatsLabel();
|
|
|
|
void calculateMPF();
|
|
|
|
void getFPSImageData(unsigned char** datapointer, ssize_t* length);
|
|
|
|
#endif
|
2021-12-25 10:04:45 +08:00
|
|
|
|
|
|
|
/** calculates delta time since last time it was called */
|
2019-11-23 20:27:39 +08:00
|
|
|
void calculateDeltaTime();
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
// textureCache creation or release
|
2019-11-23 20:27:39 +08:00
|
|
|
void initTextureCache();
|
|
|
|
void destroyTextureCache();
|
|
|
|
|
|
|
|
void initMatrixStack();
|
|
|
|
|
|
|
|
std::stack<Mat4> _modelViewMatrixStack;
|
|
|
|
std::stack<Mat4> _textureMatrixStack;
|
|
|
|
std::stack<Mat4> _projectionMatrixStack;
|
|
|
|
|
|
|
|
/** Scheduler associated with this director
|
|
|
|
@since v2.0
|
|
|
|
*/
|
2021-12-25 10:04:45 +08:00
|
|
|
Scheduler* _scheduler = nullptr;
|
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/** ActionManager associated with this director
|
|
|
|
@since v2.0
|
|
|
|
*/
|
2021-12-25 10:04:45 +08:00
|
|
|
ActionManager* _actionManager = nullptr;
|
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/** EventDispatcher associated with this director
|
|
|
|
@since v3.0
|
|
|
|
*/
|
2021-12-25 10:04:45 +08:00
|
|
|
EventDispatcher* _eventDispatcher = nullptr;
|
2019-11-23 20:27:39 +08:00
|
|
|
EventCustom* _eventProjectionChanged = nullptr;
|
2021-12-25 10:04:45 +08:00
|
|
|
EventCustom* _eventBeforeDraw = nullptr;
|
|
|
|
EventCustom* _eventAfterDraw = nullptr;
|
|
|
|
EventCustom* _eventAfterVisit = nullptr;
|
|
|
|
EventCustom* _eventBeforeUpdate = nullptr;
|
|
|
|
EventCustom* _eventAfterUpdate = nullptr;
|
|
|
|
EventCustom* _eventResetDirector = nullptr;
|
|
|
|
EventCustom* _beforeSetNextScene = nullptr;
|
|
|
|
EventCustom* _afterSetNextScene = nullptr;
|
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/* delta time since last tick to main loop */
|
2021-12-25 10:04:45 +08:00
|
|
|
float _deltaTime = 0.0f;
|
2019-11-23 20:27:39 +08:00
|
|
|
bool _deltaTimePassedByCaller = false;
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2023-12-01 09:04:51 +08:00
|
|
|
/* The _glView, where everything is rendered, GLView is a abstract class,cocos2d-x provide GLViewImpl
|
2019-11-23 20:27:39 +08:00
|
|
|
which inherit from it as default renderer context,you can have your own by inherit from it*/
|
2023-12-01 09:04:51 +08:00
|
|
|
GLView* _glView = nullptr;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
// texture cache belongs to this director
|
|
|
|
TextureCache* _textureCache = nullptr;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
float _animationInterval = 0.0f;
|
2019-11-23 20:27:39 +08:00
|
|
|
float _oldAnimationInterval = 0.0f;
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2022-07-06 13:44:55 +08:00
|
|
|
bool _statsDisplay = false;
|
2021-12-25 10:04:45 +08:00
|
|
|
float _accumDt = 0.0f;
|
|
|
|
float _frameRate = 0.0f;
|
|
|
|
|
|
|
|
LabelAtlas* _FPSLabel = nullptr;
|
|
|
|
LabelAtlas* _drawnBatchesLabel = nullptr;
|
|
|
|
LabelAtlas* _drawnVerticesLabel = nullptr;
|
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/** Whether or not the Director is paused */
|
|
|
|
bool _paused = false;
|
|
|
|
|
|
|
|
/* How many frames were called since the director started */
|
|
|
|
unsigned int _totalFrames = 0;
|
2021-12-25 10:04:45 +08:00
|
|
|
unsigned int _frames = 0;
|
|
|
|
float _secondsPerFrame = 1.f;
|
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/* The running scene */
|
2021-12-25 10:04:45 +08:00
|
|
|
Scene* _runningScene = nullptr;
|
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/* will be the next 'runningScene' in the next frame
|
|
|
|
nextScene is a weak reference. */
|
2021-12-25 10:04:45 +08:00
|
|
|
Scene* _nextScene = nullptr;
|
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/* If true, then "old" scene will receive the cleanup message */
|
|
|
|
bool _sendCleanupToScene = false;
|
|
|
|
|
|
|
|
/* scheduled scenes */
|
|
|
|
Vector<Scene*> _scenesStack;
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/* last time the main loop was updated */
|
|
|
|
std::chrono::steady_clock::time_point _lastUpdate;
|
|
|
|
|
|
|
|
/* whether or not the next delta time will be zero */
|
|
|
|
bool _nextDeltaTimeZero = false;
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/* projection used */
|
|
|
|
Projection _projection = Projection::DEFAULT;
|
|
|
|
|
|
|
|
/* window size in points */
|
2021-10-23 23:27:14 +08:00
|
|
|
Vec2 _winSizeInPoints = Vec2::ZERO;
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/* content scale factor */
|
|
|
|
float _contentScaleFactor = 1.0f;
|
|
|
|
|
|
|
|
/* This object will be visited after the scene. Useful to hook a notification node */
|
2021-12-25 10:04:45 +08:00
|
|
|
Node* _notificationNode = nullptr;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
/* Renderer for the Director */
|
2021-12-25 10:04:45 +08:00
|
|
|
Renderer* _renderer = nullptr;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
Color4F _clearColor = {0, 0, 0, 1};
|
|
|
|
|
|
|
|
/* Console for the director */
|
2021-12-25 10:04:45 +08:00
|
|
|
Console* _console = nullptr;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
bool _isStatusLabelUpdated = true;
|
|
|
|
|
2021-11-08 14:43:24 +08:00
|
|
|
/* whether or not the director is in a valid state */
|
|
|
|
bool _invalid = false;
|
|
|
|
|
2021-11-09 12:15:28 +08:00
|
|
|
bool _childrenIndexerEnabled = false;
|
|
|
|
|
2022-10-12 07:04:36 +08:00
|
|
|
/* axmol thread id */
|
|
|
|
std::thread::id _axmol_thread_id;
|
2021-11-09 12:15:28 +08:00
|
|
|
|
2023-06-25 01:17:29 +08:00
|
|
|
#if defined(AX_PLATFORM_PC)
|
|
|
|
/* axmol priority operations in render thread for PC platforms */
|
|
|
|
moodycamel::ConcurrentQueue<std::function<void()>> _operations;
|
|
|
|
#endif
|
|
|
|
|
2023-10-25 09:44:08 +08:00
|
|
|
#if AX_ENABLE_CACHE_TEXTURE_DATA
|
|
|
|
EventListenerCustom* _rendererRecreatedListener = nullptr;
|
|
|
|
#endif
|
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
// GLView will recreate stats labels to fit visible rect
|
|
|
|
friend class GLView;
|
|
|
|
};
|
|
|
|
|
|
|
|
// end of base group
|
|
|
|
/** @} */
|
|
|
|
|
2022-07-11 17:50:21 +08:00
|
|
|
NS_AX_END
|