Remove useless functions.

This commit is contained in:
DelinWorks 2022-06-16 16:16:19 +03:00
parent ee6d7d374e
commit 5491ca8e6e
15 changed files with 477 additions and 3691 deletions

View File

@ -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;

View File

@ -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
}; };

View File

@ -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)

View File

@ -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;

View File

@ -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

View File

@ -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;
@ -1452,32 +815,9 @@ public:
/* 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);
}; };

View File

@ -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;
} }
} }
} }

View File

@ -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

View File

@ -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

12
core/base/filesystem.h Normal file
View File

@ -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

View File

@ -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

View File

@ -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

View File

@ -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: