mirror of https://github.com/axmolengine/axmol.git
Remove useless functions.
This commit is contained in:
parent
ee6d7d374e
commit
5491ca8e6e
|
@ -27,7 +27,6 @@
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
#include "2d/CCCamera.h"
|
#include "2d/CCCamera.h"
|
||||||
#include "2d/CCCameraBackgroundBrush.h"
|
#include "2d/CCCameraBackgroundBrush.h"
|
||||||
#include "base/CCDirector.h"
|
|
||||||
#include "platform/CCGLView.h"
|
#include "platform/CCGLView.h"
|
||||||
#include "2d/CCScene.h"
|
#include "2d/CCScene.h"
|
||||||
#include "renderer/CCRenderer.h"
|
#include "renderer/CCRenderer.h"
|
||||||
|
@ -94,6 +93,13 @@ const Camera* Camera::getVisitingCamera()
|
||||||
// end static methods
|
// end static methods
|
||||||
|
|
||||||
Camera::Camera()
|
Camera::Camera()
|
||||||
|
: _eyeZdistance(1)
|
||||||
|
, _zoomFactor(1)
|
||||||
|
, _nearPlane(-1024)
|
||||||
|
, _farPlane(1024)
|
||||||
|
, _zoomFactorNearPlane(10)
|
||||||
|
, _zoomFactorFarPlane(1024)
|
||||||
|
, _isCameraInitialized(false)
|
||||||
{
|
{
|
||||||
// minggo comment
|
// minggo comment
|
||||||
// _frustum.setClipZ(true);
|
// _frustum.setClipZ(true);
|
||||||
|
@ -137,6 +143,7 @@ void Camera::lookAt(const Vec3& lookAtPos, const Vec3& up)
|
||||||
Vec3::cross(zaxis, xaxis, &yaxis);
|
Vec3::cross(zaxis, xaxis, &yaxis);
|
||||||
yaxis.normalize();
|
yaxis.normalize();
|
||||||
Mat4 rotation;
|
Mat4 rotation;
|
||||||
|
|
||||||
rotation.m[0] = xaxis.x;
|
rotation.m[0] = xaxis.x;
|
||||||
rotation.m[1] = xaxis.y;
|
rotation.m[1] = xaxis.y;
|
||||||
rotation.m[2] = xaxis.z;
|
rotation.m[2] = xaxis.z;
|
||||||
|
@ -146,6 +153,7 @@ void Camera::lookAt(const Vec3& lookAtPos, const Vec3& up)
|
||||||
rotation.m[5] = yaxis.y;
|
rotation.m[5] = yaxis.y;
|
||||||
rotation.m[6] = yaxis.z;
|
rotation.m[6] = yaxis.z;
|
||||||
rotation.m[7] = 0;
|
rotation.m[7] = 0;
|
||||||
|
|
||||||
rotation.m[8] = zaxis.x;
|
rotation.m[8] = zaxis.x;
|
||||||
rotation.m[9] = zaxis.y;
|
rotation.m[9] = zaxis.y;
|
||||||
rotation.m[10] = zaxis.z;
|
rotation.m[10] = zaxis.z;
|
||||||
|
@ -177,15 +185,27 @@ void Camera::setAdditionalProjection(const Mat4& mat)
|
||||||
|
|
||||||
bool Camera::initDefault()
|
bool Camera::initDefault()
|
||||||
{
|
{
|
||||||
auto size = _director->getWinSize();
|
if (_projectionType != _director->getProjection())
|
||||||
|
{
|
||||||
|
_projectionType = _director->getProjection();
|
||||||
|
_isCameraInitialized = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (_isCameraInitialized)
|
||||||
|
{
|
||||||
|
applyCustomProperties();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
_isCameraInitialized = true;
|
||||||
|
|
||||||
|
auto& size = _director->getWinSize();
|
||||||
// create default camera
|
// create default camera
|
||||||
auto projection = _director->getProjection();
|
switch (_projectionType)
|
||||||
switch (projection)
|
|
||||||
{
|
{
|
||||||
case Director::Projection::_2D:
|
case Director::Projection::_2D:
|
||||||
{
|
{
|
||||||
initOrthographic(size.width, size.height, -1024, 1024);
|
initOrthographic(size.width / 2, size.height / 2, -1024, 1024);
|
||||||
setPosition3D(Vec3(0.0f, 0.0f, 0.0f));
|
setPosition3D(Vec3(size.width / 2, size.height / 2, 0.f));
|
||||||
setRotation3D(Vec3(0.f, 0.f, 0.f));
|
setRotation3D(Vec3(0.f, 0.f, 0.f));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -193,8 +213,9 @@ bool Camera::initDefault()
|
||||||
{
|
{
|
||||||
float zeye = _director->getZEye();
|
float zeye = _director->getZEye();
|
||||||
initPerspective(60, (float)size.width / size.height, 10, zeye + size.height / 2.0f);
|
initPerspective(60, (float)size.width / size.height, 10, zeye + size.height / 2.0f);
|
||||||
Vec3 eye(size.width / 2, size.height / 2.0f, zeye), center(size.width / 2, size.height / 2, 0.0f),
|
Vec3 eye(size.width / 2.0f, size.height / 2.0f, zeye), center(size.width / 2.0f, size.height / 2.0f, 0.0f),
|
||||||
up(0.0f, 1.0f, 0.0f);
|
up(0.0f, 1.0f, 0.0f);
|
||||||
|
_eyeZdistance = eye.z;
|
||||||
setPosition3D(eye);
|
setPosition3D(eye);
|
||||||
lookAt(center, up);
|
lookAt(center, up);
|
||||||
break;
|
break;
|
||||||
|
@ -203,6 +224,8 @@ bool Camera::initDefault()
|
||||||
CCLOG("unrecognized projection");
|
CCLOG("unrecognized projection");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
if (_zoomFactor != 1.0F)
|
||||||
|
applyZoom();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -212,6 +235,12 @@ bool Camera::initPerspective(float fieldOfView, float aspectRatio, float nearPla
|
||||||
_aspectRatio = aspectRatio;
|
_aspectRatio = aspectRatio;
|
||||||
_nearPlane = nearPlane;
|
_nearPlane = nearPlane;
|
||||||
_farPlane = farPlane;
|
_farPlane = farPlane;
|
||||||
|
|
||||||
|
if (_zoomFactorFarPlane == 1024)
|
||||||
|
_zoomFactorFarPlane = farPlane;
|
||||||
|
if (_zoomFactorNearPlane == 10)
|
||||||
|
_zoomFactorNearPlane = nearPlane;
|
||||||
|
|
||||||
Mat4::createPerspective(_fieldOfView, _aspectRatio, _nearPlane, _farPlane, &_projection);
|
Mat4::createPerspective(_fieldOfView, _aspectRatio, _nearPlane, _farPlane, &_projection);
|
||||||
_viewProjectionDirty = true;
|
_viewProjectionDirty = true;
|
||||||
_frustumDirty = true;
|
_frustumDirty = true;
|
||||||
|
@ -226,7 +255,7 @@ bool Camera::initOrthographic(float zoomX, float zoomY, float nearPlane, float f
|
||||||
_zoom[1] = zoomY;
|
_zoom[1] = zoomY;
|
||||||
_nearPlane = nearPlane;
|
_nearPlane = nearPlane;
|
||||||
_farPlane = farPlane;
|
_farPlane = farPlane;
|
||||||
Mat4::createOrthographicOffCenter(0, _zoom[0], 0, _zoom[1], _nearPlane, _farPlane, &_projection);
|
Mat4::createOrthographicOffCenter(-_zoom[0], _zoom[0], -_zoom[1], _zoom[1], _nearPlane, _farPlane, &_projection);
|
||||||
_viewProjectionDirty = true;
|
_viewProjectionDirty = true;
|
||||||
_frustumDirty = true;
|
_frustumDirty = true;
|
||||||
_type = Type::ORTHOGRAPHIC;
|
_type = Type::ORTHOGRAPHIC;
|
||||||
|
@ -259,7 +288,7 @@ Vec2 Camera::projectGL(const Vec3& src) const
|
||||||
Vec4 clipPos;
|
Vec4 clipPos;
|
||||||
getViewProjectionMatrix().transformVector(Vec4(src.x, src.y, src.z, 1.0f), &clipPos);
|
getViewProjectionMatrix().transformVector(Vec4(src.x, src.y, src.z, 1.0f), &clipPos);
|
||||||
|
|
||||||
CCASSERT(clipPos.w != 0.0f, "clipPos.w can't be 0.0f!");
|
//CCASSERT(clipPos.w != 0.0f, "clipPos.w can't be 0.0f!");
|
||||||
float ndcX = clipPos.x / clipPos.w;
|
float ndcX = clipPos.x / clipPos.w;
|
||||||
float ndcY = clipPos.y / clipPos.w;
|
float ndcY = clipPos.y / clipPos.w;
|
||||||
|
|
||||||
|
@ -354,6 +383,81 @@ void Camera::setDepth(int8_t depth)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Camera::setZoom(float factor)
|
||||||
|
{
|
||||||
|
if (_projectionType == Director::Projection::_3D)
|
||||||
|
{
|
||||||
|
// Push the far plane farther the more we zoom out.
|
||||||
|
if (_zoomFactorFarPlane * factor > _farPlane)
|
||||||
|
{
|
||||||
|
_farPlane = _zoomFactorFarPlane * factor;
|
||||||
|
applyCustomProperties();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Push the near plane closer the more we zoom in.
|
||||||
|
if (_zoomFactorNearPlane * factor < _nearPlane)
|
||||||
|
{
|
||||||
|
_nearPlane = _zoomFactorNearPlane * factor;
|
||||||
|
applyCustomProperties();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
_zoomFactor = factor;
|
||||||
|
applyZoom();
|
||||||
|
}
|
||||||
|
|
||||||
|
void Camera::applyZoom()
|
||||||
|
{
|
||||||
|
switch (_projectionType)
|
||||||
|
{
|
||||||
|
case cocos2d::Director::Projection::_2D:
|
||||||
|
{
|
||||||
|
this->setScale(_zoomFactor);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case cocos2d::Director::Projection::_3D:
|
||||||
|
{
|
||||||
|
this->setPositionZ(_eyeZdistance * _zoomFactor);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Camera::applyCustomProperties()
|
||||||
|
{
|
||||||
|
if (_projectionType != _director->getProjection())
|
||||||
|
{
|
||||||
|
_projectionType = _director->getProjection();
|
||||||
|
_isCameraInitialized = false;
|
||||||
|
initDefault();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
auto& size = _director->getWinSize();
|
||||||
|
// create default camera
|
||||||
|
switch (_projectionType)
|
||||||
|
{
|
||||||
|
case Director::Projection::_2D:
|
||||||
|
{
|
||||||
|
initOrthographic(size.width / 2, size.height / 2, _nearPlane, _farPlane);
|
||||||
|
setPosition3D(Vec3(size.width / 2, size.height / 2, 0.f));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case Director::Projection::_3D:
|
||||||
|
{
|
||||||
|
float zeye = _director->getZEye();
|
||||||
|
initPerspective(_fieldOfView, _aspectRatio, _nearPlane, _farPlane);
|
||||||
|
Vec3 eye(size.width / 2.0f, size.height / 2.0f, zeye), center(size.width / 2.0f, size.height / 2.0f, 0.0f),
|
||||||
|
up(0.0f, 1.0f, 0.0f);
|
||||||
|
_eyeZdistance = eye.z;
|
||||||
|
setPosition3D(eye);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (_zoomFactor != 1.0F)
|
||||||
|
applyZoom();
|
||||||
|
}
|
||||||
|
|
||||||
void Camera::onEnter()
|
void Camera::onEnter()
|
||||||
{
|
{
|
||||||
if (_scene == nullptr)
|
if (_scene == nullptr)
|
||||||
|
@ -431,6 +535,30 @@ int Camera::getRenderOrder() const
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Camera::setAspectRatio(float ratio)
|
||||||
|
{
|
||||||
|
_aspectRatio = ratio;
|
||||||
|
applyCustomProperties();
|
||||||
|
}
|
||||||
|
|
||||||
|
void Camera::setFOV(float fieldOfView)
|
||||||
|
{
|
||||||
|
_fieldOfView = fieldOfView;
|
||||||
|
applyCustomProperties();
|
||||||
|
}
|
||||||
|
|
||||||
|
void Camera::setFarPlane(float farPlane)
|
||||||
|
{
|
||||||
|
_farPlane = farPlane;
|
||||||
|
applyCustomProperties();
|
||||||
|
}
|
||||||
|
|
||||||
|
void Camera::setNearPlane(float nearPlane)
|
||||||
|
{
|
||||||
|
_nearPlane = nearPlane;
|
||||||
|
applyCustomProperties();
|
||||||
|
}
|
||||||
|
|
||||||
void Camera::visit(Renderer* renderer, const Mat4& parentTransform, uint32_t parentFlags)
|
void Camera::visit(Renderer* renderer, const Mat4& parentTransform, uint32_t parentFlags)
|
||||||
{
|
{
|
||||||
_viewProjectionUpdated = _transformUpdated;
|
_viewProjectionUpdated = _transformUpdated;
|
||||||
|
|
|
@ -31,6 +31,7 @@ THE SOFTWARE.
|
||||||
#include "3d/CCFrustum.h"
|
#include "3d/CCFrustum.h"
|
||||||
#include "renderer/CCQuadCommand.h"
|
#include "renderer/CCQuadCommand.h"
|
||||||
#include "renderer/CCCustomCommand.h"
|
#include "renderer/CCCustomCommand.h"
|
||||||
|
#include "base/CCDirector.h"
|
||||||
|
|
||||||
NS_CC_BEGIN
|
NS_CC_BEGIN
|
||||||
|
|
||||||
|
@ -234,22 +235,96 @@ public:
|
||||||
int getRenderOrder() const;
|
int getRenderOrder() const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the frustum's far plane.
|
* Gets the aspect ratio of the camera if the projection mode is 3D.
|
||||||
|
*
|
||||||
|
* @since adxe-1.0.0b8
|
||||||
|
*/
|
||||||
|
float getAspectRatio() const { return _fieldOfView; }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the aspect ratio of the camera if the projection mode is 3D.
|
||||||
|
*
|
||||||
|
* @since adxe-1.0.0b8
|
||||||
|
*/
|
||||||
|
void setAspectRatio(float ratio);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the field of view of the camera if the projection mode is 3D.
|
||||||
|
*
|
||||||
|
* @since adxe-1.0.0b8
|
||||||
|
*/
|
||||||
|
float getFOV() const { return _fieldOfView; }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the field of view of the camera if the projection mode is 3D.
|
||||||
|
*
|
||||||
|
* @since adxe-1.0.0b8
|
||||||
|
*/
|
||||||
|
void setFOV(float fov);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the frustum's far plane.
|
||||||
*/
|
*/
|
||||||
float getFarPlane() const { return _farPlane; }
|
float getFarPlane() const { return _farPlane; }
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the frustum's near plane.
|
* Sets the frustum's far plane.
|
||||||
|
*
|
||||||
|
* @since adxe-1.0.0b8
|
||||||
|
*/
|
||||||
|
void setFarPlane(float farPlane);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the frustum's near plane.
|
||||||
*/
|
*/
|
||||||
float getNearPlane() const { return _nearPlane; }
|
float getNearPlane() const { return _nearPlane; }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the frustum's near plane.
|
||||||
|
*
|
||||||
|
* @since adxe-1.0.0b8
|
||||||
|
*/
|
||||||
|
void setNearPlane(float nearPlane);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the zoom multiplier of the camera.
|
||||||
|
*
|
||||||
|
* @since adxe-1.0.0b8
|
||||||
|
*/
|
||||||
|
float getZoom() const { return _zoomFactor; }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the zoom multiplier of the camera.
|
||||||
|
* This is designed to be used with 2D views only.
|
||||||
|
*
|
||||||
|
* @param factor The zoom factor of the camera.
|
||||||
|
*
|
||||||
|
* @since adxe-1.0.0b8
|
||||||
|
*/
|
||||||
|
void setZoom(float factor);
|
||||||
|
|
||||||
|
/**
|
||||||
|
Apply the zoom factor.
|
||||||
|
*
|
||||||
|
* @since adxe-1.0.0b8
|
||||||
|
*/
|
||||||
|
void applyZoom();
|
||||||
|
|
||||||
|
/**
|
||||||
|
Apply the fov, near far planes and aspect values non-destructively.
|
||||||
|
*
|
||||||
|
* @since adxe-1.0.0b8
|
||||||
|
*/
|
||||||
|
void applyCustomProperties();
|
||||||
|
|
||||||
// override
|
// override
|
||||||
virtual void onEnter() override;
|
virtual void onEnter() override;
|
||||||
virtual void onExit() override;
|
virtual void onExit() override;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Before rendering scene with this camera, the background need to be cleared. It clears the depth buffer with max
|
Before rendering the scene with this camera, the background needs to be cleared.
|
||||||
depth by default. Use setBackgroundBrush to modify the default behavior
|
It will clear the depth buffer with max depth by default.
|
||||||
|
Use setBackgroundBrush to modify this default behavior.
|
||||||
*/
|
*/
|
||||||
void clearBackground();
|
void clearBackground();
|
||||||
/**
|
/**
|
||||||
|
@ -258,8 +333,8 @@ public:
|
||||||
void apply();
|
void apply();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Whether or not the viewprojection matrix was updated since the last frame.
|
* Whether or not the viewprojection matrix was updated last frame.
|
||||||
* @return True if the viewprojection matrix was updated since the last frame.
|
* @return True if the viewprojection matrix was updated last frame.
|
||||||
*/
|
*/
|
||||||
bool isViewProjectionUpdated() const { return _viewProjectionUpdated; }
|
bool isViewProjectionUpdated() const { return _viewProjectionUpdated; }
|
||||||
|
|
||||||
|
@ -282,7 +357,7 @@ public:
|
||||||
~Camera();
|
~Camera();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set the scene,this method shall not be invoke manually
|
* Set the owner scene of the camera, this method shall not be invoked manually
|
||||||
*/
|
*/
|
||||||
void setScene(Scene* scene);
|
void setScene(Scene* scene);
|
||||||
|
|
||||||
|
@ -290,7 +365,7 @@ public:
|
||||||
* WP8*/
|
* WP8*/
|
||||||
void setAdditionalProjection(const Mat4& mat);
|
void setAdditionalProjection(const Mat4& mat);
|
||||||
|
|
||||||
/** init camera */
|
/** Initialize the camera with default properties */
|
||||||
bool initDefault();
|
bool initDefault();
|
||||||
bool initPerspective(float fieldOfView, float aspectRatio, float nearPlane, float farPlane);
|
bool initPerspective(float fieldOfView, float aspectRatio, float nearPlane, float farPlane);
|
||||||
bool initOrthographic(float zoomX, float zoomY, float nearPlane, float farPlane);
|
bool initOrthographic(float zoomX, float zoomY, float nearPlane, float farPlane);
|
||||||
|
@ -300,7 +375,7 @@ protected:
|
||||||
static Camera* _visitingCamera;
|
static Camera* _visitingCamera;
|
||||||
static Viewport _defaultViewport;
|
static Viewport _defaultViewport;
|
||||||
|
|
||||||
Scene* _scene = nullptr; // Scene camera belongs to
|
Scene* _scene = nullptr; // Scene that owns this camera.
|
||||||
Mat4 _projection;
|
Mat4 _projection;
|
||||||
mutable Mat4 _view;
|
mutable Mat4 _view;
|
||||||
mutable Mat4 _viewInv;
|
mutable Mat4 _viewInv;
|
||||||
|
@ -320,6 +395,14 @@ protected:
|
||||||
mutable bool _frustumDirty = true;
|
mutable bool _frustumDirty = true;
|
||||||
int8_t _depth = -1; // camera depth, the depth of camera with CameraFlag::DEFAULT flag is 0 by default, a camera
|
int8_t _depth = -1; // camera depth, the depth of camera with CameraFlag::DEFAULT flag is 0 by default, a camera
|
||||||
// with larger depth is drawn on top of camera with smaller depth
|
// with larger depth is drawn on top of camera with smaller depth
|
||||||
|
Director::Projection _projectionType;
|
||||||
|
|
||||||
|
float _eyeZdistance; // Z eye projection distance for 2D in 3D projection.
|
||||||
|
float _zoomFactor; // The zoom factor of the camera. 3D = (cameraZDistance * _zoomFactor), 2D = (cameraScale * _zoomFactor)
|
||||||
|
float _zoomFactorFarPlane;
|
||||||
|
float _zoomFactorNearPlane;
|
||||||
|
|
||||||
|
bool _isCameraInitialized;
|
||||||
|
|
||||||
CameraBackgroundBrush* _clearBrush = nullptr; // brush used to clear the back ground
|
CameraBackgroundBrush* _clearBrush = nullptr; // brush used to clear the back ground
|
||||||
};
|
};
|
||||||
|
|
|
@ -104,6 +104,7 @@ void FontAtlas::reinit()
|
||||||
|
|
||||||
addNewPage();
|
addNewPage();
|
||||||
}
|
}
|
||||||
|
|
||||||
FontAtlas::~FontAtlas()
|
FontAtlas::~FontAtlas()
|
||||||
{
|
{
|
||||||
#if CC_ENABLE_CACHE_TEXTURE_DATA
|
#if CC_ENABLE_CACHE_TEXTURE_DATA
|
||||||
|
@ -227,8 +228,8 @@ bool FontAtlas::prepareLetterDefinitions(const std::u32string& utf32Text)
|
||||||
|
|
||||||
int adjustForDistanceMap = _letterPadding / 2;
|
int adjustForDistanceMap = _letterPadding / 2;
|
||||||
int adjustForExtend = _letterEdgeExtend / 2;
|
int adjustForExtend = _letterEdgeExtend / 2;
|
||||||
int32_t bitmapWidth = 0;
|
int bitmapWidth = 0;
|
||||||
int32_t bitmapHeight = 0;
|
int bitmapHeight = 0;
|
||||||
int glyphHeight;
|
int glyphHeight;
|
||||||
Rect tempRect;
|
Rect tempRect;
|
||||||
FontLetterDefinition tempDef;
|
FontLetterDefinition tempDef;
|
||||||
|
@ -280,18 +281,13 @@ bool FontAtlas::prepareLetterDefinitions(const std::u32string& utf32Text)
|
||||||
tempDef.U = tempDef.U / scaleFactor;
|
tempDef.U = tempDef.U / scaleFactor;
|
||||||
tempDef.V = tempDef.V / scaleFactor;
|
tempDef.V = tempDef.V / scaleFactor;
|
||||||
tempDef.rotated = false;
|
tempDef.rotated = false;
|
||||||
|
|
||||||
updateTextureContent(pixelFormat, startY);
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{ // don't render anythings
|
{
|
||||||
if (bitmap)
|
if (bitmap)
|
||||||
delete[] bitmap;
|
delete[] bitmap;
|
||||||
if (tempDef.xAdvance)
|
|
||||||
tempDef.validDefinition = true;
|
|
||||||
else
|
|
||||||
tempDef.validDefinition = false;
|
|
||||||
|
|
||||||
|
tempDef.validDefinition = !!tempDef.xAdvance;
|
||||||
tempDef.width = 0;
|
tempDef.width = 0;
|
||||||
tempDef.height = 0;
|
tempDef.height = 0;
|
||||||
tempDef.U = 0;
|
tempDef.U = 0;
|
||||||
|
@ -306,6 +302,8 @@ bool FontAtlas::prepareLetterDefinitions(const std::u32string& utf32Text)
|
||||||
_letterDefinitions[charCode] = tempDef;
|
_letterDefinitions[charCode] = tempDef;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
updateTextureContent(pixelFormat, startY);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -370,7 +368,6 @@ void FontAtlas::addNewPage()
|
||||||
texture->release();
|
texture->release();
|
||||||
|
|
||||||
_currentPageOrigY = 0;
|
_currentPageOrigY = 0;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void FontAtlas::setTexture(unsigned int slot, Texture2D* texture)
|
void FontAtlas::setTexture(unsigned int slot, Texture2D* texture)
|
||||||
|
|
|
@ -26,10 +26,6 @@ THE SOFTWARE.
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#include "2d/CCFontFreeType.h"
|
#include "2d/CCFontFreeType.h"
|
||||||
|
|
||||||
#include "freetype/ftfntfmt.h"
|
|
||||||
|
|
||||||
#include FT_BBOX_H
|
|
||||||
#include "2d/CCFontAtlas.h"
|
#include "2d/CCFontAtlas.h"
|
||||||
#include "base/CCDirector.h"
|
#include "base/CCDirector.h"
|
||||||
#include "base/ccUTF8.h"
|
#include "base/ccUTF8.h"
|
||||||
|
@ -37,6 +33,12 @@ THE SOFTWARE.
|
||||||
#include "platform/CCFileUtils.h"
|
#include "platform/CCFileUtils.h"
|
||||||
#include "platform/CCFileStream.h"
|
#include "platform/CCFileStream.h"
|
||||||
|
|
||||||
|
#include "ft2build.h"
|
||||||
|
#include FT_FREETYPE_H
|
||||||
|
#include FT_STROKER_H
|
||||||
|
#include FT_BBOX_H
|
||||||
|
#include FT_FONT_FORMATS_H
|
||||||
|
|
||||||
NS_CC_BEGIN
|
NS_CC_BEGIN
|
||||||
|
|
||||||
FT_Library FontFreeType::_FTlibrary;
|
FT_Library FontFreeType::_FTlibrary;
|
||||||
|
@ -151,6 +153,7 @@ FT_Library FontFreeType::getFTLibrary()
|
||||||
// clang-format off
|
// clang-format off
|
||||||
FontFreeType::FontFreeType(bool distanceFieldEnabled /* = false */, float outline /* = 0 */)
|
FontFreeType::FontFreeType(bool distanceFieldEnabled /* = false */, float outline /* = 0 */)
|
||||||
: _fontFace(nullptr)
|
: _fontFace(nullptr)
|
||||||
|
, _fontStream(nullptr)
|
||||||
, _stroker(nullptr)
|
, _stroker(nullptr)
|
||||||
, _distanceFieldEnabled(distanceFieldEnabled)
|
, _distanceFieldEnabled(distanceFieldEnabled)
|
||||||
, _outlineSize(0.0f)
|
, _outlineSize(0.0f)
|
||||||
|
@ -172,6 +175,28 @@ FontFreeType::FontFreeType(bool distanceFieldEnabled /* = false */, float outlin
|
||||||
}
|
}
|
||||||
// clang-format on
|
// clang-format on
|
||||||
|
|
||||||
|
FontFreeType::~FontFreeType()
|
||||||
|
{
|
||||||
|
if (_FTInitialized)
|
||||||
|
{
|
||||||
|
if (_stroker)
|
||||||
|
FT_Stroker_Done(_stroker);
|
||||||
|
|
||||||
|
if (_fontFace)
|
||||||
|
FT_Done_Face(_fontFace);
|
||||||
|
}
|
||||||
|
|
||||||
|
delete _fontStream;
|
||||||
|
|
||||||
|
auto iter = s_cacheFontData.find(_fontName);
|
||||||
|
if (iter != s_cacheFontData.end())
|
||||||
|
{
|
||||||
|
iter->second.referenceCount -= 1;
|
||||||
|
if (iter->second.referenceCount == 0)
|
||||||
|
s_cacheFontData.erase(iter);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
bool FontFreeType::loadFontFace(std::string_view fontPath, float fontSize)
|
bool FontFreeType::loadFontFace(std::string_view fontPath, float fontSize)
|
||||||
{
|
{
|
||||||
FT_Face face;
|
FT_Face face;
|
||||||
|
@ -187,20 +212,20 @@ bool FontFreeType::loadFontFace(std::string_view fontPath, float fontSize)
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::unique_ptr<FT_StreamRec> fts(new FT_StreamRec());
|
FT_Stream fts = new FT_StreamRec();
|
||||||
fts->read = ft_stream_read_callback;
|
fts->read = ft_stream_read_callback;
|
||||||
fts->close = ft_stream_close_callback;
|
fts->close = ft_stream_close_callback;
|
||||||
fts->size = static_cast<unsigned long>(fs->size());
|
fts->size = static_cast<unsigned long>(fs->size());
|
||||||
fts->descriptor.pointer = fs.release(); // transfer ownership to FT_Open_Face
|
fts->descriptor.pointer = fs.release(); // transfer ownership to FT_Open_Face
|
||||||
|
|
||||||
FT_Open_Args args = {0};
|
FT_Open_Args args = {};
|
||||||
args.flags = FT_OPEN_STREAM;
|
args.flags = FT_OPEN_STREAM;
|
||||||
args.stream = fts.get();
|
args.stream = fts;
|
||||||
|
|
||||||
|
_fontStream = fts;
|
||||||
|
|
||||||
if (FT_Open_Face(getFTLibrary(), &args, 0, &face))
|
if (FT_Open_Face(getFTLibrary(), &args, 0, &face))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
_fontStream = std::move(fts);
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -274,31 +299,6 @@ bool FontFreeType::loadFontFace(std::string_view fontPath, float fontSize)
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
FontFreeType::~FontFreeType()
|
|
||||||
{
|
|
||||||
if (_FTInitialized)
|
|
||||||
{
|
|
||||||
if (_stroker)
|
|
||||||
{
|
|
||||||
FT_Stroker_Done(_stroker);
|
|
||||||
}
|
|
||||||
if (_fontFace)
|
|
||||||
{
|
|
||||||
FT_Done_Face(_fontFace);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
auto iter = s_cacheFontData.find(_fontName);
|
|
||||||
if (iter != s_cacheFontData.end())
|
|
||||||
{
|
|
||||||
iter->second.referenceCount -= 1;
|
|
||||||
if (iter->second.referenceCount == 0)
|
|
||||||
{
|
|
||||||
s_cacheFontData.erase(iter);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
FontAtlas* FontFreeType::newFontAtlas()
|
FontAtlas* FontFreeType::newFontAtlas()
|
||||||
{
|
{
|
||||||
auto fontAtlas = new FontAtlas(this);
|
auto fontAtlas = new FontAtlas(this);
|
||||||
|
@ -341,13 +341,13 @@ int* FontFreeType::getHorizontalKerningForTextUTF32(const std::u32string& text,
|
||||||
int FontFreeType::getHorizontalKerningForChars(uint64_t firstChar, uint64_t secondChar) const
|
int FontFreeType::getHorizontalKerningForChars(uint64_t firstChar, uint64_t secondChar) const
|
||||||
{
|
{
|
||||||
// get the ID to the char we need
|
// get the ID to the char we need
|
||||||
int glyphIndex1 = FT_Get_Char_Index(_fontFace, static_cast<FT_ULong>(firstChar));
|
auto glyphIndex1 = FT_Get_Char_Index(_fontFace, static_cast<FT_ULong>(firstChar));
|
||||||
|
|
||||||
if (!glyphIndex1)
|
if (!glyphIndex1)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
// get the ID to the char we need
|
// get the ID to the char we need
|
||||||
int glyphIndex2 = FT_Get_Char_Index(_fontFace, static_cast<FT_ULong>(secondChar));
|
auto glyphIndex2 = FT_Get_Char_Index(_fontFace, static_cast<FT_ULong>(secondChar));
|
||||||
|
|
||||||
if (!glyphIndex2)
|
if (!glyphIndex2)
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -374,8 +374,8 @@ const char* FontFreeType::getFontFamily() const
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned char* FontFreeType::getGlyphBitmap(char32_t charCode,
|
unsigned char* FontFreeType::getGlyphBitmap(char32_t charCode,
|
||||||
int32_t& outWidth,
|
int& outWidth,
|
||||||
int32_t& outHeight,
|
int& outHeight,
|
||||||
Rect& outRect,
|
Rect& outRect,
|
||||||
int& xAdvance)
|
int& xAdvance)
|
||||||
{
|
{
|
||||||
|
@ -386,7 +386,7 @@ unsigned char* FontFreeType::getGlyphBitmap(char32_t charCode,
|
||||||
if (_fontFace == nullptr)
|
if (_fontFace == nullptr)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
// @remark: glyphIndex=0 means charactor is mssing on current font face
|
// @remark: glyphIndex=0 means character is missing on current font face
|
||||||
auto glyphIndex = FT_Get_Char_Index(_fontFace, static_cast<FT_ULong>(charCode));
|
auto glyphIndex = FT_Get_Char_Index(_fontFace, static_cast<FT_ULong>(charCode));
|
||||||
#if defined(COCOS2D_DEBUG) && COCOS2D_DEBUG > 0
|
#if defined(COCOS2D_DEBUG) && COCOS2D_DEBUG > 0
|
||||||
if (glyphIndex == 0)
|
if (glyphIndex == 0)
|
||||||
|
@ -404,7 +404,7 @@ unsigned char* FontFreeType::getGlyphBitmap(char32_t charCode,
|
||||||
if (_mssingGlyphCharacter != 0)
|
if (_mssingGlyphCharacter != 0)
|
||||||
{
|
{
|
||||||
if (_mssingGlyphCharacter == 0x1A)
|
if (_mssingGlyphCharacter == 0x1A)
|
||||||
return nullptr; // don't render anything for this character
|
break; // don't render anything for this character
|
||||||
|
|
||||||
// Try get new glyph index with missing glyph character code
|
// Try get new glyph index with missing glyph character code
|
||||||
glyphIndex = FT_Get_Char_Index(_fontFace, static_cast<FT_ULong>(_mssingGlyphCharacter));
|
glyphIndex = FT_Get_Char_Index(_fontFace, static_cast<FT_ULong>(_mssingGlyphCharacter));
|
||||||
|
@ -568,8 +568,8 @@ void FontFreeType::renderCharAt(unsigned char* dest,
|
||||||
int posX,
|
int posX,
|
||||||
int posY,
|
int posY,
|
||||||
unsigned char* bitmap,
|
unsigned char* bitmap,
|
||||||
int32_t bitmapWidth,
|
int bitmapWidth,
|
||||||
int32_t bitmapHeight)
|
int bitmapHeight)
|
||||||
{
|
{
|
||||||
const int iX = posX;
|
const int iX = posX;
|
||||||
int iY = posY;
|
int iY = posY;
|
||||||
|
|
|
@ -31,12 +31,14 @@
|
||||||
/// @cond DO_NOT_SHOW
|
/// @cond DO_NOT_SHOW
|
||||||
|
|
||||||
#include "2d/CCFont.h"
|
#include "2d/CCFont.h"
|
||||||
|
|
||||||
#include "ft2build.h"
|
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
#include FT_FREETYPE_H
|
/* freetype fwd decls */
|
||||||
#include FT_STROKER_H
|
typedef struct FT_LibraryRec_* FT_Library;
|
||||||
|
typedef struct FT_StreamRec_* FT_Stream;
|
||||||
|
typedef struct FT_FaceRec_* FT_Face;
|
||||||
|
typedef struct FT_StrokerRec_* FT_Stroker;
|
||||||
|
typedef struct FT_BBox_ FT_BBox;
|
||||||
|
|
||||||
NS_CC_BEGIN
|
NS_CC_BEGIN
|
||||||
|
|
||||||
|
@ -88,16 +90,12 @@ public:
|
||||||
int posX,
|
int posX,
|
||||||
int posY,
|
int posY,
|
||||||
unsigned char* bitmap,
|
unsigned char* bitmap,
|
||||||
int32_t bitmapWidth,
|
int bitmapWidth,
|
||||||
int32_t bitmapHeight);
|
int bitmapHeight);
|
||||||
|
|
||||||
int* getHorizontalKerningForTextUTF32(const std::u32string& text, int& outNumLetters) const override;
|
int* getHorizontalKerningForTextUTF32(const std::u32string& text, int& outNumLetters) const override;
|
||||||
|
|
||||||
unsigned char* getGlyphBitmap(char32_t charCode,
|
unsigned char* getGlyphBitmap(char32_t charCode, int& outWidth, int& outHeight, Rect& outRect, int& xAdvance);
|
||||||
int32_t& outWidth,
|
|
||||||
int32_t& outHeight,
|
|
||||||
Rect& outRect,
|
|
||||||
int& xAdvance);
|
|
||||||
|
|
||||||
int getFontAscender() const;
|
int getFontAscender() const;
|
||||||
const char* getFontFamily() const;
|
const char* getFontFamily() const;
|
||||||
|
@ -131,7 +129,7 @@ private:
|
||||||
std::string_view getGlyphCollection() const;
|
std::string_view getGlyphCollection() const;
|
||||||
|
|
||||||
FT_Face _fontFace;
|
FT_Face _fontFace;
|
||||||
std::unique_ptr<FT_StreamRec> _fontStream;
|
FT_Stream _fontStream;
|
||||||
FT_Stroker _stroker;
|
FT_Stroker _stroker;
|
||||||
|
|
||||||
std::string _fontName;
|
std::string _fontName;
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -32,9 +32,6 @@ THE SOFTWARE.
|
||||||
#include "base/CCProtocols.h"
|
#include "base/CCProtocols.h"
|
||||||
#include "2d/CCNode.h"
|
#include "2d/CCNode.h"
|
||||||
#include "base/CCValue.h"
|
#include "base/CCValue.h"
|
||||||
#include "2d/CCSpriteFrame.h"
|
|
||||||
#include "2d/CCSpriteFrameCache.h"
|
|
||||||
#include "math/RngSeed.hpp"
|
|
||||||
|
|
||||||
NS_CC_BEGIN
|
NS_CC_BEGIN
|
||||||
|
|
||||||
|
@ -55,77 +52,6 @@ struct particle_point
|
||||||
float y;
|
float y;
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
|
||||||
* Particle emission shapes.
|
|
||||||
* Current supported shapes are Point, Rectangle, RectangularTorus, Circle, Torus
|
|
||||||
* @since adxe-1.0.0b8
|
|
||||||
*/
|
|
||||||
enum class EmissionShapeType
|
|
||||||
{
|
|
||||||
POINT,
|
|
||||||
RECT,
|
|
||||||
RECTTORUS,
|
|
||||||
CIRCLE,
|
|
||||||
TORUS,
|
|
||||||
ALPHA_MASK
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Particle emission mask descriptor.
|
|
||||||
* @since adxe-1.0.0b8
|
|
||||||
*/
|
|
||||||
struct ParticleEmissionMaskDescriptor
|
|
||||||
{
|
|
||||||
Vec2 size;
|
|
||||||
std::vector<cocos2d::Vec2> points;
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Particle emission shapes.
|
|
||||||
* Current supported shapes are Point, Rectangle, RectangularTorus, Circle, Torus, Cone, Cone Torus
|
|
||||||
* @since adxe-1.0.0b8
|
|
||||||
*/
|
|
||||||
struct EmissionShape
|
|
||||||
{
|
|
||||||
EmissionShapeType type;
|
|
||||||
|
|
||||||
float x;
|
|
||||||
float y;
|
|
||||||
|
|
||||||
float innerWidth;
|
|
||||||
float innerHeight;
|
|
||||||
float outerWidth;
|
|
||||||
float outerHeight;
|
|
||||||
|
|
||||||
float innerRadius;
|
|
||||||
float outerRadius;
|
|
||||||
float coneOffset;
|
|
||||||
float coneAngle;
|
|
||||||
float edgeBias;
|
|
||||||
|
|
||||||
uint32_t fourccId;
|
|
||||||
};
|
|
||||||
|
|
||||||
/** @struct ParticleAnimationDescriptor
|
|
||||||
Structure that contains animation description
|
|
||||||
*/
|
|
||||||
struct ParticleAnimationDescriptor
|
|
||||||
{
|
|
||||||
float animationSpeed;
|
|
||||||
float animationSpeedVariance;
|
|
||||||
std::vector<unsigned short> animationIndices;
|
|
||||||
bool reverseIndices;
|
|
||||||
};
|
|
||||||
|
|
||||||
/** @struct ParticleFrameDescriptor
|
|
||||||
Structure that contains frame description
|
|
||||||
*/
|
|
||||||
struct ParticleFrameDescriptor
|
|
||||||
{
|
|
||||||
cocos2d::Rect rect;
|
|
||||||
bool isRotated;
|
|
||||||
};
|
|
||||||
|
|
||||||
class CC_DLL ParticleData
|
class CC_DLL ParticleData
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
@ -144,27 +70,11 @@ public:
|
||||||
float* deltaColorB;
|
float* deltaColorB;
|
||||||
float* deltaColorA;
|
float* deltaColorA;
|
||||||
|
|
||||||
float* hue;
|
|
||||||
float* sat;
|
|
||||||
float* val;
|
|
||||||
|
|
||||||
float* opacityFadeInDelta;
|
|
||||||
float* opacityFadeInLength;
|
|
||||||
|
|
||||||
float* scaleInDelta;
|
|
||||||
float* scaleInLength;
|
|
||||||
|
|
||||||
float* size;
|
float* size;
|
||||||
float* deltaSize;
|
float* deltaSize;
|
||||||
float* rotation;
|
float* rotation;
|
||||||
float* staticRotation;
|
|
||||||
float* deltaRotation;
|
float* deltaRotation;
|
||||||
float* totalTimeToLive;
|
|
||||||
float* timeToLive;
|
float* timeToLive;
|
||||||
float* animTimeDelta;
|
|
||||||
float* animTimeLength;
|
|
||||||
unsigned short* animIndex;
|
|
||||||
unsigned short* animCellIndex;
|
|
||||||
unsigned int* atlasIndex;
|
unsigned int* atlasIndex;
|
||||||
|
|
||||||
//! Mode A: gravity, direction, radial accel, tangential accel
|
//! Mode A: gravity, direction, radial accel, tangential accel
|
||||||
|
@ -208,42 +118,14 @@ public:
|
||||||
deltaColorB[p1] = deltaColorB[p2];
|
deltaColorB[p1] = deltaColorB[p2];
|
||||||
deltaColorA[p1] = deltaColorA[p2];
|
deltaColorA[p1] = deltaColorA[p2];
|
||||||
|
|
||||||
if (hue && sat && val)
|
|
||||||
{
|
|
||||||
hue[p1] = hue[p2];
|
|
||||||
sat[p1] = sat[p2];
|
|
||||||
val[p1] = val[p2];
|
|
||||||
}
|
|
||||||
|
|
||||||
if (opacityFadeInDelta && opacityFadeInLength)
|
|
||||||
{
|
|
||||||
opacityFadeInDelta[p1] = opacityFadeInDelta[p2];
|
|
||||||
opacityFadeInLength[p1] = opacityFadeInLength[p2];
|
|
||||||
}
|
|
||||||
|
|
||||||
if (scaleInDelta && scaleInLength)
|
|
||||||
{
|
|
||||||
scaleInDelta[p1] = scaleInDelta[p2];
|
|
||||||
scaleInLength[p1] = scaleInLength[p2];
|
|
||||||
}
|
|
||||||
|
|
||||||
size[p1] = size[p2];
|
size[p1] = size[p2];
|
||||||
deltaSize[p1] = deltaSize[p2];
|
deltaSize[p1] = deltaSize[p2];
|
||||||
|
|
||||||
rotation[p1] = rotation[p2];
|
rotation[p1] = rotation[p2];
|
||||||
staticRotation[p1] = staticRotation[p2];
|
|
||||||
deltaRotation[p1] = deltaRotation[p2];
|
deltaRotation[p1] = deltaRotation[p2];
|
||||||
|
|
||||||
totalTimeToLive[p1] = totalTimeToLive[p2];
|
|
||||||
timeToLive[p1] = timeToLive[p2];
|
timeToLive[p1] = timeToLive[p2];
|
||||||
|
|
||||||
if (animTimeDelta && animTimeLength && animIndex && animCellIndex)
|
|
||||||
{
|
|
||||||
animTimeDelta[p1] = animTimeDelta[p2];
|
|
||||||
animTimeLength[p1] = animTimeLength[p2];
|
|
||||||
animIndex[p1] = animIndex[p2];
|
|
||||||
animCellIndex[p1] = animCellIndex[p2];
|
|
||||||
}
|
|
||||||
|
|
||||||
atlasIndex[p1] = atlasIndex[p2];
|
atlasIndex[p1] = atlasIndex[p2];
|
||||||
|
|
||||||
modeA.dirX[p1] = modeA.dirX[p2];
|
modeA.dirX[p1] = modeA.dirX[p2];
|
||||||
|
@ -258,77 +140,6 @@ public:
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
|
||||||
* Particle emission mask cache.
|
|
||||||
* @since adxe-1.0.0b8
|
|
||||||
*/
|
|
||||||
class CC_DLL ParticleEmissionMaskCache : public cocos2d::Ref
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
static ParticleEmissionMaskCache* getInstance();
|
|
||||||
|
|
||||||
/** Bakes a particle emission mask from texture data on cpu and stores it in memory by it's name.
|
|
||||||
* If the mask already exists then it will be overwritten.
|
|
||||||
*
|
|
||||||
* @param maskId The id of the mask, FOURCC starts with '#', such as "#abcd"
|
|
||||||
* @param texturePath Path of the texture that holds alpha data.
|
|
||||||
* @param alphaThreshold The threshold at which pixels are picked, If a pixel's alpha channel is greater than
|
|
||||||
* alphaThreshold then it will be picked.
|
|
||||||
* @param inverted Inverts the pick condition so that If a pixel's alpha channel is lower than alphaThreshold then
|
|
||||||
* it will be picked.
|
|
||||||
* @param inbetweenSamples How many times should pixels be filled inbetween, this value should be increased If
|
|
||||||
* you're planning to scale the emission shape up. WARNING: it will use more memory.
|
|
||||||
*/
|
|
||||||
void bakeEmissionMask(std::string_view maskId,
|
|
||||||
std::string_view texturePath,
|
|
||||||
float alphaThreshold = 0.5F,
|
|
||||||
bool inverted = false,
|
|
||||||
int inbetweenSamples = 1);
|
|
||||||
|
|
||||||
/** Bakes a particle emission mask from texture data on cpu and stores it in memory by it's name.
|
|
||||||
* If the mask already exists then it will be overwritten.
|
|
||||||
*
|
|
||||||
* @param maskId The id of the mask, FOURCC starts with '#', such as "#abcd"
|
|
||||||
* @param imageTexture Image object containing texture data with alpha channel.
|
|
||||||
* @param alphaThreshold The threshold at which pixels are picked, If a pixel's alpha channel is greater than
|
|
||||||
* alphaThreshold then it will be picked.
|
|
||||||
* @param inverted Inverts the pick condition so that If a pixel's alpha channel is lower than alphaThreshold then
|
|
||||||
* it will be picked.
|
|
||||||
* @param inbetweenSamples How many times should pixels be filled inbetween, this value should be increased If
|
|
||||||
* you're planning to scale the emission shape up. WARNING: it will use more memory.
|
|
||||||
*/
|
|
||||||
void bakeEmissionMask(std::string_view maskId,
|
|
||||||
Image* imageTexture,
|
|
||||||
float alphaThreshold = 0.5F,
|
|
||||||
bool inverted = false,
|
|
||||||
int inbetweenSamples = 1);
|
|
||||||
|
|
||||||
/** Returns a baked mask with the specified name if it exists. otherwise, it will return a dummy mask.
|
|
||||||
*
|
|
||||||
* @param fourccId The unsigned integer id of the mask.
|
|
||||||
*/
|
|
||||||
const ParticleEmissionMaskDescriptor& getEmissionMask(uint32_t fourccId);
|
|
||||||
|
|
||||||
/** Returns a baked mask with the specified name if it exists. otherwise, it will return a dummy mask.
|
|
||||||
*
|
|
||||||
* @param maskId The id of the mask, FOURCC starts with '#', such as "#abcd"
|
|
||||||
*/
|
|
||||||
const ParticleEmissionMaskDescriptor& getEmissionMask(std::string_view maskId);
|
|
||||||
|
|
||||||
/** Removes a baked mask and releases the data from memory with the specified name if it exists.
|
|
||||||
*
|
|
||||||
* @param maskId The id of the mask, FOURCC starts with '#', such as "#abcd"
|
|
||||||
*/
|
|
||||||
void removeMask(std::string_view maskId);
|
|
||||||
|
|
||||||
/** Remove all baked masks and releases their data from memory. */
|
|
||||||
void removeAllMasks();
|
|
||||||
|
|
||||||
private:
|
|
||||||
std::unordered_map<uint32_t, ParticleEmissionMaskDescriptor> masks;
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
// typedef void (*CC_UPDATE_PARTICLE_IMP)(id, SEL, tParticle*, Vec2);
|
// typedef void (*CC_UPDATE_PARTICLE_IMP)(id, SEL, tParticle*, Vec2);
|
||||||
|
|
||||||
class Texture2D;
|
class Texture2D;
|
||||||
|
@ -377,6 +188,7 @@ emitter.startSpin = 0;
|
||||||
@endcode
|
@endcode
|
||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
class CC_DLL ParticleSystem : public Node, public TextureProtocol, public PlayableProtocol
|
class CC_DLL ParticleSystem : public Node, public TextureProtocol, public PlayableProtocol
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
@ -390,7 +202,7 @@ public:
|
||||||
};
|
};
|
||||||
|
|
||||||
/** PositionType
|
/** PositionType
|
||||||
Types of particle positioning.
|
Possible types of particle positions.
|
||||||
* @js cc.ParticleSystem.TYPE_FREE
|
* @js cc.ParticleSystem.TYPE_FREE
|
||||||
*/
|
*/
|
||||||
enum class PositionType
|
enum class PositionType
|
||||||
|
@ -404,17 +216,6 @@ public:
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
/** TexAnimDir
|
|
||||||
Texture animation direction for the particles.
|
|
||||||
*/
|
|
||||||
enum class TexAnimDir
|
|
||||||
{
|
|
||||||
VERTICAL, /** texture coordinates are read top to bottom within the texture */
|
|
||||||
|
|
||||||
HORIZONTAL, /** texture coordinates are read left to right within the texture */
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
//* @enum
|
//* @enum
|
||||||
enum
|
enum
|
||||||
{
|
{
|
||||||
|
@ -426,12 +227,6 @@ public:
|
||||||
|
|
||||||
/** The starting radius of the particle is equal to the ending radius. */
|
/** The starting radius of the particle is equal to the ending radius. */
|
||||||
START_RADIUS_EQUAL_TO_END_RADIUS = -1,
|
START_RADIUS_EQUAL_TO_END_RADIUS = -1,
|
||||||
|
|
||||||
/** The simulation's seconds are set to the particles' lifetime specified inclusive of variant. */
|
|
||||||
SIMULATION_USE_PARTICLE_LIFETIME = -1,
|
|
||||||
|
|
||||||
/** The simulation's framerate is set to the animation interval specified in director. */
|
|
||||||
SIMULATION_USE_GAME_ANIMATION_INTERVAL = -1,
|
|
||||||
};
|
};
|
||||||
|
|
||||||
/** Creates an initializes a ParticleSystem from a plist file.
|
/** Creates an initializes a ParticleSystem from a plist file.
|
||||||
|
@ -456,25 +251,8 @@ public:
|
||||||
*/
|
*/
|
||||||
static Vector<ParticleSystem*>& getAllParticleSystems();
|
static Vector<ParticleSystem*>& getAllParticleSystems();
|
||||||
|
|
||||||
protected:
|
|
||||||
bool allocAnimationMem();
|
|
||||||
void deallocAnimationMem();
|
|
||||||
bool _isAnimAllocated;
|
|
||||||
|
|
||||||
bool allocHSVMem();
|
|
||||||
void deallocHSVMem();
|
|
||||||
bool _isHSVAllocated;
|
|
||||||
|
|
||||||
bool allocOpacityFadeInMem();
|
|
||||||
void deallocOpacityFadeInMem();
|
|
||||||
bool _isOpacityFadeInAllocated;
|
|
||||||
|
|
||||||
bool allocScaleInMem();
|
|
||||||
void deallocScaleInMem();
|
|
||||||
bool _isScaleInAllocated;
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
void addParticles(int count, int animationIndex = -1, int animationCellIndex = -1);
|
void addParticles(int count);
|
||||||
|
|
||||||
void stopSystem();
|
void stopSystem();
|
||||||
/** Kill all living particles.
|
/** Kill all living particles.
|
||||||
|
@ -880,58 +658,6 @@ public:
|
||||||
*/
|
*/
|
||||||
void setEndColorVar(const Color4F& color) { _endColorVar = color; }
|
void setEndColorVar(const Color4F& color) { _endColorVar = color; }
|
||||||
|
|
||||||
/** Sets wether to use HSV color system.
|
|
||||||
* WARNING: becareful when using HSV with too many particles because it's expensive.
|
|
||||||
*
|
|
||||||
* @param hsv Use HSV color system.
|
|
||||||
*/
|
|
||||||
void useHSV(bool hsv);
|
|
||||||
bool isHSV() { return _isHSVAllocated; };
|
|
||||||
|
|
||||||
/** Gets the hue of each particle.
|
|
||||||
*
|
|
||||||
* @return The hue of each particle.
|
|
||||||
*/
|
|
||||||
float getHue() const { return _hsv.h; }
|
|
||||||
/** Sets the hue of each particle.
|
|
||||||
*
|
|
||||||
* @param hsv The hue color of each particle.
|
|
||||||
*/
|
|
||||||
void setHue(float hue) { _hsv.h = hue; }
|
|
||||||
|
|
||||||
/** Gets the hue variance of each particle.
|
|
||||||
*
|
|
||||||
* @return The hue variance of each particle.
|
|
||||||
*/
|
|
||||||
float getHueVar() const { return _hsvVar.h; }
|
|
||||||
/** Sets the hue variance of each particle.
|
|
||||||
*
|
|
||||||
* @param hsv The hue variance color of each particle.
|
|
||||||
*/
|
|
||||||
void setHueVar(float hue) { _hsvVar.h = hue; }
|
|
||||||
|
|
||||||
/** Gets the HSV color of each particle.
|
|
||||||
*
|
|
||||||
* @return The HSV color of each particle.
|
|
||||||
*/
|
|
||||||
const HSV& getHSV() const { return _hsv; }
|
|
||||||
/** Sets the HSV color of each particle.
|
|
||||||
*
|
|
||||||
* @param hsv The HSV color of each particle.
|
|
||||||
*/
|
|
||||||
void setHSV(const HSV& hsv) { _hsv = hsv; }
|
|
||||||
|
|
||||||
/** Gets the HSV color variance of each particle.
|
|
||||||
*
|
|
||||||
* @return The HSV color variance of each particle.
|
|
||||||
*/
|
|
||||||
const HSV& getHSVVar() const { return _hsvVar; }
|
|
||||||
/** Sets the HSV color variance of each particle.
|
|
||||||
*
|
|
||||||
* @param hsv The HSV color variance of each particle.
|
|
||||||
*/
|
|
||||||
void setHSVVar(const HSV& hsv) { _hsvVar = hsv; }
|
|
||||||
|
|
||||||
/** Gets the start spin of each particle.
|
/** Gets the start spin of each particle.
|
||||||
*
|
*
|
||||||
* @return The start spin of each particle.
|
* @return The start spin of each particle.
|
||||||
|
@ -976,88 +702,6 @@ public:
|
||||||
*/
|
*/
|
||||||
void setEndSpinVar(float endSpinVar) { _endSpinVar = endSpinVar; }
|
void setEndSpinVar(float endSpinVar) { _endSpinVar = endSpinVar; }
|
||||||
|
|
||||||
/** Gets the spawn angle of each particle
|
|
||||||
*
|
|
||||||
* @return The angle in degrees of each particle.
|
|
||||||
*/
|
|
||||||
float getSpawnAngle() { return _spawnAngle; }
|
|
||||||
/** Sets the spawn angle of each particle
|
|
||||||
*
|
|
||||||
* @param angle The angle in degrees of each particle.
|
|
||||||
*/
|
|
||||||
void setSpawnAngle(float angle) { _spawnAngle = angle; }
|
|
||||||
|
|
||||||
/** Sets the spawn angle variance of each particle.
|
|
||||||
*
|
|
||||||
* @return The angle variance in degrees of each particle.
|
|
||||||
*/
|
|
||||||
float getSpawnAngleVar() { return _spawnAngleVar; }
|
|
||||||
/** Sets the spawn angle variance of each particle.
|
|
||||||
*
|
|
||||||
* @param angle The angle variance in degrees of each particle.
|
|
||||||
*/
|
|
||||||
void setSpawnAngleVar(float angle) { _spawnAngleVar = angle; }
|
|
||||||
|
|
||||||
/** Gets the spawn opacity fade in time of each particle.
|
|
||||||
* Particles have the ability to spawn while having 0 opacity and gradually start going to 255 opacity with a
|
|
||||||
specified time.
|
|
||||||
|
|
||||||
* @return The spawn opacity fade in time in seconds.
|
|
||||||
*/
|
|
||||||
float getSpawnFadeIn() { return _spawnFadeIn; }
|
|
||||||
/** Sets the spawn opacity fade in time of each particle when it's created.
|
|
||||||
* Particles have the ability to spawn while having 0 opacity and gradually start going to 255 opacity with a
|
|
||||||
* specified time.
|
|
||||||
*
|
|
||||||
* @param time The spawn opacity fade in time in seconds.
|
|
||||||
*/
|
|
||||||
void setSpawnFadeIn(float time);
|
|
||||||
|
|
||||||
/** Gets the spawn opacity fade in time variance of each particle.
|
|
||||||
* Particles have the ability to spawn while having 0 opacity and gradually start going to 255 opacity with a
|
|
||||||
* specified time.
|
|
||||||
*
|
|
||||||
* @return The spawn opacity fade in time variance in seconds.
|
|
||||||
*/
|
|
||||||
float getSpawnFadeInVar() { return _spawnFadeInVar; }
|
|
||||||
/** Sets the spawn opacity fade in time variance of each particle when it's created.
|
|
||||||
* Particles have the ability to spawn while having 0 opacity and gradually start going to 255 opacity with a
|
|
||||||
* specified time.
|
|
||||||
*
|
|
||||||
* @param time The spawn opacity fade in time variance in seconds.
|
|
||||||
*/
|
|
||||||
void setSpawnFadeInVar(float time);
|
|
||||||
|
|
||||||
/** Gets the spawn scale fade in time of each particle.
|
|
||||||
* Particles have the ability to spawn while having 0.0 size and gradually start going to 1.0 size with a specified
|
|
||||||
* time.
|
|
||||||
*
|
|
||||||
* @return The spawn opacity fade in time in seconds.
|
|
||||||
*/
|
|
||||||
float getSpawnScaleIn() { return _spawnScaleIn; }
|
|
||||||
/** Sets the spawn scale fade in time of each particle when it's created.
|
|
||||||
* Particles have the ability to spawn while having 0.0 size and gradually start going to 1.0 size with a specified
|
|
||||||
* time.
|
|
||||||
*
|
|
||||||
* @param time The spawn opacity fade in time in seconds.
|
|
||||||
*/
|
|
||||||
void setSpawnScaleIn(float time);
|
|
||||||
|
|
||||||
/** Gets the spawn scale fade in time variance of each particle.
|
|
||||||
* Particles have the ability to spawn while having 0.0 size and gradually start going to 1.0 size with a specified
|
|
||||||
* time.
|
|
||||||
*
|
|
||||||
* @return The spawn opacity fade in time variance in seconds.
|
|
||||||
*/
|
|
||||||
float getSpawnScaleInVar() { return _spawnScaleInVar; }
|
|
||||||
/** Sets the spawn scale fade in time variance of each particle when it's created.
|
|
||||||
* Particles have the ability to spawn while having 0.0 size and gradually start going to 1.0 size with a specified
|
|
||||||
* time.
|
|
||||||
*
|
|
||||||
* @param time The spawn opacity fade in time variance in seconds.
|
|
||||||
*/
|
|
||||||
void setSpawnScaleInVar(float time);
|
|
||||||
|
|
||||||
/** Gets the emission rate of the particles.
|
/** Gets the emission rate of the particles.
|
||||||
*
|
*
|
||||||
* @return The emission rate of the particles.
|
* @return The emission rate of the particles.
|
||||||
|
@ -1084,266 +728,6 @@ public:
|
||||||
void setOpacityModifyRGB(bool opacityModifyRGB) override { _opacityModifyRGB = opacityModifyRGB; }
|
void setOpacityModifyRGB(bool opacityModifyRGB) override { _opacityModifyRGB = opacityModifyRGB; }
|
||||||
bool isOpacityModifyRGB() const override { return _opacityModifyRGB; }
|
bool isOpacityModifyRGB() const override { return _opacityModifyRGB; }
|
||||||
|
|
||||||
/** Enables or disables tex coord animations that are set based on particle life. */
|
|
||||||
void setLifeAnimation(bool enabled);
|
|
||||||
|
|
||||||
/** Enables or disables tex coord animations that are set by the emitter randomly when a particle is emitted. */
|
|
||||||
void setEmitterAnimation(bool enabled);
|
|
||||||
|
|
||||||
/** Enables or disables tex coord animations that are used to make particles play a sequence forever until they die
|
|
||||||
*/
|
|
||||||
void setLoopAnimation(bool enabled);
|
|
||||||
|
|
||||||
bool isLifeAnimated() { return _isLifeAnimated; }
|
|
||||||
bool isEmitterAnimated() { return _isEmitterAnimated; }
|
|
||||||
bool isLoopAnimated() { return _isLoopAnimated; }
|
|
||||||
|
|
||||||
/** Gets the total number of indices.
|
|
||||||
*
|
|
||||||
* @return The size of the list holding animation indices.
|
|
||||||
*/
|
|
||||||
int getTotalAnimationIndices() { return _animIndexCount; }
|
|
||||||
|
|
||||||
/** Sets wether to start from first cell and go forwards (normal) or last cell and go backwards (reversed) */
|
|
||||||
void setAnimationReverse(bool reverse) { _isAnimationReversed = reverse; }
|
|
||||||
bool isAnimationReversed() { return _isAnimationReversed; }
|
|
||||||
|
|
||||||
/** Resets the count of indices to 0 and empties the animation index array */
|
|
||||||
void resetAnimationIndices();
|
|
||||||
|
|
||||||
/** Empties the container of animation descriptors */
|
|
||||||
void resetAnimationDescriptors();
|
|
||||||
|
|
||||||
/** Choose what animation descriptors are to be selected at random for particles.
|
|
||||||
* This function should be called after you've inserted/overwritten any animation descriptors.
|
|
||||||
*
|
|
||||||
* @param animations Array of specific indices of animations to play at random
|
|
||||||
*/
|
|
||||||
void setMultiAnimationRandomSpecific(const std::vector<unsigned short>& animations)
|
|
||||||
{
|
|
||||||
_randomAnimations = animations;
|
|
||||||
};
|
|
||||||
|
|
||||||
/** Choose ALL animation descriptors to be selected at random for particles.
|
|
||||||
* This function should be called after you've inserted/overwritten any animation descriptors.
|
|
||||||
*/
|
|
||||||
void setMultiAnimationRandom();
|
|
||||||
|
|
||||||
/** Add all particle animation indices based on cells size and direction spicified using a texture atlas.
|
|
||||||
* will erase the array and add new indices from the atlas.
|
|
||||||
* This function will automatically figure out your atlas cell size and direction for you! thank her later :) */
|
|
||||||
void setAnimationIndicesAtlas();
|
|
||||||
|
|
||||||
/** Add all particle animation indices based on cell size and direction spicified if the method of rendering
|
|
||||||
* preferred is texture atlas. will erase the array and add new indices from the atlas.
|
|
||||||
*
|
|
||||||
* @param unifiedCellSize The size of cell unified.
|
|
||||||
* @param direction What direction is the atlas
|
|
||||||
*/
|
|
||||||
void setAnimationIndicesAtlas(unsigned int unifiedCellSize, TexAnimDir direction = TexAnimDir::HORIZONTAL);
|
|
||||||
|
|
||||||
/** Add a particle animation index based on tex coords spicified using a sprite frame.
|
|
||||||
* The index is automatically incremented on each addition.
|
|
||||||
*
|
|
||||||
* @param frameName SpriteFrame name to search for
|
|
||||||
*
|
|
||||||
* @return Returns true of the index was successfully found and added. Otherwise, false
|
|
||||||
*/
|
|
||||||
bool addAnimationIndex(std::string_view frameName);
|
|
||||||
|
|
||||||
/** Add a particle animation index based on tex coords spicified using a sprite frame.
|
|
||||||
*
|
|
||||||
* @param index Index id to add the frame to or override it with the new frame
|
|
||||||
* @param frameName SpriteFrame name to search for
|
|
||||||
*
|
|
||||||
* @return Returns true of the index was successfully found and added. Otherwise, false
|
|
||||||
*/
|
|
||||||
bool addAnimationIndex(unsigned short index, std::string_view frameName);
|
|
||||||
|
|
||||||
/** Add a particle animation index based on tex coords spicified using a sprite frame.
|
|
||||||
* The index is automatically incremented on each addition.
|
|
||||||
*
|
|
||||||
* @param frame SpriteFrame containting data about tex coords
|
|
||||||
*
|
|
||||||
* @return Returns true of the index was successfully found and added. Otherwise, false
|
|
||||||
*/
|
|
||||||
bool addAnimationIndex(cocos2d::SpriteFrame* frame);
|
|
||||||
|
|
||||||
/** Add a particle animation index based on tex coords spicified using a sprite frame.
|
|
||||||
* you can specify which index you want to override in this function
|
|
||||||
*
|
|
||||||
* @param index Index id to add the frame to or override it with the new frame
|
|
||||||
* @param frame SpriteFrame containting data about tex coords
|
|
||||||
*
|
|
||||||
* @return Returns true of the index was successfully found and added. Otherwise, false
|
|
||||||
*/
|
|
||||||
bool addAnimationIndex(unsigned short index, cocos2d::SpriteFrame* frame);
|
|
||||||
|
|
||||||
/** Add a particle animation index based on tex coords spicified.
|
|
||||||
* you can specify which index you want to override in this function
|
|
||||||
*
|
|
||||||
* @param index Index id to add the frame to or override it with the new rect
|
|
||||||
* @param rect Rect containting data about tex coords in pixels
|
|
||||||
* @param rotated Not implemented.
|
|
||||||
*
|
|
||||||
* @return Returns true of the index was successfully found and added. Otherwise, false
|
|
||||||
*/
|
|
||||||
bool addAnimationIndex(unsigned short index, cocos2d::Rect rect, bool rotated = false);
|
|
||||||
|
|
||||||
/** You can specify what rect is used if an index in an animation descriptor wasn't found.
|
|
||||||
*
|
|
||||||
* @param rect Rect containting data about tex coords in pixels
|
|
||||||
*/
|
|
||||||
void setRectForUndefinedIndices(cocos2d::Rect rect) { _undefinedIndexRect = rect; };
|
|
||||||
|
|
||||||
/** Add a particle animation descriptor with an index.
|
|
||||||
*
|
|
||||||
* @param indexOfDescriptor Index of the animation to be added, adding to the same index will just override the
|
|
||||||
* pervious animation descriptor
|
|
||||||
* @param time length of the animation in seconds
|
|
||||||
* @param timeVariance Time randomly selected for each different particle added on the animation length
|
|
||||||
* @param indices An array of the indicies
|
|
||||||
* @param reverse Should the animation indicies be played backwards? (default: false)
|
|
||||||
*/
|
|
||||||
void setAnimationDescriptor(unsigned short indexOfDescriptor,
|
|
||||||
float time,
|
|
||||||
float timeVariance,
|
|
||||||
const std::vector<unsigned short>& indices,
|
|
||||||
bool reverse = false);
|
|
||||||
|
|
||||||
/** Add a particle animation descriptor with the index 0.
|
|
||||||
*
|
|
||||||
* @param indices An array of the indicies
|
|
||||||
* @param reverse Should the animation indicies be played backwards? (default: false)
|
|
||||||
*/
|
|
||||||
void setAnimationDescriptor(const std::vector<unsigned short>& indices, bool reverse = false)
|
|
||||||
{
|
|
||||||
setAnimationDescriptor(0, 0, 0, indices, reverse);
|
|
||||||
};
|
|
||||||
|
|
||||||
/** Sets wether the animation descriptors should follow the time scale of the system or not.
|
|
||||||
*
|
|
||||||
* @param independent Should the animation descriptor speeds be played independently? (default: false)
|
|
||||||
*/
|
|
||||||
void setAnimationSpeedTimescaleIndependent(bool independent) { _animationTimescaleInd = independent; };
|
|
||||||
bool isAnimationSpeedTimescaleIndependent() { return _animationTimescaleInd; };
|
|
||||||
|
|
||||||
/** Sets wether to use emission shapes for this particle system or not */
|
|
||||||
void setEmissionShapes(bool enabled) { _isEmissionShapes = enabled; }
|
|
||||||
bool isEmissionShapes() { return _isEmissionShapes; }
|
|
||||||
|
|
||||||
/** Resets the count of emission shapes to 0 and empties the emission shapes array */
|
|
||||||
void resetEmissionShapes();
|
|
||||||
|
|
||||||
/** Adds an emission shape to the system.
|
|
||||||
* The index is automatically incremented on each addition.
|
|
||||||
*
|
|
||||||
* @param shape Shape descriptor object.
|
|
||||||
*/
|
|
||||||
void addEmissionShape(EmissionShape shape);
|
|
||||||
|
|
||||||
/** Updates an existing emission shape or adds it.
|
|
||||||
* @param index index of the shape descriptor.
|
|
||||||
* @param shape Shape descriptor object.
|
|
||||||
*/
|
|
||||||
void setEmissionShape(unsigned short index, EmissionShape shape);
|
|
||||||
|
|
||||||
/** Adds an emission shape of type mask to the system.
|
|
||||||
* The mask should be added using the ParticleEmissionMaskCache class.
|
|
||||||
*
|
|
||||||
* @param maskId The id of the mask, FOURCC starts with '#', such as "#abcd"
|
|
||||||
* @param pos Position of the emission shape in local space.
|
|
||||||
* @param overrideSize Size of the emission mask in pixels, leave ZERO to use texture size.
|
|
||||||
* @param scale Scale of the emission mask, the size will be multiplied by the specified scale.
|
|
||||||
* @param angle Angle of the sampled points to be rotated in degrees.
|
|
||||||
*/
|
|
||||||
static EmissionShape createMaskShape(std::string_view maskId, Vec2 pos = Vec2::ZERO, Vec2 overrideSize = Vec2::ZERO, Vec2 scale = Vec2::ONE, float angle = 0.0F);
|
|
||||||
|
|
||||||
/** Adds an emission shape of type point to the system.
|
|
||||||
* @param pos Position of the emission shape in local space.
|
|
||||||
*/
|
|
||||||
static EmissionShape createPointShape(Vec2 pos);
|
|
||||||
|
|
||||||
/** Adds an emission shape of type Rectangle to the system.
|
|
||||||
* @param pos Position of the emission shape in local space.
|
|
||||||
* @param size Size of the rectangle.
|
|
||||||
*/
|
|
||||||
static EmissionShape createRectShape(Vec2 pos, Size size);
|
|
||||||
|
|
||||||
/** Adds an emission shape of type Rectangular Torus to the system.
|
|
||||||
* @param pos Position of the emission shape in local space.
|
|
||||||
* @param innerSize Inner size offset of the rectangle.
|
|
||||||
* @param outerSize Outer size of the rectangle.
|
|
||||||
*/
|
|
||||||
static EmissionShape createRectTorusShape(Vec2 pos, Size innerSize, Size outerSize);
|
|
||||||
|
|
||||||
/** Adds an emission shape of type Circle to the system.
|
|
||||||
*
|
|
||||||
* The default angle offset of the circle is 0 and the default angle of the circle is 360
|
|
||||||
*
|
|
||||||
* @param pos Position of the emission shape in local space.
|
|
||||||
* @param radius Radius of the circle.
|
|
||||||
* @param edgeBias circle edge center bias value, If the value is greater than 1.0 then particles will bias
|
|
||||||
* towards the edge of the circle more often the greater the value is; If the value is lower than 1.0 then particles
|
|
||||||
* will bias towards the center of the circle more often the closer the value is to 0.0; If the value is exactly 1.0
|
|
||||||
* then there will be no bias behaviour.
|
|
||||||
*/
|
|
||||||
static EmissionShape createCircleShape(Vec2 pos, float radius, float edgeBias = 1.0F);
|
|
||||||
|
|
||||||
/** Adds an emission shape of type Cone to the system.
|
|
||||||
*
|
|
||||||
* The default angle offset of the circle is 0 and the default angle of the circle is 360
|
|
||||||
*
|
|
||||||
* @param pos Position of the emission shape in local space.
|
|
||||||
* @param radius Radius of the circle.
|
|
||||||
* @param offset Cone offset angle in degrees.
|
|
||||||
* @param angle Cone angle in degrees.
|
|
||||||
* @param edgeBias circle edge center bias value, If the value is greater than 1.0 then particles will bias
|
|
||||||
* towards the edge of the circle more often the greater the value is; If the value is lower than 1.0 then particles
|
|
||||||
* will bias towards the center of the circle more often the closer the value is to 0.0; If the value is exactly 1.0
|
|
||||||
* then there will be no bias behaviour.
|
|
||||||
*/
|
|
||||||
static EmissionShape createConeShape(Vec2 pos,
|
|
||||||
float radius,
|
|
||||||
float offset,
|
|
||||||
float angle,
|
|
||||||
float edgeBias = 1.0F);
|
|
||||||
|
|
||||||
/** Adds an emission shape of type Torus to the system.
|
|
||||||
*
|
|
||||||
* The default angle offset of the torus is 0 and the default angle of the torus is 360
|
|
||||||
*
|
|
||||||
* @param pos Position of the emission shape in local space.
|
|
||||||
* @param innerRadius Inner radius offset of the torus.
|
|
||||||
* @param outerRadius Outer radius of the torus.
|
|
||||||
* @param edgeBias torus edge center bias value, If the value is greater than 1.0 then particles will bias
|
|
||||||
* towards the edge of the torus more often the greater the value is; If the value is lower than 1.0 then particles
|
|
||||||
* will bias towards the center of the torus more often the closer the value is to 0.0; If the value is exactly 1.0
|
|
||||||
* then there will be no bias behaviour.
|
|
||||||
*/
|
|
||||||
static EmissionShape createTorusShape(Vec2 pos, float innerRadius, float outerRadius, float edgeBias = 1.0F);
|
|
||||||
|
|
||||||
/** Adds an emission shape of type Torus to the system.
|
|
||||||
*
|
|
||||||
* The default angle offset of the torus is 0 and the default angle of the torus is 360
|
|
||||||
*
|
|
||||||
* @param pos Position of the emission shape in local space.
|
|
||||||
* @param innerRadius Inner radius offset of the torus.
|
|
||||||
* @param outerRadius Outer radius of the torus.
|
|
||||||
* @param offset Cone offset angle in degrees.
|
|
||||||
* @param angle Cone angle in degrees.
|
|
||||||
* @param edgeBias torus edge center bias value, If the value is greater than 1.0 then particles will bias
|
|
||||||
* towards the edge of the torus more often the greater the value is; If the value is lower than 1.0 then particles
|
|
||||||
* will bias towards the center of the torus more often the closer the value is to 0.0; If the value is exactly 1.0
|
|
||||||
* then there will be no bias behaviour.
|
|
||||||
*/
|
|
||||||
static EmissionShape createConeTorusShape(Vec2 pos,
|
|
||||||
float innerRadius,
|
|
||||||
float outerRadius,
|
|
||||||
float offset,
|
|
||||||
float angle,
|
|
||||||
float edgeBias = 1.0F);
|
|
||||||
|
|
||||||
/** Gets the particles movement type: Free or Grouped.
|
/** Gets the particles movement type: Free or Grouped.
|
||||||
@since v0.8
|
@since v0.8
|
||||||
*
|
*
|
||||||
|
@ -1357,27 +741,6 @@ public:
|
||||||
*/
|
*/
|
||||||
void setPositionType(PositionType type) { _positionType = type; }
|
void setPositionType(PositionType type) { _positionType = type; }
|
||||||
|
|
||||||
/** Advance the particle system and make it seem like it ran for this many seconds.
|
|
||||||
*
|
|
||||||
* @param seconds Seconds to advance. value of -1 means (SIMULATION_USE_PARTICLE_LIFETIME)
|
|
||||||
* @param frameRate Frame rate to run the simulation with (preferred: 30.0) The higher this value is the more
|
|
||||||
* accurate the simulation will be at the cost of performance. value of -1 means
|
|
||||||
* (SIMULATION_USE_GAME_ANIMATION_INTERVAL)
|
|
||||||
*/
|
|
||||||
void simulate(float seconds = SIMULATION_USE_PARTICLE_LIFETIME,
|
|
||||||
float frameRate = SIMULATION_USE_GAME_ANIMATION_INTERVAL);
|
|
||||||
|
|
||||||
/** Resets the particle system and then advances the particle system and make it seem like it ran for this many
|
|
||||||
* seconds. The frame rate used for simulation accuracy is the director's animation interval.
|
|
||||||
*
|
|
||||||
* @param seconds Seconds to advance. value of -1 means (SIMULATION_USE_PARTICLE_LIFETIME)
|
|
||||||
* @param frameRate Frame rate to run the simulation with (preferred: 30.0) The higher this value is the more
|
|
||||||
* accurate the simulation will be at the cost of performance. value of -1 means
|
|
||||||
* (SIMULATION_USE_GAME_ANIMATION_INTERVAL)
|
|
||||||
*/
|
|
||||||
void resimulate(float seconds = SIMULATION_USE_PARTICLE_LIFETIME,
|
|
||||||
float frameRate = SIMULATION_USE_GAME_ANIMATION_INTERVAL);
|
|
||||||
|
|
||||||
// Overrides
|
// Overrides
|
||||||
virtual void onEnter() override;
|
virtual void onEnter() override;
|
||||||
virtual void onExit() override;
|
virtual void onExit() override;
|
||||||
|
@ -1449,35 +812,12 @@ public:
|
||||||
*/
|
*/
|
||||||
virtual bool isPaused() const;
|
virtual bool isPaused() const;
|
||||||
|
|
||||||
/* Pause the emissions */
|
/* Pause the emissions*/
|
||||||
virtual void pauseEmissions();
|
virtual void pauseEmissions();
|
||||||
|
|
||||||
/* Unpause the emissions */
|
/* UnPause the emissions*/
|
||||||
virtual void resumeEmissions();
|
virtual void resumeEmissions();
|
||||||
|
|
||||||
/** Gets the fixed frame rate count of the particle system.
|
|
||||||
@return Fixed frame rate count of the particle system.
|
|
||||||
*/
|
|
||||||
virtual float getFixedFPS();
|
|
||||||
|
|
||||||
/** Sets the fixed frame rate count of the particle system.
|
|
||||||
* i.e. if the framerate is set to 30.0 while the refresh rate is greater than 30.0 then the particle system will
|
|
||||||
wait until it hits the 30.0 FPS mark.
|
|
||||||
* This is usefull for increasing performance or for creating old-school effects with it.
|
|
||||||
@param Fixed frame rate count of the particle system. (default: 0.0)
|
|
||||||
*/
|
|
||||||
virtual void setFixedFPS(float frameRate = 0.0F);
|
|
||||||
|
|
||||||
/** Gets the time scale of the particle system.
|
|
||||||
@return Time scale of the particle system.
|
|
||||||
*/
|
|
||||||
virtual float getTimeScale();
|
|
||||||
|
|
||||||
/** Sets the time scale of the particle system.
|
|
||||||
@param Time scale of the particle system. (default: 1.0)
|
|
||||||
*/
|
|
||||||
virtual void setTimeScale(float scale = 1.0F);
|
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual void updateBlendFunc();
|
virtual void updateBlendFunc();
|
||||||
|
|
||||||
|
@ -1617,10 +957,6 @@ protected:
|
||||||
Color4F _endColor;
|
Color4F _endColor;
|
||||||
/** end color variance of each particle */
|
/** end color variance of each particle */
|
||||||
Color4F _endColorVar;
|
Color4F _endColorVar;
|
||||||
/** hsv color of each particle */
|
|
||||||
HSV _hsv;
|
|
||||||
/** hsv color variance of each particle */
|
|
||||||
HSV _hsvVar;
|
|
||||||
//* initial angle of each particle
|
//* initial angle of each particle
|
||||||
float _startSpin;
|
float _startSpin;
|
||||||
//* initial angle of each particle
|
//* initial angle of each particle
|
||||||
|
@ -1629,18 +965,6 @@ protected:
|
||||||
float _endSpin;
|
float _endSpin;
|
||||||
//* initial angle of each particle
|
//* initial angle of each particle
|
||||||
float _endSpinVar;
|
float _endSpinVar;
|
||||||
//* initial rotation of each particle
|
|
||||||
float _spawnAngle;
|
|
||||||
//* initial rotation of each particle
|
|
||||||
float _spawnAngleVar;
|
|
||||||
//* initial fade in time of each particle
|
|
||||||
float _spawnFadeIn;
|
|
||||||
//* initial fade in time variance of each particle
|
|
||||||
float _spawnFadeInVar;
|
|
||||||
//* initial scale in time of each particle
|
|
||||||
float _spawnScaleIn;
|
|
||||||
//* initial scale in time variance of each particle
|
|
||||||
float _spawnScaleInVar;
|
|
||||||
/** emission rate of the particles */
|
/** emission rate of the particles */
|
||||||
float _emissionRate;
|
float _emissionRate;
|
||||||
/** maximum particles of the system */
|
/** maximum particles of the system */
|
||||||
|
@ -1651,37 +975,9 @@ protected:
|
||||||
BlendFunc _blendFunc;
|
BlendFunc _blendFunc;
|
||||||
/** does the alpha value modify color */
|
/** does the alpha value modify color */
|
||||||
bool _opacityModifyRGB;
|
bool _opacityModifyRGB;
|
||||||
/** is the particle system animated */
|
|
||||||
bool _isLifeAnimated;
|
|
||||||
/** is the emitter particle system animated */
|
|
||||||
bool _isEmitterAnimated;
|
|
||||||
/** is the emitter particle system animated */
|
|
||||||
bool _isLoopAnimated;
|
|
||||||
/** variable keeping count of sprite frames or atlas indices added */
|
|
||||||
int _animIndexCount;
|
|
||||||
/** wether to start from first or last when using life animation */
|
|
||||||
bool _isAnimationReversed;
|
|
||||||
/** A map that stores particle animation index coords */
|
|
||||||
std::unordered_map<unsigned short, ParticleFrameDescriptor> _animationIndices;
|
|
||||||
/** A map that stores particle animation descriptors */
|
|
||||||
std::unordered_map<unsigned short, ParticleAnimationDescriptor> _animations;
|
|
||||||
/** A vector that stores ids of animation descriptors that are choosen at random */
|
|
||||||
std::vector<unsigned short> _randomAnimations;
|
|
||||||
/** Wether the animation goes with the time scale of the system or is independent. */
|
|
||||||
bool _animationTimescaleInd;
|
|
||||||
/** A rect that is used instead when an index is not found */
|
|
||||||
cocos2d::Rect _undefinedIndexRect;
|
|
||||||
/** does FlippedY variance of each particle */
|
/** does FlippedY variance of each particle */
|
||||||
int _yCoordFlipped;
|
int _yCoordFlipped;
|
||||||
|
|
||||||
/** Wether to use emission shapes for this particle system or not */
|
|
||||||
bool _isEmissionShapes;
|
|
||||||
|
|
||||||
/** variable keeping count of emission shapes added */
|
|
||||||
int _emissionShapeIndex;
|
|
||||||
/** A map that stores emission shapes that are choosen at random */
|
|
||||||
std::unordered_map<unsigned short, EmissionShape> _emissionShapes;
|
|
||||||
|
|
||||||
/** particles movement type: Free or Grouped
|
/** particles movement type: Free or Grouped
|
||||||
@since v0.8
|
@since v0.8
|
||||||
*/
|
*/
|
||||||
|
@ -1690,22 +986,11 @@ protected:
|
||||||
/** is the emitter paused */
|
/** is the emitter paused */
|
||||||
bool _paused;
|
bool _paused;
|
||||||
|
|
||||||
/** time scale of the particle system */
|
|
||||||
float _timeScale;
|
|
||||||
|
|
||||||
/** Fixed frame rate of the particle system */
|
|
||||||
float _fixedFPS;
|
|
||||||
|
|
||||||
/** Fixed frame rate delta (internal) */
|
|
||||||
float _fixedFPSDelta;
|
|
||||||
|
|
||||||
/** is sourcePosition compatible */
|
/** is sourcePosition compatible */
|
||||||
bool _sourcePositionCompatible;
|
bool _sourcePositionCompatible;
|
||||||
|
|
||||||
static Vector<ParticleSystem*> __allInstances;
|
static Vector<ParticleSystem*> __allInstances;
|
||||||
|
|
||||||
RngSeed _rng;
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
CC_DISALLOW_COPY_AND_ASSIGN(ParticleSystem);
|
CC_DISALLOW_COPY_AND_ASSIGN(ParticleSystem);
|
||||||
};
|
};
|
||||||
|
|
|
@ -42,7 +42,6 @@ THE SOFTWARE.
|
||||||
#include "base/ccUTF8.h"
|
#include "base/ccUTF8.h"
|
||||||
#include "renderer/ccShaders.h"
|
#include "renderer/ccShaders.h"
|
||||||
#include "renderer/backend/ProgramState.h"
|
#include "renderer/backend/ProgramState.h"
|
||||||
#include "2d/CCTweenFunction.h"
|
|
||||||
|
|
||||||
NS_CC_BEGIN
|
NS_CC_BEGIN
|
||||||
|
|
||||||
|
@ -106,10 +105,6 @@ ParticleSystemQuad* ParticleSystemQuad::create(std::string_view filename)
|
||||||
|
|
||||||
ParticleSystemQuad* ParticleSystemQuad::createWithTotalParticles(int numberOfParticles)
|
ParticleSystemQuad* ParticleSystemQuad::createWithTotalParticles(int numberOfParticles)
|
||||||
{
|
{
|
||||||
CCASSERT(numberOfParticles <= 10000,
|
|
||||||
"Adding more than 10000 particles will crash the renderer, the mesh generated has an index format of "
|
|
||||||
"U_SHORT (uint16_t)");
|
|
||||||
|
|
||||||
ParticleSystemQuad* ret = new ParticleSystemQuad();
|
ParticleSystemQuad* ret = new ParticleSystemQuad();
|
||||||
if (ret->initWithTotalParticles(numberOfParticles))
|
if (ret->initWithTotalParticles(numberOfParticles))
|
||||||
{
|
{
|
||||||
|
@ -278,24 +273,19 @@ void ParticleSystemQuad::initIndices()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void updatePosWithParticle(V3F_C4B_T2F_Quad* quad,
|
inline void updatePosWithParticle(V3F_C4B_T2F_Quad* quad, const Vec2& newPosition, float size, float rotation)
|
||||||
const Vec2& newPosition,
|
|
||||||
float size,
|
|
||||||
float scaleInSize,
|
|
||||||
float rotation,
|
|
||||||
float staticRotation)
|
|
||||||
{
|
{
|
||||||
// vertices
|
// vertices
|
||||||
float size_2 = size / 2;
|
float size_2 = size / 2;
|
||||||
float x1 = -size_2 * scaleInSize;
|
float x1 = -size_2;
|
||||||
float y1 = -size_2 * scaleInSize;
|
float y1 = -size_2;
|
||||||
|
|
||||||
float x2 = size_2 * scaleInSize;
|
float x2 = size_2;
|
||||||
float y2 = size_2 * scaleInSize;
|
float y2 = size_2;
|
||||||
float x = newPosition.x;
|
float x = newPosition.x;
|
||||||
float y = newPosition.y;
|
float y = newPosition.y;
|
||||||
|
|
||||||
float r = (float)-CC_DEGREES_TO_RADIANS(rotation + staticRotation);
|
float r = (float)-CC_DEGREES_TO_RADIANS(rotation);
|
||||||
float cr = cosf(r);
|
float cr = cosf(r);
|
||||||
float sr = sinf(r);
|
float sr = sinf(r);
|
||||||
float ax = x1 * cr - y1 * sr + x;
|
float ax = x1 * cr - y1 * sr + x;
|
||||||
|
@ -367,14 +357,8 @@ void ParticleSystemQuad::updateParticleQuads()
|
||||||
float* y = _particleData.posy;
|
float* y = _particleData.posy;
|
||||||
float* s = _particleData.size;
|
float* s = _particleData.size;
|
||||||
float* r = _particleData.rotation;
|
float* r = _particleData.rotation;
|
||||||
float* sr = _particleData.staticRotation;
|
|
||||||
float* sid = _particleData.scaleInDelta;
|
|
||||||
float* sil = _particleData.scaleInLength;
|
|
||||||
V3F_C4B_T2F_Quad* quadStart = startQuad;
|
V3F_C4B_T2F_Quad* quadStart = startQuad;
|
||||||
if (_isScaleInAllocated)
|
for (int i = 0; i < _particleCount; ++i, ++startX, ++startY, ++x, ++y, ++quadStart, ++s, ++r)
|
||||||
{
|
|
||||||
for (int i = 0; i < _particleCount;
|
|
||||||
++i, ++startX, ++startY, ++x, ++y, ++quadStart, ++s, ++r, ++sr, ++sid, ++sil)
|
|
||||||
{
|
{
|
||||||
p2.set(*startX, *startY, 0);
|
p2.set(*startX, *startY, 0);
|
||||||
worldToNodeTM.transformPoint(&p2);
|
worldToNodeTM.transformPoint(&p2);
|
||||||
|
@ -382,21 +366,7 @@ void ParticleSystemQuad::updateParticleQuads()
|
||||||
p2 = p1 - p2;
|
p2 = p1 - p2;
|
||||||
newPos.x -= p2.x - pos.x;
|
newPos.x -= p2.x - pos.x;
|
||||||
newPos.y -= p2.y - pos.y;
|
newPos.y -= p2.y - pos.y;
|
||||||
updatePosWithParticle(quadStart, newPos, *s, tweenfunc::expoEaseOut(*sid / *sil), *r, *sr);
|
updatePosWithParticle(quadStart, newPos, *s, *r);
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
for (int i = 0; i < _particleCount; ++i, ++startX, ++startY, ++x, ++y, ++quadStart, ++s, ++r, ++sr)
|
|
||||||
{
|
|
||||||
p2.set(*startX, *startY, 0);
|
|
||||||
worldToNodeTM.transformPoint(&p2);
|
|
||||||
newPos.set(*x, *y);
|
|
||||||
p2 = p1 - p2;
|
|
||||||
newPos.x -= p2.x - pos.x;
|
|
||||||
newPos.y -= p2.y - pos.y;
|
|
||||||
updatePosWithParticle(quadStart, newPos, *s, 1.0F, *r, *sr);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (_positionType == PositionType::RELATIVE)
|
else if (_positionType == PositionType::RELATIVE)
|
||||||
|
@ -408,32 +378,14 @@ void ParticleSystemQuad::updateParticleQuads()
|
||||||
float* y = _particleData.posy;
|
float* y = _particleData.posy;
|
||||||
float* s = _particleData.size;
|
float* s = _particleData.size;
|
||||||
float* r = _particleData.rotation;
|
float* r = _particleData.rotation;
|
||||||
float* sr = _particleData.staticRotation;
|
|
||||||
float* sid = _particleData.scaleInDelta;
|
|
||||||
float* sil = _particleData.scaleInLength;
|
|
||||||
V3F_C4B_T2F_Quad* quadStart = startQuad;
|
V3F_C4B_T2F_Quad* quadStart = startQuad;
|
||||||
if (_isScaleInAllocated)
|
for (int i = 0; i < _particleCount; ++i, ++startX, ++startY, ++x, ++y, ++quadStart, ++s, ++r)
|
||||||
{
|
|
||||||
for (int i = 0; i < _particleCount;
|
|
||||||
++i, ++startX, ++startY, ++x, ++y, ++quadStart, ++s, ++r, ++sr, ++sid, ++sil)
|
|
||||||
{
|
{
|
||||||
newPos.set(*x, *y);
|
newPos.set(*x, *y);
|
||||||
newPos.x = *x - (currentPosition.x - *startX);
|
newPos.x = *x - (currentPosition.x - *startX);
|
||||||
newPos.y = *y - (currentPosition.y - *startY);
|
newPos.y = *y - (currentPosition.y - *startY);
|
||||||
newPos += pos;
|
newPos += pos;
|
||||||
updatePosWithParticle(quadStart, newPos, *s, tweenfunc::expoEaseOut(*sid / *sil), *r, *sr);
|
updatePosWithParticle(quadStart, newPos, *s, *r);
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
for (int i = 0; i < _particleCount; ++i, ++startX, ++startY, ++x, ++y, ++quadStart, ++s, ++r, ++sr)
|
|
||||||
{
|
|
||||||
newPos.set(*x, *y);
|
|
||||||
newPos.x = *x - (currentPosition.x - *startX);
|
|
||||||
newPos.y = *y - (currentPosition.y - *startY);
|
|
||||||
newPos += pos;
|
|
||||||
updatePosWithParticle(quadStart, newPos, *s, 1.0F, *r, *sr);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -445,186 +397,23 @@ void ParticleSystemQuad::updateParticleQuads()
|
||||||
float* y = _particleData.posy;
|
float* y = _particleData.posy;
|
||||||
float* s = _particleData.size;
|
float* s = _particleData.size;
|
||||||
float* r = _particleData.rotation;
|
float* r = _particleData.rotation;
|
||||||
float* sr = _particleData.staticRotation;
|
|
||||||
float* sid = _particleData.scaleInDelta;
|
|
||||||
float* sil = _particleData.scaleInLength;
|
|
||||||
V3F_C4B_T2F_Quad* quadStart = startQuad;
|
V3F_C4B_T2F_Quad* quadStart = startQuad;
|
||||||
if (_isScaleInAllocated)
|
for (int i = 0; i < _particleCount; ++i, ++startX, ++startY, ++x, ++y, ++quadStart, ++s, ++r)
|
||||||
{
|
|
||||||
for (int i = 0; i < _particleCount;
|
|
||||||
++i, ++startX, ++startY, ++x, ++y, ++quadStart, ++s, ++r, ++sr, ++sid, ++sil)
|
|
||||||
{
|
{
|
||||||
newPos.set(*x + pos.x, *y + pos.y);
|
newPos.set(*x + pos.x, *y + pos.y);
|
||||||
updatePosWithParticle(quadStart, newPos, *s, tweenfunc::expoEaseOut(*sid / *sil), *r, *sr);
|
updatePosWithParticle(quadStart, newPos, *s, *r);
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
for (int i = 0; i < _particleCount; ++i, ++startX, ++startY, ++x, ++y, ++quadStart, ++s, ++r, ++sr)
|
|
||||||
{
|
|
||||||
newPos.set(*x + pos.x, *y + pos.y);
|
|
||||||
updatePosWithParticle(quadStart, newPos, *s, 1.0F, *r, *sr);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// set color
|
||||||
|
if (_opacityModifyRGB)
|
||||||
|
{
|
||||||
V3F_C4B_T2F_Quad* quad = startQuad;
|
V3F_C4B_T2F_Quad* quad = startQuad;
|
||||||
float* r = _particleData.colorR;
|
float* r = _particleData.colorR;
|
||||||
float* g = _particleData.colorG;
|
float* g = _particleData.colorG;
|
||||||
float* b = _particleData.colorB;
|
float* b = _particleData.colorB;
|
||||||
float* a = _particleData.colorA;
|
float* a = _particleData.colorA;
|
||||||
|
|
||||||
if (_isOpacityFadeInAllocated)
|
|
||||||
{
|
|
||||||
float* fadeDt = _particleData.opacityFadeInDelta;
|
|
||||||
float* fadeLn = _particleData.opacityFadeInLength;
|
|
||||||
|
|
||||||
// HSV calculation is expensive, so we should skip it if it's not enabled.
|
|
||||||
if (_isHSVAllocated)
|
|
||||||
{
|
|
||||||
float* hue = _particleData.hue;
|
|
||||||
float* sat = _particleData.sat;
|
|
||||||
float* val = _particleData.val;
|
|
||||||
|
|
||||||
if (_opacityModifyRGB)
|
|
||||||
{
|
|
||||||
auto hsv = HSV();
|
|
||||||
for (int i = 0; i < _particleCount;
|
|
||||||
++i, ++quad, ++r, ++g, ++b, ++a, ++hue, ++sat, ++val, ++fadeDt, ++fadeLn)
|
|
||||||
{
|
|
||||||
float colorR = *r;
|
|
||||||
float colorG = *g;
|
|
||||||
float colorB = *b;
|
|
||||||
float colorA = *a * (*fadeDt / *fadeLn);
|
|
||||||
hsv.set(colorR, colorG, colorB, colorA);
|
|
||||||
hsv.h += *hue;
|
|
||||||
hsv.s = abs(*sat);
|
|
||||||
hsv.v = abs(*val);
|
|
||||||
auto colF = hsv.toColor4F();
|
|
||||||
quad->bl.colors.set(colF.r * colF.a * 255.0F, colF.g * colF.a * 255.0F, colF.b * colF.a * 255.0F,
|
|
||||||
colF.a * 255.0F);
|
|
||||||
quad->br.colors.set(colF.r * colF.a * 255.0F, colF.g * colF.a * 255.0F, colF.b * colF.a * 255.0F,
|
|
||||||
colF.a * 255.0F);
|
|
||||||
quad->tl.colors.set(colF.r * colF.a * 255.0F, colF.g * colF.a * 255.0F, colF.b * colF.a * 255.0F,
|
|
||||||
colF.a * 255.0F);
|
|
||||||
quad->tr.colors.set(colF.r * colF.a * 255.0F, colF.g * colF.a * 255.0F, colF.b * colF.a * 255.0F,
|
|
||||||
colF.a * 255.0F);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
auto hsv = HSV();
|
|
||||||
for (int i = 0; i < _particleCount;
|
|
||||||
++i, ++quad, ++r, ++g, ++b, ++a, ++hue, ++sat, ++val, ++fadeDt, ++fadeLn)
|
|
||||||
{
|
|
||||||
float colorR = *r;
|
|
||||||
float colorG = *g;
|
|
||||||
float colorB = *b;
|
|
||||||
float colorA = *a * (*fadeDt / *fadeLn);
|
|
||||||
hsv.set(colorR, colorG, colorB, colorA);
|
|
||||||
hsv.h += *hue;
|
|
||||||
hsv.s = abs(*sat);
|
|
||||||
hsv.v = abs(*val);
|
|
||||||
auto col = hsv.toColor4B();
|
|
||||||
quad->bl.colors.set(col.r, col.g, col.b, col.a);
|
|
||||||
quad->br.colors.set(col.r, col.g, col.b, col.a);
|
|
||||||
quad->tl.colors.set(col.r, col.g, col.b, col.a);
|
|
||||||
quad->tr.colors.set(col.r, col.g, col.b, col.a);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// set color
|
|
||||||
if (_opacityModifyRGB)
|
|
||||||
{
|
|
||||||
for (int i = 0; i < _particleCount; ++i, ++quad, ++r, ++g, ++b, ++a, ++fadeDt, ++fadeLn)
|
|
||||||
{
|
|
||||||
uint8_t colorR = *r * *a * 255;
|
|
||||||
uint8_t colorG = *g * *a * 255;
|
|
||||||
uint8_t colorB = *b * *a * 255;
|
|
||||||
uint8_t colorA = *a * (*fadeDt / *fadeLn) * 255;
|
|
||||||
quad->bl.colors.set(colorR, colorG, colorB, colorA);
|
|
||||||
quad->br.colors.set(colorR, colorG, colorB, colorA);
|
|
||||||
quad->tl.colors.set(colorR, colorG, colorB, colorA);
|
|
||||||
quad->tr.colors.set(colorR, colorG, colorB, colorA);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
for (int i = 0; i < _particleCount; ++i, ++quad, ++r, ++g, ++b, ++a, ++fadeDt, ++fadeLn)
|
|
||||||
{
|
|
||||||
uint8_t colorR = *r * 255;
|
|
||||||
uint8_t colorG = *g * 255;
|
|
||||||
uint8_t colorB = *b * 255;
|
|
||||||
uint8_t colorA = *a * (*fadeDt / *fadeLn) * 255;
|
|
||||||
quad->bl.colors.set(colorR, colorG, colorB, colorA);
|
|
||||||
quad->br.colors.set(colorR, colorG, colorB, colorA);
|
|
||||||
quad->tl.colors.set(colorR, colorG, colorB, colorA);
|
|
||||||
quad->tr.colors.set(colorR, colorG, colorB, colorA);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// HSV calculation is expensive, so we should skip it if it's not enabled.
|
|
||||||
if (_isHSVAllocated)
|
|
||||||
{
|
|
||||||
float* hue = _particleData.hue;
|
|
||||||
float* sat = _particleData.sat;
|
|
||||||
float* val = _particleData.val;
|
|
||||||
|
|
||||||
if (_opacityModifyRGB)
|
|
||||||
{
|
|
||||||
auto hsv = HSV();
|
|
||||||
for (int i = 0; i < _particleCount; ++i, ++quad, ++r, ++g, ++b, ++a, ++hue, ++sat, ++val)
|
|
||||||
{
|
|
||||||
float colorR = *r;
|
|
||||||
float colorG = *g;
|
|
||||||
float colorB = *b;
|
|
||||||
float colorA = *a;
|
|
||||||
hsv.set(colorR, colorG, colorB, colorA);
|
|
||||||
hsv.h += *hue;
|
|
||||||
hsv.s = abs(*sat);
|
|
||||||
hsv.v = abs(*val);
|
|
||||||
auto colF = hsv.toColor4F();
|
|
||||||
quad->bl.colors.set(colF.r * colF.a * 255.0F, colF.g * colF.a * 255.0F, colF.b * colF.a * 255.0F,
|
|
||||||
colF.a * 255.0F);
|
|
||||||
quad->br.colors.set(colF.r * colF.a * 255.0F, colF.g * colF.a * 255.0F, colF.b * colF.a * 255.0F,
|
|
||||||
colF.a * 255.0F);
|
|
||||||
quad->tl.colors.set(colF.r * colF.a * 255.0F, colF.g * colF.a * 255.0F, colF.b * colF.a * 255.0F,
|
|
||||||
colF.a * 255.0F);
|
|
||||||
quad->tr.colors.set(colF.r * colF.a * 255.0F, colF.g * colF.a * 255.0F, colF.b * colF.a * 255.0F,
|
|
||||||
colF.a * 255.0F);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
auto hsv = HSV();
|
|
||||||
for (int i = 0; i < _particleCount; ++i, ++quad, ++r, ++g, ++b, ++a, ++hue, ++sat, ++val)
|
|
||||||
{
|
|
||||||
float colorR = *r;
|
|
||||||
float colorG = *g;
|
|
||||||
float colorB = *b;
|
|
||||||
float colorA = *a;
|
|
||||||
hsv.set(colorR, colorG, colorB, colorA);
|
|
||||||
hsv.h += *hue;
|
|
||||||
hsv.s = abs(*sat);
|
|
||||||
hsv.v = abs(*val);
|
|
||||||
auto col = hsv.toColor4B();
|
|
||||||
quad->bl.colors.set(col.r, col.g, col.b, col.a);
|
|
||||||
quad->br.colors.set(col.r, col.g, col.b, col.a);
|
|
||||||
quad->tl.colors.set(col.r, col.g, col.b, col.a);
|
|
||||||
quad->tr.colors.set(col.r, col.g, col.b, col.a);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// set color
|
|
||||||
if (_opacityModifyRGB)
|
|
||||||
{
|
|
||||||
for (int i = 0; i < _particleCount; ++i, ++quad, ++r, ++g, ++b, ++a)
|
for (int i = 0; i < _particleCount; ++i, ++quad, ++r, ++g, ++b, ++a)
|
||||||
{
|
{
|
||||||
uint8_t colorR = *r * *a * 255;
|
uint8_t colorR = *r * *a * 255;
|
||||||
|
@ -638,66 +427,23 @@ void ParticleSystemQuad::updateParticleQuads()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
|
||||||
for (int i = 0; i < _particleCount; ++i, ++quad, ++r, ++g, ++b, ++a)
|
|
||||||
{
|
|
||||||
uint8_t colorR = *r * 255;
|
|
||||||
uint8_t colorG = *g * 255;
|
|
||||||
uint8_t colorB = *b * 255;
|
|
||||||
uint8_t colorA = *a * 255;
|
|
||||||
quad->bl.colors.set(colorR, colorG, colorB, colorA);
|
|
||||||
quad->br.colors.set(colorR, colorG, colorB, colorA);
|
|
||||||
quad->tl.colors.set(colorR, colorG, colorB, colorA);
|
|
||||||
quad->tr.colors.set(colorR, colorG, colorB, colorA);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// The reason for using for-loops separately for every property is because
|
|
||||||
// When the processor needs to read from or write to a location in memory,
|
|
||||||
// it first checks whether a copy of that data is in the cpu's cache.
|
|
||||||
// And wether if every property's memory of the particle system is continuous,
|
|
||||||
// for the purpose of improving cache hit rate, we should process only one property in one for-loop.
|
|
||||||
// It was proved to be effective especially for low-end devices.
|
|
||||||
if (_isLifeAnimated || _isEmitterAnimated || _isLoopAnimated || _isAnimAllocated)
|
|
||||||
{
|
{
|
||||||
V3F_C4B_T2F_Quad* quad = startQuad;
|
V3F_C4B_T2F_Quad* quad = startQuad;
|
||||||
unsigned short* cellIndex = _particleData.animCellIndex;
|
float* r = _particleData.colorR;
|
||||||
|
float* g = _particleData.colorG;
|
||||||
|
float* b = _particleData.colorB;
|
||||||
|
float* a = _particleData.colorA;
|
||||||
|
|
||||||
ParticleFrameDescriptor index;
|
for (int i = 0; i < _particleCount; ++i, ++quad, ++r, ++g, ++b, ++a)
|
||||||
for (int i = 0; i < _particleCount; ++i, ++quad, ++cellIndex)
|
|
||||||
{
|
{
|
||||||
float left = 0.0F, bottom = 0.0F, top = 1.0F, right = 1.0F;
|
uint8_t colorR = *r * 255;
|
||||||
|
uint8_t colorG = *g * 255;
|
||||||
// TODO: index.isRotated should be treated accordingly
|
uint8_t colorB = *b * 255;
|
||||||
|
uint8_t colorA = *a * 255;
|
||||||
auto iter = _animationIndices.find(*cellIndex);
|
quad->bl.colors.set(colorR, colorG, colorB, colorA);
|
||||||
if (iter == _animationIndices.end())
|
quad->br.colors.set(colorR, colorG, colorB, colorA);
|
||||||
index.rect = {0, 0, float(_texture->getPixelsWide()), float(_texture->getPixelsHigh())};
|
quad->tl.colors.set(colorR, colorG, colorB, colorA);
|
||||||
else
|
quad->tr.colors.set(colorR, colorG, colorB, colorA);
|
||||||
index = iter->second;
|
|
||||||
|
|
||||||
auto texWidth = _texture->getPixelsWide();
|
|
||||||
auto texHeight = _texture->getPixelsHigh();
|
|
||||||
|
|
||||||
left = index.rect.origin.x / texWidth;
|
|
||||||
right = (index.rect.origin.x + index.rect.size.x) / texWidth;
|
|
||||||
|
|
||||||
top = index.rect.origin.y / texHeight;
|
|
||||||
bottom = (index.rect.origin.y + index.rect.size.y) / texHeight;
|
|
||||||
|
|
||||||
quad->bl.texCoords.u = left;
|
|
||||||
quad->bl.texCoords.v = bottom;
|
|
||||||
|
|
||||||
quad->br.texCoords.u = right;
|
|
||||||
quad->br.texCoords.v = bottom;
|
|
||||||
|
|
||||||
quad->tl.texCoords.u = left;
|
|
||||||
quad->tl.texCoords.v = top;
|
|
||||||
|
|
||||||
quad->tr.texCoords.u = right;
|
|
||||||
quad->tr.texCoords.v = top;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -780,15 +780,6 @@ std::string urlDecode(std::string_view st)
|
||||||
return decoded;
|
return decoded;
|
||||||
}
|
}
|
||||||
|
|
||||||
CC_DLL uint32_t fourccValue(std::string_view str)
|
|
||||||
{
|
|
||||||
if (str.empty() || str[0] != '#')
|
|
||||||
return (uint32_t)-1;
|
|
||||||
uint32_t value = 0;
|
|
||||||
memcpy(&value, str.data() + 1, std::min(sizeof(value), str.size() - 1));
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace utils
|
} // namespace utils
|
||||||
|
|
||||||
NS_CC_END
|
NS_CC_END
|
||||||
|
|
|
@ -404,8 +404,6 @@ inline char* char2hex(char* p, unsigned char c, unsigned char a = 'a')
|
||||||
CC_DLL std::string urlEncode(std::string_view s);
|
CC_DLL std::string urlEncode(std::string_view s);
|
||||||
|
|
||||||
CC_DLL std::string urlDecode(std::string_view st);
|
CC_DLL std::string urlDecode(std::string_view st);
|
||||||
|
|
||||||
CC_DLL uint32_t fourccValue(std::string_view str);
|
|
||||||
} // namespace utils
|
} // namespace utils
|
||||||
|
|
||||||
NS_CC_END
|
NS_CC_END
|
||||||
|
|
|
@ -0,0 +1,12 @@
|
||||||
|
// The stdfs workaround header, if not avaiable on current system, use ghc::filesystem
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
/* ios < 13 or ndk < 22, ghc as workaround */
|
||||||
|
#if (defined(__IPHONE_OS_VERSION_MIN_REQUIRED) && __IPHONE_OS_VERSION_MIN_REQUIRED < 130000) || \
|
||||||
|
(defined(__NDK_MAJOR__) && __NDK_MAJOR__ < 22)
|
||||||
|
# include "ghc/filesystem.hpp"
|
||||||
|
namespace stdfs = ghc::filesystem;
|
||||||
|
#else
|
||||||
|
# include <filesystem>
|
||||||
|
namespace stdfs = std::filesystem;
|
||||||
|
#endif
|
|
@ -1,88 +0,0 @@
|
||||||
#ifndef RNGSEED_H_
|
|
||||||
#define RNGSEED_H_
|
|
||||||
|
|
||||||
/** A more effective seeded random number generator struct, made by kiss rng.
|
|
||||||
* @since adxe-1.0.0b8
|
|
||||||
*/
|
|
||||||
struct RngSeed
|
|
||||||
{
|
|
||||||
const unsigned long RNG_RAND_MAX = 4294967295;
|
|
||||||
const unsigned long RNG_RAND_MAX_SIGNED = 2147483647;
|
|
||||||
unsigned long _x = 1;
|
|
||||||
unsigned long _y = 2;
|
|
||||||
unsigned long _z = 4;
|
|
||||||
unsigned long _w = 8;
|
|
||||||
unsigned long _carry = 0;
|
|
||||||
unsigned long _k = 0;
|
|
||||||
unsigned long _m = 0;
|
|
||||||
unsigned long _seed = 0;
|
|
||||||
|
|
||||||
RngSeed() { seed_rand(time(NULL)); }
|
|
||||||
|
|
||||||
// initialize this object with seed
|
|
||||||
void seed_rand(unsigned long seed)
|
|
||||||
{
|
|
||||||
_seed = seed;
|
|
||||||
_x = seed | 1;
|
|
||||||
_y = seed | 2;
|
|
||||||
_z = seed | 4;
|
|
||||||
_w = seed | 8;
|
|
||||||
_carry = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
// returns an unsigned long random value
|
|
||||||
unsigned long rand()
|
|
||||||
{
|
|
||||||
_x = _x * 69069 + 1;
|
|
||||||
_y ^= _y << 13;
|
|
||||||
_y ^= _y >> 17;
|
|
||||||
_y ^= _y << 5;
|
|
||||||
_k = (_z >> 2) + (_w >> 3) + (_carry >> 2);
|
|
||||||
_m = _w + _w + _z + _carry;
|
|
||||||
_z = _w;
|
|
||||||
_w = _m;
|
|
||||||
_carry = _k >> 30;
|
|
||||||
return _x + _y + _w;
|
|
||||||
}
|
|
||||||
|
|
||||||
// returns a random integer from min to max
|
|
||||||
int range(int min, int max)
|
|
||||||
{
|
|
||||||
return floor(min + static_cast<float>(rand()) / (static_cast<float>(RNG_RAND_MAX / (max - min))));
|
|
||||||
}
|
|
||||||
|
|
||||||
// returns a random unsigned integer from min to max
|
|
||||||
unsigned int rangeu(unsigned int min, unsigned int max)
|
|
||||||
{
|
|
||||||
return floor(min + static_cast<float>(rand()) / (static_cast<float>(RNG_RAND_MAX / (max - min))));
|
|
||||||
}
|
|
||||||
|
|
||||||
// returns a random float from min to max
|
|
||||||
float rangef(float min = -1.0F, float max = 1.0F)
|
|
||||||
{
|
|
||||||
return min + static_cast<float>(rand()) / (static_cast<float>(RNG_RAND_MAX / (max - min)));
|
|
||||||
}
|
|
||||||
|
|
||||||
// returns a random integer from 0 to max
|
|
||||||
int max(int max = INT_MAX)
|
|
||||||
{
|
|
||||||
return floor(0 + static_cast<float>(rand()) / (static_cast<float>(RNG_RAND_MAX / (max - 0))));
|
|
||||||
}
|
|
||||||
|
|
||||||
// returns a random unsigned integer from 0 to max
|
|
||||||
unsigned int maxu(unsigned int max = UINT_MAX)
|
|
||||||
{
|
|
||||||
return floor(0 + static_cast<float>(rand()) / (static_cast<float>(RNG_RAND_MAX / (max - 0))));
|
|
||||||
}
|
|
||||||
|
|
||||||
// returns a random float from 0.0 to max
|
|
||||||
float maxf(float max) { return 0 + static_cast<float>(rand()) / (static_cast<float>(RNG_RAND_MAX / (max - 0))); }
|
|
||||||
|
|
||||||
// returns a random float from 0.0 to 1.0
|
|
||||||
float float01() { return 0 + static_cast<float>(rand()) / (static_cast<float>(RNG_RAND_MAX / (1 - 0))); }
|
|
||||||
|
|
||||||
// returns either false or true randomly
|
|
||||||
bool bool01() { return (bool)floor(0 + static_cast<float>(rand()) / (static_cast<float>(RNG_RAND_MAX / (2 - 0)))); }
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif
|
|
|
@ -53,14 +53,7 @@ THE SOFTWARE.
|
||||||
|
|
||||||
#define DECLARE_GUARD (void)0
|
#define DECLARE_GUARD (void)0
|
||||||
|
|
||||||
#if CC_TARGET_PLATFORM != CC_PLATFORM_IOS && \
|
#include "base/filesystem.h"
|
||||||
(CC_TARGET_PLATFORM != CC_PLATFORM_ANDROID || (defined(__NDK_MAJOR__) && __NDK_MAJOR__ >= 22))
|
|
||||||
# include <filesystem>
|
|
||||||
namespace stdfs = std::filesystem;
|
|
||||||
#else
|
|
||||||
#include "ghc/filesystem.hpp"
|
|
||||||
namespace stdfs = ghc::filesystem;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
# if defined(_WIN32)
|
# if defined(_WIN32)
|
||||||
inline stdfs::path toFspath(const std::string_view& pathSV)
|
inline stdfs::path toFspath(const std::string_view& pathSV)
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -182,225 +182,6 @@ public:
|
||||||
virtual std::string subtitle() const override;
|
virtual std::string subtitle() const override;
|
||||||
};
|
};
|
||||||
|
|
||||||
class DemoFixedFPS : public ParticleDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CREATE_FUNC(DemoFixedFPS);
|
|
||||||
virtual void onEnter() override;
|
|
||||||
virtual std::string subtitle() const override;
|
|
||||||
};
|
|
||||||
|
|
||||||
class DemoTimeScale: public ParticleDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CREATE_FUNC(DemoTimeScale);
|
|
||||||
virtual void onEnter() override;
|
|
||||||
virtual std::string subtitle() const override;
|
|
||||||
virtual void update(float dt) override;
|
|
||||||
|
|
||||||
float elapsedTime = 0.0F;
|
|
||||||
};
|
|
||||||
|
|
||||||
class DemoSpawnFadeIn : public ParticleDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CREATE_FUNC(DemoSpawnFadeIn);
|
|
||||||
virtual void onEnter() override;
|
|
||||||
virtual std::string subtitle() const override;
|
|
||||||
};
|
|
||||||
|
|
||||||
class DemoScaleFadeIn : public ParticleDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CREATE_FUNC(DemoScaleFadeIn);
|
|
||||||
virtual void onEnter() override;
|
|
||||||
virtual std::string subtitle() const override;
|
|
||||||
};
|
|
||||||
|
|
||||||
class DemoSimulation : public ParticleDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CREATE_FUNC(DemoSimulation);
|
|
||||||
virtual void onEnter() override;
|
|
||||||
virtual std::string subtitle() const override;
|
|
||||||
};
|
|
||||||
|
|
||||||
class DemoSpawnRotation : public ParticleDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CREATE_FUNC(DemoSpawnRotation);
|
|
||||||
virtual void onEnter() override;
|
|
||||||
virtual std::string subtitle() const override;
|
|
||||||
};
|
|
||||||
|
|
||||||
class DemoHSV : public ParticleDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CREATE_FUNC(DemoHSV);
|
|
||||||
virtual void onEnter() override;
|
|
||||||
virtual std::string subtitle() const override;
|
|
||||||
};
|
|
||||||
|
|
||||||
class DemoLifeAnimation : public ParticleDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CREATE_FUNC(DemoLifeAnimation);
|
|
||||||
virtual void onEnter() override;
|
|
||||||
virtual std::string subtitle() const override;
|
|
||||||
};
|
|
||||||
|
|
||||||
class DemoLifeAnimationAtlas : public ParticleDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CREATE_FUNC(DemoLifeAnimationAtlas);
|
|
||||||
virtual void onEnter() override;
|
|
||||||
virtual std::string subtitle() const override;
|
|
||||||
};
|
|
||||||
|
|
||||||
class DemoLifeAnimationReversed : public ParticleDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CREATE_FUNC(DemoLifeAnimationReversed);
|
|
||||||
virtual void onEnter() override;
|
|
||||||
virtual std::string subtitle() const override;
|
|
||||||
};
|
|
||||||
|
|
||||||
class DemoLoopAnimation : public ParticleDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CREATE_FUNC(DemoLoopAnimation);
|
|
||||||
virtual void onEnter() override;
|
|
||||||
virtual std::string subtitle() const override;
|
|
||||||
};
|
|
||||||
|
|
||||||
class DemoLoopAnimationReversed : public ParticleDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CREATE_FUNC(DemoLoopAnimationReversed);
|
|
||||||
virtual void onEnter() override;
|
|
||||||
virtual std::string subtitle() const override;
|
|
||||||
};
|
|
||||||
|
|
||||||
class DemoEmitterAnimation : public ParticleDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CREATE_FUNC(DemoEmitterAnimation);
|
|
||||||
virtual void onEnter() override;
|
|
||||||
virtual std::string subtitle() const override;
|
|
||||||
};
|
|
||||||
|
|
||||||
class DemoEmitterAnimationDescriptor : public ParticleDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CREATE_FUNC(DemoEmitterAnimationDescriptor);
|
|
||||||
virtual void onEnter() override;
|
|
||||||
virtual std::string subtitle() const override;
|
|
||||||
};
|
|
||||||
|
|
||||||
class DemoLoopAnimationMultiDescriptor : public ParticleDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CREATE_FUNC(DemoLoopAnimationMultiDescriptor);
|
|
||||||
virtual void onEnter() override;
|
|
||||||
virtual std::string subtitle() const override;
|
|
||||||
};
|
|
||||||
|
|
||||||
class DemoEmissionShapePoint : public ParticleDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CREATE_FUNC(DemoEmissionShapePoint);
|
|
||||||
virtual void onEnter() override;
|
|
||||||
virtual std::string subtitle() const override;
|
|
||||||
};
|
|
||||||
|
|
||||||
class DemoEmissionShapeRect : public ParticleDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CREATE_FUNC(DemoEmissionShapeRect);
|
|
||||||
virtual void onEnter() override;
|
|
||||||
virtual std::string subtitle() const override;
|
|
||||||
};
|
|
||||||
|
|
||||||
class DemoEmissionShapeRectTorus : public ParticleDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CREATE_FUNC(DemoEmissionShapeRectTorus);
|
|
||||||
virtual void onEnter() override;
|
|
||||||
virtual std::string subtitle() const override;
|
|
||||||
};
|
|
||||||
|
|
||||||
class DemoEmissionShapeCircle : public ParticleDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CREATE_FUNC(DemoEmissionShapeCircle);
|
|
||||||
virtual void onEnter() override;
|
|
||||||
virtual std::string subtitle() const override;
|
|
||||||
};
|
|
||||||
|
|
||||||
class DemoEmissionShapeCircleBiasEdge : public ParticleDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CREATE_FUNC(DemoEmissionShapeCircleBiasEdge);
|
|
||||||
virtual void onEnter() override;
|
|
||||||
virtual std::string subtitle() const override;
|
|
||||||
};
|
|
||||||
|
|
||||||
class DemoEmissionShapeCircleBiasCenter : public ParticleDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CREATE_FUNC(DemoEmissionShapeCircleBiasCenter);
|
|
||||||
virtual void onEnter() override;
|
|
||||||
virtual std::string subtitle() const override;
|
|
||||||
};
|
|
||||||
|
|
||||||
class DemoEmissionShapeTorus : public ParticleDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CREATE_FUNC(DemoEmissionShapeTorus);
|
|
||||||
virtual void onEnter() override;
|
|
||||||
virtual std::string subtitle() const override;
|
|
||||||
};
|
|
||||||
|
|
||||||
class DemoEmissionShapeTorusBiasEdge : public ParticleDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CREATE_FUNC(DemoEmissionShapeTorusBiasEdge);
|
|
||||||
virtual void onEnter() override;
|
|
||||||
virtual std::string subtitle() const override;
|
|
||||||
};
|
|
||||||
|
|
||||||
class DemoEmissionShapeTorusBiasInner : public ParticleDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CREATE_FUNC(DemoEmissionShapeTorusBiasInner);
|
|
||||||
virtual void onEnter() override;
|
|
||||||
virtual std::string subtitle() const override;
|
|
||||||
};
|
|
||||||
|
|
||||||
class DemoEmissionShapeCone : public ParticleDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CREATE_FUNC(DemoEmissionShapeCone);
|
|
||||||
virtual void onEnter() override;
|
|
||||||
virtual std::string subtitle() const override;
|
|
||||||
};
|
|
||||||
|
|
||||||
class DemoEmissionShapeConeTorus : public ParticleDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CREATE_FUNC(DemoEmissionShapeConeTorus);
|
|
||||||
virtual void onEnter() override;
|
|
||||||
virtual std::string subtitle() const override;
|
|
||||||
};
|
|
||||||
|
|
||||||
class DemoEmissionShapeAlphaMask : public ParticleDemo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CREATE_FUNC(DemoEmissionShapeAlphaMask);
|
|
||||||
virtual void onEnter() override;
|
|
||||||
virtual std::string subtitle() const override;
|
|
||||||
};
|
|
||||||
|
|
||||||
class DemoParticleFromFile : public ParticleDemo
|
class DemoParticleFromFile : public ParticleDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
Loading…
Reference in New Issue