mirror of https://github.com/axmolengine/axmol.git
[IMPROVMENT] Change class name `Sprite3D` to `MeshRenderer` (#705)
* First draft [skip ci] * Improve comments [skip ci] * Rename MeshRendererMaterial to MeshMaterial [skip ci] * Update dependent classes. * Replace occurrences of Sprite3D with MeshRenderer. * Update cpp-tests and extensions. * Fix compilation. * Try fixing lua-bindings * Try fixing lua-bindings * Update lua_cocos2dx_3d_manual.cpp [skip ci] * Create RENAMED_TYPES.md
This commit is contained in:
parent
5edbfa5448
commit
656babac78
|
@ -0,0 +1,8 @@
|
||||||
|
adxe-1.0 ??
|
||||||
|
|
||||||
|
### Classes & Types
|
||||||
|
* ```Sprite3D``` => ```MeshRenderer```
|
||||||
|
|
||||||
|
### Functions & Methods
|
||||||
|
* ```Director::isDisplayStats()``` => ```Director::isStatsDisplay()```
|
||||||
|
|
|
@ -24,7 +24,7 @@
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#include "3d/CCAnimate3D.h"
|
#include "3d/CCAnimate3D.h"
|
||||||
#include "3d/CCSprite3D.h"
|
#include "3d/CCMeshRenderer.h"
|
||||||
#include "3d/CCSkeleton3D.h"
|
#include "3d/CCSkeleton3D.h"
|
||||||
#include "platform/CCFileUtils.h"
|
#include "platform/CCFileUtils.h"
|
||||||
#include "base/CCConfiguration.h"
|
#include "base/CCConfiguration.h"
|
||||||
|
@ -156,9 +156,9 @@ void Animate3D::startWithTarget(Node* target)
|
||||||
_nodeCurves.clear();
|
_nodeCurves.clear();
|
||||||
|
|
||||||
bool hasCurve = false;
|
bool hasCurve = false;
|
||||||
Sprite3D* sprite = dynamic_cast<Sprite3D*>(target);
|
MeshRenderer* mesh = dynamic_cast<MeshRenderer*>(target);
|
||||||
|
|
||||||
if (sprite)
|
if (mesh)
|
||||||
{
|
{
|
||||||
if (_animation)
|
if (_animation)
|
||||||
{
|
{
|
||||||
|
@ -166,7 +166,7 @@ void Animate3D::startWithTarget(Node* target)
|
||||||
for (const auto& iter : boneCurves)
|
for (const auto& iter : boneCurves)
|
||||||
{
|
{
|
||||||
std::string_view boneName = iter.first;
|
std::string_view boneName = iter.first;
|
||||||
auto skin = sprite->getSkeleton();
|
auto skin = mesh->getSkeleton();
|
||||||
if (skin)
|
if (skin)
|
||||||
{
|
{
|
||||||
auto bone = skin->getBoneByName(boneName);
|
auto bone = skin->getBoneByName(boneName);
|
||||||
|
|
|
@ -37,7 +37,7 @@
|
||||||
NS_CC_BEGIN
|
NS_CC_BEGIN
|
||||||
|
|
||||||
class Bone3D;
|
class Bone3D;
|
||||||
class Sprite3D;
|
class MeshRenderer;
|
||||||
class EventCustom;
|
class EventCustom;
|
||||||
|
|
||||||
enum class Animate3DQuality
|
enum class Animate3DQuality
|
||||||
|
@ -54,7 +54,7 @@ enum class Animate3DQuality
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Animate3D, Animates a Sprite3D given with an Animation3D
|
* @brief Animate3D, Animates a MeshRenderer given with an Animation3D
|
||||||
*/
|
*/
|
||||||
class CC_DLL Animate3D : public ActionInterval
|
class CC_DLL Animate3D : public ActionInterval
|
||||||
{
|
{
|
||||||
|
@ -174,7 +174,7 @@ protected:
|
||||||
std::unordered_map<int, EventCustom*> _keyFrameEvent;
|
std::unordered_map<int, EventCustom*> _keyFrameEvent;
|
||||||
std::unordered_map<int, Animate3DDisplayedEventInfo> _displayedEventInfo;
|
std::unordered_map<int, Animate3DDisplayedEventInfo> _displayedEventInfo;
|
||||||
|
|
||||||
// sprite animates
|
// mesh animations
|
||||||
static std::unordered_map<Node*, Animate3D*> s_fadeInAnimates;
|
static std::unordered_map<Node*, Animate3D*> s_fadeInAnimates;
|
||||||
static std::unordered_map<Node*, Animate3D*> s_fadeOutAnimates;
|
static std::unordered_map<Node*, Animate3D*> s_fadeOutAnimates;
|
||||||
static std::unordered_map<Node*, Animate3D*> s_runningAnimates;
|
static std::unordered_map<Node*, Animate3D*> s_runningAnimates;
|
||||||
|
|
|
@ -38,9 +38,9 @@ class Bone3D;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief attach a node to a bone
|
* @brief attach a node to a bone
|
||||||
* usage: auto sprite = Sprite3D::create("girl.c3b");
|
* usage: auto mesh = MeshRenderer::create("girl.c3b");
|
||||||
* auto weapon = Sprite3D::create("weapon.c3b");
|
* auto weapon = MeshRenderer::create("weapon.c3b");
|
||||||
* auto attachNode = sprite->getAttachNode("left hand");
|
* auto attachNode = mesh->getAttachNode("left hand");
|
||||||
* attachNode->addChild(weapon);
|
* attachNode->addChild(weapon);
|
||||||
*/
|
*/
|
||||||
class CC_DLL AttachNode : public Node
|
class CC_DLL AttachNode : public Node
|
||||||
|
|
|
@ -109,7 +109,7 @@ struct NodeData
|
||||||
struct NodeDatas
|
struct NodeDatas
|
||||||
{
|
{
|
||||||
std::vector<NodeData*> skeleton; // skeleton
|
std::vector<NodeData*> skeleton; // skeleton
|
||||||
std::vector<NodeData*> nodes; // nodes, CCNode, Sprite3D or part of Sprite3D
|
std::vector<NodeData*> nodes; // nodes, CCNode, MeshRenderer or parts of MeshRenderer
|
||||||
|
|
||||||
virtual ~NodeDatas() { resetData(); }
|
virtual ~NodeDatas() { resetData(); }
|
||||||
|
|
||||||
|
|
|
@ -61,7 +61,7 @@ class Buffer;
|
||||||
*/
|
*/
|
||||||
class CC_DLL Mesh : public Ref
|
class CC_DLL Mesh : public Ref
|
||||||
{
|
{
|
||||||
friend class Sprite3D;
|
friend class MeshRenderer;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
typedef std::vector<unsigned short> IndexArray;
|
typedef std::vector<unsigned short> IndexArray;
|
||||||
|
@ -234,7 +234,7 @@ public:
|
||||||
void calculateAABB();
|
void calculateAABB();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* force set this Sprite3D to 2D render queue
|
* force set this Mesh renderer to 2D render queue
|
||||||
*/
|
*/
|
||||||
void setForce2DQueue(bool force2D) { _force2DQueue = force2D; }
|
void setForce2DQueue(bool force2D) { _force2DQueue = force2D; }
|
||||||
|
|
||||||
|
|
|
@ -23,7 +23,7 @@
|
||||||
THE SOFTWARE.
|
THE SOFTWARE.
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#include "3d/CCSprite3DMaterial.h"
|
#include "3d/CCMeshMaterial.h"
|
||||||
#include "3d/CCMesh.h"
|
#include "3d/CCMesh.h"
|
||||||
#include "platform/CCFileUtils.h"
|
#include "platform/CCFileUtils.h"
|
||||||
#include "renderer/CCTexture2D.h"
|
#include "renderer/CCTexture2D.h"
|
||||||
|
@ -36,102 +36,102 @@
|
||||||
|
|
||||||
NS_CC_BEGIN
|
NS_CC_BEGIN
|
||||||
|
|
||||||
Sprite3DMaterialCache* Sprite3DMaterialCache::_cacheInstance = nullptr;
|
MeshMaterialCache* MeshMaterialCache::_cacheInstance = nullptr;
|
||||||
|
|
||||||
std::unordered_map<std::string, Sprite3DMaterial*> Sprite3DMaterial::_materials;
|
std::unordered_map<std::string, MeshMaterial*> MeshMaterial::_materials;
|
||||||
Sprite3DMaterial* Sprite3DMaterial::_unLitMaterial = nullptr;
|
MeshMaterial* MeshMaterial::_unLitMaterial = nullptr;
|
||||||
Sprite3DMaterial* Sprite3DMaterial::_unLitNoTexMaterial = nullptr;
|
MeshMaterial* MeshMaterial::_unLitNoTexMaterial = nullptr;
|
||||||
Sprite3DMaterial* Sprite3DMaterial::_vertexLitMaterial = nullptr;
|
MeshMaterial* MeshMaterial::_vertexLitMaterial = nullptr;
|
||||||
Sprite3DMaterial* Sprite3DMaterial::_diffuseMaterial = nullptr;
|
MeshMaterial* MeshMaterial::_diffuseMaterial = nullptr;
|
||||||
Sprite3DMaterial* Sprite3DMaterial::_diffuseNoTexMaterial = nullptr;
|
MeshMaterial* MeshMaterial::_diffuseNoTexMaterial = nullptr;
|
||||||
Sprite3DMaterial* Sprite3DMaterial::_bumpedDiffuseMaterial = nullptr;
|
MeshMaterial* MeshMaterial::_bumpedDiffuseMaterial = nullptr;
|
||||||
|
|
||||||
Sprite3DMaterial* Sprite3DMaterial::_unLitMaterialSkin = nullptr;
|
MeshMaterial* MeshMaterial::_unLitMaterialSkin = nullptr;
|
||||||
Sprite3DMaterial* Sprite3DMaterial::_vertexLitMaterialSkin = nullptr;
|
MeshMaterial* MeshMaterial::_vertexLitMaterialSkin = nullptr;
|
||||||
Sprite3DMaterial* Sprite3DMaterial::_diffuseMaterialSkin = nullptr;
|
MeshMaterial* MeshMaterial::_diffuseMaterialSkin = nullptr;
|
||||||
Sprite3DMaterial* Sprite3DMaterial::_bumpedDiffuseMaterialSkin = nullptr;
|
MeshMaterial* MeshMaterial::_bumpedDiffuseMaterialSkin = nullptr;
|
||||||
|
|
||||||
backend::ProgramState* Sprite3DMaterial::_unLitMaterialProgState = nullptr;
|
backend::ProgramState* MeshMaterial::_unLitMaterialProgState = nullptr;
|
||||||
backend::ProgramState* Sprite3DMaterial::_unLitNoTexMaterialProgState = nullptr;
|
backend::ProgramState* MeshMaterial::_unLitNoTexMaterialProgState = nullptr;
|
||||||
backend::ProgramState* Sprite3DMaterial::_vertexLitMaterialProgState = nullptr;
|
backend::ProgramState* MeshMaterial::_vertexLitMaterialProgState = nullptr;
|
||||||
backend::ProgramState* Sprite3DMaterial::_diffuseMaterialProgState = nullptr;
|
backend::ProgramState* MeshMaterial::_diffuseMaterialProgState = nullptr;
|
||||||
backend::ProgramState* Sprite3DMaterial::_diffuseNoTexMaterialProgState = nullptr;
|
backend::ProgramState* MeshMaterial::_diffuseNoTexMaterialProgState = nullptr;
|
||||||
backend::ProgramState* Sprite3DMaterial::_bumpedDiffuseMaterialProgState = nullptr;
|
backend::ProgramState* MeshMaterial::_bumpedDiffuseMaterialProgState = nullptr;
|
||||||
|
|
||||||
backend::ProgramState* Sprite3DMaterial::_unLitMaterialSkinProgState = nullptr;
|
backend::ProgramState* MeshMaterial::_unLitMaterialSkinProgState = nullptr;
|
||||||
backend::ProgramState* Sprite3DMaterial::_vertexLitMaterialSkinProgState = nullptr;
|
backend::ProgramState* MeshMaterial::_vertexLitMaterialSkinProgState = nullptr;
|
||||||
backend::ProgramState* Sprite3DMaterial::_diffuseMaterialSkinProgState = nullptr;
|
backend::ProgramState* MeshMaterial::_diffuseMaterialSkinProgState = nullptr;
|
||||||
backend::ProgramState* Sprite3DMaterial::_bumpedDiffuseMaterialSkinProgState = nullptr;
|
backend::ProgramState* MeshMaterial::_bumpedDiffuseMaterialSkinProgState = nullptr;
|
||||||
|
|
||||||
void Sprite3DMaterial::createBuiltInMaterial()
|
void MeshMaterial::createBuiltInMaterial()
|
||||||
{
|
{
|
||||||
auto* program = backend::Program::getBuiltinProgram(backend::ProgramType::SKINPOSITION_TEXTURE_3D);
|
auto* program = backend::Program::getBuiltinProgram(backend::ProgramType::SKINPOSITION_TEXTURE_3D);
|
||||||
_unLitMaterialSkinProgState = new backend::ProgramState(program);
|
_unLitMaterialSkinProgState = new backend::ProgramState(program);
|
||||||
_unLitMaterialSkin = new Sprite3DMaterial();
|
_unLitMaterialSkin = new MeshMaterial();
|
||||||
if (_unLitMaterialSkin && _unLitMaterialSkin->initWithProgramState(_unLitMaterialSkinProgState))
|
if (_unLitMaterialSkin && _unLitMaterialSkin->initWithProgramState(_unLitMaterialSkinProgState))
|
||||||
{
|
{
|
||||||
_unLitMaterialSkin->_type = Sprite3DMaterial::MaterialType::UNLIT;
|
_unLitMaterialSkin->_type = MeshMaterial::MaterialType::UNLIT;
|
||||||
}
|
}
|
||||||
|
|
||||||
program = backend::Program::getBuiltinProgram(backend::ProgramType::SKINPOSITION_NORMAL_TEXTURE_3D);
|
program = backend::Program::getBuiltinProgram(backend::ProgramType::SKINPOSITION_NORMAL_TEXTURE_3D);
|
||||||
_diffuseMaterialSkinProgState = new backend::ProgramState(program);
|
_diffuseMaterialSkinProgState = new backend::ProgramState(program);
|
||||||
_diffuseMaterialSkin = new Sprite3DMaterial();
|
_diffuseMaterialSkin = new MeshMaterial();
|
||||||
if (_diffuseMaterialSkin && _diffuseMaterialSkin->initWithProgramState(_diffuseMaterialSkinProgState))
|
if (_diffuseMaterialSkin && _diffuseMaterialSkin->initWithProgramState(_diffuseMaterialSkinProgState))
|
||||||
{
|
{
|
||||||
_diffuseMaterialSkin->_type = Sprite3DMaterial::MaterialType::DIFFUSE;
|
_diffuseMaterialSkin->_type = MeshMaterial::MaterialType::DIFFUSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
program = backend::Program::getBuiltinProgram(backend::ProgramType::POSITION_NORMAL_TEXTURE_3D);
|
program = backend::Program::getBuiltinProgram(backend::ProgramType::POSITION_NORMAL_TEXTURE_3D);
|
||||||
_diffuseMaterialProgState = new backend::ProgramState(program);
|
_diffuseMaterialProgState = new backend::ProgramState(program);
|
||||||
_diffuseMaterial = new Sprite3DMaterial();
|
_diffuseMaterial = new MeshMaterial();
|
||||||
if (_diffuseMaterial && _diffuseMaterial->initWithProgramState(_diffuseMaterialProgState))
|
if (_diffuseMaterial && _diffuseMaterial->initWithProgramState(_diffuseMaterialProgState))
|
||||||
{
|
{
|
||||||
_diffuseMaterial->_type = Sprite3DMaterial::MaterialType::DIFFUSE;
|
_diffuseMaterial->_type = MeshMaterial::MaterialType::DIFFUSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
program = backend::Program::getBuiltinProgram(backend::ProgramType::POSITION_TEXTURE_3D);
|
program = backend::Program::getBuiltinProgram(backend::ProgramType::POSITION_TEXTURE_3D);
|
||||||
_unLitMaterialProgState = new backend::ProgramState(program);
|
_unLitMaterialProgState = new backend::ProgramState(program);
|
||||||
_unLitMaterial = new Sprite3DMaterial();
|
_unLitMaterial = new MeshMaterial();
|
||||||
if (_unLitMaterial && _unLitMaterial->initWithProgramState(_unLitMaterialProgState))
|
if (_unLitMaterial && _unLitMaterial->initWithProgramState(_unLitMaterialProgState))
|
||||||
{
|
{
|
||||||
_unLitMaterial->_type = Sprite3DMaterial::MaterialType::UNLIT;
|
_unLitMaterial->_type = MeshMaterial::MaterialType::UNLIT;
|
||||||
}
|
}
|
||||||
|
|
||||||
program = backend::Program::getBuiltinProgram(backend::ProgramType::POSITION_3D);
|
program = backend::Program::getBuiltinProgram(backend::ProgramType::POSITION_3D);
|
||||||
_unLitNoTexMaterialProgState = new backend::ProgramState(program);
|
_unLitNoTexMaterialProgState = new backend::ProgramState(program);
|
||||||
_unLitNoTexMaterial = new Sprite3DMaterial();
|
_unLitNoTexMaterial = new MeshMaterial();
|
||||||
if (_unLitNoTexMaterial && _unLitNoTexMaterial->initWithProgramState(_unLitNoTexMaterialProgState))
|
if (_unLitNoTexMaterial && _unLitNoTexMaterial->initWithProgramState(_unLitNoTexMaterialProgState))
|
||||||
{
|
{
|
||||||
_unLitNoTexMaterial->_type = Sprite3DMaterial::MaterialType::UNLIT_NOTEX;
|
_unLitNoTexMaterial->_type = MeshMaterial::MaterialType::UNLIT_NOTEX;
|
||||||
}
|
}
|
||||||
|
|
||||||
program = backend::Program::getBuiltinProgram(backend::ProgramType::POSITION_NORMAL_3D);
|
program = backend::Program::getBuiltinProgram(backend::ProgramType::POSITION_NORMAL_3D);
|
||||||
_diffuseNoTexMaterialProgState = new backend::ProgramState(program);
|
_diffuseNoTexMaterialProgState = new backend::ProgramState(program);
|
||||||
_diffuseNoTexMaterial = new Sprite3DMaterial();
|
_diffuseNoTexMaterial = new MeshMaterial();
|
||||||
if (_diffuseNoTexMaterial && _diffuseNoTexMaterial->initWithProgramState(_diffuseNoTexMaterialProgState))
|
if (_diffuseNoTexMaterial && _diffuseNoTexMaterial->initWithProgramState(_diffuseNoTexMaterialProgState))
|
||||||
{
|
{
|
||||||
_diffuseNoTexMaterial->_type = Sprite3DMaterial::MaterialType::DIFFUSE_NOTEX;
|
_diffuseNoTexMaterial->_type = MeshMaterial::MaterialType::DIFFUSE_NOTEX;
|
||||||
}
|
}
|
||||||
|
|
||||||
program = backend::Program::getBuiltinProgram(backend::ProgramType::POSITION_BUMPEDNORMAL_TEXTURE_3D);
|
program = backend::Program::getBuiltinProgram(backend::ProgramType::POSITION_BUMPEDNORMAL_TEXTURE_3D);
|
||||||
_bumpedDiffuseMaterialProgState = new backend::ProgramState(program);
|
_bumpedDiffuseMaterialProgState = new backend::ProgramState(program);
|
||||||
_bumpedDiffuseMaterial = new Sprite3DMaterial();
|
_bumpedDiffuseMaterial = new MeshMaterial();
|
||||||
if (_bumpedDiffuseMaterial && _bumpedDiffuseMaterial->initWithProgramState(_bumpedDiffuseMaterialProgState))
|
if (_bumpedDiffuseMaterial && _bumpedDiffuseMaterial->initWithProgramState(_bumpedDiffuseMaterialProgState))
|
||||||
{
|
{
|
||||||
_bumpedDiffuseMaterial->_type = Sprite3DMaterial::MaterialType::BUMPED_DIFFUSE;
|
_bumpedDiffuseMaterial->_type = MeshMaterial::MaterialType::BUMPED_DIFFUSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
program = backend::Program::getBuiltinProgram(backend::ProgramType::SKINPOSITION_BUMPEDNORMAL_TEXTURE_3D);
|
program = backend::Program::getBuiltinProgram(backend::ProgramType::SKINPOSITION_BUMPEDNORMAL_TEXTURE_3D);
|
||||||
_bumpedDiffuseMaterialSkinProgState = new backend::ProgramState(program);
|
_bumpedDiffuseMaterialSkinProgState = new backend::ProgramState(program);
|
||||||
_bumpedDiffuseMaterialSkin = new Sprite3DMaterial();
|
_bumpedDiffuseMaterialSkin = new MeshMaterial();
|
||||||
if (_bumpedDiffuseMaterialSkin &&
|
if (_bumpedDiffuseMaterialSkin &&
|
||||||
_bumpedDiffuseMaterialSkin->initWithProgramState(_bumpedDiffuseMaterialSkinProgState))
|
_bumpedDiffuseMaterialSkin->initWithProgramState(_bumpedDiffuseMaterialSkinProgState))
|
||||||
{
|
{
|
||||||
_bumpedDiffuseMaterialSkin->_type = Sprite3DMaterial::MaterialType::BUMPED_DIFFUSE;
|
_bumpedDiffuseMaterialSkin->_type = MeshMaterial::MaterialType::BUMPED_DIFFUSE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sprite3DMaterial::releaseBuiltInMaterial()
|
void MeshMaterial::releaseBuiltInMaterial()
|
||||||
{
|
{
|
||||||
CC_SAFE_RELEASE_NULL(_unLitMaterial);
|
CC_SAFE_RELEASE_NULL(_unLitMaterial);
|
||||||
CC_SAFE_RELEASE_NULL(_unLitMaterialSkin);
|
CC_SAFE_RELEASE_NULL(_unLitMaterialSkin);
|
||||||
|
@ -159,7 +159,7 @@ void Sprite3DMaterial::releaseBuiltInMaterial()
|
||||||
CC_SAFE_RELEASE_NULL(_bumpedDiffuseMaterialSkinProgState);
|
CC_SAFE_RELEASE_NULL(_bumpedDiffuseMaterialSkinProgState);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sprite3DMaterial::releaseCachedMaterial()
|
void MeshMaterial::releaseCachedMaterial()
|
||||||
{
|
{
|
||||||
for (auto& it : _materials)
|
for (auto& it : _materials)
|
||||||
{
|
{
|
||||||
|
@ -169,11 +169,10 @@ void Sprite3DMaterial::releaseCachedMaterial()
|
||||||
_materials.clear();
|
_materials.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
Material* Sprite3DMaterial::clone() const
|
Material* MeshMaterial::clone() const
|
||||||
{
|
{
|
||||||
auto material = new Sprite3DMaterial();
|
auto material = new MeshMaterial();
|
||||||
|
|
||||||
// RenderState::cloneInto(material);
|
|
||||||
material->_renderState = _renderState;
|
material->_renderState = _renderState;
|
||||||
|
|
||||||
for (const auto& technique : _techniques)
|
for (const auto& technique : _techniques)
|
||||||
|
@ -196,36 +195,36 @@ Material* Sprite3DMaterial::clone() const
|
||||||
return material;
|
return material;
|
||||||
}
|
}
|
||||||
|
|
||||||
Sprite3DMaterial* Sprite3DMaterial::createBuiltInMaterial(MaterialType type, bool skinned)
|
MeshMaterial* MeshMaterial::createBuiltInMaterial(MaterialType type, bool skinned)
|
||||||
{
|
{
|
||||||
/////
|
/////
|
||||||
if (_diffuseMaterial == nullptr)
|
if (_diffuseMaterial == nullptr)
|
||||||
createBuiltInMaterial();
|
createBuiltInMaterial();
|
||||||
|
|
||||||
Sprite3DMaterial* material = nullptr;
|
MeshMaterial* material = nullptr;
|
||||||
switch (type)
|
switch (type)
|
||||||
{
|
{
|
||||||
case Sprite3DMaterial::MaterialType::UNLIT:
|
case MeshMaterial::MaterialType::UNLIT:
|
||||||
material = skinned ? _unLitMaterialSkin : _unLitMaterial;
|
material = skinned ? _unLitMaterialSkin : _unLitMaterial;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Sprite3DMaterial::MaterialType::UNLIT_NOTEX:
|
case MeshMaterial::MaterialType::UNLIT_NOTEX:
|
||||||
material = _unLitNoTexMaterial;
|
material = _unLitNoTexMaterial;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Sprite3DMaterial::MaterialType::VERTEX_LIT:
|
case MeshMaterial::MaterialType::VERTEX_LIT:
|
||||||
CCASSERT(0, "not implement");
|
CCASSERT(0, "not implemented.");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Sprite3DMaterial::MaterialType::DIFFUSE:
|
case MeshMaterial::MaterialType::DIFFUSE:
|
||||||
material = skinned ? _diffuseMaterialSkin : _diffuseMaterial;
|
material = skinned ? _diffuseMaterialSkin : _diffuseMaterial;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Sprite3DMaterial::MaterialType::DIFFUSE_NOTEX:
|
case MeshMaterial::MaterialType::DIFFUSE_NOTEX:
|
||||||
material = _diffuseNoTexMaterial;
|
material = _diffuseNoTexMaterial;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Sprite3DMaterial::MaterialType::BUMPED_DIFFUSE:
|
case MeshMaterial::MaterialType::BUMPED_DIFFUSE:
|
||||||
material = skinned ? _bumpedDiffuseMaterialSkin : _bumpedDiffuseMaterial;
|
material = skinned ? _bumpedDiffuseMaterialSkin : _bumpedDiffuseMaterial;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -233,41 +232,41 @@ Sprite3DMaterial* Sprite3DMaterial::createBuiltInMaterial(MaterialType type, boo
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (material)
|
if (material)
|
||||||
return (Sprite3DMaterial*)material->clone();
|
return (MeshMaterial*)material->clone();
|
||||||
|
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
Sprite3DMaterial* Sprite3DMaterial::createWithFilename(std::string_view path)
|
MeshMaterial* MeshMaterial::createWithFilename(std::string_view path)
|
||||||
{
|
{
|
||||||
auto validfilename = FileUtils::getInstance()->fullPathForFilename(path);
|
auto validfilename = FileUtils::getInstance()->fullPathForFilename(path);
|
||||||
if (!validfilename.empty())
|
if (!validfilename.empty())
|
||||||
{
|
{
|
||||||
auto it = _materials.find(validfilename);
|
auto it = _materials.find(validfilename);
|
||||||
if (it != _materials.end())
|
if (it != _materials.end())
|
||||||
return (Sprite3DMaterial*)it->second->clone();
|
return (MeshMaterial*)it->second->clone();
|
||||||
|
|
||||||
auto material = new Sprite3DMaterial();
|
auto material = new MeshMaterial();
|
||||||
if (material->initWithFile(path))
|
if (material->initWithFile(path))
|
||||||
{
|
{
|
||||||
material->_type = Sprite3DMaterial::MaterialType::CUSTOM;
|
material->_type = MeshMaterial::MaterialType::CUSTOM;
|
||||||
_materials[validfilename] = material;
|
_materials[validfilename] = material;
|
||||||
|
|
||||||
return (Sprite3DMaterial*)material->clone();
|
return (MeshMaterial*)material->clone();
|
||||||
}
|
}
|
||||||
CC_SAFE_DELETE(material);
|
CC_SAFE_DELETE(material);
|
||||||
}
|
}
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
Sprite3DMaterial* Sprite3DMaterial::createWithProgramState(backend::ProgramState* programState)
|
MeshMaterial* MeshMaterial::createWithProgramState(backend::ProgramState* programState)
|
||||||
{
|
{
|
||||||
CCASSERT(programState, "Invalid GL Program State");
|
CCASSERT(programState, "Invalid program state.");
|
||||||
|
|
||||||
auto mat = new Sprite3DMaterial();
|
auto mat = new MeshMaterial();
|
||||||
if (mat->initWithProgramState(programState))
|
if (mat->initWithProgramState(programState))
|
||||||
{
|
{
|
||||||
mat->_type = Sprite3DMaterial::MaterialType::CUSTOM;
|
mat->_type = MeshMaterial::MaterialType::CUSTOM;
|
||||||
mat->autorelease();
|
mat->autorelease();
|
||||||
return mat;
|
return mat;
|
||||||
}
|
}
|
||||||
|
@ -275,7 +274,7 @@ Sprite3DMaterial* Sprite3DMaterial::createWithProgramState(backend::ProgramState
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sprite3DMaterial::setTexture(Texture2D* tex, NTextureData::Usage usage)
|
void MeshMaterial::setTexture(Texture2D* tex, NTextureData::Usage usage)
|
||||||
{
|
{
|
||||||
const auto& passes = getTechnique()->getPasses();
|
const auto& passes = getTechnique()->getPasses();
|
||||||
for (auto& pass : passes)
|
for (auto& pass : passes)
|
||||||
|
@ -286,24 +285,24 @@ void Sprite3DMaterial::setTexture(Texture2D* tex, NTextureData::Usage usage)
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
Sprite3DMaterialCache::Sprite3DMaterialCache() {}
|
MeshMaterialCache::MeshMaterialCache() {}
|
||||||
|
|
||||||
Sprite3DMaterialCache::~Sprite3DMaterialCache()
|
MeshMaterialCache::~MeshMaterialCache()
|
||||||
{
|
{
|
||||||
removeAllSprite3DMaterial();
|
removeAllMeshMaterial();
|
||||||
}
|
}
|
||||||
|
|
||||||
Sprite3DMaterialCache* Sprite3DMaterialCache::getInstance()
|
MeshMaterialCache* MeshMaterialCache::getInstance()
|
||||||
{
|
{
|
||||||
if (!_cacheInstance)
|
if (!_cacheInstance)
|
||||||
{
|
{
|
||||||
_cacheInstance = new Sprite3DMaterialCache();
|
_cacheInstance = new MeshMaterialCache();
|
||||||
}
|
}
|
||||||
|
|
||||||
return _cacheInstance;
|
return _cacheInstance;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sprite3DMaterialCache::destroyInstance()
|
void MeshMaterialCache::destroyInstance()
|
||||||
{
|
{
|
||||||
if (_cacheInstance)
|
if (_cacheInstance)
|
||||||
{
|
{
|
||||||
|
@ -311,7 +310,7 @@ void Sprite3DMaterialCache::destroyInstance()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Sprite3DMaterialCache::addSprite3DMaterial(std::string_view key, Texture2D* texture)
|
bool MeshMaterialCache::addMeshMaterial(std::string_view key, Texture2D* texture)
|
||||||
{
|
{
|
||||||
auto itr = _materials.find(key);
|
auto itr = _materials.find(key);
|
||||||
if (itr == _materials.end())
|
if (itr == _materials.end())
|
||||||
|
@ -323,7 +322,7 @@ bool Sprite3DMaterialCache::addSprite3DMaterial(std::string_view key, Texture2D*
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
Texture2D* Sprite3DMaterialCache::getSprite3DMaterial(std::string_view key)
|
Texture2D* MeshMaterialCache::getMeshMaterial(std::string_view key)
|
||||||
{
|
{
|
||||||
auto itr = _materials.find(key);
|
auto itr = _materials.find(key);
|
||||||
if (itr != _materials.end())
|
if (itr != _materials.end())
|
||||||
|
@ -333,7 +332,7 @@ Texture2D* Sprite3DMaterialCache::getSprite3DMaterial(std::string_view key)
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sprite3DMaterialCache::removeAllSprite3DMaterial()
|
void MeshMaterialCache::removeAllMeshMaterial()
|
||||||
{
|
{
|
||||||
for (auto& itr : _materials)
|
for (auto& itr : _materials)
|
||||||
{
|
{
|
||||||
|
@ -341,14 +340,14 @@ void Sprite3DMaterialCache::removeAllSprite3DMaterial()
|
||||||
}
|
}
|
||||||
_materials.clear();
|
_materials.clear();
|
||||||
}
|
}
|
||||||
void Sprite3DMaterialCache::removeUnusedSprite3DMaterial()
|
void MeshMaterialCache::removeUnusedMeshMaterial()
|
||||||
{
|
{
|
||||||
for (auto it = _materials.cbegin(), itCend = _materials.cend(); it != itCend; /* nothing */)
|
for (auto it = _materials.cbegin(), itCend = _materials.cend(); it != itCend; /* nothing */)
|
||||||
{
|
{
|
||||||
auto value = it->second;
|
auto value = it->second;
|
||||||
if (value->getReferenceCount() == 1)
|
if (value->getReferenceCount() == 1)
|
||||||
{
|
{
|
||||||
CCLOG("cocos2d: Sprite3DMaterialCache: removing unused Sprite3DMaterial");
|
CCLOG("cocos2d: MeshMaterialCache: removing unused mesh renderer materials.");
|
||||||
|
|
||||||
value->release();
|
value->release();
|
||||||
it = _materials.erase(it);
|
it = _materials.erase(it);
|
|
@ -46,26 +46,26 @@ class ProgramState;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Sprite3DMaterial: Material for Sprite3D.
|
* @brief MeshMaterial: a mesh material for MeshRenderers.
|
||||||
*/
|
*/
|
||||||
class CC_DLL Sprite3DMaterial : public Material
|
class CC_DLL MeshMaterial : public Material
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
/**
|
/**
|
||||||
* Material type, there are mainly two types of materials. Built in materials and Custom material
|
* Material types, there are mainly two types of materials. Built-in materials and Custom materials.
|
||||||
*/
|
*/
|
||||||
enum class MaterialType
|
enum class MaterialType
|
||||||
{
|
{
|
||||||
// Built in material
|
// Built in materials
|
||||||
UNLIT, // unlit material
|
UNLIT, // unlit material
|
||||||
UNLIT_NOTEX, // unlit material without texture
|
UNLIT_NOTEX, // unlit material (without texture)
|
||||||
VERTEX_LIT, // vertex lit
|
VERTEX_LIT, // vertex lit
|
||||||
DIFFUSE, // diffuse (pixel lighting)
|
DIFFUSE, // diffuse (pixel lighting)
|
||||||
DIFFUSE_NOTEX, // diffuse (without texture)
|
DIFFUSE_NOTEX, // diffuse (without texture)
|
||||||
BUMPED_DIFFUSE, // bumped diffuse
|
BUMPED_DIFFUSE, // bumped diffuse
|
||||||
|
|
||||||
// Custom material
|
// Custom material
|
||||||
CUSTOM, // Create from material file
|
CUSTOM, // Create from a material file
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -77,35 +77,34 @@ public:
|
||||||
/**
|
/**
|
||||||
* Create built in material from material type
|
* Create built in material from material type
|
||||||
* @param type Material type
|
* @param type Material type
|
||||||
* @param skinned Has skin?
|
* @param skinned Has hardware skinning?
|
||||||
* @return Created material
|
* @return An autorelease material object
|
||||||
*/
|
*/
|
||||||
static Sprite3DMaterial* createBuiltInMaterial(MaterialType type, bool skinned);
|
static MeshMaterial* createBuiltInMaterial(MaterialType type, bool skinned);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create material with file name, it creates material from cache if it is previously loaded
|
* Create material with file name, it creates material from cache if it is previously loaded
|
||||||
* @param path Path of material file
|
* @param path Path of material file
|
||||||
* @return Created material
|
* @return An autorelease material object
|
||||||
*/
|
*/
|
||||||
static Sprite3DMaterial* createWithFilename(std::string_view path);
|
static MeshMaterial* createWithFilename(std::string_view path);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create material with GLProgramState
|
* Create material with a ProgramState
|
||||||
* @param programState GLProgramState instance
|
* @param programState GLProgramState instance
|
||||||
* @return Created material
|
* @return An autorelease material object
|
||||||
*/
|
*/
|
||||||
// static Sprite3DMaterial* createWithGLStateProgram(GLProgramState* programState);
|
static MeshMaterial* createWithProgramState(backend::ProgramState* programState);
|
||||||
static Sprite3DMaterial* createWithProgramState(backend::ProgramState* programState);
|
|
||||||
|
|
||||||
void setTexture(Texture2D* tex, NTextureData::Usage usage);
|
void setTexture(Texture2D* tex, NTextureData::Usage usage);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create all build in materials
|
* Create all built-in materials
|
||||||
*/
|
*/
|
||||||
static void createBuiltInMaterial();
|
static void createBuiltInMaterial();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Release all built in materials
|
* Release all built-in materials
|
||||||
*/
|
*/
|
||||||
static void releaseBuiltInMaterial();
|
static void releaseBuiltInMaterial();
|
||||||
|
|
||||||
|
@ -115,24 +114,24 @@ public:
|
||||||
static void releaseCachedMaterial();
|
static void releaseCachedMaterial();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Clone material
|
* Clone this material.
|
||||||
*/
|
*/
|
||||||
virtual Material* clone() const override;
|
virtual Material* clone() const override;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
MaterialType _type;
|
MaterialType _type;
|
||||||
static std::unordered_map<std::string, Sprite3DMaterial*> _materials; // cached material
|
static std::unordered_map<std::string, MeshMaterial*> _materials; // cached material
|
||||||
static Sprite3DMaterial* _unLitMaterial;
|
static MeshMaterial* _unLitMaterial;
|
||||||
static Sprite3DMaterial* _unLitNoTexMaterial;
|
static MeshMaterial* _unLitNoTexMaterial;
|
||||||
static Sprite3DMaterial* _vertexLitMaterial;
|
static MeshMaterial* _vertexLitMaterial;
|
||||||
static Sprite3DMaterial* _diffuseMaterial;
|
static MeshMaterial* _diffuseMaterial;
|
||||||
static Sprite3DMaterial* _diffuseNoTexMaterial;
|
static MeshMaterial* _diffuseNoTexMaterial;
|
||||||
static Sprite3DMaterial* _bumpedDiffuseMaterial;
|
static MeshMaterial* _bumpedDiffuseMaterial;
|
||||||
|
|
||||||
static Sprite3DMaterial* _unLitMaterialSkin;
|
static MeshMaterial* _unLitMaterialSkin;
|
||||||
static Sprite3DMaterial* _vertexLitMaterialSkin;
|
static MeshMaterial* _vertexLitMaterialSkin;
|
||||||
static Sprite3DMaterial* _diffuseMaterialSkin;
|
static MeshMaterial* _diffuseMaterialSkin;
|
||||||
static Sprite3DMaterial* _bumpedDiffuseMaterialSkin;
|
static MeshMaterial* _bumpedDiffuseMaterialSkin;
|
||||||
|
|
||||||
static backend::ProgramState* _unLitMaterialProgState;
|
static backend::ProgramState* _unLitMaterialProgState;
|
||||||
static backend::ProgramState* _unLitNoTexMaterialProgState;
|
static backend::ProgramState* _unLitNoTexMaterialProgState;
|
||||||
|
@ -148,36 +147,33 @@ protected:
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief the sprite3D material is only texture for now
|
* @brief MeshMaterialCache: the MeshRenderer material cache, it can only cache textures for now.
|
||||||
* @js NA
|
* @js NA
|
||||||
* @lua NA
|
* @lua NA
|
||||||
*/
|
*/
|
||||||
class Sprite3DMaterialCache
|
class MeshMaterialCache
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
/**get & destroy cache*/
|
static MeshMaterialCache* getInstance();
|
||||||
static Sprite3DMaterialCache* getInstance();
|
|
||||||
|
|
||||||
/**destroy the instance*/
|
|
||||||
static void destroyInstance();
|
static void destroyInstance();
|
||||||
|
|
||||||
/**add to cache*/
|
/** add a material to cache */
|
||||||
bool addSprite3DMaterial(std::string_view key, Texture2D* tex);
|
bool addMeshMaterial(std::string_view key, Texture2D* tex);
|
||||||
|
|
||||||
/** get material from cache */
|
/** get material from cache */
|
||||||
Texture2D* getSprite3DMaterial(std::string_view key);
|
Texture2D* getMeshMaterial(std::string_view key);
|
||||||
|
|
||||||
/**remove all spritematerial*/
|
/** remove all cached materials */
|
||||||
void removeAllSprite3DMaterial();
|
void removeAllMeshMaterial();
|
||||||
/**remove unused spritematerial*/
|
/** remove unused cached materials */
|
||||||
void removeUnusedSprite3DMaterial();
|
void removeUnusedMeshMaterial();
|
||||||
|
|
||||||
Sprite3DMaterialCache();
|
MeshMaterialCache();
|
||||||
~Sprite3DMaterialCache();
|
~MeshMaterialCache();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
static Sprite3DMaterialCache* _cacheInstance; // instance
|
static MeshMaterialCache* _cacheInstance; // cache instance
|
||||||
hlookup::string_map<Texture2D*> _materials; // cached material
|
hlookup::string_map<Texture2D*> _materials; // cached materials
|
||||||
};
|
};
|
||||||
|
|
||||||
// end of 3d group
|
// end of 3d group
|
|
@ -23,11 +23,11 @@
|
||||||
THE SOFTWARE.
|
THE SOFTWARE.
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#include "3d/CCSprite3D.h"
|
#include "3d/CCMeshRenderer.h"
|
||||||
#include "3d/CCObjLoader.h"
|
#include "3d/CCObjLoader.h"
|
||||||
#include "3d/CCMeshSkin.h"
|
#include "3d/CCMeshSkin.h"
|
||||||
#include "3d/CCBundle3D.h"
|
#include "3d/CCBundle3D.h"
|
||||||
#include "3d/CCSprite3DMaterial.h"
|
#include "3d/CCMeshMaterial.h"
|
||||||
#include "3d/CCAttachNode.h"
|
#include "3d/CCAttachNode.h"
|
||||||
#include "3d/CCMesh.h"
|
#include "3d/CCMesh.h"
|
||||||
|
|
||||||
|
@ -48,87 +48,87 @@
|
||||||
|
|
||||||
NS_CC_BEGIN
|
NS_CC_BEGIN
|
||||||
|
|
||||||
static Sprite3DMaterial* getSprite3DMaterialForAttribs(MeshVertexData* meshVertexData, bool usesLight);
|
static MeshMaterial* getMeshRendererMaterialForAttribs(MeshVertexData* meshVertexData, bool usesLight);
|
||||||
|
|
||||||
Sprite3D* Sprite3D::create()
|
MeshRenderer* MeshRenderer::create()
|
||||||
{
|
{
|
||||||
auto sprite = new Sprite3D();
|
auto mesh = new MeshRenderer();
|
||||||
if (sprite->init())
|
if (mesh->init())
|
||||||
{
|
{
|
||||||
sprite->autorelease();
|
mesh->autorelease();
|
||||||
return sprite;
|
return mesh;
|
||||||
}
|
}
|
||||||
CC_SAFE_DELETE(sprite);
|
CC_SAFE_DELETE(mesh);
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
Sprite3D* Sprite3D::create(std::string_view modelPath)
|
MeshRenderer* MeshRenderer::create(std::string_view modelPath)
|
||||||
{
|
{
|
||||||
CCASSERT(modelPath.length() >= 4, "invalid filename for Sprite3D");
|
CCASSERT(modelPath.length() >= 4, "Invalid filename.");
|
||||||
|
|
||||||
auto sprite = new Sprite3D();
|
auto mesh = new MeshRenderer();
|
||||||
if (sprite->initWithFile(modelPath))
|
if (mesh->initWithFile(modelPath))
|
||||||
{
|
{
|
||||||
sprite->_contentSize = sprite->getBoundingBox().size;
|
mesh->_contentSize = mesh->getBoundingBox().size;
|
||||||
sprite->autorelease();
|
mesh->autorelease();
|
||||||
return sprite;
|
return mesh;
|
||||||
}
|
}
|
||||||
CC_SAFE_DELETE(sprite);
|
CC_SAFE_DELETE(mesh);
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
Sprite3D* Sprite3D::create(std::string_view modelPath, std::string_view texturePath)
|
MeshRenderer* MeshRenderer::create(std::string_view modelPath, std::string_view texturePath)
|
||||||
{
|
{
|
||||||
auto sprite = create(modelPath);
|
auto mesh = create(modelPath);
|
||||||
if (sprite)
|
if (mesh)
|
||||||
{
|
{
|
||||||
sprite->setTexture(texturePath);
|
mesh->setTexture(texturePath);
|
||||||
}
|
}
|
||||||
|
|
||||||
return sprite;
|
return mesh;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sprite3D::createAsync(std::string_view modelPath,
|
void MeshRenderer::createAsync(std::string_view modelPath,
|
||||||
const std::function<void(Sprite3D*, void*)>& callback,
|
const std::function<void(MeshRenderer*, void*)>& callback,
|
||||||
void* callbackparam)
|
void* callbackparam)
|
||||||
{
|
{
|
||||||
createAsync(modelPath, "", callback, callbackparam);
|
createAsync(modelPath, "", callback, callbackparam);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sprite3D::createAsync(std::string_view modelPath,
|
void MeshRenderer::createAsync(std::string_view modelPath,
|
||||||
std::string_view texturePath,
|
std::string_view texturePath,
|
||||||
const std::function<void(Sprite3D*, void*)>& callback,
|
const std::function<void(MeshRenderer*, void*)>& callback,
|
||||||
void* callbackparam)
|
void* callbackparam)
|
||||||
{
|
{
|
||||||
Sprite3D* sprite = new Sprite3D();
|
MeshRenderer* mesh = new MeshRenderer();
|
||||||
if (sprite->loadFromCache(modelPath))
|
if (mesh->loadFromCache(modelPath))
|
||||||
{
|
{
|
||||||
sprite->autorelease();
|
mesh->autorelease();
|
||||||
if (!texturePath.empty())
|
if (!texturePath.empty())
|
||||||
sprite->setTexture(texturePath);
|
mesh->setTexture(texturePath);
|
||||||
callback(sprite, callbackparam);
|
callback(mesh, callbackparam);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
sprite->_asyncLoadParam.afterLoadCallback = callback;
|
mesh->_asyncLoadParam.afterLoadCallback = callback;
|
||||||
sprite->_asyncLoadParam.texPath = texturePath;
|
mesh->_asyncLoadParam.texPath = texturePath;
|
||||||
sprite->_asyncLoadParam.modelPath = modelPath;
|
mesh->_asyncLoadParam.modelPath = modelPath;
|
||||||
sprite->_asyncLoadParam.modelFullPath = FileUtils::getInstance()->fullPathForFilename(modelPath);
|
mesh->_asyncLoadParam.modelFullPath = FileUtils::getInstance()->fullPathForFilename(modelPath);
|
||||||
sprite->_asyncLoadParam.callbackParam = callbackparam;
|
mesh->_asyncLoadParam.callbackParam = callbackparam;
|
||||||
sprite->_asyncLoadParam.materialdatas = new MaterialDatas();
|
mesh->_asyncLoadParam.materialdatas = new MaterialDatas();
|
||||||
sprite->_asyncLoadParam.meshdatas = new MeshDatas();
|
mesh->_asyncLoadParam.meshdatas = new MeshDatas();
|
||||||
sprite->_asyncLoadParam.nodeDatas = new NodeDatas();
|
mesh->_asyncLoadParam.nodeDatas = new NodeDatas();
|
||||||
AsyncTaskPool::getInstance()->enqueue(
|
AsyncTaskPool::getInstance()->enqueue(
|
||||||
AsyncTaskPool::TaskType::TASK_IO, CC_CALLBACK_1(Sprite3D::afterAsyncLoad, sprite),
|
AsyncTaskPool::TaskType::TASK_IO, CC_CALLBACK_1(MeshRenderer::afterAsyncLoad, mesh),
|
||||||
(void*)(&sprite->_asyncLoadParam), [sprite]() {
|
(void*)(&mesh->_asyncLoadParam), [mesh]() {
|
||||||
sprite->_asyncLoadParam.result =
|
mesh->_asyncLoadParam.result =
|
||||||
sprite->loadFromFile(sprite->_asyncLoadParam.modelFullPath, sprite->_asyncLoadParam.nodeDatas,
|
mesh->loadFromFile(mesh->_asyncLoadParam.modelFullPath, mesh->_asyncLoadParam.nodeDatas,
|
||||||
sprite->_asyncLoadParam.meshdatas, sprite->_asyncLoadParam.materialdatas);
|
mesh->_asyncLoadParam.meshdatas, mesh->_asyncLoadParam.materialdatas);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sprite3D::afterAsyncLoad(void* param)
|
void MeshRenderer::afterAsyncLoad(void* param)
|
||||||
{
|
{
|
||||||
Sprite3D::AsyncLoadParam* asyncParam = (Sprite3D::AsyncLoadParam*)param;
|
MeshRenderer::AsyncLoadParam* asyncParam = (MeshRenderer::AsyncLoadParam*)param;
|
||||||
autorelease();
|
autorelease();
|
||||||
if (asyncParam)
|
if (asyncParam)
|
||||||
{
|
{
|
||||||
|
@ -145,11 +145,11 @@ void Sprite3D::afterAsyncLoad(void* param)
|
||||||
auto& nodeDatas = asyncParam->nodeDatas;
|
auto& nodeDatas = asyncParam->nodeDatas;
|
||||||
if (initFrom(*nodeDatas, *meshdatas, *materialdatas))
|
if (initFrom(*nodeDatas, *meshdatas, *materialdatas))
|
||||||
{
|
{
|
||||||
auto spritedata = Sprite3DCache::getInstance()->getSpriteData(asyncParam->modelPath);
|
auto meshdata = MeshRendererCache::getInstance()->getMeshData(asyncParam->modelPath);
|
||||||
if (spritedata == nullptr)
|
if (meshdata == nullptr)
|
||||||
{
|
{
|
||||||
// add to cache
|
// add to cache
|
||||||
auto data = new Sprite3DCache::Sprite3DData();
|
auto data = new MeshRendererCache::MeshRendererData();
|
||||||
data->materialdatas = materialdatas;
|
data->materialdatas = materialdatas;
|
||||||
data->nodedatas = nodeDatas;
|
data->nodedatas = nodeDatas;
|
||||||
data->meshVertexDatas = _meshVertexDatas;
|
data->meshVertexDatas = _meshVertexDatas;
|
||||||
|
@ -158,7 +158,7 @@ void Sprite3D::afterAsyncLoad(void* param)
|
||||||
data->programStates.pushBack(mesh->getProgramState());
|
data->programStates.pushBack(mesh->getProgramState());
|
||||||
}
|
}
|
||||||
|
|
||||||
Sprite3DCache::getInstance()->addSprite3DData(asyncParam->modelPath, data);
|
MeshRendererCache::getInstance()->addMeshRendererData(asyncParam->modelPath, data);
|
||||||
|
|
||||||
CC_SAFE_DELETE(meshdatas);
|
CC_SAFE_DELETE(meshdatas);
|
||||||
materialdatas = nullptr;
|
materialdatas = nullptr;
|
||||||
|
@ -176,13 +176,13 @@ void Sprite3D::afterAsyncLoad(void* param)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
CCLOG("file load failed: %s ", asyncParam->modelPath.c_str());
|
CCLOG("file load failed: %s\n", asyncParam->modelPath.c_str());
|
||||||
}
|
}
|
||||||
asyncParam->afterLoadCallback(this, asyncParam->callbackParam);
|
asyncParam->afterLoadCallback(this, asyncParam->callbackParam);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
AABB Sprite3D::getAABBRecursivelyImp(Node* node)
|
AABB MeshRenderer::getAABBRecursivelyImp(Node* node)
|
||||||
{
|
{
|
||||||
AABB aabb;
|
AABB aabb;
|
||||||
for (auto iter : node->getChildren())
|
for (auto iter : node->getChildren())
|
||||||
|
@ -190,46 +190,46 @@ AABB Sprite3D::getAABBRecursivelyImp(Node* node)
|
||||||
aabb.merge(getAABBRecursivelyImp(iter));
|
aabb.merge(getAABBRecursivelyImp(iter));
|
||||||
}
|
}
|
||||||
|
|
||||||
Sprite3D* sprite3d = dynamic_cast<Sprite3D*>(node);
|
MeshRenderer* meshRenderer = dynamic_cast<MeshRenderer*>(node);
|
||||||
if (sprite3d)
|
if (meshRenderer)
|
||||||
aabb.merge(sprite3d->getAABB());
|
aabb.merge(meshRenderer->getAABB());
|
||||||
|
|
||||||
return aabb;
|
return aabb;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Sprite3D::loadFromCache(std::string_view path)
|
bool MeshRenderer::loadFromCache(std::string_view path)
|
||||||
{
|
{
|
||||||
auto spritedata = Sprite3DCache::getInstance()->getSpriteData(path);
|
auto meshdata = MeshRendererCache::getInstance()->getMeshData(path);
|
||||||
if (spritedata)
|
if (meshdata)
|
||||||
{
|
{
|
||||||
for (auto it : spritedata->meshVertexDatas)
|
for (auto it : meshdata->meshVertexDatas)
|
||||||
{
|
{
|
||||||
_meshVertexDatas.pushBack(it);
|
_meshVertexDatas.pushBack(it);
|
||||||
}
|
}
|
||||||
_skeleton = Skeleton3D::create(spritedata->nodedatas->skeleton);
|
_skeleton = Skeleton3D::create(meshdata->nodedatas->skeleton);
|
||||||
CC_SAFE_RETAIN(_skeleton);
|
CC_SAFE_RETAIN(_skeleton);
|
||||||
|
|
||||||
const bool singleSprite = (spritedata->nodedatas->nodes.size() == 1);
|
const bool singleMesh = (meshdata->nodedatas->nodes.size() == 1);
|
||||||
for (const auto& it : spritedata->nodedatas->nodes)
|
for (const auto& it : meshdata->nodedatas->nodes)
|
||||||
{
|
{
|
||||||
if (it)
|
if (it)
|
||||||
{
|
{
|
||||||
createNode(it, this, *(spritedata->materialdatas), singleSprite);
|
createNode(it, this, *(meshdata->materialdatas), singleMesh);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (const auto& it : spritedata->nodedatas->skeleton)
|
for (const auto& it : meshdata->nodedatas->skeleton)
|
||||||
{
|
{
|
||||||
if (it)
|
if (it)
|
||||||
{
|
{
|
||||||
createAttachSprite3DNode(it, *(spritedata->materialdatas));
|
createAttachMeshRendererNode(it, *(meshdata->materialdatas));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (ssize_t i = 0, size = _meshes.size(); i < size; ++i)
|
for (ssize_t i = 0, size = _meshes.size(); i < size; ++i)
|
||||||
{
|
{
|
||||||
// cloning is needed in order to have one state per sprite
|
// cloning is needed in order to have one state per mesh
|
||||||
auto glstate = spritedata->programStates.at(i);
|
auto glstate = meshdata->programStates.at(i);
|
||||||
_meshes.at(i)->setProgramState(glstate->clone());
|
_meshes.at(i)->setProgramState(glstate->clone());
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
@ -238,7 +238,7 @@ bool Sprite3D::loadFromCache(std::string_view path)
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Sprite3D::loadFromFile(std::string_view path,
|
bool MeshRenderer::loadFromFile(std::string_view path,
|
||||||
NodeDatas* nodedatas,
|
NodeDatas* nodedatas,
|
||||||
MeshDatas* meshdatas,
|
MeshDatas* meshdatas,
|
||||||
MaterialDatas* materialdatas)
|
MaterialDatas* materialdatas)
|
||||||
|
@ -269,7 +269,7 @@ bool Sprite3D::loadFromFile(std::string_view path,
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
Sprite3D::Sprite3D()
|
MeshRenderer::MeshRenderer()
|
||||||
: _skeleton(nullptr)
|
: _skeleton(nullptr)
|
||||||
, _blend(BlendFunc::ALPHA_NON_PREMULTIPLIED)
|
, _blend(BlendFunc::ALPHA_NON_PREMULTIPLIED)
|
||||||
, _aabbDirty(true)
|
, _aabbDirty(true)
|
||||||
|
@ -279,7 +279,7 @@ Sprite3D::Sprite3D()
|
||||||
, _usingAutogeneratedGLProgram(true)
|
, _usingAutogeneratedGLProgram(true)
|
||||||
{}
|
{}
|
||||||
|
|
||||||
Sprite3D::~Sprite3D()
|
MeshRenderer::~MeshRenderer()
|
||||||
{
|
{
|
||||||
_meshes.clear();
|
_meshes.clear();
|
||||||
_meshVertexDatas.clear();
|
_meshVertexDatas.clear();
|
||||||
|
@ -287,7 +287,7 @@ Sprite3D::~Sprite3D()
|
||||||
removeAllAttachNode();
|
removeAllAttachNode();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Sprite3D::init()
|
bool MeshRenderer::init()
|
||||||
{
|
{
|
||||||
if (Node::init())
|
if (Node::init())
|
||||||
{
|
{
|
||||||
|
@ -296,7 +296,7 @@ bool Sprite3D::init()
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Sprite3D::initWithFile(std::string_view path)
|
bool MeshRenderer::initWithFile(std::string_view path)
|
||||||
{
|
{
|
||||||
_aabbDirty = true;
|
_aabbDirty = true;
|
||||||
_meshes.clear();
|
_meshes.clear();
|
||||||
|
@ -315,7 +315,7 @@ bool Sprite3D::initWithFile(std::string_view path)
|
||||||
if (initFrom(*nodeDatas, *meshdatas, *materialdatas))
|
if (initFrom(*nodeDatas, *meshdatas, *materialdatas))
|
||||||
{
|
{
|
||||||
// add to cache
|
// add to cache
|
||||||
auto data = new Sprite3DCache::Sprite3DData();
|
auto data = new MeshRendererCache::MeshRendererData();
|
||||||
data->materialdatas = materialdatas;
|
data->materialdatas = materialdatas;
|
||||||
data->nodedatas = nodeDatas;
|
data->nodedatas = nodeDatas;
|
||||||
data->meshVertexDatas = _meshVertexDatas;
|
data->meshVertexDatas = _meshVertexDatas;
|
||||||
|
@ -324,7 +324,7 @@ bool Sprite3D::initWithFile(std::string_view path)
|
||||||
data->programStates.pushBack(mesh->getProgramState());
|
data->programStates.pushBack(mesh->getProgramState());
|
||||||
}
|
}
|
||||||
|
|
||||||
Sprite3DCache::getInstance()->addSprite3DData(path, data);
|
MeshRendererCache::getInstance()->addMeshRendererData(path, data);
|
||||||
CC_SAFE_DELETE(meshdatas);
|
CC_SAFE_DELETE(meshdatas);
|
||||||
_contentSize = getBoundingBox().size;
|
_contentSize = getBoundingBox().size;
|
||||||
return true;
|
return true;
|
||||||
|
@ -337,7 +337,7 @@ bool Sprite3D::initWithFile(std::string_view path)
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Sprite3D::initFrom(const NodeDatas& nodeDatas, const MeshDatas& meshdatas, const MaterialDatas& materialdatas)
|
bool MeshRenderer::initFrom(const NodeDatas& nodeDatas, const MeshDatas& meshdatas, const MaterialDatas& materialdatas)
|
||||||
{
|
{
|
||||||
for (const auto& it : meshdatas.meshDatas)
|
for (const auto& it : meshdatas.meshDatas)
|
||||||
{
|
{
|
||||||
|
@ -364,7 +364,7 @@ bool Sprite3D::initFrom(const NodeDatas& nodeDatas, const MeshDatas& meshdatas,
|
||||||
{
|
{
|
||||||
if (it)
|
if (it)
|
||||||
{
|
{
|
||||||
createAttachSprite3DNode(it, materialdatas);
|
createAttachMeshRendererNode(it, materialdatas);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
genMaterial();
|
genMaterial();
|
||||||
|
@ -372,11 +372,11 @@ bool Sprite3D::initFrom(const NodeDatas& nodeDatas, const MeshDatas& meshdatas,
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
Sprite3D* Sprite3D::createSprite3DNode(NodeData* nodedata, ModelData* modeldata, const MaterialDatas& materialdatas)
|
MeshRenderer* MeshRenderer::createMeshRendererNode(NodeData* nodedata, ModelData* modeldata, const MaterialDatas& materialdatas)
|
||||||
{
|
{
|
||||||
auto sprite = new Sprite3D();
|
auto meshRenderer = new MeshRenderer();
|
||||||
|
|
||||||
sprite->setName(nodedata->id);
|
meshRenderer->setName(nodedata->id);
|
||||||
auto mesh = Mesh::create(nodedata->id, getMeshIndexData(modeldata->subMeshId));
|
auto mesh = Mesh::create(nodedata->id, getMeshIndexData(modeldata->subMeshId));
|
||||||
|
|
||||||
if (_skeleton && modeldata->bones.size())
|
if (_skeleton && modeldata->bones.size())
|
||||||
|
@ -434,46 +434,46 @@ Sprite3D* Sprite3D::createSprite3DNode(NodeData* nodedata, ModelData* modeldata,
|
||||||
Quaternion qua;
|
Quaternion qua;
|
||||||
Vec3 scale;
|
Vec3 scale;
|
||||||
nodedata->transform.decompose(&scale, &qua, &pos);
|
nodedata->transform.decompose(&scale, &qua, &pos);
|
||||||
sprite->setPosition3D(pos);
|
meshRenderer->setPosition3D(pos);
|
||||||
sprite->setRotationQuat(qua);
|
meshRenderer->setRotationQuat(qua);
|
||||||
sprite->setScaleX(scale.x);
|
meshRenderer->setScaleX(scale.x);
|
||||||
sprite->setScaleY(scale.y);
|
meshRenderer->setScaleY(scale.y);
|
||||||
sprite->setScaleZ(scale.z);
|
meshRenderer->setScaleZ(scale.z);
|
||||||
|
|
||||||
sprite->addMesh(mesh);
|
meshRenderer->addMesh(mesh);
|
||||||
sprite->autorelease();
|
meshRenderer->autorelease();
|
||||||
sprite->genMaterial();
|
meshRenderer->genMaterial();
|
||||||
|
|
||||||
return sprite;
|
return meshRenderer;
|
||||||
}
|
}
|
||||||
void Sprite3D::createAttachSprite3DNode(NodeData* nodedata, const MaterialDatas& materialdatas)
|
void MeshRenderer::createAttachMeshRendererNode(NodeData* nodedata, const MaterialDatas& materialdatas)
|
||||||
{
|
{
|
||||||
for (const auto& it : nodedata->modelNodeDatas)
|
for (const auto& it : nodedata->modelNodeDatas)
|
||||||
{
|
{
|
||||||
if (it && getAttachNode(nodedata->id))
|
if (it && getAttachNode(nodedata->id))
|
||||||
{
|
{
|
||||||
auto sprite = createSprite3DNode(nodedata, it, materialdatas);
|
auto mesh = createMeshRendererNode(nodedata, it, materialdatas);
|
||||||
if (sprite)
|
if (mesh)
|
||||||
{
|
{
|
||||||
getAttachNode(nodedata->id)->addChild(sprite);
|
getAttachNode(nodedata->id)->addChild(mesh);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (const auto& it : nodedata->children)
|
for (const auto& it : nodedata->children)
|
||||||
{
|
{
|
||||||
createAttachSprite3DNode(it, materialdatas);
|
createAttachMeshRendererNode(it, materialdatas);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sprite3D::setMaterial(Material* material)
|
void MeshRenderer::setMaterial(Material* material)
|
||||||
{
|
{
|
||||||
setMaterial(material, -1);
|
setMaterial(material, -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sprite3D::setMaterial(Material* material, int meshIndex)
|
void MeshRenderer::setMaterial(Material* material, int meshIndex)
|
||||||
{
|
{
|
||||||
CCASSERT(material, "Invalid Material");
|
CCASSERT(material, "Invalid Material");
|
||||||
CCASSERT(meshIndex == -1 || (meshIndex >= 0 && meshIndex < _meshes.size()), "Invalid meshIndex");
|
CCASSERT(meshIndex == -1 || (meshIndex >= 0 && meshIndex < _meshes.size()), "Invalid meshIndex.");
|
||||||
|
|
||||||
if (meshIndex == -1)
|
if (meshIndex == -1)
|
||||||
{
|
{
|
||||||
|
@ -491,21 +491,21 @@ void Sprite3D::setMaterial(Material* material, int meshIndex)
|
||||||
_usingAutogeneratedGLProgram = false;
|
_usingAutogeneratedGLProgram = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
Material* Sprite3D::getMaterial(int meshIndex) const
|
Material* MeshRenderer::getMaterial(int meshIndex) const
|
||||||
{
|
{
|
||||||
CCASSERT(meshIndex >= 0 && meshIndex < _meshes.size(), "Invalid meshIndex");
|
CCASSERT(meshIndex >= 0 && meshIndex < _meshes.size(), "Invalid meshIndex.");
|
||||||
return _meshes.at(meshIndex)->getMaterial();
|
return _meshes.at(meshIndex)->getMaterial();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sprite3D::genMaterial(bool useLight)
|
void MeshRenderer::genMaterial(bool useLight)
|
||||||
{
|
{
|
||||||
_shaderUsingLight = useLight;
|
_shaderUsingLight = useLight;
|
||||||
|
|
||||||
std::unordered_map<const MeshVertexData*, Sprite3DMaterial*> materials;
|
std::unordered_map<const MeshVertexData*, MeshMaterial*> materials;
|
||||||
for (auto meshVertexData : _meshVertexDatas)
|
for (auto meshVertexData : _meshVertexDatas)
|
||||||
{
|
{
|
||||||
auto material = getSprite3DMaterialForAttribs(meshVertexData, useLight);
|
auto material = getMeshRendererMaterialForAttribs(meshVertexData, useLight);
|
||||||
CCASSERT(material, "material should not be null");
|
CCASSERT(material, "material should cannot be null.");
|
||||||
materials[meshVertexData] = material;
|
materials[meshVertexData] = material;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -526,16 +526,16 @@ void Sprite3D::genMaterial(bool useLight)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sprite3D::createNode(NodeData* nodedata, Node* root, const MaterialDatas& materialdatas, bool singleSprite)
|
void MeshRenderer::createNode(NodeData* nodedata, Node* root, const MaterialDatas& materialdatas, bool singleMesh)
|
||||||
{
|
{
|
||||||
Node* node = nullptr;
|
Node* node = nullptr;
|
||||||
for (const auto& it : nodedata->modelNodeDatas)
|
for (const auto& it : nodedata->modelNodeDatas)
|
||||||
{
|
{
|
||||||
if (it)
|
if (it)
|
||||||
{
|
{
|
||||||
if (!it->bones.empty() || singleSprite)
|
if (!it->bones.empty() || singleMesh)
|
||||||
{
|
{
|
||||||
if (singleSprite && root != nullptr)
|
if (singleMesh && root != nullptr)
|
||||||
root->setName(nodedata->id);
|
root->setName(nodedata->id);
|
||||||
auto mesh = Mesh::create(nodedata->id, getMeshIndexData(it->subMeshId));
|
auto mesh = Mesh::create(nodedata->id, getMeshIndexData(it->subMeshId));
|
||||||
if (mesh)
|
if (mesh)
|
||||||
|
@ -546,7 +546,7 @@ void Sprite3D::createNode(NodeData* nodedata, Node* root, const MaterialDatas& m
|
||||||
auto skin = MeshSkin::create(_skeleton, it->bones, it->invBindPose);
|
auto skin = MeshSkin::create(_skeleton, it->bones, it->invBindPose);
|
||||||
mesh->setSkin(skin);
|
mesh->setSkin(skin);
|
||||||
}
|
}
|
||||||
mesh->_visibleChanged = std::bind(&Sprite3D::onAABBDirty, this);
|
mesh->_visibleChanged = std::bind(&MeshRenderer::onAABBDirty, this);
|
||||||
|
|
||||||
if (it->materialId == "" && materialdatas.materials.size())
|
if (it->materialId == "" && materialdatas.materials.size())
|
||||||
{
|
{
|
||||||
|
@ -610,15 +610,15 @@ void Sprite3D::createNode(NodeData* nodedata, Node* root, const MaterialDatas& m
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
auto sprite = createSprite3DNode(nodedata, it, materialdatas);
|
auto mesh = createMeshRendererNode(nodedata, it, materialdatas);
|
||||||
if (sprite)
|
if (mesh)
|
||||||
{
|
{
|
||||||
if (root)
|
if (root)
|
||||||
{
|
{
|
||||||
root->addChild(sprite);
|
root->addChild(mesh);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
node = sprite;
|
node = mesh;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -654,7 +654,7 @@ void Sprite3D::createNode(NodeData* nodedata, Node* root, const MaterialDatas& m
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
MeshIndexData* Sprite3D::getMeshIndexData(std::string_view indexId) const
|
MeshIndexData* MeshRenderer::getMeshIndexData(std::string_view indexId) const
|
||||||
{
|
{
|
||||||
for (auto it : _meshVertexDatas)
|
for (auto it : _meshVertexDatas)
|
||||||
{
|
{
|
||||||
|
@ -665,27 +665,27 @@ MeshIndexData* Sprite3D::getMeshIndexData(std::string_view indexId) const
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sprite3D::addMesh(Mesh* mesh)
|
void MeshRenderer::addMesh(Mesh* mesh)
|
||||||
{
|
{
|
||||||
auto meshVertex = mesh->getMeshIndexData()->_vertexData;
|
auto meshVertex = mesh->getMeshIndexData()->_vertexData;
|
||||||
_meshVertexDatas.pushBack(meshVertex);
|
_meshVertexDatas.pushBack(meshVertex);
|
||||||
_meshes.pushBack(mesh);
|
_meshes.pushBack(mesh);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sprite3D::setTexture(std::string_view texFile)
|
void MeshRenderer::setTexture(std::string_view texFile)
|
||||||
{
|
{
|
||||||
auto tex = _director->getTextureCache()->addImage(texFile);
|
auto tex = _director->getTextureCache()->addImage(texFile);
|
||||||
setTexture(tex);
|
setTexture(tex);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sprite3D::setTexture(Texture2D* texture)
|
void MeshRenderer::setTexture(Texture2D* texture)
|
||||||
{
|
{
|
||||||
for (auto mesh : _meshes)
|
for (auto mesh : _meshes)
|
||||||
{
|
{
|
||||||
mesh->setTexture(texture);
|
mesh->setTexture(texture);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
AttachNode* Sprite3D::getAttachNode(std::string_view boneName)
|
AttachNode* MeshRenderer::getAttachNode(std::string_view boneName)
|
||||||
{
|
{
|
||||||
auto it = _attachments.find(boneName);
|
auto it = _attachments.find(boneName);
|
||||||
if (it != _attachments.end())
|
if (it != _attachments.end())
|
||||||
|
@ -706,7 +706,7 @@ AttachNode* Sprite3D::getAttachNode(std::string_view boneName)
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sprite3D::removeAttachNode(std::string_view boneName)
|
void MeshRenderer::removeAttachNode(std::string_view boneName)
|
||||||
{
|
{
|
||||||
auto it = _attachments.find(boneName);
|
auto it = _attachments.find(boneName);
|
||||||
if (it != _attachments.end())
|
if (it != _attachments.end())
|
||||||
|
@ -716,7 +716,7 @@ void Sprite3D::removeAttachNode(std::string_view boneName)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sprite3D::removeAllAttachNode()
|
void MeshRenderer::removeAllAttachNode()
|
||||||
{
|
{
|
||||||
for (auto& it : _attachments)
|
for (auto& it : _attachments)
|
||||||
{
|
{
|
||||||
|
@ -725,7 +725,7 @@ void Sprite3D::removeAllAttachNode()
|
||||||
_attachments.clear();
|
_attachments.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sprite3D::visit(cocos2d::Renderer* renderer, const cocos2d::Mat4& parentTransform, uint32_t parentFlags)
|
void MeshRenderer::visit(cocos2d::Renderer* renderer, const cocos2d::Mat4& parentTransform, uint32_t parentFlags)
|
||||||
{
|
{
|
||||||
// quick return if not visible. children won't be drawn.
|
// quick return if not visible. children won't be drawn.
|
||||||
if (!_visible)
|
if (!_visible)
|
||||||
|
@ -772,7 +772,7 @@ void Sprite3D::visit(cocos2d::Renderer* renderer, const cocos2d::Mat4& parentTra
|
||||||
_director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW);
|
_director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sprite3D::draw(Renderer* renderer, const Mat4& transform, uint32_t flags)
|
void MeshRenderer::draw(Renderer* renderer, const Mat4& transform, uint32_t flags)
|
||||||
{
|
{
|
||||||
#if CC_USE_CULLING
|
#if CC_USE_CULLING
|
||||||
// TODO new-renderer: interface isVisibleInFrustum removal
|
// TODO new-renderer: interface isVisibleInFrustum removal
|
||||||
|
@ -815,7 +815,7 @@ void Sprite3D::draw(Renderer* renderer, const Mat4& transform, uint32_t flags)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Sprite3D::setProgramState(backend::ProgramState* programState, bool needsRetain)
|
bool MeshRenderer::setProgramState(backend::ProgramState* programState, bool needsRetain)
|
||||||
{
|
{
|
||||||
if (Node::setProgramState(programState, needsRetain))
|
if (Node::setProgramState(programState, needsRetain))
|
||||||
{
|
{
|
||||||
|
@ -828,7 +828,7 @@ bool Sprite3D::setProgramState(backend::ProgramState* programState, bool needsRe
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sprite3D::setBlendFunc(const BlendFunc& blendFunc)
|
void MeshRenderer::setBlendFunc(const BlendFunc& blendFunc)
|
||||||
{
|
{
|
||||||
if (_blend.src != blendFunc.src || _blend.dst != blendFunc.dst)
|
if (_blend.src != blendFunc.src || _blend.dst != blendFunc.dst)
|
||||||
{
|
{
|
||||||
|
@ -840,17 +840,17 @@ void Sprite3D::setBlendFunc(const BlendFunc& blendFunc)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const BlendFunc& Sprite3D::getBlendFunc() const
|
const BlendFunc& MeshRenderer::getBlendFunc() const
|
||||||
{
|
{
|
||||||
return _blend;
|
return _blend;
|
||||||
}
|
}
|
||||||
|
|
||||||
AABB Sprite3D::getAABBRecursively()
|
AABB MeshRenderer::getAABBRecursively()
|
||||||
{
|
{
|
||||||
return getAABBRecursivelyImp(this);
|
return getAABBRecursivelyImp(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
const AABB& Sprite3D::getAABB() const
|
const AABB& MeshRenderer::getAABB() const
|
||||||
{
|
{
|
||||||
Mat4 nodeToWorldTransform(getNodeToWorldTransform());
|
Mat4 nodeToWorldTransform(getNodeToWorldTransform());
|
||||||
|
|
||||||
|
@ -880,45 +880,43 @@ const AABB& Sprite3D::getAABB() const
|
||||||
return _aabb;
|
return _aabb;
|
||||||
}
|
}
|
||||||
|
|
||||||
Action* Sprite3D::runAction(Action* action)
|
Action* MeshRenderer::runAction(Action* action)
|
||||||
{
|
{
|
||||||
setForceDepthWrite(true);
|
setForceDepthWrite(true);
|
||||||
return Node::runAction(action);
|
return Node::runAction(action);
|
||||||
}
|
}
|
||||||
|
|
||||||
Rect Sprite3D::getBoundingBox() const
|
Rect MeshRenderer::getBoundingBox() const
|
||||||
{
|
{
|
||||||
AABB aabb = getAABB();
|
AABB aabb = getAABB();
|
||||||
Rect ret(aabb._min.x, aabb._min.y, (aabb._max.x - aabb._min.x), (aabb._max.y - aabb._min.y));
|
Rect ret(aabb._min.x, aabb._min.y, (aabb._max.x - aabb._min.x), (aabb._max.y - aabb._min.y));
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sprite3D::setCullFace(CullFaceSide side)
|
void MeshRenderer::setCullFace(CullFaceSide side)
|
||||||
{
|
{
|
||||||
for (auto& it : _meshes)
|
for (auto& it : _meshes)
|
||||||
{
|
{
|
||||||
it->getMaterial()->getStateBlock().setCullFaceSide(side);
|
it->getMaterial()->getStateBlock().setCullFaceSide(side);
|
||||||
// it->getMeshCommand().setCullFace(cullFace);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sprite3D::setCullFaceEnabled(bool enable)
|
void MeshRenderer::setCullFaceEnabled(bool enable)
|
||||||
{
|
{
|
||||||
for (auto& it : _meshes)
|
for (auto& it : _meshes)
|
||||||
{
|
{
|
||||||
it->getMaterial()->getStateBlock().setCullFace(enable);
|
it->getMaterial()->getStateBlock().setCullFace(enable);
|
||||||
// it->getMeshCommand().setCullFaceEnabled(enable);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Mesh* Sprite3D::getMeshByIndex(int index) const
|
Mesh* MeshRenderer::getMeshByIndex(int index) const
|
||||||
{
|
{
|
||||||
CCASSERT(index < _meshes.size(), "invalid index");
|
CCASSERT(index < _meshes.size(), "Invalid index.");
|
||||||
return _meshes.at(index);
|
return _meshes.at(index);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**get Mesh by Name */
|
/**get Mesh by Name */
|
||||||
Mesh* Sprite3D::getMeshByName(std::string_view name) const
|
Mesh* MeshRenderer::getMeshByName(std::string_view name) const
|
||||||
{
|
{
|
||||||
for (const auto& it : _meshes)
|
for (const auto& it : _meshes)
|
||||||
{
|
{
|
||||||
|
@ -928,7 +926,7 @@ Mesh* Sprite3D::getMeshByName(std::string_view name) const
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<Mesh*> Sprite3D::getMeshArrayByName(std::string_view name) const
|
std::vector<Mesh*> MeshRenderer::getMeshArrayByName(std::string_view name) const
|
||||||
{
|
{
|
||||||
std::vector<Mesh*> meshes;
|
std::vector<Mesh*> meshes;
|
||||||
for (const auto& it : _meshes)
|
for (const auto& it : _meshes)
|
||||||
|
@ -939,7 +937,7 @@ std::vector<Mesh*> Sprite3D::getMeshArrayByName(std::string_view name) const
|
||||||
return meshes;
|
return meshes;
|
||||||
}
|
}
|
||||||
|
|
||||||
Mesh* Sprite3D::getMesh() const
|
Mesh* MeshRenderer::getMesh() const
|
||||||
{
|
{
|
||||||
if (_meshes.empty())
|
if (_meshes.empty())
|
||||||
{
|
{
|
||||||
|
@ -948,7 +946,7 @@ Mesh* Sprite3D::getMesh() const
|
||||||
return _meshes.at(0);
|
return _meshes.at(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sprite3D::setForce2DQueue(bool force2D)
|
void MeshRenderer::setForce2DQueue(bool force2D)
|
||||||
{
|
{
|
||||||
for (const auto& mesh : _meshes)
|
for (const auto& mesh : _meshes)
|
||||||
{
|
{
|
||||||
|
@ -957,14 +955,14 @@ void Sprite3D::setForce2DQueue(bool force2D)
|
||||||
}
|
}
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////////
|
||||||
Sprite3DCache* Sprite3DCache::_cacheInstance = nullptr;
|
MeshRendererCache* MeshRendererCache::_cacheInstance = nullptr;
|
||||||
Sprite3DCache* Sprite3DCache::getInstance()
|
MeshRendererCache* MeshRendererCache::getInstance()
|
||||||
{
|
{
|
||||||
if (_cacheInstance == nullptr)
|
if (_cacheInstance == nullptr)
|
||||||
_cacheInstance = new Sprite3DCache();
|
_cacheInstance = new MeshRendererCache();
|
||||||
return _cacheInstance;
|
return _cacheInstance;
|
||||||
}
|
}
|
||||||
void Sprite3DCache::destroyInstance()
|
void MeshRendererCache::destroyInstance()
|
||||||
{
|
{
|
||||||
if (_cacheInstance)
|
if (_cacheInstance)
|
||||||
{
|
{
|
||||||
|
@ -973,54 +971,51 @@ void Sprite3DCache::destroyInstance()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Sprite3DCache::Sprite3DData* Sprite3DCache::getSpriteData(std::string_view key) const
|
MeshRendererCache::MeshRendererData* MeshRendererCache::getMeshData(std::string_view key) const
|
||||||
{
|
{
|
||||||
auto it = _spriteDatas.find(key);
|
auto it = _meshDatas.find(key);
|
||||||
if (it != _spriteDatas.end())
|
if (it != _meshDatas.end())
|
||||||
return it->second;
|
return it->second;
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Sprite3DCache::addSprite3DData(std::string_view key, Sprite3DCache::Sprite3DData* spritedata)
|
bool MeshRendererCache::addMeshRendererData(std::string_view key, MeshRendererCache::MeshRendererData* meshdata)
|
||||||
{
|
{
|
||||||
auto it = _spriteDatas.find(key);
|
auto it = _meshDatas.find(key);
|
||||||
if (it == _spriteDatas.end())
|
if (it == _meshDatas.end())
|
||||||
{
|
{
|
||||||
_spriteDatas.emplace(key, spritedata); // _spriteDatas[key] = spritedata;
|
_meshDatas.emplace(key, meshdata);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sprite3DCache::removeSprite3DData(std::string_view key)
|
void MeshRendererCache::removeMeshRendererData(std::string_view key)
|
||||||
{
|
{
|
||||||
auto it = _spriteDatas.find(key);
|
auto it = _meshDatas.find(key);
|
||||||
if (it != _spriteDatas.end())
|
if (it != _meshDatas.end())
|
||||||
{
|
{
|
||||||
delete it->second;
|
delete it->second;
|
||||||
_spriteDatas.erase(it);
|
_meshDatas.erase(it);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sprite3DCache::removeAllSprite3DData()
|
void MeshRendererCache::removeAllMeshRendererData()
|
||||||
{
|
{
|
||||||
for (auto& it : _spriteDatas)
|
for (auto& it : _meshDatas)
|
||||||
{
|
{
|
||||||
delete it.second;
|
delete it.second;
|
||||||
}
|
}
|
||||||
_spriteDatas.clear();
|
_meshDatas.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
Sprite3DCache::Sprite3DCache() {}
|
MeshRendererCache::MeshRendererCache() {}
|
||||||
Sprite3DCache::~Sprite3DCache()
|
MeshRendererCache::~MeshRendererCache()
|
||||||
{
|
{
|
||||||
removeAllSprite3DData();
|
removeAllMeshRendererData();
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
static MeshMaterial* getMeshRendererMaterialForAttribs(MeshVertexData* meshVertexData, bool usesLight)
|
||||||
// MARK: Helpers
|
|
||||||
//
|
|
||||||
static Sprite3DMaterial* getSprite3DMaterialForAttribs(MeshVertexData* meshVertexData, bool usesLight)
|
|
||||||
{
|
{
|
||||||
bool textured = meshVertexData->hasVertexAttrib(shaderinfos::VertexKey::VERTEX_ATTRIB_TEX_COORD);
|
bool textured = meshVertexData->hasVertexAttrib(shaderinfos::VertexKey::VERTEX_ATTRIB_TEX_COORD);
|
||||||
bool hasSkin = meshVertexData->hasVertexAttrib(shaderinfos::VertexKey::VERTEX_ATTRIB_BLEND_INDEX) &&
|
bool hasSkin = meshVertexData->hasVertexAttrib(shaderinfos::VertexKey::VERTEX_ATTRIB_BLEND_INDEX) &&
|
||||||
|
@ -1028,27 +1023,27 @@ static Sprite3DMaterial* getSprite3DMaterialForAttribs(MeshVertexData* meshVerte
|
||||||
bool hasNormal = meshVertexData->hasVertexAttrib(shaderinfos::VertexKey::VERTEX_ATTRIB_NORMAL);
|
bool hasNormal = meshVertexData->hasVertexAttrib(shaderinfos::VertexKey::VERTEX_ATTRIB_NORMAL);
|
||||||
bool hasTangentSpace = meshVertexData->hasVertexAttrib(shaderinfos::VertexKey::VERTEX_ATTRIB_TANGENT) &&
|
bool hasTangentSpace = meshVertexData->hasVertexAttrib(shaderinfos::VertexKey::VERTEX_ATTRIB_TANGENT) &&
|
||||||
meshVertexData->hasVertexAttrib(shaderinfos::VertexKey::VERTEX_ATTRIB_BINORMAL);
|
meshVertexData->hasVertexAttrib(shaderinfos::VertexKey::VERTEX_ATTRIB_BINORMAL);
|
||||||
Sprite3DMaterial::MaterialType type;
|
MeshMaterial::MaterialType type;
|
||||||
if (textured)
|
if (textured)
|
||||||
{
|
{
|
||||||
if (hasTangentSpace)
|
if (hasTangentSpace)
|
||||||
{
|
{
|
||||||
type = hasNormal && usesLight ? Sprite3DMaterial::MaterialType::BUMPED_DIFFUSE
|
type = hasNormal && usesLight ? MeshMaterial::MaterialType::BUMPED_DIFFUSE
|
||||||
: Sprite3DMaterial::MaterialType::UNLIT;
|
: MeshMaterial::MaterialType::UNLIT;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
type = hasNormal && usesLight ? Sprite3DMaterial::MaterialType::DIFFUSE
|
type = hasNormal && usesLight ? MeshMaterial::MaterialType::DIFFUSE
|
||||||
: Sprite3DMaterial::MaterialType::UNLIT;
|
: MeshMaterial::MaterialType::UNLIT;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
type = hasNormal && usesLight ? Sprite3DMaterial::MaterialType::DIFFUSE_NOTEX
|
type = hasNormal && usesLight ? MeshMaterial::MaterialType::DIFFUSE_NOTEX
|
||||||
: Sprite3DMaterial::MaterialType::UNLIT_NOTEX;
|
: MeshMaterial::MaterialType::UNLIT_NOTEX;
|
||||||
}
|
}
|
||||||
|
|
||||||
return Sprite3DMaterial::createBuiltInMaterial(type, hasSkin);
|
return MeshMaterial::createBuiltInMaterial(type, hasSkin);
|
||||||
}
|
}
|
||||||
|
|
||||||
NS_CC_END
|
NS_CC_END
|
|
@ -23,8 +23,8 @@
|
||||||
THE SOFTWARE.
|
THE SOFTWARE.
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#ifndef __CCSPRITE3D_H__
|
#ifndef __CC_MESH_RENDERER_H__
|
||||||
#define __CCSPRITE3D_H__
|
#define __CC_MESH_RENDERER_H__
|
||||||
|
|
||||||
#include <unordered_map>
|
#include <unordered_map>
|
||||||
|
|
||||||
|
@ -33,7 +33,7 @@
|
||||||
#include "base/CCProtocols.h"
|
#include "base/CCProtocols.h"
|
||||||
#include "2d/CCNode.h"
|
#include "2d/CCNode.h"
|
||||||
#include "renderer/CCMeshCommand.h"
|
#include "renderer/CCMeshCommand.h"
|
||||||
#include "3d/CCSkeleton3D.h" // need to include for lua-binding
|
#include "3d/CCSkeleton3D.h" // needs to be included for lua-bindings
|
||||||
#include "3d/CCAABB.h"
|
#include "3d/CCAABB.h"
|
||||||
#include "3d/CCBundle3DData.h"
|
#include "3d/CCBundle3DData.h"
|
||||||
#include "3d/CCMeshVertexIndexData.h"
|
#include "3d/CCMeshVertexIndexData.h"
|
||||||
|
@ -50,49 +50,52 @@ class Texture2D;
|
||||||
class MeshSkin;
|
class MeshSkin;
|
||||||
class AttachNode;
|
class AttachNode;
|
||||||
struct NodeData;
|
struct NodeData;
|
||||||
/** @brief Sprite3D: A sprite can be loaded from 3D model files, .obj, .c3t, .c3b, then can be drawn as sprite */
|
/** @brief MeshRenderer: A mesh can be loaded from model files, .obj, .c3t, .c3b
|
||||||
class CC_DLL Sprite3D : public Node, public BlendProtocol
|
*and a mesh renderer renders a list of these loaded meshes with specified materials
|
||||||
|
*/
|
||||||
|
class CC_DLL MeshRenderer : public Node, public BlendProtocol
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
/**
|
/**
|
||||||
* Creates an empty sprite3D without 3D model and texture.
|
* Creates an empty MeshRenderer without a mesh or a texture.
|
||||||
|
* Can be used to create procedural meshes on runtime.
|
||||||
*
|
*
|
||||||
* @return An autoreleased sprite3D object.
|
* @return An autoreleased MeshRenderer object.
|
||||||
*/
|
*/
|
||||||
static Sprite3D* create();
|
static MeshRenderer* create();
|
||||||
|
|
||||||
/** creates a Sprite3D*/
|
/** creates a MeshRenderer with a specified path */
|
||||||
static Sprite3D* create(std::string_view modelPath);
|
static MeshRenderer* create(std::string_view modelPath);
|
||||||
|
|
||||||
// creates a Sprite3D. It only supports one texture, and overrides the internal texture with 'texturePath'
|
/** creates a MeshRenderer. A mesh can only have one texture, the default texture can be overridden with 'texturePath' */
|
||||||
static Sprite3D* create(std::string_view modelPath, std::string_view texturePath);
|
static MeshRenderer* create(std::string_view modelPath, std::string_view texturePath);
|
||||||
|
|
||||||
/** create 3d sprite asynchronously
|
/** create 3d mesh asynchronously
|
||||||
* If the 3d model was previously loaded, it will create a new 3d sprite and the callback will be called at once.
|
* If the 3d model was previously loaded, it will create a new 3d mesh and the callback will be called once.
|
||||||
* Otherwise it will load the model file in a new thread, and when the 3d sprite is loaded, the callback will be
|
* Otherwise it will load the model file in a new thread, and when the 3d mesh is loaded, the callback will be
|
||||||
* called with the created Sprite3D and a user-defined parameter. The callback will be called from the main thread,
|
* called with the created MeshRenderer and a user-defined parameter. The callback will be called from the main thread,
|
||||||
* so it is safe to create any cocos2d object from the callback.
|
* so it is safe to create any object from the callback.
|
||||||
* @param modelPath model to be loaded
|
* @param modelPath model to be loaded
|
||||||
* @param callback callback after loading
|
* @param callback callback when loading is finished
|
||||||
* @param callbackparam user defined parameter for the callback
|
* @param callbackparam user-defined parameter for the callback
|
||||||
*/
|
*/
|
||||||
static void createAsync(std::string_view modelPath,
|
static void createAsync(std::string_view modelPath,
|
||||||
const std::function<void(Sprite3D*, void*)>& callback,
|
const std::function<void(MeshRenderer*, void*)>& callback,
|
||||||
void* callbackparam);
|
void* callbackparam);
|
||||||
|
|
||||||
static void createAsync(std::string_view modelPath,
|
static void createAsync(std::string_view modelPath,
|
||||||
std::string_view texturePath,
|
std::string_view texturePath,
|
||||||
const std::function<void(Sprite3D*, void*)>& callback,
|
const std::function<void(MeshRenderer*, void*)>& callback,
|
||||||
void* callbackparam);
|
void* callbackparam);
|
||||||
|
|
||||||
/**set diffuse texture, set the first if multiple textures exist*/
|
/** set diffuse texture, set the first mesh's texture if multiple textures exist */
|
||||||
void setTexture(std::string_view texFile);
|
void setTexture(std::string_view texFile);
|
||||||
void setTexture(Texture2D* texture);
|
void setTexture(Texture2D* texture);
|
||||||
|
|
||||||
/** get Mesh by index */
|
/** get Mesh by index */
|
||||||
Mesh* getMeshByIndex(int index) const;
|
Mesh* getMeshByIndex(int index) const;
|
||||||
|
|
||||||
/**get Mesh by Name, it returns the first one if there are more than one mesh with the same name */
|
/** get Mesh by Name, returns the first one if there are more than one mesh with the same name */
|
||||||
Mesh* getMeshByName(std::string_view name) const;
|
Mesh* getMeshByName(std::string_view name) const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -102,7 +105,7 @@ public:
|
||||||
*/
|
*/
|
||||||
std::vector<Mesh*> getMeshArrayByName(std::string_view name) const;
|
std::vector<Mesh*> getMeshArrayByName(std::string_view name) const;
|
||||||
|
|
||||||
/**get mesh*/
|
/** get mesh at index 0 which is the default mesh */
|
||||||
Mesh* getMesh() const;
|
Mesh* getMesh() const;
|
||||||
|
|
||||||
/** get mesh count */
|
/** get mesh count */
|
||||||
|
@ -110,13 +113,13 @@ public:
|
||||||
|
|
||||||
Skeleton3D* getSkeleton() const { return _skeleton; }
|
Skeleton3D* getSkeleton() const { return _skeleton; }
|
||||||
|
|
||||||
/**get AttachNode by bone name, return nullptr if not exist*/
|
/** return an AttachNode by bone name. Otherwise, return nullptr if it doesn't exist */
|
||||||
AttachNode* getAttachNode(std::string_view boneName);
|
AttachNode* getAttachNode(std::string_view boneName);
|
||||||
|
|
||||||
/**remove attach node*/
|
/** remove an attached node */
|
||||||
void removeAttachNode(std::string_view boneName);
|
void removeAttachNode(std::string_view boneName);
|
||||||
|
|
||||||
/**remove all attach nodes*/
|
/** remove all attached nodes */
|
||||||
void removeAllAttachNode();
|
void removeAllAttachNode();
|
||||||
|
|
||||||
// overrides
|
// overrides
|
||||||
|
@ -124,91 +127,88 @@ public:
|
||||||
virtual const BlendFunc& getBlendFunc() const override;
|
virtual const BlendFunc& getBlendFunc() const override;
|
||||||
|
|
||||||
// overrides
|
// overrides
|
||||||
/** Sets ProgramState, you should bind attributes by yourself */
|
/** Sets ProgramState, attributes should be bound by the user */
|
||||||
bool setProgramState(backend::ProgramState* programState, bool needsRetain = true) override;
|
bool setProgramState(backend::ProgramState* programState, bool needsRetain = true) override;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Get AABB
|
* Get AABB
|
||||||
* If the sprite has animation, it can't be calculated accurately,
|
* If the mesh has animations, it can't be calculated accurately,
|
||||||
* because bone can drive the vertices, we just use the origin vertices
|
* because a bone can transform the vertices, and the untransformed vertices are used
|
||||||
* to calculate the AABB.
|
* to calculate the AABB.
|
||||||
*/
|
*/
|
||||||
const AABB& getAABB() const;
|
const AABB& getAABB() const;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Get AABB Recursively
|
* Get AABB Recursively
|
||||||
* Because some times we may have an empty Sprite3D Node as parent, but
|
* Because sometimes we may have an empty MeshRenderer Node as parent, If
|
||||||
* the Sprite3D don't contain any meshes, so getAABB()
|
* the MeshRenderer doesn't contain any meshes, then we use getAABB()
|
||||||
* will return a wrong value at that time.
|
|
||||||
*/
|
*/
|
||||||
AABB getAABBRecursively();
|
AABB getAABBRecursively();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Executes an action, and returns the action that is executed. For Sprite3D special logic are needed to take care
|
* Executes an action, and returns the action that is executed. For the MeshRenderer special logic is needed to take
|
||||||
* of Fading.
|
* care of Fading.
|
||||||
*
|
*
|
||||||
* This node becomes the action's target. Refer to Action::getTarget()
|
* This node becomes the action's target. Refer to Action::getTarget()
|
||||||
* @warning Actions don't retain their target.
|
* @warning Actions don't retain their target.
|
||||||
*
|
*
|
||||||
* @return An Action pointer
|
* @return a pointer to Action
|
||||||
*/
|
*/
|
||||||
virtual Action* runAction(Action* action) override;
|
virtual Action* runAction(Action* action) override;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Force to write to depth buffer, this is useful if you want to achieve effects like fading.
|
* Force depth buffer writing, this is useful if you want to achieve effects like fading.
|
||||||
*/
|
*/
|
||||||
void setForceDepthWrite(bool value) { _forceDepthWrite = value; }
|
void setForceDepthWrite(bool value) { _forceDepthWrite = value; }
|
||||||
bool isForceDepthWrite() const { return _forceDepthWrite; };
|
bool isForceDepthWrite() const { return _forceDepthWrite; };
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns 2d bounding-box
|
* Returns a 2d bounding-box
|
||||||
* Note: the bounding-box is just get from the AABB which as Z=0, so that is not very accurate.
|
* Note: the bounding-box is taken from the mesh's AABB with Z-axis ignored.
|
||||||
*/
|
*/
|
||||||
virtual Rect getBoundingBox() const override;
|
virtual Rect getBoundingBox() const override;
|
||||||
|
|
||||||
// set which face is going to cull, CullFaceSide::BACK, CullFaceSide::FRONT and CullFaceSide::NONE.
|
// set face culling side, CullFaceSide::BACK, CullFaceSide::FRONT and CullFaceSide::NONE.
|
||||||
virtual void setCullFace(CullFaceSide side);
|
virtual void setCullFace(CullFaceSide side);
|
||||||
// set cull face enable or not
|
// set face culling enabled.
|
||||||
void setCullFaceEnabled(bool enable);
|
void setCullFaceEnabled(bool enable);
|
||||||
|
|
||||||
/** light mask getter & setter, light works only when _lightmask & light's flag is true, default value of _lightmask
|
/** light mask getter & setter, lighting only works when _lightmask & light's flag are set to true, the default
|
||||||
* is 0xffff */
|
value of _lightmask is 0xffff */
|
||||||
void setLightMask(unsigned int mask) { _lightMask = mask; }
|
void setLightMask(unsigned int mask) { _lightMask = mask; }
|
||||||
unsigned int getLightMask() const { return _lightMask; }
|
unsigned int getLightMask() const { return _lightMask; }
|
||||||
|
|
||||||
/**draw*/
|
/** render all meshes within this mesh renderer */
|
||||||
virtual void draw(Renderer* renderer, const Mat4& transform, uint32_t flags) override;
|
virtual void draw(Renderer* renderer, const Mat4& transform, uint32_t flags) override;
|
||||||
|
|
||||||
/** Adds a new material to the sprite.
|
/** Adds a new material to this mesh renderer.
|
||||||
The Material will be applied to all the meshes that belong to the sprite.
|
The Material will be applied to all the meshes that belong to the mesh renderer.
|
||||||
Internally it will call `setMaterial(material,-1)`
|
It will internally call `setMaterial(material,-1)`
|
||||||
*/
|
*/
|
||||||
void setMaterial(Material* material);
|
void setMaterial(Material* material);
|
||||||
|
|
||||||
/** Adds a new material to a particular mesh of the sprite.
|
/** Adds a new material to a particular mesh in this mesh renderer.
|
||||||
meshIndex is the mesh that will be applied to.
|
* if meshIndex == -1, then it will be applied to all the meshes that belong to this mesh renderer.
|
||||||
if meshIndex == -1, then it will be applied to all the meshes that belong to the sprite.
|
*
|
||||||
|
* @param meshIndex Index of the mesh to apply the material to.
|
||||||
*/
|
*/
|
||||||
void setMaterial(Material* material, int meshIndex);
|
void setMaterial(Material* material, int meshIndex);
|
||||||
|
|
||||||
/** Adds a new material to a particular mesh of the sprite.
|
/** Adds a new material to a particular mesh in this mesh renderer.
|
||||||
meshIndex is the mesh that will be applied to.
|
* if meshIndex == -1, then it will be applied to all the meshes that belong to this mesh renderer.
|
||||||
if meshIndex == -1, then it will be applied to all the meshes that belong to the sprite.
|
*
|
||||||
|
* @param meshIndex Index of the mesh to apply the material to.
|
||||||
*/
|
*/
|
||||||
Material* getMaterial(int meshIndex) const;
|
Material* getMaterial(int meshIndex) const;
|
||||||
|
|
||||||
/**
|
/** force render this mesh renderer in 2D queue. */
|
||||||
* force set this Sprite3D to 2D render queue
|
|
||||||
*/
|
|
||||||
void setForce2DQueue(bool force2D);
|
void setForce2DQueue(bool force2D);
|
||||||
|
|
||||||
/**
|
/** Get list of meshes used in this mesh renderer. */
|
||||||
* Get meshes used in sprite 3d
|
|
||||||
*/
|
|
||||||
const Vector<Mesh*>& getMeshes() const { return _meshes; }
|
const Vector<Mesh*>& getMeshes() const { return _meshes; }
|
||||||
|
|
||||||
Sprite3D();
|
MeshRenderer();
|
||||||
virtual ~Sprite3D();
|
virtual ~MeshRenderer();
|
||||||
|
|
||||||
virtual bool init() override;
|
virtual bool init() override;
|
||||||
|
|
||||||
|
@ -216,25 +216,26 @@ public:
|
||||||
|
|
||||||
bool initFrom(const NodeDatas& nodedatas, const MeshDatas& meshdatas, const MaterialDatas& materialdatas);
|
bool initFrom(const NodeDatas& nodedatas, const MeshDatas& meshdatas, const MaterialDatas& materialdatas);
|
||||||
|
|
||||||
/**load sprite3d from cache, return true if succeed, false otherwise*/
|
/** load a mesh renderer from cache, returns true if succeeded, false otherwise. */
|
||||||
bool loadFromCache(std::string_view path);
|
bool loadFromCache(std::string_view path);
|
||||||
|
|
||||||
/** load file and set it to meshedatas, nodedatas and materialdatas, obj file .mtl file should be at the same
|
/** load a file and feed it's content into meshedatas, nodedatas and materialdatas, obj file and .mtl file
|
||||||
* directory if exist */
|
should be in the same directory. */
|
||||||
bool loadFromFile(std::string_view path, NodeDatas* nodedatas, MeshDatas* meshdatas, MaterialDatas* materialdatas);
|
bool loadFromFile(std::string_view path, NodeDatas* nodedatas, MeshDatas* meshdatas, MaterialDatas* materialdatas);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Visits this Sprite3D's children and draw them recursively.
|
* Visits this MeshRenderer's children and draws them recursively.
|
||||||
* Note: all its children will rendered as 3D objects
|
* Note: all children will be rendered in 3D space with depth, this behaviour can be changed using
|
||||||
|
* setForce2DQueue()
|
||||||
*/
|
*/
|
||||||
virtual void visit(Renderer* renderer, const Mat4& parentTransform, uint32_t parentFlags) override;
|
virtual void visit(Renderer* renderer, const Mat4& parentTransform, uint32_t parentFlags) override;
|
||||||
|
|
||||||
/**generate default material*/
|
/** generate default material. */
|
||||||
void genMaterial(bool useLight = false);
|
void genMaterial(bool useLight = false);
|
||||||
|
|
||||||
void createNode(NodeData* nodedata, Node* root, const MaterialDatas& materialdatas, bool singleSprite);
|
void createNode(NodeData* nodedata, Node* root, const MaterialDatas& materialdatas, bool singleMesh);
|
||||||
void createAttachSprite3DNode(NodeData* nodedata, const MaterialDatas& materialdatas);
|
void createAttachMeshRendererNode(NodeData* nodedata, const MaterialDatas& materialdatas);
|
||||||
Sprite3D* createSprite3DNode(NodeData* nodedata, ModelData* modeldata, const MaterialDatas& materialdatas);
|
MeshRenderer* createMeshRendererNode(NodeData* nodedata, ModelData* modeldata, const MaterialDatas& materialdatas);
|
||||||
|
|
||||||
/** get MeshIndexData by Id */
|
/** get MeshIndexData by Id */
|
||||||
MeshIndexData* getMeshIndexData(std::string_view indexId) const;
|
MeshIndexData* getMeshIndexData(std::string_view indexId) const;
|
||||||
|
@ -248,7 +249,7 @@ public:
|
||||||
static AABB getAABBRecursivelyImp(Node* node);
|
static AABB getAABBRecursivelyImp(Node* node);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
Skeleton3D* _skeleton; // skeleton
|
Skeleton3D* _skeleton;
|
||||||
|
|
||||||
Vector<MeshVertexData*> _meshVertexDatas;
|
Vector<MeshVertexData*> _meshVertexDatas;
|
||||||
|
|
||||||
|
@ -259,21 +260,21 @@ protected:
|
||||||
Vector<Mesh*> _meshes;
|
Vector<Mesh*> _meshes;
|
||||||
|
|
||||||
mutable AABB _aabb; // cache current aabb
|
mutable AABB _aabb; // cache current aabb
|
||||||
mutable Mat4 _nodeToWorldTransform; // cache the matrix
|
mutable Mat4 _nodeToWorldTransform; // cache current matrix
|
||||||
mutable bool _aabbDirty;
|
mutable bool _aabbDirty;
|
||||||
unsigned int _lightMask;
|
unsigned int _lightMask;
|
||||||
bool _shaderUsingLight; // is current shader using light ?
|
bool _shaderUsingLight; // Is the current shader using lighting?
|
||||||
bool _forceDepthWrite; // Always write to depth buffer
|
bool _forceDepthWrite; // Always write to depth buffer
|
||||||
bool _usingAutogeneratedGLProgram;
|
bool _usingAutogeneratedGLProgram;
|
||||||
|
|
||||||
struct AsyncLoadParam
|
struct AsyncLoadParam
|
||||||
{
|
{
|
||||||
std::function<void(Sprite3D*, void*)> afterLoadCallback; // callback after load
|
std::function<void(MeshRenderer*, void*)> afterLoadCallback; // callback after loading is finished
|
||||||
void* callbackParam;
|
void* callbackParam;
|
||||||
bool result; // sprite load result
|
bool result; // mesh renderer loading result
|
||||||
std::string modelPath;
|
std::string modelPath;
|
||||||
std::string modelFullPath;
|
std::string modelFullPath;
|
||||||
std::string texPath; //
|
std::string texPath;
|
||||||
MeshDatas* meshdatas;
|
MeshDatas* meshdatas;
|
||||||
MaterialDatas* materialdatas;
|
MaterialDatas* materialdatas;
|
||||||
NodeDatas* nodeDatas;
|
NodeDatas* nodeDatas;
|
||||||
|
@ -283,19 +284,18 @@ protected:
|
||||||
|
|
||||||
///////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////
|
||||||
/**
|
/**
|
||||||
* Sprite3DCache
|
* @brief MeshRendererCache: the cache data of MeshRenderer, used to speed up the creation process of MeshRenderer
|
||||||
* @brief the cache data of Sprite3D, use to speed up Sprite3D::create
|
|
||||||
*/
|
*/
|
||||||
class CC_DLL Sprite3DCache
|
class CC_DLL MeshRendererCache
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
struct Sprite3DData
|
struct MeshRendererData
|
||||||
{
|
{
|
||||||
Vector<MeshVertexData*> meshVertexDatas;
|
Vector<MeshVertexData*> meshVertexDatas;
|
||||||
Vector<backend::ProgramState*> programStates;
|
Vector<backend::ProgramState*> programStates;
|
||||||
NodeDatas* nodedatas;
|
NodeDatas* nodedatas;
|
||||||
MaterialDatas* materialdatas;
|
MaterialDatas* materialdatas;
|
||||||
~Sprite3DData()
|
~MeshRendererData()
|
||||||
{
|
{
|
||||||
if (nodedatas)
|
if (nodedatas)
|
||||||
delete nodedatas;
|
delete nodedatas;
|
||||||
|
@ -306,40 +306,39 @@ public:
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
/**get & destroy*/
|
static MeshRendererCache* getInstance();
|
||||||
static Sprite3DCache* getInstance();
|
|
||||||
static void destroyInstance();
|
static void destroyInstance();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* get the SpriteData struct
|
* get a MeshData object by key
|
||||||
*
|
*
|
||||||
* @lua NA
|
* @lua NA
|
||||||
*/
|
*/
|
||||||
Sprite3DData* getSpriteData(std::string_view key) const;
|
MeshRendererData* getMeshData(std::string_view key) const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* add the SpriteData into Sprite3D by given the specified key
|
* add a MeshData object into the MeshRenderer with a specified key
|
||||||
*
|
*
|
||||||
* @lua NA
|
* @lua NA
|
||||||
*/
|
*/
|
||||||
bool addSprite3DData(std::string_view key, Sprite3DData* spritedata);
|
bool addMeshRendererData(std::string_view key, MeshRendererData* meshdata);
|
||||||
|
|
||||||
/**remove the SpriteData from Sprite3D by given the specified key*/
|
/** remove a MeshData from the MeshRenderer with a specified key */
|
||||||
void removeSprite3DData(std::string_view key);
|
void removeMeshRendererData(std::string_view key);
|
||||||
|
|
||||||
/**remove all the SpriteData from Sprite3D*/
|
/** remove all the MeshData objects from the MeshRenderer */
|
||||||
void removeAllSprite3DData();
|
void removeAllMeshRendererData();
|
||||||
|
|
||||||
Sprite3DCache();
|
MeshRendererCache();
|
||||||
~Sprite3DCache();
|
~MeshRendererCache();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
static Sprite3DCache* _cacheInstance;
|
static MeshRendererCache* _cacheInstance;
|
||||||
hlookup::string_map<Sprite3DData*> _spriteDatas; // cached sprite data
|
hlookup::string_map<MeshRendererData*> _meshDatas; // cached mesh data
|
||||||
};
|
};
|
||||||
|
|
||||||
// end of 3d group
|
// end of 3d group
|
||||||
/// @}
|
/// @}
|
||||||
|
|
||||||
NS_CC_END
|
NS_CC_END
|
||||||
#endif // __SPRITE3D_H_
|
#endif // __CC_MESH_RENDERER_H__
|
|
@ -30,7 +30,7 @@
|
||||||
|
|
||||||
#include "3d/CCMeshVertexIndexData.h"
|
#include "3d/CCMeshVertexIndexData.h"
|
||||||
#include "3d/CCObjLoader.h"
|
#include "3d/CCObjLoader.h"
|
||||||
#include "3d/CCSprite3DMaterial.h"
|
#include "3d/CCMeshMaterial.h"
|
||||||
#include "3d/CCMesh.h"
|
#include "3d/CCMesh.h"
|
||||||
#include "3d/CCBundle3D.h"
|
#include "3d/CCBundle3D.h"
|
||||||
|
|
||||||
|
|
|
@ -95,7 +95,7 @@ protected:
|
||||||
MeshData::IndexArray _indexData;
|
MeshData::IndexArray _indexData;
|
||||||
|
|
||||||
friend class MeshVertexData;
|
friend class MeshVertexData;
|
||||||
friend class Sprite3D;
|
friend class MeshRenderer;
|
||||||
#if CC_ENABLE_CACHE_TEXTURE_DATA
|
#if CC_ENABLE_CACHE_TEXTURE_DATA
|
||||||
EventListenerCustom* _backToForegroundListener = nullptr;
|
EventListenerCustom* _backToForegroundListener = nullptr;
|
||||||
#endif
|
#endif
|
||||||
|
@ -107,7 +107,7 @@ protected:
|
||||||
*/
|
*/
|
||||||
class CC_DLL MeshVertexData : public Ref
|
class CC_DLL MeshVertexData : public Ref
|
||||||
{
|
{
|
||||||
friend class Sprite3D;
|
friend class MeshRenderer;
|
||||||
friend class Mesh;
|
friend class Mesh;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
|
@ -36,9 +36,9 @@ NS_CC_BEGIN
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Oriented Bounding Box(OBB)
|
*
|
||||||
* @brief the OBB is similar to the AABB but the bounding box has the same direction as Sprite3D. so it's collision
|
* @brief Oriented Bounding Box(OBB): OBB is similar to AABB except the bounding box has the same direction as the
|
||||||
* detection more precise than AABB
|
* MeshRenderer. so collision detection is more precise than AABB.
|
||||||
* @js NA
|
* @js NA
|
||||||
*/
|
*/
|
||||||
class CC_DLL OBB
|
class CC_DLL OBB
|
||||||
|
|
|
@ -2,7 +2,6 @@ set(COCOS_3D_HEADER
|
||||||
|
|
||||||
3d/CCBillBoard.h
|
3d/CCBillBoard.h
|
||||||
3d/CCFrustum.h
|
3d/CCFrustum.h
|
||||||
3d/CCSprite3DMaterial.h
|
|
||||||
3d/CCMeshVertexIndexData.h
|
3d/CCMeshVertexIndexData.h
|
||||||
3d/CCPlane.h
|
3d/CCPlane.h
|
||||||
3d/CCRay.h
|
3d/CCRay.h
|
||||||
|
@ -10,7 +9,8 @@ set(COCOS_3D_HEADER
|
||||||
3d/CCAnimate3D.h
|
3d/CCAnimate3D.h
|
||||||
3d/CCTerrain.h
|
3d/CCTerrain.h
|
||||||
3d/CCAnimationCurve.h
|
3d/CCAnimationCurve.h
|
||||||
3d/CCSprite3D.h
|
3d/CCMeshRenderer.h
|
||||||
|
3d/CCMeshMaterial.h
|
||||||
3d/CCOBB.h
|
3d/CCOBB.h
|
||||||
3d/CCAnimation3D.h
|
3d/CCAnimation3D.h
|
||||||
3d/CCMotionStreak3D.h
|
3d/CCMotionStreak3D.h
|
||||||
|
@ -49,8 +49,8 @@ set(COCOS_3D_SRC
|
||||||
3d/CCRay.cpp
|
3d/CCRay.cpp
|
||||||
3d/CCSkeleton3D.cpp
|
3d/CCSkeleton3D.cpp
|
||||||
3d/CCSkybox.cpp
|
3d/CCSkybox.cpp
|
||||||
3d/CCSprite3D.cpp
|
3d/CCMeshRenderer.cpp
|
||||||
3d/CCSprite3DMaterial.cpp
|
3d/CCMeshMaterial.cpp
|
||||||
3d/CCTerrain.cpp
|
3d/CCTerrain.cpp
|
||||||
3d/CCVertexAttribBinding.cpp
|
3d/CCVertexAttribBinding.cpp
|
||||||
3d/CC3DProgramInfo.cpp
|
3d/CC3DProgramInfo.cpp
|
||||||
|
|
|
@ -265,8 +265,8 @@ THE SOFTWARE.
|
||||||
#include "3d/CCRay.h"
|
#include "3d/CCRay.h"
|
||||||
#include "3d/CCSkeleton3D.h"
|
#include "3d/CCSkeleton3D.h"
|
||||||
#include "3d/CCSkybox.h"
|
#include "3d/CCSkybox.h"
|
||||||
#include "3d/CCSprite3D.h"
|
#include "3d/CCMeshRenderer.h"
|
||||||
#include "3d/CCSprite3DMaterial.h"
|
#include "3d/CCMeshMaterial.h"
|
||||||
#include "3d/CCTerrain.h"
|
#include "3d/CCTerrain.h"
|
||||||
#include "3d/CCVertexAttribBinding.h"
|
#include "3d/CCVertexAttribBinding.h"
|
||||||
|
|
||||||
|
|
|
@ -176,23 +176,23 @@ public:
|
||||||
*/
|
*/
|
||||||
bool supportsMapBuffer() const;
|
bool supportsMapBuffer() const;
|
||||||
|
|
||||||
/** Max support directional light in shader, for Sprite3D.
|
/** Max supported directional lights in a shader, for MeshRenderer.
|
||||||
*
|
*
|
||||||
* @return Maximum supports directional light in shader.
|
* @return Maximum supported directional lights in a shader.
|
||||||
* @since v3.3
|
* @since v3.3
|
||||||
*/
|
*/
|
||||||
int getMaxSupportDirLightInShader() const;
|
int getMaxSupportDirLightInShader() const;
|
||||||
|
|
||||||
/** Max support point light in shader, for Sprite3D.
|
/** Max supported point lights in a shader, for MeshRenderer.
|
||||||
*
|
*
|
||||||
* @return Maximum supports point light in shader.
|
* @return Maximum supported point lights in a shader.
|
||||||
* @since v3.3
|
* @since v3.3
|
||||||
*/
|
*/
|
||||||
int getMaxSupportPointLightInShader() const;
|
int getMaxSupportPointLightInShader() const;
|
||||||
|
|
||||||
/** Max support spot light in shader, for Sprite3D.
|
/** Max supported spot lights in a shader, for MeshRenderer.
|
||||||
*
|
*
|
||||||
* @return Maximum supports spot light in shader.
|
* @return Maximum supported spot lights in a shader.
|
||||||
* @since v3.3
|
* @since v3.3
|
||||||
*/
|
*/
|
||||||
int getMaxSupportSpotLightInShader() const;
|
int getMaxSupportSpotLightInShader() const;
|
||||||
|
@ -200,10 +200,10 @@ public:
|
||||||
/** get 3d animate quality */
|
/** get 3d animate quality */
|
||||||
Animate3DQuality getAnimate3DQuality() const;
|
Animate3DQuality getAnimate3DQuality() const;
|
||||||
|
|
||||||
/** Returns whether or not an OpenGL is supported.
|
/** Returns whether or not an OpenGL extension is supported.
|
||||||
*
|
*
|
||||||
* @param searchName A given search name.
|
* @param searchName A given search name.
|
||||||
* @return Is true if an OpenGL is supported.
|
* @return Is true if an OpenGL extension is supported.
|
||||||
*/
|
*/
|
||||||
bool checkForGLExtension(std::string_view searchName) const;
|
bool checkForGLExtension(std::string_view searchName) const;
|
||||||
|
|
||||||
|
|
|
@ -32,7 +32,7 @@
|
||||||
#if CC_USE_3D_PHYSICS
|
#if CC_USE_3D_PHYSICS
|
||||||
|
|
||||||
# include "physics3d/CCPhysics3DShape.h"
|
# include "physics3d/CCPhysics3DShape.h"
|
||||||
# include "physics3d/CCPhysicsSprite3D.h"
|
# include "physics3d/CCPhysicsMeshRenderer.h"
|
||||||
# include "physics3d/CCPhysics3DWorld.h"
|
# include "physics3d/CCPhysics3DWorld.h"
|
||||||
# include "physics3d/CCPhysics3DDebugDrawer.h"
|
# include "physics3d/CCPhysics3DDebugDrawer.h"
|
||||||
# include "physics3d/CCPhysics3DObject.h"
|
# include "physics3d/CCPhysics3DObject.h"
|
||||||
|
|
|
@ -31,12 +31,12 @@
|
||||||
|
|
||||||
NS_CC_BEGIN
|
NS_CC_BEGIN
|
||||||
|
|
||||||
PhysicsSprite3D* PhysicsSprite3D::create(std::string_view modelPath,
|
PhysicsMeshRenderer* PhysicsMeshRenderer::create(std::string_view modelPath,
|
||||||
Physics3DRigidBodyDes* rigidDes,
|
Physics3DRigidBodyDes* rigidDes,
|
||||||
const cocos2d::Vec3& translateInPhysics,
|
const cocos2d::Vec3& translateInPhysics,
|
||||||
const cocos2d::Quaternion& rotInPhsyics)
|
const cocos2d::Quaternion& rotInPhsyics)
|
||||||
{
|
{
|
||||||
auto ret = new PhysicsSprite3D();
|
auto ret = new PhysicsMeshRenderer();
|
||||||
if (ret->initWithFile(modelPath))
|
if (ret->initWithFile(modelPath))
|
||||||
{
|
{
|
||||||
auto obj = Physics3DRigidBody::create(rigidDes);
|
auto obj = Physics3DRigidBody::create(rigidDes);
|
||||||
|
@ -50,12 +50,12 @@ PhysicsSprite3D* PhysicsSprite3D::create(std::string_view modelPath,
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
PhysicsSprite3D* PhysicsSprite3D::createWithCollider(std::string_view modelPath,
|
PhysicsMeshRenderer* PhysicsMeshRenderer::createWithCollider(std::string_view modelPath,
|
||||||
Physics3DColliderDes* colliderDes,
|
Physics3DColliderDes* colliderDes,
|
||||||
const cocos2d::Vec3& translateInPhysics,
|
const cocos2d::Vec3& translateInPhysics,
|
||||||
const cocos2d::Quaternion& rotInPhsyics)
|
const cocos2d::Quaternion& rotInPhsyics)
|
||||||
{
|
{
|
||||||
auto ret = new PhysicsSprite3D();
|
auto ret = new PhysicsMeshRenderer();
|
||||||
if (ret->initWithFile(modelPath))
|
if (ret->initWithFile(modelPath))
|
||||||
{
|
{
|
||||||
auto obj = Physics3DCollider::create(colliderDes);
|
auto obj = Physics3DCollider::create(colliderDes);
|
||||||
|
@ -69,31 +69,31 @@ PhysicsSprite3D* PhysicsSprite3D::createWithCollider(std::string_view modelPath,
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
Physics3DObject* PhysicsSprite3D::getPhysicsObj() const
|
Physics3DObject* PhysicsMeshRenderer::getPhysicsObj() const
|
||||||
{
|
{
|
||||||
return _physicsComponent->getPhysics3DObject();
|
return _physicsComponent->getPhysics3DObject();
|
||||||
}
|
}
|
||||||
|
|
||||||
void PhysicsSprite3D::setSyncFlag(Physics3DComponent::PhysicsSyncFlag syncFlag)
|
void PhysicsMeshRenderer::setSyncFlag(Physics3DComponent::PhysicsSyncFlag syncFlag)
|
||||||
{
|
{
|
||||||
if (_physicsComponent)
|
if (_physicsComponent)
|
||||||
_physicsComponent->setSyncFlag(syncFlag);
|
_physicsComponent->setSyncFlag(syncFlag);
|
||||||
}
|
}
|
||||||
|
|
||||||
void PhysicsSprite3D::syncNodeToPhysics()
|
void PhysicsMeshRenderer::syncNodeToPhysics()
|
||||||
{
|
{
|
||||||
if (_physicsComponent)
|
if (_physicsComponent)
|
||||||
_physicsComponent->syncNodeToPhysics();
|
_physicsComponent->syncNodeToPhysics();
|
||||||
}
|
}
|
||||||
|
|
||||||
void PhysicsSprite3D::syncPhysicsToNode()
|
void PhysicsMeshRenderer::syncPhysicsToNode()
|
||||||
{
|
{
|
||||||
if (_physicsComponent)
|
if (_physicsComponent)
|
||||||
_physicsComponent->syncPhysicsToNode();
|
_physicsComponent->syncPhysicsToNode();
|
||||||
}
|
}
|
||||||
|
|
||||||
PhysicsSprite3D::PhysicsSprite3D() : _physicsComponent(nullptr) {}
|
PhysicsMeshRenderer::PhysicsMeshRenderer() : _physicsComponent(nullptr) {}
|
||||||
PhysicsSprite3D::~PhysicsSprite3D() {}
|
PhysicsMeshRenderer::~PhysicsMeshRenderer() {}
|
||||||
|
|
||||||
NS_CC_END
|
NS_CC_END
|
||||||
|
|
|
@ -23,11 +23,11 @@
|
||||||
THE SOFTWARE.
|
THE SOFTWARE.
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#ifndef __PHYSICS_SPRITE_3D_H__
|
#ifndef __PHYSICS_MESH_RENDERER_H__
|
||||||
#define __PHYSICS_SPRITE_3D_H__
|
#define __PHYSICS_MESH_RENDERER_H__
|
||||||
|
|
||||||
#include "base/ccConfig.h"
|
#include "base/ccConfig.h"
|
||||||
#include "3d/CCSprite3D.h"
|
#include "3d/CCMeshRenderer.h"
|
||||||
#include "physics3d/CCPhysics3DObject.h"
|
#include "physics3d/CCPhysics3DObject.h"
|
||||||
#include "physics3d/CCPhysics3DComponent.h"
|
#include "physics3d/CCPhysics3DComponent.h"
|
||||||
|
|
||||||
|
@ -42,19 +42,19 @@ NS_CC_BEGIN
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Convenient class to create a rigid body with Sprite3D
|
* @brief Convenient class to create a rigid body with a MeshRenderer
|
||||||
*/
|
*/
|
||||||
class CC_DLL PhysicsSprite3D : public cocos2d::Sprite3D
|
class CC_DLL PhysicsMeshRenderer : public cocos2d::MeshRenderer
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
/** creates a PhysicsSprite3D*/
|
/** creates a PhysicsMeshRenderer */
|
||||||
static PhysicsSprite3D* create(std::string_view modelPath,
|
static PhysicsMeshRenderer* create(std::string_view modelPath,
|
||||||
Physics3DRigidBodyDes* rigidDes,
|
Physics3DRigidBodyDes* rigidDes,
|
||||||
const cocos2d::Vec3& translateInPhysics = cocos2d::Vec3::ZERO,
|
const cocos2d::Vec3& translateInPhysics = cocos2d::Vec3::ZERO,
|
||||||
const cocos2d::Quaternion& rotInPhsyics = cocos2d::Quaternion::ZERO);
|
const cocos2d::Quaternion& rotInPhsyics = cocos2d::Quaternion::ZERO);
|
||||||
|
|
||||||
/** creates a PhysicsSprite3D as a collider*/
|
/** creates a PhysicsMeshRenderer with a collider */
|
||||||
static PhysicsSprite3D* createWithCollider(std::string_view modelPath,
|
static PhysicsMeshRenderer* createWithCollider(std::string_view modelPath,
|
||||||
Physics3DColliderDes* colliderDes,
|
Physics3DColliderDes* colliderDes,
|
||||||
const cocos2d::Vec3& translateInPhysics = cocos2d::Vec3::ZERO,
|
const cocos2d::Vec3& translateInPhysics = cocos2d::Vec3::ZERO,
|
||||||
const cocos2d::Quaternion& rotInPhsyics = cocos2d::Quaternion::ZERO);
|
const cocos2d::Quaternion& rotInPhsyics = cocos2d::Quaternion::ZERO);
|
||||||
|
@ -71,8 +71,8 @@ public:
|
||||||
/** synchronize physics transformation to node. */
|
/** synchronize physics transformation to node. */
|
||||||
void syncPhysicsToNode();
|
void syncPhysicsToNode();
|
||||||
|
|
||||||
PhysicsSprite3D();
|
PhysicsMeshRenderer();
|
||||||
virtual ~PhysicsSprite3D();
|
virtual ~PhysicsMeshRenderer();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
Physics3DComponent* _physicsComponent;
|
Physics3DComponent* _physicsComponent;
|
||||||
|
@ -86,4 +86,4 @@ NS_CC_END
|
||||||
|
|
||||||
#endif // CC_USE_3D_PHYSICS
|
#endif // CC_USE_3D_PHYSICS
|
||||||
|
|
||||||
#endif // __PHYSICS_SPRITE_3D_H__
|
#endif // __PHYSICS_MESH_RENDERER_H__
|
|
@ -3,7 +3,7 @@ set(COCOS_PHYSICS3D_HEADER
|
||||||
physics3d/CCPhysics3DShape.h
|
physics3d/CCPhysics3DShape.h
|
||||||
physics3d/CCPhysics3D.h
|
physics3d/CCPhysics3D.h
|
||||||
physics3d/CCPhysics3DWorld.h
|
physics3d/CCPhysics3DWorld.h
|
||||||
physics3d/CCPhysicsSprite3D.h
|
physics3d/CCPhysicsMeshRenderer.h
|
||||||
physics3d/CCPhysics3DObject.h
|
physics3d/CCPhysics3DObject.h
|
||||||
physics3d/CCPhysics3DComponent.h
|
physics3d/CCPhysics3DComponent.h
|
||||||
physics3d/CCPhysics3DDebugDrawer.h
|
physics3d/CCPhysics3DDebugDrawer.h
|
||||||
|
@ -17,5 +17,5 @@ set(COCOS_PHYSICS3D_SRC
|
||||||
physics3d/CCPhysics3DObject.cpp
|
physics3d/CCPhysics3DObject.cpp
|
||||||
physics3d/CCPhysics3DShape.cpp
|
physics3d/CCPhysics3DShape.cpp
|
||||||
physics3d/CCPhysics3DWorld.cpp
|
physics3d/CCPhysics3DWorld.cpp
|
||||||
physics3d/CCPhysicsSprite3D.cpp
|
physics3d/CCPhysicsMeshRenderer.cpp
|
||||||
)
|
)
|
||||||
|
|
|
@ -34,7 +34,7 @@
|
||||||
#include "renderer/backend/Device.h"
|
#include "renderer/backend/Device.h"
|
||||||
#include "renderer/ccShaders.h"
|
#include "renderer/ccShaders.h"
|
||||||
#include "base/CCDirector.h"
|
#include "base/CCDirector.h"
|
||||||
#include "3d/CCSprite3D.h"
|
#include "3d/CCMeshRenderer.h"
|
||||||
#include "2d/CCCamera.h"
|
#include "2d/CCCamera.h"
|
||||||
|
|
||||||
NS_CC_BEGIN
|
NS_CC_BEGIN
|
||||||
|
@ -280,10 +280,10 @@ void Particle3DQuadRender::reset()
|
||||||
}
|
}
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////////
|
||||||
Particle3DModelRender::Particle3DModelRender() : _spriteSize(Vec3::ONE) {}
|
Particle3DModelRender::Particle3DModelRender() : _meshSize(Vec3::ONE) {}
|
||||||
Particle3DModelRender::~Particle3DModelRender()
|
Particle3DModelRender::~Particle3DModelRender()
|
||||||
{
|
{
|
||||||
for (auto iter : _spriteList)
|
for (auto iter : _meshList)
|
||||||
{
|
{
|
||||||
iter->release();
|
iter->release();
|
||||||
}
|
}
|
||||||
|
@ -302,26 +302,26 @@ void Particle3DModelRender::render(Renderer* renderer, const Mat4& transform, Pa
|
||||||
if (!_isVisible)
|
if (!_isVisible)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (_spriteList.empty())
|
if (_meshList.empty())
|
||||||
{
|
{
|
||||||
for (unsigned int i = 0; i < particleSystem->getParticleQuota(); ++i)
|
for (unsigned int i = 0; i < particleSystem->getParticleQuota(); ++i)
|
||||||
{
|
{
|
||||||
Sprite3D* sprite = Sprite3D::create(_modelFile);
|
MeshRenderer* mesh = MeshRenderer::create(_modelFile);
|
||||||
if (sprite == nullptr)
|
if (mesh == nullptr)
|
||||||
{
|
{
|
||||||
CCLOG("failed to load file %s", _modelFile.c_str());
|
CCLOG("failed to load file %s", _modelFile.c_str());
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
sprite->setTexture(_texFile);
|
mesh->setTexture(_texFile);
|
||||||
sprite->retain();
|
mesh->retain();
|
||||||
_spriteList.push_back(sprite);
|
_meshList.push_back(mesh);
|
||||||
}
|
}
|
||||||
if (!_spriteList.empty())
|
if (!_meshList.empty())
|
||||||
{
|
{
|
||||||
const AABB& aabb = _spriteList[0]->getAABB();
|
const AABB& aabb = _meshList[0]->getAABB();
|
||||||
Vec3 corners[8];
|
Vec3 corners[8];
|
||||||
aabb.getCorners(corners);
|
aabb.getCorners(corners);
|
||||||
_spriteSize = corners[3] - corners[6];
|
_meshSize = corners[3] - corners[6];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -337,24 +337,24 @@ void Particle3DModelRender::render(Renderer* renderer, const Mat4& transform, Pa
|
||||||
{
|
{
|
||||||
auto particle = iter;
|
auto particle = iter;
|
||||||
Mat4::createRotation(q * particle->orientation, &rotMat);
|
Mat4::createRotation(q * particle->orientation, &rotMat);
|
||||||
sclMat.m[0] = particle->width / _spriteSize.x;
|
sclMat.m[0] = particle->width / _meshSize.x;
|
||||||
sclMat.m[5] = particle->height / _spriteSize.y;
|
sclMat.m[5] = particle->height / _meshSize.y;
|
||||||
sclMat.m[10] = particle->depth / _spriteSize.z;
|
sclMat.m[10] = particle->depth / _meshSize.z;
|
||||||
mat = rotMat * sclMat;
|
mat = rotMat * sclMat;
|
||||||
mat.m[12] = particle->position.x;
|
mat.m[12] = particle->position.x;
|
||||||
mat.m[13] = particle->position.y;
|
mat.m[13] = particle->position.y;
|
||||||
mat.m[14] = particle->position.z;
|
mat.m[14] = particle->position.z;
|
||||||
_spriteList[index++]->draw(renderer, mat, 0);
|
_meshList[index++]->draw(renderer, mat, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Particle3DModelRender::reset()
|
void Particle3DModelRender::reset()
|
||||||
{
|
{
|
||||||
for (auto iter : _spriteList)
|
for (auto iter : _meshList)
|
||||||
{
|
{
|
||||||
iter->release();
|
iter->release();
|
||||||
}
|
}
|
||||||
_spriteList.clear();
|
_meshList.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
// MARK: Particle3DRender
|
// MARK: Particle3DRender
|
||||||
|
|
|
@ -41,7 +41,7 @@ NS_CC_BEGIN
|
||||||
class ParticleSystem3D;
|
class ParticleSystem3D;
|
||||||
class Renderer;
|
class Renderer;
|
||||||
class MeshCommand;
|
class MeshCommand;
|
||||||
class Sprite3D;
|
class MeshRenderer;
|
||||||
class GLProgramState;
|
class GLProgramState;
|
||||||
class IndexBuffer;
|
class IndexBuffer;
|
||||||
class VertexBuffer;
|
class VertexBuffer;
|
||||||
|
@ -141,7 +141,7 @@ protected:
|
||||||
bool _rendererDepthWrite = false;
|
bool _rendererDepthWrite = false;
|
||||||
};
|
};
|
||||||
|
|
||||||
// particle render for Sprite3D
|
// particle renderer using MeshRenderer
|
||||||
class CC_EX_DLL Particle3DModelRender : public Particle3DRender
|
class CC_EX_DLL Particle3DModelRender : public Particle3DRender
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
@ -154,10 +154,10 @@ public:
|
||||||
virtual ~Particle3DModelRender();
|
virtual ~Particle3DModelRender();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
std::vector<Sprite3D*> _spriteList;
|
std::vector<MeshRenderer*> _meshList;
|
||||||
std::string _modelFile;
|
std::string _modelFile;
|
||||||
std::string _texFile;
|
std::string _texFile;
|
||||||
Vec3 _spriteSize;
|
Vec3 _meshSize;
|
||||||
};
|
};
|
||||||
|
|
||||||
NS_CC_END
|
NS_CC_END
|
||||||
|
|
|
@ -34,7 +34,7 @@
|
||||||
#include "renderer/CCTextureCache.h"
|
#include "renderer/CCTextureCache.h"
|
||||||
#include "renderer/backend/ProgramState.h"
|
#include "renderer/backend/ProgramState.h"
|
||||||
#include "base/CCDirector.h"
|
#include "base/CCDirector.h"
|
||||||
#include "3d/CCSprite3D.h"
|
#include "3d/CCMeshRenderer.h"
|
||||||
#include "3d/CCMesh.h"
|
#include "3d/CCMesh.h"
|
||||||
#include "2d/CCCamera.h"
|
#include "2d/CCCamera.h"
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
|
|
|
@ -36,7 +36,7 @@
|
||||||
#include "renderer/backend/Buffer.h"
|
#include "renderer/backend/Buffer.h"
|
||||||
#include "renderer/backend/Device.h"
|
#include "renderer/backend/Device.h"
|
||||||
#include "2d/CCCamera.h"
|
#include "2d/CCCamera.h"
|
||||||
#include "3d/CCSprite3D.h"
|
#include "3d/CCMeshRenderer.h"
|
||||||
|
|
||||||
NS_CC_BEGIN
|
NS_CC_BEGIN
|
||||||
|
|
||||||
|
|
|
@ -36,7 +36,7 @@
|
||||||
#include "renderer/backend/Device.h"
|
#include "renderer/backend/Device.h"
|
||||||
#include "renderer/backend/Buffer.h"
|
#include "renderer/backend/Buffer.h"
|
||||||
#include "base/CCDirector.h"
|
#include "base/CCDirector.h"
|
||||||
#include "3d/CCSprite3D.h"
|
#include "3d/CCMeshRenderer.h"
|
||||||
#include "3d/CCMesh.h"
|
#include "3d/CCMesh.h"
|
||||||
#include "2d/CCCamera.h"
|
#include "2d/CCCamera.h"
|
||||||
|
|
||||||
|
@ -501,28 +501,28 @@ void PUParticle3DModelRender::render(Renderer* renderer, const Mat4& transform,
|
||||||
if (!_isVisible)
|
if (!_isVisible)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (_spriteList.empty())
|
if (_meshList.empty())
|
||||||
{
|
{
|
||||||
for (unsigned int i = 0; i < particleSystem->getParticleQuota(); ++i)
|
for (unsigned int i = 0; i < particleSystem->getParticleQuota(); ++i)
|
||||||
{
|
{
|
||||||
Sprite3D* sprite = Sprite3D::create(_modelFile);
|
MeshRenderer* mesh = MeshRenderer::create(_modelFile);
|
||||||
if (sprite == nullptr)
|
if (mesh == nullptr)
|
||||||
{
|
{
|
||||||
CCLOG("failed to load file %s", _modelFile.c_str());
|
CCLOG("failed to load file %s", _modelFile.c_str());
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
sprite->setTexture(_texFile);
|
mesh->setTexture(_texFile);
|
||||||
sprite->setBlendFunc(particleSystem->getBlendFunc());
|
mesh->setBlendFunc(particleSystem->getBlendFunc());
|
||||||
sprite->setCullFaceEnabled(false);
|
mesh->setCullFaceEnabled(false);
|
||||||
sprite->retain();
|
mesh->retain();
|
||||||
_spriteList.push_back(sprite);
|
_meshList.push_back(mesh);
|
||||||
}
|
}
|
||||||
if (!_spriteList.empty())
|
if (!_meshList.empty())
|
||||||
{
|
{
|
||||||
const AABB& aabb = _spriteList[0]->getAABB();
|
const AABB& aabb = _meshList[0]->getAABB();
|
||||||
Vec3 corners[8];
|
Vec3 corners[8];
|
||||||
aabb.getCorners(corners);
|
aabb.getCorners(corners);
|
||||||
_spriteSize = corners[3] - corners[6];
|
_meshSize = corners[3] - corners[6];
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -543,19 +543,19 @@ void PUParticle3DModelRender::render(Renderer* renderer, const Mat4& transform,
|
||||||
{
|
{
|
||||||
auto particle = static_cast<PUParticle3D*>(iter);
|
auto particle = static_cast<PUParticle3D*>(iter);
|
||||||
Mat4::createRotation(q * particle->orientation, &rotMat);
|
Mat4::createRotation(q * particle->orientation, &rotMat);
|
||||||
sclMat.m[0] = particle->width / _spriteSize.x;
|
sclMat.m[0] = particle->width / _meshSize.x;
|
||||||
sclMat.m[5] = particle->height / _spriteSize.y;
|
sclMat.m[5] = particle->height / _meshSize.y;
|
||||||
sclMat.m[10] = particle->depth / _spriteSize.z;
|
sclMat.m[10] = particle->depth / _meshSize.z;
|
||||||
mat = rotMat * sclMat;
|
mat = rotMat * sclMat;
|
||||||
mat.m[12] = particle->position.x;
|
mat.m[12] = particle->position.x;
|
||||||
mat.m[13] = particle->position.y;
|
mat.m[13] = particle->position.y;
|
||||||
mat.m[14] = particle->position.z;
|
mat.m[14] = particle->position.z;
|
||||||
if (_spriteList[index]->getCameraMask() != particleSystem->getCameraMask())
|
if (_meshList[index]->getCameraMask() != particleSystem->getCameraMask())
|
||||||
_spriteList[index]->setCameraMask(particleSystem->getCameraMask());
|
_meshList[index]->setCameraMask(particleSystem->getCameraMask());
|
||||||
_spriteList[index]->setColor(
|
_meshList[index]->setColor(
|
||||||
Color3B(particle->color.x * 255, particle->color.y * 255, particle->color.z * 255));
|
Color3B(particle->color.x * 255, particle->color.y * 255, particle->color.z * 255));
|
||||||
_spriteList[index]->setOpacity(particle->color.w * 255);
|
_meshList[index]->setOpacity(particle->color.w * 255);
|
||||||
_spriteList[index]->visit(renderer, mat, Node::FLAGS_DIRTY_MASK);
|
_meshList[index]->visit(renderer, mat, Node::FLAGS_DIRTY_MASK);
|
||||||
++index;
|
++index;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -567,7 +567,7 @@ PUParticle3DModelRender::PUParticle3DModelRender()
|
||||||
|
|
||||||
PUParticle3DModelRender::~PUParticle3DModelRender()
|
PUParticle3DModelRender::~PUParticle3DModelRender()
|
||||||
{
|
{
|
||||||
for (auto iter : _spriteList)
|
for (auto iter : _meshList)
|
||||||
{
|
{
|
||||||
iter->release();
|
iter->release();
|
||||||
}
|
}
|
||||||
|
@ -587,11 +587,11 @@ PUParticle3DModelRender* PUParticle3DModelRender::clone()
|
||||||
|
|
||||||
void PUParticle3DModelRender::reset()
|
void PUParticle3DModelRender::reset()
|
||||||
{
|
{
|
||||||
for (auto iter : _spriteList)
|
for (auto iter : _meshList)
|
||||||
{
|
{
|
||||||
iter->release();
|
iter->release();
|
||||||
}
|
}
|
||||||
_spriteList.clear();
|
_meshList.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
PUParticle3DEntityRender::PUParticle3DEntityRender()
|
PUParticle3DEntityRender::PUParticle3DEntityRender()
|
||||||
|
|
|
@ -55,7 +55,7 @@ public:
|
||||||
|
|
||||||
public:
|
public:
|
||||||
bool autoRotate; // Means that the objects to render automatically rotate if the node to which the particle system
|
bool autoRotate; // Means that the objects to render automatically rotate if the node to which the particle system
|
||||||
// is attached, rotates.
|
// is attached to rotates.
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
std::string _renderType;
|
std::string _renderType;
|
||||||
|
@ -203,10 +203,10 @@ public:
|
||||||
virtual ~PUParticle3DModelRender();
|
virtual ~PUParticle3DModelRender();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
std::vector<Sprite3D*> _spriteList;
|
std::vector<MeshRenderer*> _meshList;
|
||||||
std::string _modelFile;
|
std::string _modelFile;
|
||||||
std::string _texFile;
|
std::string _texFile;
|
||||||
Vec3 _spriteSize;
|
Vec3 _meshSize;
|
||||||
};
|
};
|
||||||
|
|
||||||
class CC_EX_DLL PUParticle3DBoxRender : public PUParticle3DEntityRender
|
class CC_EX_DLL PUParticle3DBoxRender : public PUParticle3DEntityRender
|
||||||
|
|
|
@ -32,7 +32,7 @@
|
||||||
#include "renderer/CCTextureCache.h"
|
#include "renderer/CCTextureCache.h"
|
||||||
#include "renderer/backend/ProgramState.h"
|
#include "renderer/backend/ProgramState.h"
|
||||||
#include "2d/CCCamera.h"
|
#include "2d/CCCamera.h"
|
||||||
#include "3d/CCSprite3D.h"
|
#include "3d/CCMeshRenderer.h"
|
||||||
|
|
||||||
NS_CC_BEGIN
|
NS_CC_BEGIN
|
||||||
|
|
||||||
|
|
|
@ -32,7 +32,7 @@
|
||||||
#include "renderer/CCRenderer.h"
|
#include "renderer/CCRenderer.h"
|
||||||
#include "renderer/CCTextureCache.h"
|
#include "renderer/CCTextureCache.h"
|
||||||
#include "base/CCDirector.h"
|
#include "base/CCDirector.h"
|
||||||
#include "3d/CCSprite3D.h"
|
#include "3d/CCMeshRenderer.h"
|
||||||
#include "3d/CCMesh.h"
|
#include "3d/CCMesh.h"
|
||||||
#include "2d/CCCamera.h"
|
#include "2d/CCCamera.h"
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
|
|
|
@ -69,7 +69,7 @@
|
||||||
#include "WidgetReader/ListViewReader/ListViewReader.h"
|
#include "WidgetReader/ListViewReader/ListViewReader.h"
|
||||||
#include "WidgetReader/ArmatureNodeReader/ArmatureNodeReader.h"
|
#include "WidgetReader/ArmatureNodeReader/ArmatureNodeReader.h"
|
||||||
#include "WidgetReader/Node3DReader/Node3DReader.h"
|
#include "WidgetReader/Node3DReader/Node3DReader.h"
|
||||||
#include "WidgetReader/Sprite3DReader/Sprite3DReader.h"
|
#include "WidgetReader/MeshReader/MeshReader.h"
|
||||||
#include "WidgetReader/UserCameraReader/UserCameraReader.h"
|
#include "WidgetReader/UserCameraReader/UserCameraReader.h"
|
||||||
#include "WidgetReader/Particle3DReader/Particle3DReader.h"
|
#include "WidgetReader/Particle3DReader/Particle3DReader.h"
|
||||||
#include "WidgetReader/GameNode3DReader/GameNode3DReader.h"
|
#include "WidgetReader/GameNode3DReader/GameNode3DReader.h"
|
||||||
|
@ -226,7 +226,7 @@ CSLoader::CSLoader()
|
||||||
|
|
||||||
CREATE_CLASS_NODE_READER_INFO(ArmatureNodeReader);
|
CREATE_CLASS_NODE_READER_INFO(ArmatureNodeReader);
|
||||||
CREATE_CLASS_NODE_READER_INFO(Node3DReader);
|
CREATE_CLASS_NODE_READER_INFO(Node3DReader);
|
||||||
CREATE_CLASS_NODE_READER_INFO(Sprite3DReader);
|
CREATE_CLASS_NODE_READER_INFO(MeshReader);
|
||||||
CREATE_CLASS_NODE_READER_INFO(UserCameraReader);
|
CREATE_CLASS_NODE_READER_INFO(UserCameraReader);
|
||||||
CREATE_CLASS_NODE_READER_INFO(Particle3DReader);
|
CREATE_CLASS_NODE_READER_INFO(Particle3DReader);
|
||||||
CREATE_CLASS_NODE_READER_INFO(GameNode3DReader);
|
CREATE_CLASS_NODE_READER_INFO(GameNode3DReader);
|
||||||
|
|
|
@ -24,7 +24,7 @@
|
||||||
#include "WidgetReader/ListViewReader/ListViewReader.h"
|
#include "WidgetReader/ListViewReader/ListViewReader.h"
|
||||||
#include "WidgetReader/ArmatureNodeReader/ArmatureNodeReader.h"
|
#include "WidgetReader/ArmatureNodeReader/ArmatureNodeReader.h"
|
||||||
#include "WidgetReader/Node3DReader/Node3DReader.h"
|
#include "WidgetReader/Node3DReader/Node3DReader.h"
|
||||||
#include "WidgetReader/Sprite3DReader/Sprite3DReader.h"
|
#include "WidgetReader/MeshReader/MeshReader.h"
|
||||||
#include "WidgetReader/UserCameraReader/UserCameraReader.h"
|
#include "WidgetReader/UserCameraReader/UserCameraReader.h"
|
||||||
#include "WidgetReader/Particle3DReader/Particle3DReader.h"
|
#include "WidgetReader/Particle3DReader/Particle3DReader.h"
|
||||||
|
|
||||||
|
@ -57,7 +57,7 @@ void destroyCocosStudio()
|
||||||
|
|
||||||
ArmatureNodeReader::destroyInstance();
|
ArmatureNodeReader::destroyInstance();
|
||||||
Node3DReader::destroyInstance();
|
Node3DReader::destroyInstance();
|
||||||
Sprite3DReader::destroyInstance();
|
MeshReader::destroyInstance();
|
||||||
UserCameraReader::destroyInstance();
|
UserCameraReader::destroyInstance();
|
||||||
Particle3DReader::destroyInstance();
|
Particle3DReader::destroyInstance();
|
||||||
|
|
||||||
|
|
|
@ -24,11 +24,11 @@
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#include "2d/CCLight.h"
|
#include "2d/CCLight.h"
|
||||||
#include "3d/CCSprite3D.h"
|
#include "3d/CCMeshRenderer.h"
|
||||||
#include "3d/CCAnimate3D.h"
|
#include "3d/CCAnimate3D.h"
|
||||||
#include "3d/CCAnimation3D.h"
|
#include "3d/CCAnimation3D.h"
|
||||||
#include "platform/CCFileUtils.h"
|
#include "platform/CCFileUtils.h"
|
||||||
#include "WidgetReader/Sprite3DReader/Sprite3DReader.h"
|
#include "WidgetReader/MeshReader/MeshReader.h"
|
||||||
|
|
||||||
#include "CSParseBinary_generated.h"
|
#include "CSParseBinary_generated.h"
|
||||||
#include "CSParse3DBinary_generated.h"
|
#include "CSParse3DBinary_generated.h"
|
||||||
|
@ -43,35 +43,35 @@ using namespace flatbuffers;
|
||||||
|
|
||||||
namespace cocostudio
|
namespace cocostudio
|
||||||
{
|
{
|
||||||
IMPLEMENT_CLASS_NODE_READER_INFO(Sprite3DReader)
|
IMPLEMENT_CLASS_NODE_READER_INFO(MeshReader)
|
||||||
|
|
||||||
Sprite3DReader::Sprite3DReader() {}
|
MeshReader::MeshReader() {}
|
||||||
|
|
||||||
Sprite3DReader::~Sprite3DReader() {}
|
MeshReader::~MeshReader() {}
|
||||||
|
|
||||||
static Sprite3DReader* _instanceSprite3DReader = nullptr;
|
static MeshReader* _instanceMeshReader = nullptr;
|
||||||
|
|
||||||
Sprite3DReader* Sprite3DReader::getInstance()
|
MeshReader* MeshReader::getInstance()
|
||||||
{
|
{
|
||||||
if (!_instanceSprite3DReader)
|
if (!_instanceMeshReader)
|
||||||
{
|
{
|
||||||
_instanceSprite3DReader = new Sprite3DReader();
|
_instanceMeshReader = new MeshReader();
|
||||||
}
|
}
|
||||||
|
|
||||||
return _instanceSprite3DReader;
|
return _instanceMeshReader;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sprite3DReader::purge()
|
void MeshReader::purge()
|
||||||
{
|
{
|
||||||
CC_SAFE_DELETE(_instanceSprite3DReader);
|
CC_SAFE_DELETE(_instanceMeshReader);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sprite3DReader::destroyInstance()
|
void MeshReader::destroyInstance()
|
||||||
{
|
{
|
||||||
CC_SAFE_DELETE(_instanceSprite3DReader);
|
CC_SAFE_DELETE(_instanceMeshReader);
|
||||||
}
|
}
|
||||||
|
|
||||||
Vec2 Sprite3DReader::getVec2Attribute(pugi::xml_attribute attribute) const
|
Vec2 MeshReader::getVec2Attribute(pugi::xml_attribute attribute) const
|
||||||
{
|
{
|
||||||
if (!attribute)
|
if (!attribute)
|
||||||
return Vec2::ZERO;
|
return Vec2::ZERO;
|
||||||
|
@ -99,7 +99,7 @@ Vec2 Sprite3DReader::getVec2Attribute(pugi::xml_attribute attribute) const
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
Offset<Table> Sprite3DReader::createOptionsWithFlatBuffers(pugi::xml_node objectData,
|
Offset<Table> MeshReader::createOptionsWithFlatBuffers(pugi::xml_node objectData,
|
||||||
flatbuffers::FlatBufferBuilder* builder)
|
flatbuffers::FlatBufferBuilder* builder)
|
||||||
{
|
{
|
||||||
auto temp = Node3DReader::getInstance()->createOptionsWithFlatBuffers(objectData, builder);
|
auto temp = Node3DReader::getInstance()->createOptionsWithFlatBuffers(objectData, builder);
|
||||||
|
@ -205,9 +205,9 @@ Offset<Table> Sprite3DReader::createOptionsWithFlatBuffers(pugi::xml_node object
|
||||||
return *(Offset<Table>*)(&options);
|
return *(Offset<Table>*)(&options);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sprite3DReader::setPropsWithFlatBuffers(cocos2d::Node* node, const flatbuffers::Table* sprite3DOptions)
|
void MeshReader::setPropsWithFlatBuffers(cocos2d::Node* node, const flatbuffers::Table* sprite3DOptions)
|
||||||
{
|
{
|
||||||
Sprite3D* sprite3D = static_cast<Sprite3D*>(node);
|
MeshRenderer* mesh = static_cast<MeshRenderer*>(node);
|
||||||
|
|
||||||
auto options = (Sprite3DOptions*)sprite3DOptions;
|
auto options = (Sprite3DOptions*)sprite3DOptions;
|
||||||
|
|
||||||
|
@ -224,7 +224,7 @@ void Sprite3DReader::setPropsWithFlatBuffers(cocos2d::Node* node, const flatbuff
|
||||||
{
|
{
|
||||||
Animate3D* animate = Animate3D::create(animation);
|
Animate3D* animate = Animate3D::create(animation);
|
||||||
Action* action = RepeatForever::create(animate);
|
Action* action = RepeatForever::create(animate);
|
||||||
sprite3D->runAction(action);
|
mesh->runAction(action);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -237,36 +237,36 @@ void Sprite3DReader::setPropsWithFlatBuffers(cocos2d::Node* node, const flatbuff
|
||||||
|
|
||||||
if (alpha != 255)
|
if (alpha != 255)
|
||||||
{
|
{
|
||||||
sprite3D->setOpacity(alpha);
|
mesh->setOpacity(alpha);
|
||||||
}
|
}
|
||||||
if (red != 255 || green != 255 || blue != 255)
|
if (red != 255 || green != 255 || blue != 255)
|
||||||
{
|
{
|
||||||
sprite3D->setColor(Color3B(red, green, blue));
|
mesh->setColor(Color3B(red, green, blue));
|
||||||
}
|
}
|
||||||
if (isFlipped)
|
if (isFlipped)
|
||||||
{
|
{
|
||||||
sprite3D->setCullFaceEnabled(true);
|
mesh->setCullFaceEnabled(true);
|
||||||
sprite3D->setCullFace(CullFaceSide::FRONT);
|
mesh->setCullFace(CullFaceSide::FRONT);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (lightFlag <= 0)
|
if (lightFlag <= 0)
|
||||||
{
|
{
|
||||||
lightFlag = 1;
|
lightFlag = 1;
|
||||||
}
|
}
|
||||||
sprite3D->setLightMask(lightFlag);
|
mesh->setLightMask(lightFlag);
|
||||||
|
|
||||||
auto node3DReader = Node3DReader::getInstance();
|
auto node3DReader = Node3DReader::getInstance();
|
||||||
node3DReader->setPropsWithFlatBuffers(sprite3D, (Table*)(options->node3DOption()));
|
node3DReader->setPropsWithFlatBuffers(mesh, (Table*)(options->node3DOption()));
|
||||||
}
|
}
|
||||||
|
|
||||||
Node* Sprite3DReader::createNodeWithFlatBuffers(const flatbuffers::Table* sprite3DOptions)
|
Node* MeshReader::createNodeWithFlatBuffers(const flatbuffers::Table* sprite3DOptions)
|
||||||
{
|
{
|
||||||
auto options = (Sprite3DOptions*)sprite3DOptions;
|
auto options = (Sprite3DOptions*)sprite3DOptions;
|
||||||
|
|
||||||
auto fileData = options->fileData();
|
auto fileData = options->fileData();
|
||||||
std::string path = fileData->path()->c_str();
|
std::string path = fileData->path()->c_str();
|
||||||
|
|
||||||
Sprite3D* ret = Sprite3D::create();
|
MeshRenderer* ret = MeshRenderer::create();
|
||||||
if (FileUtils::getInstance()->isFileExist(path))
|
if (FileUtils::getInstance()->isFileExist(path))
|
||||||
{
|
{
|
||||||
ret->initWithFile(path);
|
ret->initWithFile(path);
|
|
@ -32,15 +32,15 @@
|
||||||
|
|
||||||
namespace cocostudio
|
namespace cocostudio
|
||||||
{
|
{
|
||||||
class CCS_DLL Sprite3DReader : public cocos2d::Ref, public NodeReaderProtocol
|
class CCS_DLL MeshReader : public cocos2d::Ref, public NodeReaderProtocol
|
||||||
{
|
{
|
||||||
DECLARE_CLASS_NODE_READER_INFO
|
DECLARE_CLASS_NODE_READER_INFO
|
||||||
|
|
||||||
public:
|
public:
|
||||||
Sprite3DReader();
|
MeshReader();
|
||||||
~Sprite3DReader();
|
~MeshReader();
|
||||||
|
|
||||||
static Sprite3DReader* getInstance();
|
static MeshReader* getInstance();
|
||||||
/** @deprecated Use method destroyInstance() instead */
|
/** @deprecated Use method destroyInstance() instead */
|
||||||
CC_DEPRECATED_ATTRIBUTE static void purge();
|
CC_DEPRECATED_ATTRIBUTE static void purge();
|
||||||
static void destroyInstance();
|
static void destroyInstance();
|
File diff suppressed because it is too large
Load Diff
|
@ -3972,10 +3972,10 @@ int lua_register_cocos2dx_physics3d_Physics3DComponent(lua_State* tolua_S)
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int lua_cocos2dx_physics3d_PhysicsSprite3D_syncNodeToPhysics(lua_State* tolua_S)
|
int lua_cocos2dx_physics3d_PhysicsMeshRenderer_syncNodeToPhysics(lua_State* tolua_S)
|
||||||
{
|
{
|
||||||
int argc = 0;
|
int argc = 0;
|
||||||
cocos2d::PhysicsSprite3D* cobj = nullptr;
|
cocos2d::PhysicsMeshRenderer* cobj = nullptr;
|
||||||
bool ok = true;
|
bool ok = true;
|
||||||
|
|
||||||
#if COCOS2D_DEBUG >= 1
|
#if COCOS2D_DEBUG >= 1
|
||||||
|
@ -3984,15 +3984,15 @@ int lua_cocos2dx_physics3d_PhysicsSprite3D_syncNodeToPhysics(lua_State* tolua_S)
|
||||||
|
|
||||||
|
|
||||||
#if COCOS2D_DEBUG >= 1
|
#if COCOS2D_DEBUG >= 1
|
||||||
if (!tolua_isusertype(tolua_S,1,"cc.PhysicsSprite3D",0,&tolua_err)) goto tolua_lerror;
|
if (!tolua_isusertype(tolua_S,1,"cc.PhysicsMeshRenderer",0,&tolua_err)) goto tolua_lerror;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
cobj = (cocos2d::PhysicsSprite3D*)tolua_tousertype(tolua_S,1,0);
|
cobj = (cocos2d::PhysicsMeshRenderer*)tolua_tousertype(tolua_S,1,0);
|
||||||
|
|
||||||
#if COCOS2D_DEBUG >= 1
|
#if COCOS2D_DEBUG >= 1
|
||||||
if (!cobj)
|
if (!cobj)
|
||||||
{
|
{
|
||||||
tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_physics3d_PhysicsSprite3D_syncNodeToPhysics'", nullptr);
|
tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_physics3d_PhysicsMeshRenderer_syncNodeToPhysics'", nullptr);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -4002,27 +4002,27 @@ int lua_cocos2dx_physics3d_PhysicsSprite3D_syncNodeToPhysics(lua_State* tolua_S)
|
||||||
{
|
{
|
||||||
if(!ok)
|
if(!ok)
|
||||||
{
|
{
|
||||||
tolua_error(tolua_S,"invalid arguments in function 'lua_cocos2dx_physics3d_PhysicsSprite3D_syncNodeToPhysics'", nullptr);
|
tolua_error(tolua_S,"invalid arguments in function 'lua_cocos2dx_physics3d_PhysicsMeshRenderer_syncNodeToPhysics'", nullptr);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
cobj->syncNodeToPhysics();
|
cobj->syncNodeToPhysics();
|
||||||
lua_settop(tolua_S, 1);
|
lua_settop(tolua_S, 1);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
luaL_error(tolua_S, "%s has wrong number of arguments: %d, was expecting %d \n", "cc.PhysicsSprite3D:syncNodeToPhysics",argc, 0);
|
luaL_error(tolua_S, "%s has wrong number of arguments: %d, was expecting %d \n", "cc.PhysicsMeshRenderer:syncNodeToPhysics",argc, 0);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
#if COCOS2D_DEBUG >= 1
|
#if COCOS2D_DEBUG >= 1
|
||||||
tolua_lerror:
|
tolua_lerror:
|
||||||
tolua_error(tolua_S,"#ferror in function 'lua_cocos2dx_physics3d_PhysicsSprite3D_syncNodeToPhysics'.",&tolua_err);
|
tolua_error(tolua_S,"#ferror in function 'lua_cocos2dx_physics3d_PhysicsMeshRenderer_syncNodeToPhysics'.",&tolua_err);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
int lua_cocos2dx_physics3d_PhysicsSprite3D_syncPhysicsToNode(lua_State* tolua_S)
|
int lua_cocos2dx_physics3d_PhysicsMeshRenderer_syncPhysicsToNode(lua_State* tolua_S)
|
||||||
{
|
{
|
||||||
int argc = 0;
|
int argc = 0;
|
||||||
cocos2d::PhysicsSprite3D* cobj = nullptr;
|
cocos2d::PhysicsMeshRenderer* cobj = nullptr;
|
||||||
bool ok = true;
|
bool ok = true;
|
||||||
|
|
||||||
#if COCOS2D_DEBUG >= 1
|
#if COCOS2D_DEBUG >= 1
|
||||||
|
@ -4031,15 +4031,15 @@ int lua_cocos2dx_physics3d_PhysicsSprite3D_syncPhysicsToNode(lua_State* tolua_S)
|
||||||
|
|
||||||
|
|
||||||
#if COCOS2D_DEBUG >= 1
|
#if COCOS2D_DEBUG >= 1
|
||||||
if (!tolua_isusertype(tolua_S,1,"cc.PhysicsSprite3D",0,&tolua_err)) goto tolua_lerror;
|
if (!tolua_isusertype(tolua_S,1,"cc.PhysicsMeshRenderer",0,&tolua_err)) goto tolua_lerror;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
cobj = (cocos2d::PhysicsSprite3D*)tolua_tousertype(tolua_S,1,0);
|
cobj = (cocos2d::PhysicsMeshRenderer*)tolua_tousertype(tolua_S,1,0);
|
||||||
|
|
||||||
#if COCOS2D_DEBUG >= 1
|
#if COCOS2D_DEBUG >= 1
|
||||||
if (!cobj)
|
if (!cobj)
|
||||||
{
|
{
|
||||||
tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_physics3d_PhysicsSprite3D_syncPhysicsToNode'", nullptr);
|
tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_physics3d_PhysicsMeshRenderer_syncPhysicsToNode'", nullptr);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -4049,27 +4049,27 @@ int lua_cocos2dx_physics3d_PhysicsSprite3D_syncPhysicsToNode(lua_State* tolua_S)
|
||||||
{
|
{
|
||||||
if(!ok)
|
if(!ok)
|
||||||
{
|
{
|
||||||
tolua_error(tolua_S,"invalid arguments in function 'lua_cocos2dx_physics3d_PhysicsSprite3D_syncPhysicsToNode'", nullptr);
|
tolua_error(tolua_S,"invalid arguments in function 'lua_cocos2dx_physics3d_PhysicsMeshRenderer_syncPhysicsToNode'", nullptr);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
cobj->syncPhysicsToNode();
|
cobj->syncPhysicsToNode();
|
||||||
lua_settop(tolua_S, 1);
|
lua_settop(tolua_S, 1);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
luaL_error(tolua_S, "%s has wrong number of arguments: %d, was expecting %d \n", "cc.PhysicsSprite3D:syncPhysicsToNode",argc, 0);
|
luaL_error(tolua_S, "%s has wrong number of arguments: %d, was expecting %d \n", "cc.PhysicsMeshRenderer:syncPhysicsToNode",argc, 0);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
#if COCOS2D_DEBUG >= 1
|
#if COCOS2D_DEBUG >= 1
|
||||||
tolua_lerror:
|
tolua_lerror:
|
||||||
tolua_error(tolua_S,"#ferror in function 'lua_cocos2dx_physics3d_PhysicsSprite3D_syncPhysicsToNode'.",&tolua_err);
|
tolua_error(tolua_S,"#ferror in function 'lua_cocos2dx_physics3d_PhysicsMeshRenderer_syncPhysicsToNode'.",&tolua_err);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
int lua_cocos2dx_physics3d_PhysicsSprite3D_getPhysicsObj(lua_State* tolua_S)
|
int lua_cocos2dx_physics3d_PhysicsMeshRenderer_getPhysicsObj(lua_State* tolua_S)
|
||||||
{
|
{
|
||||||
int argc = 0;
|
int argc = 0;
|
||||||
cocos2d::PhysicsSprite3D* cobj = nullptr;
|
cocos2d::PhysicsMeshRenderer* cobj = nullptr;
|
||||||
bool ok = true;
|
bool ok = true;
|
||||||
|
|
||||||
#if COCOS2D_DEBUG >= 1
|
#if COCOS2D_DEBUG >= 1
|
||||||
|
@ -4078,15 +4078,15 @@ int lua_cocos2dx_physics3d_PhysicsSprite3D_getPhysicsObj(lua_State* tolua_S)
|
||||||
|
|
||||||
|
|
||||||
#if COCOS2D_DEBUG >= 1
|
#if COCOS2D_DEBUG >= 1
|
||||||
if (!tolua_isusertype(tolua_S,1,"cc.PhysicsSprite3D",0,&tolua_err)) goto tolua_lerror;
|
if (!tolua_isusertype(tolua_S,1,"cc.PhysicsMeshRenderer",0,&tolua_err)) goto tolua_lerror;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
cobj = (cocos2d::PhysicsSprite3D*)tolua_tousertype(tolua_S,1,0);
|
cobj = (cocos2d::PhysicsMeshRenderer*)tolua_tousertype(tolua_S,1,0);
|
||||||
|
|
||||||
#if COCOS2D_DEBUG >= 1
|
#if COCOS2D_DEBUG >= 1
|
||||||
if (!cobj)
|
if (!cobj)
|
||||||
{
|
{
|
||||||
tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_physics3d_PhysicsSprite3D_getPhysicsObj'", nullptr);
|
tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_physics3d_PhysicsMeshRenderer_getPhysicsObj'", nullptr);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -4096,27 +4096,27 @@ int lua_cocos2dx_physics3d_PhysicsSprite3D_getPhysicsObj(lua_State* tolua_S)
|
||||||
{
|
{
|
||||||
if(!ok)
|
if(!ok)
|
||||||
{
|
{
|
||||||
tolua_error(tolua_S,"invalid arguments in function 'lua_cocos2dx_physics3d_PhysicsSprite3D_getPhysicsObj'", nullptr);
|
tolua_error(tolua_S,"invalid arguments in function 'lua_cocos2dx_physics3d_PhysicsMeshRenderer_getPhysicsObj'", nullptr);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
cocos2d::Physics3DObject* ret = cobj->getPhysicsObj();
|
cocos2d::Physics3DObject* ret = cobj->getPhysicsObj();
|
||||||
object_to_luaval<cocos2d::Physics3DObject>(tolua_S, "cc.Physics3DObject",(cocos2d::Physics3DObject*)ret);
|
object_to_luaval<cocos2d::Physics3DObject>(tolua_S, "cc.Physics3DObject",(cocos2d::Physics3DObject*)ret);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
luaL_error(tolua_S, "%s has wrong number of arguments: %d, was expecting %d \n", "cc.PhysicsSprite3D:getPhysicsObj",argc, 0);
|
luaL_error(tolua_S, "%s has wrong number of arguments: %d, was expecting %d \n", "cc.PhysicsMeshRenderer:getPhysicsObj",argc, 0);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
#if COCOS2D_DEBUG >= 1
|
#if COCOS2D_DEBUG >= 1
|
||||||
tolua_lerror:
|
tolua_lerror:
|
||||||
tolua_error(tolua_S,"#ferror in function 'lua_cocos2dx_physics3d_PhysicsSprite3D_getPhysicsObj'.",&tolua_err);
|
tolua_error(tolua_S,"#ferror in function 'lua_cocos2dx_physics3d_PhysicsMeshRenderer_getPhysicsObj'.",&tolua_err);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
int lua_cocos2dx_physics3d_PhysicsSprite3D_setSyncFlag(lua_State* tolua_S)
|
int lua_cocos2dx_physics3d_PhysicsMeshRenderer_setSyncFlag(lua_State* tolua_S)
|
||||||
{
|
{
|
||||||
int argc = 0;
|
int argc = 0;
|
||||||
cocos2d::PhysicsSprite3D* cobj = nullptr;
|
cocos2d::PhysicsMeshRenderer* cobj = nullptr;
|
||||||
bool ok = true;
|
bool ok = true;
|
||||||
|
|
||||||
#if COCOS2D_DEBUG >= 1
|
#if COCOS2D_DEBUG >= 1
|
||||||
|
@ -4125,15 +4125,15 @@ int lua_cocos2dx_physics3d_PhysicsSprite3D_setSyncFlag(lua_State* tolua_S)
|
||||||
|
|
||||||
|
|
||||||
#if COCOS2D_DEBUG >= 1
|
#if COCOS2D_DEBUG >= 1
|
||||||
if (!tolua_isusertype(tolua_S,1,"cc.PhysicsSprite3D",0,&tolua_err)) goto tolua_lerror;
|
if (!tolua_isusertype(tolua_S,1,"cc.PhysicsMeshRenderer",0,&tolua_err)) goto tolua_lerror;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
cobj = (cocos2d::PhysicsSprite3D*)tolua_tousertype(tolua_S,1,0);
|
cobj = (cocos2d::PhysicsMeshRenderer*)tolua_tousertype(tolua_S,1,0);
|
||||||
|
|
||||||
#if COCOS2D_DEBUG >= 1
|
#if COCOS2D_DEBUG >= 1
|
||||||
if (!cobj)
|
if (!cobj)
|
||||||
{
|
{
|
||||||
tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_physics3d_PhysicsSprite3D_setSyncFlag'", nullptr);
|
tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_physics3d_PhysicsMeshRenderer_setSyncFlag'", nullptr);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -4143,30 +4143,30 @@ int lua_cocos2dx_physics3d_PhysicsSprite3D_setSyncFlag(lua_State* tolua_S)
|
||||||
{
|
{
|
||||||
cocos2d::Physics3DComponent::PhysicsSyncFlag arg0;
|
cocos2d::Physics3DComponent::PhysicsSyncFlag arg0;
|
||||||
|
|
||||||
ok &= luaval_to_int32(tolua_S, 2,(int *)&arg0, "cc.PhysicsSprite3D:setSyncFlag");
|
ok &= luaval_to_int32(tolua_S, 2,(int *)&arg0, "cc.PhysicsMeshRenderer:setSyncFlag");
|
||||||
if(!ok)
|
if(!ok)
|
||||||
{
|
{
|
||||||
tolua_error(tolua_S,"invalid arguments in function 'lua_cocos2dx_physics3d_PhysicsSprite3D_setSyncFlag'", nullptr);
|
tolua_error(tolua_S,"invalid arguments in function 'lua_cocos2dx_physics3d_PhysicsMeshRenderer_setSyncFlag'", nullptr);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
cobj->setSyncFlag(arg0);
|
cobj->setSyncFlag(arg0);
|
||||||
lua_settop(tolua_S, 1);
|
lua_settop(tolua_S, 1);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
luaL_error(tolua_S, "%s has wrong number of arguments: %d, was expecting %d \n", "cc.PhysicsSprite3D:setSyncFlag",argc, 1);
|
luaL_error(tolua_S, "%s has wrong number of arguments: %d, was expecting %d \n", "cc.PhysicsMeshRenderer:setSyncFlag",argc, 1);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
#if COCOS2D_DEBUG >= 1
|
#if COCOS2D_DEBUG >= 1
|
||||||
tolua_lerror:
|
tolua_lerror:
|
||||||
tolua_error(tolua_S,"#ferror in function 'lua_cocos2dx_physics3d_PhysicsSprite3D_setSyncFlag'.",&tolua_err);
|
tolua_error(tolua_S,"#ferror in function 'lua_cocos2dx_physics3d_PhysicsMeshRenderer_setSyncFlag'.",&tolua_err);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
int lua_cocos2dx_physics3d_PhysicsSprite3D_constructor(lua_State* tolua_S)
|
int lua_cocos2dx_physics3d_PhysicsMeshRenderer_constructor(lua_State* tolua_S)
|
||||||
{
|
{
|
||||||
int argc = 0;
|
int argc = 0;
|
||||||
cocos2d::PhysicsSprite3D* cobj = nullptr;
|
cocos2d::PhysicsMeshRenderer* cobj = nullptr;
|
||||||
bool ok = true;
|
bool ok = true;
|
||||||
|
|
||||||
#if COCOS2D_DEBUG >= 1
|
#if COCOS2D_DEBUG >= 1
|
||||||
|
@ -4180,47 +4180,47 @@ int lua_cocos2dx_physics3d_PhysicsSprite3D_constructor(lua_State* tolua_S)
|
||||||
{
|
{
|
||||||
if(!ok)
|
if(!ok)
|
||||||
{
|
{
|
||||||
tolua_error(tolua_S,"invalid arguments in function 'lua_cocos2dx_physics3d_PhysicsSprite3D_constructor'", nullptr);
|
tolua_error(tolua_S,"invalid arguments in function 'lua_cocos2dx_physics3d_PhysicsMeshRenderer_constructor'", nullptr);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
cobj = new cocos2d::PhysicsSprite3D();
|
cobj = new cocos2d::PhysicsMeshRenderer();
|
||||||
cobj->autorelease();
|
cobj->autorelease();
|
||||||
int ID = (int)cobj->_ID ;
|
int ID = (int)cobj->_ID ;
|
||||||
int* luaID = &cobj->_luaID ;
|
int* luaID = &cobj->_luaID ;
|
||||||
toluafix_pushusertype_ccobject(tolua_S, ID, luaID, (void*)cobj,"cc.PhysicsSprite3D");
|
toluafix_pushusertype_ccobject(tolua_S, ID, luaID, (void*)cobj,"cc.PhysicsMeshRenderer");
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
luaL_error(tolua_S, "%s has wrong number of arguments: %d, was expecting %d \n", "cc.PhysicsSprite3D:PhysicsSprite3D",argc, 0);
|
luaL_error(tolua_S, "%s has wrong number of arguments: %d, was expecting %d \n", "cc.PhysicsMeshRenderer:PhysicsMeshRenderer",argc, 0);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
#if COCOS2D_DEBUG >= 1
|
#if COCOS2D_DEBUG >= 1
|
||||||
tolua_error(tolua_S,"#ferror in function 'lua_cocos2dx_physics3d_PhysicsSprite3D_constructor'.",&tolua_err);
|
tolua_error(tolua_S,"#ferror in function 'lua_cocos2dx_physics3d_PhysicsMeshRenderer_constructor'.",&tolua_err);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int lua_cocos2dx_physics3d_PhysicsSprite3D_finalize(lua_State* tolua_S)
|
static int lua_cocos2dx_physics3d_PhysicsMeshRenderer_finalize(lua_State* tolua_S)
|
||||||
{
|
{
|
||||||
printf("luabindings: finalizing LUA object (PhysicsSprite3D)");
|
printf("luabindings: finalizing LUA object (PhysicsMeshRenderer)");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int lua_register_cocos2dx_physics3d_PhysicsSprite3D(lua_State* tolua_S)
|
int lua_register_cocos2dx_physics3d_PhysicsMeshRenderer(lua_State* tolua_S)
|
||||||
{
|
{
|
||||||
tolua_usertype(tolua_S,"cc.PhysicsSprite3D");
|
tolua_usertype(tolua_S,"cc.PhysicsMeshRenderer");
|
||||||
tolua_cclass(tolua_S,"PhysicsSprite3D","cc.PhysicsSprite3D","cc.Sprite3D",nullptr);
|
tolua_cclass(tolua_S,"PhysicsMeshRenderer","cc.PhysicsMeshRenderer","cc.Sprite3D",nullptr);
|
||||||
|
|
||||||
tolua_beginmodule(tolua_S,"PhysicsSprite3D");
|
tolua_beginmodule(tolua_S,"PhysicsMeshRenderer");
|
||||||
tolua_function(tolua_S,"new",lua_cocos2dx_physics3d_PhysicsSprite3D_constructor);
|
tolua_function(tolua_S,"new",lua_cocos2dx_physics3d_PhysicsMeshRenderer_constructor);
|
||||||
tolua_function(tolua_S,"syncNodeToPhysics",lua_cocos2dx_physics3d_PhysicsSprite3D_syncNodeToPhysics);
|
tolua_function(tolua_S,"syncNodeToPhysics",lua_cocos2dx_physics3d_PhysicsMeshRenderer_syncNodeToPhysics);
|
||||||
tolua_function(tolua_S,"syncPhysicsToNode",lua_cocos2dx_physics3d_PhysicsSprite3D_syncPhysicsToNode);
|
tolua_function(tolua_S,"syncPhysicsToNode",lua_cocos2dx_physics3d_PhysicsMeshRenderer_syncPhysicsToNode);
|
||||||
tolua_function(tolua_S,"getPhysicsObj",lua_cocos2dx_physics3d_PhysicsSprite3D_getPhysicsObj);
|
tolua_function(tolua_S,"getPhysicsObj",lua_cocos2dx_physics3d_PhysicsMeshRenderer_getPhysicsObj);
|
||||||
tolua_function(tolua_S,"setSyncFlag",lua_cocos2dx_physics3d_PhysicsSprite3D_setSyncFlag);
|
tolua_function(tolua_S,"setSyncFlag",lua_cocos2dx_physics3d_PhysicsMeshRenderer_setSyncFlag);
|
||||||
tolua_endmodule(tolua_S);
|
tolua_endmodule(tolua_S);
|
||||||
auto typeName = typeid(cocos2d::PhysicsSprite3D).name(); // rtti is literal storage
|
auto typeName = typeid(cocos2d::PhysicsMeshRenderer).name(); // rtti is literal storage
|
||||||
g_luaType[reinterpret_cast<uintptr_t>(typeName)] = "cc.PhysicsSprite3D";
|
g_luaType[reinterpret_cast<uintptr_t>(typeName)] = "cc.PhysicsMeshRenderer";
|
||||||
g_typeCast[typeName] = "cc.PhysicsSprite3D";
|
g_typeCast[typeName] = "cc.PhysicsMeshRenderer";
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -12373,7 +12373,7 @@ TOLUA_API int register_all_cocos2dx_physics3d(lua_State* tolua_S)
|
||||||
lua_register_cocos2dx_physics3d_Physics3DComponent(tolua_S);
|
lua_register_cocos2dx_physics3d_Physics3DComponent(tolua_S);
|
||||||
lua_register_cocos2dx_physics3d_Physics3DConeTwistConstraint(tolua_S);
|
lua_register_cocos2dx_physics3d_Physics3DConeTwistConstraint(tolua_S);
|
||||||
lua_register_cocos2dx_physics3d_Physics3DPointToPointConstraint(tolua_S);
|
lua_register_cocos2dx_physics3d_Physics3DPointToPointConstraint(tolua_S);
|
||||||
lua_register_cocos2dx_physics3d_PhysicsSprite3D(tolua_S);
|
lua_register_cocos2dx_physics3d_PhysicsMeshRenderer(tolua_S);
|
||||||
lua_register_cocos2dx_physics3d_Physics3DHingeConstraint(tolua_S);
|
lua_register_cocos2dx_physics3d_Physics3DHingeConstraint(tolua_S);
|
||||||
lua_register_cocos2dx_physics3d_Physics3DShape(tolua_S);
|
lua_register_cocos2dx_physics3d_Physics3DShape(tolua_S);
|
||||||
|
|
||||||
|
|
|
@ -27,29 +27,29 @@
|
||||||
#include "scripting/lua-bindings/manual/LuaBasicConversions.h"
|
#include "scripting/lua-bindings/manual/LuaBasicConversions.h"
|
||||||
#include "scripting/lua-bindings/manual/CCLuaEngine.h"
|
#include "scripting/lua-bindings/manual/CCLuaEngine.h"
|
||||||
#include "3d/CCBundle3D.h"
|
#include "3d/CCBundle3D.h"
|
||||||
#include "3d/CCSprite3D.h"
|
#include "3d/CCMeshRenderer.h"
|
||||||
#include "3d/CCTerrain.h"
|
#include "3d/CCTerrain.h"
|
||||||
|
|
||||||
int lua_cocos2dx_3d_Sprite3D_getAABB(lua_State* L)
|
int lua_cocos2dx_3d_MeshRenderer_getAABB(lua_State* L)
|
||||||
{
|
{
|
||||||
int argc = 0;
|
int argc = 0;
|
||||||
cocos2d::Sprite3D* cobj = nullptr;
|
cocos2d::MeshRenderer* cobj = nullptr;
|
||||||
|
|
||||||
#if COCOS2D_DEBUG >= 1
|
#if COCOS2D_DEBUG >= 1
|
||||||
tolua_Error tolua_err;
|
tolua_Error tolua_err;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if COCOS2D_DEBUG >= 1
|
#if COCOS2D_DEBUG >= 1
|
||||||
if (!tolua_isusertype(L, 1, "cc.Sprite3D", 0, &tolua_err))
|
if (!tolua_isusertype(L, 1, "cc.MeshRenderer", 0, &tolua_err))
|
||||||
goto tolua_lerror;
|
goto tolua_lerror;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
cobj = (cocos2d::Sprite3D*)tolua_tousertype(L, 1, 0);
|
cobj = (cocos2d::MeshRenderer*)tolua_tousertype(L, 1, 0);
|
||||||
|
|
||||||
#if COCOS2D_DEBUG >= 1
|
#if COCOS2D_DEBUG >= 1
|
||||||
if (!cobj)
|
if (!cobj)
|
||||||
{
|
{
|
||||||
tolua_error(L, "invalid 'cobj' in function 'lua_cocos2dx_3d_Sprite3D_getAABB'", nullptr);
|
tolua_error(L, "invalid 'cobj' in function 'lua_cocos2dx_3d_MeshRenderer_getAABB'", nullptr);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -61,17 +61,17 @@ int lua_cocos2dx_3d_Sprite3D_getAABB(lua_State* L)
|
||||||
object_to_luaval<cocos2d::AABB>(L, "cc.AABB", (cocos2d::AABB*)ret);
|
object_to_luaval<cocos2d::AABB>(L, "cc.AABB", (cocos2d::AABB*)ret);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
luaL_error(L, "%s has wrong number of arguments: %d, was expecting %d \n", "cc.Sprite3D:getAABB", argc, 0);
|
luaL_error(L, "%s has wrong number of arguments: %d, was expecting %d \n", "cc.MeshRenderer:getAABB", argc, 0);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
#if COCOS2D_DEBUG >= 1
|
#if COCOS2D_DEBUG >= 1
|
||||||
tolua_lerror:
|
tolua_lerror:
|
||||||
tolua_error(L, "#ferror in function 'lua_cocos2dx_3d_Sprite3D_getAABB'.", &tolua_err);
|
tolua_error(L, "#ferror in function 'lua_cocos2dx_3d_MeshRenderer_getAABB'.", &tolua_err);
|
||||||
#endif
|
#endif
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int lua_cocos2dx_3d_Sprite3D_createAsync(lua_State* L)
|
int lua_cocos2dx_3d_MeshRenderer_createAsync(lua_State* L)
|
||||||
{
|
{
|
||||||
int argc = 0;
|
int argc = 0;
|
||||||
bool ok = true;
|
bool ok = true;
|
||||||
|
@ -80,7 +80,7 @@ int lua_cocos2dx_3d_Sprite3D_createAsync(lua_State* L)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if COCOS2D_DEBUG >= 1
|
#if COCOS2D_DEBUG >= 1
|
||||||
if (!tolua_isusertable(L, 1, "cc.Sprite3D", 0, &tolua_err))
|
if (!tolua_isusertable(L, 1, "cc.MeshRenderer", 0, &tolua_err))
|
||||||
goto tolua_lerror;
|
goto tolua_lerror;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -91,11 +91,11 @@ int lua_cocos2dx_3d_Sprite3D_createAsync(lua_State* L)
|
||||||
if (argc == 3)
|
if (argc == 3)
|
||||||
{
|
{
|
||||||
std::string modelPath;
|
std::string modelPath;
|
||||||
ok &= luaval_to_std_string(L, 2, &modelPath, "cc.Sprite3D:createAsync");
|
ok &= luaval_to_std_string(L, 2, &modelPath, "cc.MeshRenderer:createAsync");
|
||||||
if (!ok)
|
if (!ok)
|
||||||
break;
|
break;
|
||||||
std::string texturePath;
|
std::string texturePath;
|
||||||
ok &= luaval_to_std_string(L, 3, &texturePath, "cc.Sprite3D:createAsync");
|
ok &= luaval_to_std_string(L, 3, &texturePath, "cc.MeshRenderer:createAsync");
|
||||||
if (!ok)
|
if (!ok)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -107,13 +107,13 @@ int lua_cocos2dx_3d_Sprite3D_createAsync(lua_State* L)
|
||||||
#endif
|
#endif
|
||||||
LUA_FUNCTION handler = toluafix_ref_function(L, 4, 0);
|
LUA_FUNCTION handler = toluafix_ref_function(L, 4, 0);
|
||||||
|
|
||||||
cocos2d::Sprite3D::createAsync(
|
cocos2d::MeshRenderer::createAsync(
|
||||||
modelPath, texturePath,
|
modelPath, texturePath,
|
||||||
[=](cocos2d::Sprite3D* sprite, void* callbackparam) {
|
[=](cocos2d::MeshRenderer* mesh, void* callbackparam) {
|
||||||
auto stack = LuaEngine::getInstance()->getLuaStack();
|
auto stack = LuaEngine::getInstance()->getLuaStack();
|
||||||
int id = (sprite) ? (int)sprite->_ID : -1;
|
int id = (mesh) ? (int)mesh->_ID : -1;
|
||||||
int* luaID = (sprite) ? &sprite->_luaID : nullptr;
|
int* luaID = (mesh) ? &mesh->_luaID : nullptr;
|
||||||
toluafix_pushusertype_ccobject(stack->getLuaState(), id, luaID, (void*)sprite, "cc.Sprite3D");
|
toluafix_pushusertype_ccobject(stack->getLuaState(), id, luaID, (void*)mesh, "cc.MeshRenderer");
|
||||||
stack->executeFunctionByHandler(handler, 1);
|
stack->executeFunctionByHandler(handler, 1);
|
||||||
},
|
},
|
||||||
nullptr);
|
nullptr);
|
||||||
|
@ -128,7 +128,7 @@ int lua_cocos2dx_3d_Sprite3D_createAsync(lua_State* L)
|
||||||
if (argc == 2)
|
if (argc == 2)
|
||||||
{
|
{
|
||||||
std::string modelPath;
|
std::string modelPath;
|
||||||
ok &= luaval_to_std_string(L, 2, &modelPath, "cc.Sprite3D:createAsync");
|
ok &= luaval_to_std_string(L, 2, &modelPath, "cc.MeshRenderer:createAsync");
|
||||||
if (!ok)
|
if (!ok)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -140,13 +140,13 @@ int lua_cocos2dx_3d_Sprite3D_createAsync(lua_State* L)
|
||||||
#endif
|
#endif
|
||||||
LUA_FUNCTION handler = toluafix_ref_function(L, 3, 0);
|
LUA_FUNCTION handler = toluafix_ref_function(L, 3, 0);
|
||||||
|
|
||||||
cocos2d::Sprite3D::createAsync(
|
cocos2d::MeshRenderer::createAsync(
|
||||||
modelPath,
|
modelPath,
|
||||||
[=](cocos2d::Sprite3D* sprite, void* callbackparam) {
|
[=](cocos2d::MeshRenderer* mesh, void* callbackparam) {
|
||||||
auto stack = LuaEngine::getInstance()->getLuaStack();
|
auto stack = LuaEngine::getInstance()->getLuaStack();
|
||||||
int id = (sprite) ? (int)sprite->_ID : -1;
|
int id = (mesh) ? (int)mesh->_ID : -1;
|
||||||
int* luaID = (sprite) ? &sprite->_luaID : nullptr;
|
int* luaID = (mesh) ? &mesh->_luaID : nullptr;
|
||||||
toluafix_pushusertype_ccobject(stack->getLuaState(), id, luaID, (void*)sprite, "cc.Sprite3D");
|
toluafix_pushusertype_ccobject(stack->getLuaState(), id, luaID, (void*)mesh, "cc.MeshRenderer");
|
||||||
stack->executeFunctionByHandler(handler, 1);
|
stack->executeFunctionByHandler(handler, 1);
|
||||||
},
|
},
|
||||||
nullptr);
|
nullptr);
|
||||||
|
@ -156,23 +156,23 @@ int lua_cocos2dx_3d_Sprite3D_createAsync(lua_State* L)
|
||||||
}
|
}
|
||||||
} while (0);
|
} while (0);
|
||||||
ok = true;
|
ok = true;
|
||||||
luaL_error(L, "%s has wrong number of arguments: %d, was expecting %d", "cc.Sprite3D:createAsync", argc, 3);
|
luaL_error(L, "%s has wrong number of arguments: %d, was expecting %d", "cc.MeshRenderer:createAsync", argc, 3);
|
||||||
return 0;
|
return 0;
|
||||||
#if COCOS2D_DEBUG >= 1
|
#if COCOS2D_DEBUG >= 1
|
||||||
tolua_lerror:
|
tolua_lerror:
|
||||||
tolua_error(L, "#ferror in function 'lua_cocos2dx_3d_Sprite3D_createAsync'.", &tolua_err);
|
tolua_error(L, "#ferror in function 'lua_cocos2dx_3d_MeshRenderer_createAsync'.", &tolua_err);
|
||||||
#endif
|
#endif
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void extendSprite3D(lua_State* L)
|
static void extendMeshRenderer(lua_State* L)
|
||||||
{
|
{
|
||||||
lua_pushstring(L, "cc.Sprite3D");
|
lua_pushstring(L, "cc.MeshRenderer");
|
||||||
lua_rawget(L, LUA_REGISTRYINDEX);
|
lua_rawget(L, LUA_REGISTRYINDEX);
|
||||||
if (lua_istable(L, -1))
|
if (lua_istable(L, -1))
|
||||||
{
|
{
|
||||||
tolua_function(L, "getAABB", lua_cocos2dx_3d_Sprite3D_getAABB);
|
tolua_function(L, "getAABB", lua_cocos2dx_3d_MeshRenderer_getAABB);
|
||||||
tolua_function(L, "createAsync", lua_cocos2dx_3d_Sprite3D_createAsync);
|
tolua_function(L, "createAsync", lua_cocos2dx_3d_MeshRenderer_createAsync);
|
||||||
}
|
}
|
||||||
lua_pop(L, 1);
|
lua_pop(L, 1);
|
||||||
}
|
}
|
||||||
|
@ -656,7 +656,7 @@ static int register_all_cocos2dx_3d_manual(lua_State* L)
|
||||||
if (nullptr == L)
|
if (nullptr == L)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
extendSprite3D(L);
|
extendMeshRenderer(L);
|
||||||
extendTerrain(L);
|
extendTerrain(L);
|
||||||
extendBundle3D(L);
|
extendBundle3D(L);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -186,7 +186,7 @@ void Physics3DWorld_HitResult_to_luaval(lua_State* L, const cocos2d::Physics3DWo
|
||||||
lua_rawset(L, -3);
|
lua_rawset(L, -3);
|
||||||
}
|
}
|
||||||
|
|
||||||
int lua_cocos2dx_physics3d_PhysicsSprite3D_create(lua_State* L)
|
int lua_cocos2dx_physics3d_PhysicsMeshRenderer_create(lua_State* L)
|
||||||
{
|
{
|
||||||
int argc = 0;
|
int argc = 0;
|
||||||
bool ok = true;
|
bool ok = true;
|
||||||
|
@ -196,7 +196,7 @@ int lua_cocos2dx_physics3d_PhysicsSprite3D_create(lua_State* L)
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
# if COCOS2D_DEBUG >= 1
|
# if COCOS2D_DEBUG >= 1
|
||||||
if (!tolua_isusertable(L, 1, "cc.PhysicsSprite3D", 0, &tolua_err))
|
if (!tolua_isusertable(L, 1, "cc.PhysicsMeshRenderer", 0, &tolua_err))
|
||||||
goto tolua_lerror;
|
goto tolua_lerror;
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
|
@ -206,15 +206,15 @@ int lua_cocos2dx_physics3d_PhysicsSprite3D_create(lua_State* L)
|
||||||
{
|
{
|
||||||
std::string arg0;
|
std::string arg0;
|
||||||
cocos2d::Physics3DRigidBodyDes arg1;
|
cocos2d::Physics3DRigidBodyDes arg1;
|
||||||
ok &= luaval_to_std_string(L, 2, &arg0, "cc.PhysicsSprite3D:create");
|
ok &= luaval_to_std_string(L, 2, &arg0, "cc.PhysicsMeshRenderer:create");
|
||||||
ok &= luaval_to_Physics3DRigidBodyDes(L, 3, &arg1, "cc.PhysicsSprite3D:create");
|
ok &= luaval_to_Physics3DRigidBodyDes(L, 3, &arg1, "cc.PhysicsMeshRenderer:create");
|
||||||
if (!ok)
|
if (!ok)
|
||||||
{
|
{
|
||||||
tolua_error(L, "invalid arguments in function 'lua_cocos2dx_physics3d_PhysicsSprite3D_create'", nullptr);
|
tolua_error(L, "invalid arguments in function 'lua_cocos2dx_physics3d_PhysicsMeshRenderer_create'", nullptr);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
cocos2d::PhysicsSprite3D* ret = cocos2d::PhysicsSprite3D::create(arg0, &arg1);
|
cocos2d::PhysicsMeshRenderer* ret = cocos2d::PhysicsMeshRenderer::create(arg0, &arg1);
|
||||||
object_to_luaval<cocos2d::PhysicsSprite3D>(L, "cc.PhysicsSprite3D", (cocos2d::PhysicsSprite3D*)ret);
|
object_to_luaval<cocos2d::PhysicsMeshRenderer>(L, "cc.PhysicsMeshRenderer", (cocos2d::PhysicsMeshRenderer*)ret);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
if (argc == 3)
|
if (argc == 3)
|
||||||
|
@ -222,16 +222,16 @@ int lua_cocos2dx_physics3d_PhysicsSprite3D_create(lua_State* L)
|
||||||
std::string arg0;
|
std::string arg0;
|
||||||
cocos2d::Physics3DRigidBodyDes arg1;
|
cocos2d::Physics3DRigidBodyDes arg1;
|
||||||
cocos2d::Vec3 arg2;
|
cocos2d::Vec3 arg2;
|
||||||
ok &= luaval_to_std_string(L, 2, &arg0, "cc.PhysicsSprite3D:create");
|
ok &= luaval_to_std_string(L, 2, &arg0, "cc.PhysicsMeshRenderer:create");
|
||||||
ok &= luaval_to_Physics3DRigidBodyDes(L, 3, &arg1, "cc.PhysicsSprite3D:create");
|
ok &= luaval_to_Physics3DRigidBodyDes(L, 3, &arg1, "cc.PhysicsMeshRenderer:create");
|
||||||
ok &= luaval_to_vec3(L, 4, &arg2, "cc.PhysicsSprite3D:create");
|
ok &= luaval_to_vec3(L, 4, &arg2, "cc.PhysicsMeshRenderer:create");
|
||||||
if (!ok)
|
if (!ok)
|
||||||
{
|
{
|
||||||
tolua_error(L, "invalid arguments in function 'lua_cocos2dx_physics3d_PhysicsSprite3D_create'", nullptr);
|
tolua_error(L, "invalid arguments in function 'lua_cocos2dx_physics3d_PhysicsMeshRenderer_create'", nullptr);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
cocos2d::PhysicsSprite3D* ret = cocos2d::PhysicsSprite3D::create(arg0, &arg1, arg2);
|
cocos2d::PhysicsMeshRenderer* ret = cocos2d::PhysicsMeshRenderer::create(arg0, &arg1, arg2);
|
||||||
object_to_luaval<cocos2d::PhysicsSprite3D>(L, "cc.PhysicsSprite3D", (cocos2d::PhysicsSprite3D*)ret);
|
object_to_luaval<cocos2d::PhysicsMeshRenderer>(L, "cc.PhysicsMeshRenderer", (cocos2d::PhysicsMeshRenderer*)ret);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
if (argc == 4)
|
if (argc == 4)
|
||||||
|
@ -240,35 +240,35 @@ int lua_cocos2dx_physics3d_PhysicsSprite3D_create(lua_State* L)
|
||||||
cocos2d::Physics3DRigidBodyDes arg1;
|
cocos2d::Physics3DRigidBodyDes arg1;
|
||||||
cocos2d::Vec3 arg2;
|
cocos2d::Vec3 arg2;
|
||||||
cocos2d::Quaternion arg3;
|
cocos2d::Quaternion arg3;
|
||||||
ok &= luaval_to_std_string(L, 2, &arg0, "cc.PhysicsSprite3D:create");
|
ok &= luaval_to_std_string(L, 2, &arg0, "cc.PhysicsMeshRenderer:create");
|
||||||
ok &= luaval_to_Physics3DRigidBodyDes(L, 3, &arg1, "cc.PhysicsSprite3D:create");
|
ok &= luaval_to_Physics3DRigidBodyDes(L, 3, &arg1, "cc.PhysicsMeshRenderer:create");
|
||||||
ok &= luaval_to_vec3(L, 4, &arg2, "cc.PhysicsSprite3D:create");
|
ok &= luaval_to_vec3(L, 4, &arg2, "cc.PhysicsMeshRenderer:create");
|
||||||
ok &= luaval_to_quaternion(L, 5, &arg3);
|
ok &= luaval_to_quaternion(L, 5, &arg3);
|
||||||
if (!ok)
|
if (!ok)
|
||||||
{
|
{
|
||||||
tolua_error(L, "invalid arguments in function 'lua_cocos2dx_physics3d_PhysicsSprite3D_create'", nullptr);
|
tolua_error(L, "invalid arguments in function 'lua_cocos2dx_physics3d_PhysicsMeshRenderer_create'", nullptr);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
cocos2d::PhysicsSprite3D* ret = cocos2d::PhysicsSprite3D::create(arg0, &arg1, arg2, arg3);
|
cocos2d::PhysicsMeshRenderer* ret = cocos2d::PhysicsMeshRenderer::create(arg0, &arg1, arg2, arg3);
|
||||||
object_to_luaval<cocos2d::PhysicsSprite3D>(L, "cc.PhysicsSprite3D", (cocos2d::PhysicsSprite3D*)ret);
|
object_to_luaval<cocos2d::PhysicsMeshRenderer>(L, "cc.PhysicsMeshRenderer", (cocos2d::PhysicsMeshRenderer*)ret);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
luaL_error(L, "%s has wrong number of arguments: %d, was expecting %d\n ", "cc.PhysicsSprite3D:create", argc, 2);
|
luaL_error(L, "%s has wrong number of arguments: %d, was expecting %d\n ", "cc.PhysicsMeshRenderer:create", argc, 2);
|
||||||
return 0;
|
return 0;
|
||||||
# if COCOS2D_DEBUG >= 1
|
# if COCOS2D_DEBUG >= 1
|
||||||
tolua_lerror:
|
tolua_lerror:
|
||||||
tolua_error(L, "#ferror in function 'lua_cocos2dx_physics3d_PhysicsSprite3D_create'.", &tolua_err);
|
tolua_error(L, "#ferror in function 'lua_cocos2dx_physics3d_PhysicsMeshRenderer_create'.", &tolua_err);
|
||||||
# endif
|
# endif
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void extendPhysicsSprite3D(lua_State* L)
|
void extendPhysicsMeshRenderer(lua_State* L)
|
||||||
{
|
{
|
||||||
lua_pushstring(L, "cc.PhysicsSprite3D");
|
lua_pushstring(L, "cc.PhysicsMeshRenderer");
|
||||||
lua_rawget(L, LUA_REGISTRYINDEX);
|
lua_rawget(L, LUA_REGISTRYINDEX);
|
||||||
if (lua_istable(L, -1))
|
if (lua_istable(L, -1))
|
||||||
{
|
{
|
||||||
tolua_function(L, "create", lua_cocos2dx_physics3d_PhysicsSprite3D_create);
|
tolua_function(L, "create", lua_cocos2dx_physics3d_PhysicsMeshRenderer_create);
|
||||||
}
|
}
|
||||||
lua_pop(L, 1);
|
lua_pop(L, 1);
|
||||||
}
|
}
|
||||||
|
@ -847,7 +847,7 @@ int register_all_physics3d_manual(lua_State* L)
|
||||||
if (nullptr == L)
|
if (nullptr == L)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
extendPhysicsSprite3D(L);
|
extendPhysicsMeshRenderer(L);
|
||||||
extendPhysics3DRigidBody(L);
|
extendPhysics3DRigidBody(L);
|
||||||
extendPhysics3DComponent(L);
|
extendPhysics3DComponent(L);
|
||||||
extendPhysics3DWorld(L);
|
extendPhysics3DWorld(L);
|
||||||
|
|
|
@ -160,8 +160,8 @@ list(APPEND GAME_HEADER
|
||||||
Classes/ExtensionsTest/ExtensionsTest.h
|
Classes/ExtensionsTest/ExtensionsTest.h
|
||||||
Classes/ExtensionsTest/TableViewTest/CustomTableViewCell.h
|
Classes/ExtensionsTest/TableViewTest/CustomTableViewCell.h
|
||||||
Classes/ExtensionsTest/TableViewTest/TableViewTestScene.h
|
Classes/ExtensionsTest/TableViewTest/TableViewTestScene.h
|
||||||
Classes/Sprite3DTest/Sprite3DTest.h
|
Classes/MeshRendererTest/MeshRendererTest.h
|
||||||
Classes/Sprite3DTest/DrawNode3D.h
|
Classes/MeshRendererTest/DrawNode3D.h
|
||||||
Classes/BaseTest.h
|
Classes/BaseTest.h
|
||||||
Classes/SceneTest/SceneTest.h
|
Classes/SceneTest/SceneTest.h
|
||||||
Classes/ReleasePoolTest/ReleasePoolTest.h
|
Classes/ReleasePoolTest/ReleasePoolTest.h
|
||||||
|
@ -296,8 +296,8 @@ list(APPEND GAME_SOURCE
|
||||||
Classes/ShaderTest/ShaderTest2.cpp
|
Classes/ShaderTest/ShaderTest2.cpp
|
||||||
Classes/SpineTest/SpineTest.cpp
|
Classes/SpineTest/SpineTest.cpp
|
||||||
# Classes/Scene3DTest/Scene3DTest.cpp
|
# Classes/Scene3DTest/Scene3DTest.cpp
|
||||||
Classes/Sprite3DTest/DrawNode3D.cpp
|
Classes/MeshRendererTest/DrawNode3D.cpp
|
||||||
Classes/Sprite3DTest/Sprite3DTest.cpp
|
Classes/MeshRendererTest/MeshRendererTest.cpp
|
||||||
Classes/SpritePolygonTest/SpritePolygonTest.cpp
|
Classes/SpritePolygonTest/SpritePolygonTest.cpp
|
||||||
Classes/SpriteTest/SpriteTest.cpp
|
Classes/SpriteTest/SpriteTest.cpp
|
||||||
Classes/TerrainTest/TerrainTest.cpp
|
Classes/TerrainTest/TerrainTest.cpp
|
||||||
|
|
|
@ -85,7 +85,12 @@ bool AppDelegate::applicationDidFinishLaunching()
|
||||||
}
|
}
|
||||||
|
|
||||||
director->setStatsDisplay(true);
|
director->setStatsDisplay(true);
|
||||||
|
|
||||||
|
#ifdef CC_PLATFORM_PC
|
||||||
|
director->setAnimationInterval(1.0f / glfwGetVideoMode(glfwGetPrimaryMonitor())->refreshRate);
|
||||||
|
#else
|
||||||
director->setAnimationInterval(1.0f / 60);
|
director->setAnimationInterval(1.0f / 60);
|
||||||
|
#endif
|
||||||
|
|
||||||
auto screenSize = glview->getFrameSize();
|
auto screenSize = glview->getFrameSize();
|
||||||
|
|
||||||
|
|
|
@ -47,11 +47,11 @@ BillBoardTests::BillBoardTests()
|
||||||
//------------------------------------------------------------------
|
//------------------------------------------------------------------
|
||||||
BillBoardRotationTest::BillBoardRotationTest()
|
BillBoardRotationTest::BillBoardRotationTest()
|
||||||
{
|
{
|
||||||
auto root = Sprite3D::create();
|
auto root = MeshRenderer::create();
|
||||||
root->setPositionNormalized(Vec2(0.5f, 0.25f));
|
root->setPositionNormalized(Vec2(0.5f, 0.25f));
|
||||||
addChild(root);
|
addChild(root);
|
||||||
|
|
||||||
auto model = Sprite3D::create("Sprite3DTest/orc.c3b");
|
auto model = MeshRenderer::create("MeshRendererTest/orc.c3b");
|
||||||
model->setScale(5);
|
model->setScale(5);
|
||||||
model->setRotation3D(Vec3(0.0f, 180.0f, 0.0f));
|
model->setRotation3D(Vec3(0.0f, 180.0f, 0.0f));
|
||||||
root->addChild(model);
|
root->addChild(model);
|
||||||
|
@ -150,11 +150,11 @@ BillBoardTest::BillBoardTest() : _camera(nullptr)
|
||||||
_billboards.push_back(billboard);
|
_billboards.push_back(billboard);
|
||||||
_billboards.push_back(billboard2);
|
_billboards.push_back(billboard2);
|
||||||
|
|
||||||
auto sprite3d = Sprite3D::create("Sprite3DTest/orc.c3t");
|
auto mesh = MeshRenderer::create("MeshRendererTest/orc.c3t");
|
||||||
sprite3d->setScale(2.0f);
|
mesh->setScale(2.0f);
|
||||||
sprite3d->addChild(billboard);
|
mesh->addChild(billboard);
|
||||||
sprite3d->runAction(RepeatForever::create(RotateBy::create(10.0f, Vec3(0.0f, 360.0f, 0.0f))));
|
mesh->runAction(RepeatForever::create(RotateBy::create(10.0f, Vec3(0.0f, 360.0f, 0.0f))));
|
||||||
_layerBillBoard->addChild(sprite3d);
|
_layerBillBoard->addChild(mesh);
|
||||||
}
|
}
|
||||||
|
|
||||||
addNewBillBoardWithCoords(Vec3(20.0f, 5.0f, 0.0f));
|
addNewBillBoardWithCoords(Vec3(20.0f, 5.0f, 0.0f));
|
||||||
|
|
|
@ -40,15 +40,15 @@ bool Bug15594Layer::init()
|
||||||
{
|
{
|
||||||
if (BugsTestBase::init())
|
if (BugsTestBase::init())
|
||||||
{
|
{
|
||||||
auto sprite3d = Sprite3D::create("Images/bugs/bug15594.c3t", "Images/bugs/bug15594.jpg");
|
auto mesh = MeshRenderer::create("Images/bugs/bug15594.c3t", "Images/bugs/bug15594.jpg");
|
||||||
addChild(sprite3d);
|
addChild(mesh);
|
||||||
auto size = Director::getInstance()->getWinSize();
|
auto size = Director::getInstance()->getWinSize();
|
||||||
sprite3d->setPosition(size / 2);
|
mesh->setPosition(size / 2);
|
||||||
|
|
||||||
auto animation = Animation3D::create("Images/bugs/bug15594.c3t");
|
auto animation = Animation3D::create("Images/bugs/bug15594.c3t");
|
||||||
auto animate = Animate3D::create(animation);
|
auto animate = Animate3D::create(animation);
|
||||||
auto repeat = RepeatForever::create(animate);
|
auto repeat = RepeatForever::create(animate);
|
||||||
sprite3d->runAction(repeat);
|
mesh->runAction(repeat);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -77,14 +77,14 @@ CameraRotationTest::CameraRotationTest()
|
||||||
_camNode->setPositionZ(Camera::getDefaultCamera()->getPosition3D().z);
|
_camNode->setPositionZ(Camera::getDefaultCamera()->getPosition3D().z);
|
||||||
_camControlNode->addChild(_camNode);
|
_camControlNode->addChild(_camNode);
|
||||||
|
|
||||||
auto sp3d = Sprite3D::create();
|
auto mesh = MeshRenderer::create();
|
||||||
sp3d->setPosition(s.width / 2, s.height / 2);
|
mesh->setPosition(s.width / 2, s.height / 2);
|
||||||
addChild(sp3d);
|
addChild(mesh);
|
||||||
|
|
||||||
auto lship = Label::create();
|
auto lship = Label::create();
|
||||||
lship->setString("Ship");
|
lship->setString("Ship");
|
||||||
lship->setPosition(0, 20);
|
lship->setPosition(0, 20);
|
||||||
sp3d->addChild(lship);
|
mesh->addChild(lship);
|
||||||
|
|
||||||
// Billboards
|
// Billboards
|
||||||
// Yellow is at the back
|
// Yellow is at the back
|
||||||
|
@ -92,7 +92,7 @@ CameraRotationTest::CameraRotationTest()
|
||||||
bill1->setPosition3D(Vec3(50.0f, 10.0f, -10.0f));
|
bill1->setPosition3D(Vec3(50.0f, 10.0f, -10.0f));
|
||||||
bill1->setColor(Color3B::YELLOW);
|
bill1->setColor(Color3B::YELLOW);
|
||||||
bill1->setScale(0.6f);
|
bill1->setScale(0.6f);
|
||||||
sp3d->addChild(bill1);
|
mesh->addChild(bill1);
|
||||||
|
|
||||||
l1 = Label::create();
|
l1 = Label::create();
|
||||||
l1->setPosition(Vec2(0.0f, -10.0f));
|
l1->setPosition(Vec2(0.0f, -10.0f));
|
||||||
|
@ -108,7 +108,7 @@ CameraRotationTest::CameraRotationTest()
|
||||||
bill2 = BillBoard::create("Images/Icon.png");
|
bill2 = BillBoard::create("Images/Icon.png");
|
||||||
bill2->setPosition3D(Vec3(-50.0f, -10.0f, 10.0f));
|
bill2->setPosition3D(Vec3(-50.0f, -10.0f, 10.0f));
|
||||||
bill2->setScale(0.6f);
|
bill2->setScale(0.6f);
|
||||||
sp3d->addChild(bill2);
|
mesh->addChild(bill2);
|
||||||
|
|
||||||
l2 = Label::create();
|
l2 = Label::create();
|
||||||
l2->setString("Billboard2");
|
l2->setString("Billboard2");
|
||||||
|
@ -122,9 +122,9 @@ CameraRotationTest::CameraRotationTest()
|
||||||
bill2->addChild(p2);
|
bill2->addChild(p2);
|
||||||
|
|
||||||
// 3D models
|
// 3D models
|
||||||
auto model = Sprite3D::create("Sprite3DTest/boss1.obj");
|
auto model = MeshRenderer::create("MeshRendererTest/boss1.obj");
|
||||||
model->setScale(4);
|
model->setScale(4);
|
||||||
model->setTexture("Sprite3DTest/boss.png");
|
model->setTexture("MeshRendererTest/boss.png");
|
||||||
model->setPosition3D(Vec3(s.width / 2, s.height / 2, 0));
|
model->setPosition3D(Vec3(s.width / 2, s.height / 2, 0));
|
||||||
addChild(model);
|
addChild(model);
|
||||||
|
|
||||||
|
@ -226,8 +226,8 @@ void Camera3DTestDemo::SwitchViewCallback(Ref* sender, CameraType cameraType)
|
||||||
_cameraType = cameraType;
|
_cameraType = cameraType;
|
||||||
if (_cameraType == CameraType::Free)
|
if (_cameraType == CameraType::Free)
|
||||||
{
|
{
|
||||||
_camera->setPosition3D(Vec3(0, 130, 130) + _sprite3D->getPosition3D());
|
_camera->setPosition3D(Vec3(0, 130, 130) + _mesh->getPosition3D());
|
||||||
_camera->lookAt(_sprite3D->getPosition3D());
|
_camera->lookAt(_mesh->getPosition3D());
|
||||||
|
|
||||||
_RotateRightlabel->setColor(Color3B::WHITE);
|
_RotateRightlabel->setColor(Color3B::WHITE);
|
||||||
_RotateLeftlabel->setColor(Color3B::WHITE);
|
_RotateLeftlabel->setColor(Color3B::WHITE);
|
||||||
|
@ -237,10 +237,10 @@ void Camera3DTestDemo::SwitchViewCallback(Ref* sender, CameraType cameraType)
|
||||||
else if (_cameraType == CameraType::FirstPerson)
|
else if (_cameraType == CameraType::FirstPerson)
|
||||||
{
|
{
|
||||||
Vec3 newFaceDir;
|
Vec3 newFaceDir;
|
||||||
_sprite3D->getWorldToNodeTransform().getForwardVector(&newFaceDir);
|
_mesh->getWorldToNodeTransform().getForwardVector(&newFaceDir);
|
||||||
newFaceDir.normalize();
|
newFaceDir.normalize();
|
||||||
_camera->setPosition3D(Vec3(0, 35, 0) + _sprite3D->getPosition3D());
|
_camera->setPosition3D(Vec3(0, 35, 0) + _mesh->getPosition3D());
|
||||||
_camera->lookAt(_sprite3D->getPosition3D() + newFaceDir * 50);
|
_camera->lookAt(_mesh->getPosition3D() + newFaceDir * 50);
|
||||||
|
|
||||||
_RotateRightlabel->setColor(Color3B::WHITE);
|
_RotateRightlabel->setColor(Color3B::WHITE);
|
||||||
_RotateLeftlabel->setColor(Color3B::WHITE);
|
_RotateLeftlabel->setColor(Color3B::WHITE);
|
||||||
|
@ -249,8 +249,8 @@ void Camera3DTestDemo::SwitchViewCallback(Ref* sender, CameraType cameraType)
|
||||||
}
|
}
|
||||||
else if (_cameraType == CameraType::ThirdPerson)
|
else if (_cameraType == CameraType::ThirdPerson)
|
||||||
{
|
{
|
||||||
_camera->setPosition3D(Vec3(0, 130, 130) + _sprite3D->getPosition3D());
|
_camera->setPosition3D(Vec3(0, 130, 130) + _mesh->getPosition3D());
|
||||||
_camera->lookAt(_sprite3D->getPosition3D());
|
_camera->lookAt(_mesh->getPosition3D());
|
||||||
|
|
||||||
_RotateRightlabel->setColor(Color3B::GRAY);
|
_RotateRightlabel->setColor(Color3B::GRAY);
|
||||||
_RotateLeftlabel->setColor(Color3B::GRAY);
|
_RotateLeftlabel->setColor(Color3B::GRAY);
|
||||||
|
@ -261,7 +261,7 @@ void Camera3DTestDemo::SwitchViewCallback(Ref* sender, CameraType cameraType)
|
||||||
void Camera3DTestDemo::onEnter()
|
void Camera3DTestDemo::onEnter()
|
||||||
{
|
{
|
||||||
CameraBaseTest::onEnter();
|
CameraBaseTest::onEnter();
|
||||||
_sprite3D = nullptr;
|
_mesh = nullptr;
|
||||||
auto s = Director::getInstance()->getWinSize();
|
auto s = Director::getInstance()->getWinSize();
|
||||||
auto listener = EventListenerTouchAllAtOnce::create();
|
auto listener = EventListenerTouchAllAtOnce::create();
|
||||||
listener->onTouchesBegan = CC_CALLBACK_2(Camera3DTestDemo::onTouchesBegan, this);
|
listener->onTouchesBegan = CC_CALLBACK_2(Camera3DTestDemo::onTouchesBegan, this);
|
||||||
|
@ -272,7 +272,7 @@ void Camera3DTestDemo::onEnter()
|
||||||
addChild(layer3D, 0);
|
addChild(layer3D, 0);
|
||||||
_layer3D = layer3D;
|
_layer3D = layer3D;
|
||||||
_curState = State_None;
|
_curState = State_None;
|
||||||
addNewSpriteWithCoords(Vec3(0, 0, 0), "Sprite3DTest/girl.c3b", true, 0.2f, true);
|
addNewSpriteWithCoords(Vec3(0, 0, 0), "MeshRendererTest/girl.c3b", true, 0.2f, true);
|
||||||
TTFConfig ttfConfig("fonts/arial.ttf", 20);
|
TTFConfig ttfConfig("fonts/arial.ttf", 20);
|
||||||
|
|
||||||
auto containerForLabel1 = Node::create();
|
auto containerForLabel1 = Node::create();
|
||||||
|
@ -389,25 +389,25 @@ void Camera3DTestDemo::addNewSpriteWithCoords(Vec3 p,
|
||||||
float scale,
|
float scale,
|
||||||
bool bindCamera)
|
bool bindCamera)
|
||||||
{
|
{
|
||||||
auto sprite = Sprite3D::create(fileName);
|
auto mesh = MeshRenderer::create(fileName);
|
||||||
_layer3D->addChild(sprite);
|
_layer3D->addChild(mesh);
|
||||||
float globalZOrder = sprite->getGlobalZOrder();
|
float globalZOrder = mesh->getGlobalZOrder();
|
||||||
sprite->setPosition3D(Vec3(p.x, p.y, p.z));
|
mesh->setPosition3D(Vec3(p.x, p.y, p.z));
|
||||||
sprite->setGlobalZOrder(globalZOrder);
|
mesh->setGlobalZOrder(globalZOrder);
|
||||||
if (playAnimation)
|
if (playAnimation)
|
||||||
{
|
{
|
||||||
auto animation = Animation3D::create(fileName, "Take 001");
|
auto animation = Animation3D::create(fileName, "Take 001");
|
||||||
if (animation)
|
if (animation)
|
||||||
{
|
{
|
||||||
auto animate = Animate3D::create(animation);
|
auto animate = Animate3D::create(animation);
|
||||||
sprite->runAction(RepeatForever::create(animate));
|
mesh->runAction(RepeatForever::create(animate));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (bindCamera)
|
if (bindCamera)
|
||||||
{
|
{
|
||||||
_sprite3D = sprite;
|
_mesh = mesh;
|
||||||
}
|
}
|
||||||
sprite->setScale(scale);
|
mesh->setScale(scale);
|
||||||
}
|
}
|
||||||
void Camera3DTestDemo::onTouchesBegan(const std::vector<Touch*>& touches, cocos2d::Event* event) {}
|
void Camera3DTestDemo::onTouchesBegan(const std::vector<Touch*>& touches, cocos2d::Event* event) {}
|
||||||
void Camera3DTestDemo::onTouchesMoved(const std::vector<Touch*>& touches, cocos2d::Event* event)
|
void Camera3DTestDemo::onTouchesMoved(const std::vector<Touch*>& touches, cocos2d::Event* event)
|
||||||
|
@ -431,25 +431,25 @@ void Camera3DTestDemo::onTouchesMoved(const std::vector<Touch*>& touches, cocos2
|
||||||
cameraPos += cameraDir * newPos.y * 0.1f;
|
cameraPos += cameraDir * newPos.y * 0.1f;
|
||||||
cameraPos += cameraRightDir * newPos.x * 0.1f;
|
cameraPos += cameraRightDir * newPos.x * 0.1f;
|
||||||
_camera->setPosition3D(cameraPos);
|
_camera->setPosition3D(cameraPos);
|
||||||
if (_sprite3D && _cameraType == CameraType::FirstPerson)
|
if (_mesh && _cameraType == CameraType::FirstPerson)
|
||||||
{
|
{
|
||||||
_sprite3D->setPosition3D(Vec3(_camera->getPositionX(), 0, _camera->getPositionZ()));
|
_mesh->setPosition3D(Vec3(_camera->getPositionX(), 0, _camera->getPositionZ()));
|
||||||
_targetPos = _sprite3D->getPosition3D();
|
_targetPos = _mesh->getPosition3D();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
void Camera3DTestDemo::move3D(float elapsedTime)
|
void Camera3DTestDemo::move3D(float elapsedTime)
|
||||||
{
|
{
|
||||||
if (_sprite3D)
|
if (_mesh)
|
||||||
{
|
{
|
||||||
Vec3 curPos = _sprite3D->getPosition3D();
|
Vec3 curPos = _mesh->getPosition3D();
|
||||||
Vec3 newFaceDir = _targetPos - curPos;
|
Vec3 newFaceDir = _targetPos - curPos;
|
||||||
newFaceDir.y = 0.0f;
|
newFaceDir.y = 0.0f;
|
||||||
newFaceDir.normalize();
|
newFaceDir.normalize();
|
||||||
Vec3 offset = newFaceDir * 25.0f * elapsedTime;
|
Vec3 offset = newFaceDir * 25.0f * elapsedTime;
|
||||||
curPos += offset;
|
curPos += offset;
|
||||||
_sprite3D->setPosition3D(curPos);
|
_mesh->setPosition3D(curPos);
|
||||||
if (_cameraType == CameraType::ThirdPerson)
|
if (_cameraType == CameraType::ThirdPerson)
|
||||||
{
|
{
|
||||||
Vec3 cameraPos = _camera->getPosition3D();
|
Vec3 cameraPos = _camera->getPosition3D();
|
||||||
|
@ -461,11 +461,11 @@ void Camera3DTestDemo::move3D(float elapsedTime)
|
||||||
}
|
}
|
||||||
void Camera3DTestDemo::updateState(float elapsedTime)
|
void Camera3DTestDemo::updateState(float elapsedTime)
|
||||||
{
|
{
|
||||||
if (_sprite3D)
|
if (_mesh)
|
||||||
{
|
{
|
||||||
Vec3 curPos = _sprite3D->getPosition3D();
|
Vec3 curPos = _mesh->getPosition3D();
|
||||||
Vec3 curFaceDir;
|
Vec3 curFaceDir;
|
||||||
_sprite3D->getNodeToWorldTransform().getForwardVector(&curFaceDir);
|
_mesh->getNodeToWorldTransform().getForwardVector(&curFaceDir);
|
||||||
curFaceDir = -curFaceDir;
|
curFaceDir = -curFaceDir;
|
||||||
curFaceDir.normalize();
|
curFaceDir.normalize();
|
||||||
Vec3 newFaceDir = _targetPos - curPos;
|
Vec3 newFaceDir = _targetPos - curPos;
|
||||||
|
@ -497,7 +497,7 @@ void Camera3DTestDemo::onTouchesEnded(const std::vector<Touch*>& touches, cocos2
|
||||||
auto location = touch->getLocationInView();
|
auto location = touch->getLocationInView();
|
||||||
if (_camera)
|
if (_camera)
|
||||||
{
|
{
|
||||||
if (_sprite3D && _cameraType == CameraType::ThirdPerson && _bZoomOut == false && _bZoomIn == false &&
|
if (_mesh && _cameraType == CameraType::ThirdPerson && _bZoomOut == false && _bZoomIn == false &&
|
||||||
_bRotateLeft == false && _bRotateRight == false)
|
_bRotateLeft == false && _bRotateRight == false)
|
||||||
{
|
{
|
||||||
Vec3 nearP(location.x, location.y, -1.0f), farP(location.x, location.y, 1.0f);
|
Vec3 nearP(location.x, location.y, -1.0f), farP(location.x, location.y, 1.0f);
|
||||||
|
@ -531,7 +531,7 @@ void Camera3DTestDemo::onTouchesEnded(const std::vector<Touch*>& touches, cocos2
|
||||||
void onTouchesCancelled(const std::vector<Touch*>& touches, cocos2d::Event* event) {}
|
void onTouchesCancelled(const std::vector<Touch*>& touches, cocos2d::Event* event) {}
|
||||||
void Camera3DTestDemo::updateCamera(float fDelta)
|
void Camera3DTestDemo::updateCamera(float fDelta)
|
||||||
{
|
{
|
||||||
if (_sprite3D)
|
if (_mesh)
|
||||||
{
|
{
|
||||||
if (_cameraType == CameraType::ThirdPerson)
|
if (_cameraType == CameraType::ThirdPerson)
|
||||||
{
|
{
|
||||||
|
@ -541,13 +541,13 @@ void Camera3DTestDemo::updateCamera(float fDelta)
|
||||||
move3D(fDelta);
|
move3D(fDelta);
|
||||||
if (isState(_curState, State_Rotate))
|
if (isState(_curState, State_Rotate))
|
||||||
{
|
{
|
||||||
Vec3 curPos = _sprite3D->getPosition3D();
|
Vec3 curPos = _mesh->getPosition3D();
|
||||||
|
|
||||||
Vec3 newFaceDir = _targetPos - curPos;
|
Vec3 newFaceDir = _targetPos - curPos;
|
||||||
newFaceDir.y = 0;
|
newFaceDir.y = 0;
|
||||||
newFaceDir.normalize();
|
newFaceDir.normalize();
|
||||||
Vec3 up;
|
Vec3 up;
|
||||||
_sprite3D->getNodeToWorldTransform().getUpVector(&up);
|
_mesh->getNodeToWorldTransform().getUpVector(&up);
|
||||||
up.normalize();
|
up.normalize();
|
||||||
Vec3 right;
|
Vec3 right;
|
||||||
Vec3::cross(-newFaceDir, up, &right);
|
Vec3::cross(-newFaceDir, up, &right);
|
||||||
|
@ -573,7 +573,7 @@ void Camera3DTestDemo::updateCamera(float fDelta)
|
||||||
mat.m[13] = pos.y;
|
mat.m[13] = pos.y;
|
||||||
mat.m[14] = pos.z;
|
mat.m[14] = pos.z;
|
||||||
mat.m[15] = 1.0f;
|
mat.m[15] = 1.0f;
|
||||||
_sprite3D->setAdditionalTransform(&mat);
|
_mesh->setAdditionalTransform(&mat);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -583,7 +583,7 @@ void Camera3DTestDemo::updateCamera(float fDelta)
|
||||||
{
|
{
|
||||||
if (_cameraType == CameraType::ThirdPerson)
|
if (_cameraType == CameraType::ThirdPerson)
|
||||||
{
|
{
|
||||||
Vec3 lookDir = _camera->getPosition3D() - _sprite3D->getPosition3D();
|
Vec3 lookDir = _camera->getPosition3D() - _mesh->getPosition3D();
|
||||||
Vec3 cameraPos = _camera->getPosition3D();
|
Vec3 cameraPos = _camera->getPosition3D();
|
||||||
if (lookDir.length() <= 300)
|
if (lookDir.length() <= 300)
|
||||||
{
|
{
|
||||||
|
@ -608,7 +608,7 @@ void Camera3DTestDemo::updateCamera(float fDelta)
|
||||||
{
|
{
|
||||||
if (_cameraType == CameraType::ThirdPerson)
|
if (_cameraType == CameraType::ThirdPerson)
|
||||||
{
|
{
|
||||||
Vec3 lookDir = _camera->getPosition3D() - _sprite3D->getPosition3D();
|
Vec3 lookDir = _camera->getPosition3D() - _mesh->getPosition3D();
|
||||||
Vec3 cameraPos = _camera->getPosition3D();
|
Vec3 cameraPos = _camera->getPosition3D();
|
||||||
if (lookDir.length() >= 50)
|
if (lookDir.length() >= 50)
|
||||||
{
|
{
|
||||||
|
@ -747,9 +747,9 @@ void CameraCullingDemo::onEnter()
|
||||||
|
|
||||||
// + -
|
// + -
|
||||||
MenuItemFont::setFontSize(40);
|
MenuItemFont::setFontSize(40);
|
||||||
auto decrease = MenuItemFont::create(" - ", CC_CALLBACK_1(CameraCullingDemo::delSpriteCallback, this));
|
auto decrease = MenuItemFont::create(" - ", CC_CALLBACK_1(CameraCullingDemo::delMeshCallback, this));
|
||||||
decrease->setColor(Color3B(0, 200, 20));
|
decrease->setColor(Color3B(0, 200, 20));
|
||||||
auto increase = MenuItemFont::create(" + ", CC_CALLBACK_1(CameraCullingDemo::addSpriteCallback, this));
|
auto increase = MenuItemFont::create(" + ", CC_CALLBACK_1(CameraCullingDemo::addMeshCallback, this));
|
||||||
increase->setColor(Color3B(0, 200, 20));
|
increase->setColor(Color3B(0, 200, 20));
|
||||||
|
|
||||||
menu = Menu::create(decrease, increase, nullptr);
|
menu = Menu::create(decrease, increase, nullptr);
|
||||||
|
@ -758,10 +758,10 @@ void CameraCullingDemo::onEnter()
|
||||||
addChild(menu, 1);
|
addChild(menu, 1);
|
||||||
|
|
||||||
TTFConfig ttfCount("fonts/Marker Felt.ttf", 30);
|
TTFConfig ttfCount("fonts/Marker Felt.ttf", 30);
|
||||||
_labelSprite3DCount = Label::createWithTTF(ttfCount, "0 sprits");
|
_labelMeshCount = Label::createWithTTF(ttfCount, "0 sprits");
|
||||||
_labelSprite3DCount->setColor(Color3B(0, 200, 20));
|
_labelMeshCount->setColor(Color3B(0, 200, 20));
|
||||||
_labelSprite3DCount->setPosition(Vec2(s.width / 2, VisibleRect::top().y - 70));
|
_labelMeshCount->setPosition(Vec2(s.width / 2, VisibleRect::top().y - 70));
|
||||||
addChild(_labelSprite3DCount);
|
addChild(_labelMeshCount);
|
||||||
|
|
||||||
// aabb drawNode3D
|
// aabb drawNode3D
|
||||||
_drawAABB = DrawNode3D::create();
|
_drawAABB = DrawNode3D::create();
|
||||||
|
@ -777,7 +777,7 @@ void CameraCullingDemo::onEnter()
|
||||||
switchViewCallback(this);
|
switchViewCallback(this);
|
||||||
|
|
||||||
// add sprite
|
// add sprite
|
||||||
addSpriteCallback(nullptr);
|
addMeshCallback(nullptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CameraCullingDemo::onExit()
|
void CameraCullingDemo::onExit()
|
||||||
|
@ -805,7 +805,7 @@ void CameraCullingDemo::update(float dt)
|
||||||
|
|
||||||
for (const auto& iter : children)
|
for (const auto& iter : children)
|
||||||
{
|
{
|
||||||
const AABB& aabb = static_cast<Sprite3D*>(iter)->getAABB();
|
const AABB& aabb = static_cast<MeshRenderer*>(iter)->getAABB();
|
||||||
if (_cameraFirst->isVisibleInFrustum(&aabb))
|
if (_cameraFirst->isVisibleInFrustum(&aabb))
|
||||||
{
|
{
|
||||||
aabb.getCorners(corners);
|
aabb.getCorners(corners);
|
||||||
|
@ -872,7 +872,7 @@ void CameraCullingDemo::switchViewCallback(Ref* sender)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void CameraCullingDemo::addSpriteCallback(Ref* sender)
|
void CameraCullingDemo::addMeshCallback(Ref* sender)
|
||||||
{
|
{
|
||||||
_layer3D->removeAllChildren();
|
_layer3D->removeAllChildren();
|
||||||
_objects.clear();
|
_objects.clear();
|
||||||
|
@ -883,7 +883,7 @@ void CameraCullingDemo::addSpriteCallback(Ref* sender)
|
||||||
{
|
{
|
||||||
for (int z = -_row; z < _row; z++)
|
for (int z = -_row; z < _row; z++)
|
||||||
{
|
{
|
||||||
auto sprite = Sprite3D::create("Sprite3DTest/orc.c3b");
|
auto sprite = MeshRenderer::create("MeshRendererTest/orc.c3b");
|
||||||
sprite->setPosition3D(Vec3(x * 30.0f, 0.0f, z * 30.0f));
|
sprite->setPosition3D(Vec3(x * 30.0f, 0.0f, z * 30.0f));
|
||||||
sprite->setRotation3D(Vec3(0.0f, 180.0f, 0.0f));
|
sprite->setRotation3D(Vec3(0.0f, 180.0f, 0.0f));
|
||||||
_objects.push_back(sprite);
|
_objects.push_back(sprite);
|
||||||
|
@ -897,10 +897,10 @@ void CameraCullingDemo::addSpriteCallback(Ref* sender)
|
||||||
// update sprite number
|
// update sprite number
|
||||||
char szText[16];
|
char szText[16];
|
||||||
sprintf(szText, "%d sprits", static_cast<int32_t>(_layer3D->getChildrenCount()));
|
sprintf(szText, "%d sprits", static_cast<int32_t>(_layer3D->getChildrenCount()));
|
||||||
_labelSprite3DCount->setString(szText);
|
_labelMeshCount->setString(szText);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CameraCullingDemo::delSpriteCallback(Ref* sender)
|
void CameraCullingDemo::delMeshCallback(Ref* sender)
|
||||||
{
|
{
|
||||||
if (_row == 0)
|
if (_row == 0)
|
||||||
return;
|
return;
|
||||||
|
@ -913,7 +913,7 @@ void CameraCullingDemo::delSpriteCallback(Ref* sender)
|
||||||
{
|
{
|
||||||
for (int z = -_row; z < _row; z++)
|
for (int z = -_row; z < _row; z++)
|
||||||
{
|
{
|
||||||
auto sprite = Sprite3D::create("Sprite3DTest/orc.c3b");
|
auto sprite = MeshRenderer::create("MeshRendererTest/orc.c3b");
|
||||||
sprite->setPosition3D(Vec3(x * 30.0f, 0.0f, z * 30.0f));
|
sprite->setPosition3D(Vec3(x * 30.0f, 0.0f, z * 30.0f));
|
||||||
_objects.push_back(sprite);
|
_objects.push_back(sprite);
|
||||||
_layer3D->addChild(sprite);
|
_layer3D->addChild(sprite);
|
||||||
|
@ -926,7 +926,7 @@ void CameraCullingDemo::delSpriteCallback(Ref* sender)
|
||||||
// update sprite number
|
// update sprite number
|
||||||
char szText[16];
|
char szText[16];
|
||||||
sprintf(szText, "%l sprits", static_cast<int32_t>(_layer3D->getChildrenCount()));
|
sprintf(szText, "%l sprits", static_cast<int32_t>(_layer3D->getChildrenCount()));
|
||||||
_labelSprite3DCount->setString(szText);
|
_labelMeshCount->setString(szText);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CameraCullingDemo::drawCameraFrustum()
|
void CameraCullingDemo::drawCameraFrustum()
|
||||||
|
@ -993,8 +993,8 @@ CameraArcBallDemo::CameraArcBallDemo()
|
||||||
, _operate(OperateCamType::RotateCamera)
|
, _operate(OperateCamType::RotateCamera)
|
||||||
, _center(Vec3(0, 0, 0))
|
, _center(Vec3(0, 0, 0))
|
||||||
, _target(0)
|
, _target(0)
|
||||||
, _sprite3D1(nullptr)
|
, _mesh1(nullptr)
|
||||||
, _sprite3D2(nullptr)
|
, _mesh2(nullptr)
|
||||||
{}
|
{}
|
||||||
CameraArcBallDemo::~CameraArcBallDemo() {}
|
CameraArcBallDemo::~CameraArcBallDemo() {}
|
||||||
|
|
||||||
|
@ -1043,17 +1043,17 @@ void CameraArcBallDemo::onEnter()
|
||||||
_layer3D->addChild(_camera);
|
_layer3D->addChild(_camera);
|
||||||
}
|
}
|
||||||
|
|
||||||
_sprite3D1 = Sprite3D::create("Sprite3DTest/orc.c3b");
|
_mesh1 = MeshRenderer::create("MeshRendererTest/orc.c3b");
|
||||||
_sprite3D1->setScale(0.5);
|
_mesh1->setScale(0.5);
|
||||||
_sprite3D1->setRotation3D(Vec3(0.0f, 180.0f, 0.0f));
|
_mesh1->setRotation3D(Vec3(0.0f, 180.0f, 0.0f));
|
||||||
_sprite3D1->setPosition3D(Vec3(0, 0, 0));
|
_mesh1->setPosition3D(Vec3(0, 0, 0));
|
||||||
_layer3D->addChild(_sprite3D1);
|
_layer3D->addChild(_mesh1);
|
||||||
|
|
||||||
_sprite3D2 = Sprite3D::create("Sprite3DTest/boss.c3b");
|
_mesh2 = MeshRenderer::create("MeshRendererTest/boss.c3b");
|
||||||
_sprite3D2->setScale(0.6f);
|
_mesh2->setScale(0.6f);
|
||||||
_sprite3D2->setRotation3D(Vec3(-90.0f, 0.0f, 0.0f));
|
_mesh2->setRotation3D(Vec3(-90.0f, 0.0f, 0.0f));
|
||||||
_sprite3D2->setPosition3D(Vec3(20.0f, 0.0f, 0.0f));
|
_mesh2->setPosition3D(Vec3(20.0f, 0.0f, 0.0f));
|
||||||
_layer3D->addChild(_sprite3D2);
|
_layer3D->addChild(_mesh2);
|
||||||
|
|
||||||
_drawGrid = DrawNode3D::create();
|
_drawGrid = DrawNode3D::create();
|
||||||
|
|
||||||
|
@ -1187,13 +1187,13 @@ void CameraArcBallDemo::switchTargetCallback(Ref* sender)
|
||||||
if (_target == 0)
|
if (_target == 0)
|
||||||
{
|
{
|
||||||
_target = 1;
|
_target = 1;
|
||||||
_center = _sprite3D2->getPosition3D();
|
_center = _mesh2->getPosition3D();
|
||||||
updateCameraTransform();
|
updateCameraTransform();
|
||||||
}
|
}
|
||||||
else if (_target == 1)
|
else if (_target == 1)
|
||||||
{
|
{
|
||||||
_target = 0;
|
_target = 0;
|
||||||
_center = _sprite3D1->getPosition3D();
|
_center = _mesh1->getPosition3D();
|
||||||
updateCameraTransform();
|
updateCameraTransform();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1253,18 +1253,18 @@ void FogTestDemo::onEnter()
|
||||||
CC_SAFE_RELEASE_NULL(_programState1);
|
CC_SAFE_RELEASE_NULL(_programState1);
|
||||||
CC_SAFE_RELEASE_NULL(_programState2);
|
CC_SAFE_RELEASE_NULL(_programState2);
|
||||||
|
|
||||||
auto vertexSource = FileUtils::getInstance()->getStringFromFile("Sprite3DTest/fog.vert");
|
auto vertexSource = FileUtils::getInstance()->getStringFromFile("MeshRendererTest/fog.vert");
|
||||||
auto fragSource = FileUtils::getInstance()->getStringFromFile("Sprite3DTest/fog.frag");
|
auto fragSource = FileUtils::getInstance()->getStringFromFile("MeshRendererTest/fog.frag");
|
||||||
auto program = backend::Device::getInstance()->newProgram(vertexSource, fragSource);
|
auto program = backend::Device::getInstance()->newProgram(vertexSource, fragSource);
|
||||||
_programState1 = new backend::ProgramState(program);
|
_programState1 = new backend::ProgramState(program);
|
||||||
_programState2 = new backend::ProgramState(program);
|
_programState2 = new backend::ProgramState(program);
|
||||||
CC_SAFE_RELEASE(program);
|
CC_SAFE_RELEASE(program);
|
||||||
|
|
||||||
_sprite3D1 = Sprite3D::create("Sprite3DTest/teapot.c3b");
|
_mesh1 = MeshRenderer::create("MeshRendererTest/teapot.c3b");
|
||||||
_sprite3D2 = Sprite3D::create("Sprite3DTest/teapot.c3b");
|
_mesh2 = MeshRenderer::create("MeshRendererTest/teapot.c3b");
|
||||||
|
|
||||||
_sprite3D1->setProgramState(_programState1);
|
_mesh1->setProgramState(_programState1);
|
||||||
_sprite3D2->setProgramState(_programState2);
|
_mesh2->setProgramState(_programState2);
|
||||||
|
|
||||||
auto fogColor = Vec4(0.5, 0.5, 0.5, 1.0);
|
auto fogColor = Vec4(0.5, 0.5, 0.5, 1.0);
|
||||||
float fogStart = 10;
|
float fogStart = 10;
|
||||||
|
@ -1276,15 +1276,15 @@ void FogTestDemo::onEnter()
|
||||||
SET_UNIFORM("u_fogEnd", &fogEnd, sizeof(fogEnd));
|
SET_UNIFORM("u_fogEnd", &fogEnd, sizeof(fogEnd));
|
||||||
SET_UNIFORM("u_fogEquation", &fogEquation, sizeof(fogEquation));
|
SET_UNIFORM("u_fogEquation", &fogEquation, sizeof(fogEquation));
|
||||||
|
|
||||||
_layer3D->addChild(_sprite3D1);
|
_layer3D->addChild(_mesh1);
|
||||||
_sprite3D1->setPosition3D(Vec3(0, 0, 0));
|
_mesh1->setPosition3D(Vec3(0, 0, 0));
|
||||||
_sprite3D1->setScale(2.0f);
|
_mesh1->setScale(2.0f);
|
||||||
_sprite3D1->setRotation3D(Vec3(-90.0f, 180.0f, 0.0f));
|
_mesh1->setRotation3D(Vec3(-90.0f, 180.0f, 0.0f));
|
||||||
|
|
||||||
_layer3D->addChild(_sprite3D2);
|
_layer3D->addChild(_mesh2);
|
||||||
_sprite3D2->setPosition3D(Vec3(0.0f, 0.0f, -20.0f));
|
_mesh2->setPosition3D(Vec3(0.0f, 0.0f, -20.0f));
|
||||||
_sprite3D2->setScale(2.0f);
|
_mesh2->setScale(2.0f);
|
||||||
_sprite3D2->setRotation3D(Vec3(-90.0f, 180.0f, 0.0f));
|
_mesh2->setRotation3D(Vec3(-90.0f, 180.0f, 0.0f));
|
||||||
|
|
||||||
if (_camera == nullptr)
|
if (_camera == nullptr)
|
||||||
{
|
{
|
||||||
|
@ -1303,14 +1303,14 @@ void FogTestDemo::onEnter()
|
||||||
CC_SAFE_RELEASE_NULL(_programState1);
|
CC_SAFE_RELEASE_NULL(_programState1);
|
||||||
CC_SAFE_RELEASE_NULL(_programState2);
|
CC_SAFE_RELEASE_NULL(_programState2);
|
||||||
|
|
||||||
auto vertexSource = FileUtils::getInstance()->getStringFromFile("Sprite3DTest/fog.vert");
|
auto vertexSource = FileUtils::getInstance()->getStringFromFile("MeshRendererTest/fog.vert");
|
||||||
auto fragSource = FileUtils::getInstance()->getStringFromFile("Sprite3DTest/fog.frag");
|
auto fragSource = FileUtils::getInstance()->getStringFromFile("MeshRendererTest/fog.frag");
|
||||||
auto program = backend::Device::getInstance()->newProgram(vertexSource, fragSource);
|
auto program = backend::Device::getInstance()->newProgram(vertexSource, fragSource);
|
||||||
_programState1 = new backend::ProgramState(program);
|
_programState1 = new backend::ProgramState(program);
|
||||||
_programState2 = new backend::ProgramState(program);
|
_programState2 = new backend::ProgramState(program);
|
||||||
|
|
||||||
_sprite3D1->setProgramState(_programState1);
|
_mesh1->setProgramState(_programState1);
|
||||||
_sprite3D2->setProgramState(_programState2);
|
_mesh2->setProgramState(_programState2);
|
||||||
CC_SAFE_RELEASE(program);
|
CC_SAFE_RELEASE(program);
|
||||||
|
|
||||||
auto fogColor = Vec4(0.5, 0.5, 0.5, 1.0);
|
auto fogColor = Vec4(0.5, 0.5, 0.5, 1.0);
|
||||||
|
@ -1429,8 +1429,8 @@ void FogTestDemo::onTouchesMoved(const std::vector<Touch*>& touches, cocos2d::Ev
|
||||||
// CameraBaseTest::onEnter();
|
// CameraBaseTest::onEnter();
|
||||||
// //auto sprite = Sprite::createWithTexture(fbo);
|
// //auto sprite = Sprite::createWithTexture(fbo);
|
||||||
// //sprite->setPosition(Vec2(100,100));
|
// //sprite->setPosition(Vec2(100,100));
|
||||||
// //std::string filename = "Sprite3DTest/girl.c3b";
|
// //std::string filename = "MeshRendererTest/girl.c3b";
|
||||||
// //auto sprite = Sprite3D::create(filename);
|
// //auto sprite = MeshRenderer::create(filename);
|
||||||
// //sprite->setScale(1.0);
|
// //sprite->setScale(1.0);
|
||||||
// //auto animation = Animation3D::create(filename);
|
// //auto animation = Animation3D::create(filename);
|
||||||
// //if (animation)
|
// //if (animation)
|
||||||
|
@ -1500,10 +1500,10 @@ void BackgroundColorBrushTest::onEnter()
|
||||||
addChild(camera);
|
addChild(camera);
|
||||||
|
|
||||||
// 3D model
|
// 3D model
|
||||||
auto model = Sprite3D::create("Sprite3DTest/boss1.obj");
|
auto model = MeshRenderer::create("MeshRendererTest/boss1.obj");
|
||||||
model->setScale(4);
|
model->setScale(4);
|
||||||
model->setPosition3D(Vec3(20.0f, 0.0f, 0.0f));
|
model->setPosition3D(Vec3(20.0f, 0.0f, 0.0f));
|
||||||
model->setTexture("Sprite3DTest/boss.png");
|
model->setTexture("MeshRendererTest/boss.png");
|
||||||
model->setCameraMask(static_cast<unsigned short>(CameraFlag::USER1));
|
model->setCameraMask(static_cast<unsigned short>(CameraFlag::USER1));
|
||||||
addChild(model);
|
addChild(model);
|
||||||
model->runAction(RepeatForever::create(RotateBy::create(1.f, Vec3(10.0f, 20.0f, 30.0f))));
|
model->runAction(RepeatForever::create(RotateBy::create(1.f, Vec3(10.0f, 20.0f, 30.0f))));
|
||||||
|
@ -1538,10 +1538,10 @@ void BackgroundColorBrushTest::onEnter()
|
||||||
addChild(slider);
|
addChild(slider);
|
||||||
|
|
||||||
// 3D model for 2nd camera
|
// 3D model for 2nd camera
|
||||||
auto model = Sprite3D::create("Sprite3DTest/boss1.obj");
|
auto model = MeshRenderer::create("MeshRendererTest/boss1.obj");
|
||||||
model->setScale(4);
|
model->setScale(4);
|
||||||
model->setPosition3D(Vec3(-20.0f, 0.0f, 0.0f));
|
model->setPosition3D(Vec3(-20.0f, 0.0f, 0.0f));
|
||||||
model->setTexture("Sprite3DTest/boss.png");
|
model->setTexture("MeshRendererTest/boss.png");
|
||||||
model->setCameraMask(static_cast<unsigned short>(CameraFlag::USER2));
|
model->setCameraMask(static_cast<unsigned short>(CameraFlag::USER2));
|
||||||
base->addChild(model);
|
base->addChild(model);
|
||||||
model->runAction(RepeatForever::create(RotateBy::create(1.f, Vec3(10.0f, 20.0f, 30.0f))));
|
model->runAction(RepeatForever::create(RotateBy::create(1.f, Vec3(10.0f, 20.0f, 30.0f))));
|
||||||
|
|
|
@ -26,7 +26,7 @@ THE SOFTWARE.
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "../BaseTest.h"
|
#include "../BaseTest.h"
|
||||||
#include "../Sprite3DTest/DrawNode3D.h"
|
#include "../MeshRendererTest/DrawNode3D.h"
|
||||||
|
|
||||||
#include "renderer/backend/ProgramState.h"
|
#include "renderer/backend/ProgramState.h"
|
||||||
#include "renderer/backend/Types.h"
|
#include "renderer/backend/Types.h"
|
||||||
|
@ -35,7 +35,7 @@ THE SOFTWARE.
|
||||||
|
|
||||||
namespace cocos2d
|
namespace cocos2d
|
||||||
{
|
{
|
||||||
class Sprite3D;
|
class MeshRenderer;
|
||||||
class Delay;
|
class Delay;
|
||||||
} // namespace cocos2d
|
} // namespace cocos2d
|
||||||
|
|
||||||
|
@ -142,7 +142,7 @@ public:
|
||||||
protected:
|
protected:
|
||||||
std::string _title;
|
std::string _title;
|
||||||
cocos2d::Layer* _layer3D;
|
cocos2d::Layer* _layer3D;
|
||||||
cocos2d::Sprite3D* _sprite3D;
|
cocos2d::MeshRenderer* _mesh;
|
||||||
cocos2d::Vec3 _targetPos;
|
cocos2d::Vec3 _targetPos;
|
||||||
CameraType _cameraType;
|
CameraType _cameraType;
|
||||||
cocos2d::MenuItem* _incRot;
|
cocos2d::MenuItem* _incRot;
|
||||||
|
@ -176,15 +176,15 @@ public:
|
||||||
virtual std::string title() const override;
|
virtual std::string title() const override;
|
||||||
void reachEndCallBack();
|
void reachEndCallBack();
|
||||||
void switchViewCallback(cocos2d::Ref* sender);
|
void switchViewCallback(cocos2d::Ref* sender);
|
||||||
void addSpriteCallback(cocos2d::Ref* sender);
|
void addMeshCallback(cocos2d::Ref* sender);
|
||||||
void delSpriteCallback(cocos2d::Ref* sender);
|
void delMeshCallback(cocos2d::Ref* sender);
|
||||||
|
|
||||||
void drawCameraFrustum();
|
void drawCameraFrustum();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
cocos2d::Label* _labelSprite3DCount;
|
cocos2d::Label* _labelMeshCount;
|
||||||
cocos2d::Layer* _layer3D;
|
cocos2d::Layer* _layer3D;
|
||||||
std::vector<cocos2d::Sprite3D*> _objects;
|
std::vector<cocos2d::MeshRenderer*> _objects;
|
||||||
CameraType _cameraType;
|
CameraType _cameraType;
|
||||||
cocos2d::Camera* _cameraFirst;
|
cocos2d::Camera* _cameraFirst;
|
||||||
cocos2d::Camera* _cameraThird;
|
cocos2d::Camera* _cameraThird;
|
||||||
|
@ -232,8 +232,8 @@ protected:
|
||||||
OperateCamType _operate; // switch rotate or zoom
|
OperateCamType _operate; // switch rotate or zoom
|
||||||
cocos2d::Vec3 _center; // camera look target
|
cocos2d::Vec3 _center; // camera look target
|
||||||
int _target; // switch camera look target
|
int _target; // switch camera look target
|
||||||
cocos2d::Sprite3D* _sprite3D1;
|
cocos2d::MeshRenderer* _mesh1;
|
||||||
cocos2d::Sprite3D* _sprite3D2;
|
cocos2d::MeshRenderer* _mesh2;
|
||||||
};
|
};
|
||||||
|
|
||||||
class FogTestDemo : public CameraBaseTest
|
class FogTestDemo : public CameraBaseTest
|
||||||
|
@ -259,8 +259,8 @@ protected:
|
||||||
CameraType _cameraType = CameraType::Free;
|
CameraType _cameraType = CameraType::Free;
|
||||||
cocos2d::Layer* _layer3D = nullptr;
|
cocos2d::Layer* _layer3D = nullptr;
|
||||||
cocos2d::Camera* _camera = nullptr;
|
cocos2d::Camera* _camera = nullptr;
|
||||||
cocos2d::Sprite3D* _sprite3D1 = nullptr;
|
cocos2d::MeshRenderer* _mesh1 = nullptr;
|
||||||
cocos2d::Sprite3D* _sprite3D2 = nullptr;
|
cocos2d::MeshRenderer* _mesh2 = nullptr;
|
||||||
cocos2d::backend::ProgramState* _programState1 = nullptr;
|
cocos2d::backend::ProgramState* _programState1 = nullptr;
|
||||||
cocos2d::backend::ProgramState* _programState2 = nullptr;
|
cocos2d::backend::ProgramState* _programState2 = nullptr;
|
||||||
|
|
||||||
|
|
|
@ -108,8 +108,8 @@ void LightTest::addSprite()
|
||||||
auto s = Director::getInstance()->getWinSize();
|
auto s = Director::getInstance()->getWinSize();
|
||||||
|
|
||||||
//{
|
//{
|
||||||
// std::string fileName = "Sprite3DTest/plane.c3b";
|
// std::string fileName = "MeshRendererTest/plane.c3b";
|
||||||
// auto sprite = Sprite3D::create(fileName);
|
// auto sprite = MeshRenderer::create(fileName);
|
||||||
// sprite->setRotation3D(Vec3(-90.0, 0.0, 0.0));
|
// sprite->setRotation3D(Vec3(-90.0, 0.0, 0.0));
|
||||||
// sprite->setScale(5.0f);
|
// sprite->setScale(5.0f);
|
||||||
// sprite->setPosition(Vec2(0.0, -50.0));
|
// sprite->setPosition(Vec2(0.0, -50.0));
|
||||||
|
@ -118,35 +118,35 @@ void LightTest::addSprite()
|
||||||
//}
|
//}
|
||||||
|
|
||||||
{
|
{
|
||||||
std::string fileName = "Sprite3DTest/orc.c3b";
|
std::string fileName = "MeshRendererTest/orc.c3b";
|
||||||
auto sprite = Sprite3D::create(fileName);
|
auto mesh = MeshRenderer::create(fileName);
|
||||||
sprite->setRotation3D(Vec3(0.0f, 180.0f, 0.0f));
|
mesh->setRotation3D(Vec3(0.0f, 180.0f, 0.0f));
|
||||||
sprite->setPosition(Vec2(0.0f, 0.0f));
|
mesh->setPosition(Vec2(0.0f, 0.0f));
|
||||||
sprite->setScale(2.0);
|
mesh->setScale(2.0);
|
||||||
auto sp = Sprite3D::create("Sprite3DTest/axe.c3b");
|
auto m = MeshRenderer::create("MeshRendererTest/axe.c3b");
|
||||||
sprite->getAttachNode("Bip001 R Hand")->addChild(sp);
|
mesh->getAttachNode("Bip001 R Hand")->addChild(m);
|
||||||
auto animation = Animation3D::create(fileName);
|
auto animation = Animation3D::create(fileName);
|
||||||
if (animation)
|
if (animation)
|
||||||
{
|
{
|
||||||
auto animate = Animate3D::create(animation);
|
auto animate = Animate3D::create(animation);
|
||||||
sprite->runAction(RepeatForever::create(animate));
|
mesh->runAction(RepeatForever::create(animate));
|
||||||
}
|
}
|
||||||
|
|
||||||
addChild(sprite);
|
addChild(mesh);
|
||||||
sprite->setCameraMask(2);
|
mesh->setCameraMask(2);
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
std::string fileName = "Sprite3DTest/sphere.c3b";
|
std::string fileName = "MeshRendererTest/sphere.c3b";
|
||||||
auto sprite = Sprite3D::create(fileName);
|
auto sprite = MeshRenderer::create(fileName);
|
||||||
sprite->setPosition(Vec2(30.0f, 0.0f));
|
sprite->setPosition(Vec2(30.0f, 0.0f));
|
||||||
addChild(sprite);
|
addChild(sprite);
|
||||||
sprite->setCameraMask(2);
|
sprite->setCameraMask(2);
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
std::string fileName = "Sprite3DTest/sphere.c3b";
|
std::string fileName = "MeshRendererTest/sphere.c3b";
|
||||||
auto sprite = Sprite3D::create(fileName);
|
auto sprite = MeshRenderer::create(fileName);
|
||||||
sprite->setScale(0.5f);
|
sprite->setScale(0.5f);
|
||||||
sprite->setPosition(Vec2(-50.0f, 0.0f));
|
sprite->setPosition(Vec2(-50.0f, 0.0f));
|
||||||
addChild(sprite);
|
addChild(sprite);
|
||||||
|
@ -154,8 +154,8 @@ void LightTest::addSprite()
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
std::string fileName = "Sprite3DTest/sphere.c3b";
|
std::string fileName = "MeshRendererTest/sphere.c3b";
|
||||||
auto sprite = Sprite3D::create(fileName);
|
auto sprite = MeshRenderer::create(fileName);
|
||||||
sprite->setScale(0.5f);
|
sprite->setScale(0.5f);
|
||||||
sprite->setPosition(Vec2(-30.0f, 10.0f));
|
sprite->setPosition(Vec2(-30.0f, 10.0f));
|
||||||
addChild(sprite);
|
addChild(sprite);
|
||||||
|
|
|
@ -45,8 +45,8 @@ MaterialSystemTest::MaterialSystemTest()
|
||||||
ADD_TEST_CASE(Material_AutoBindings);
|
ADD_TEST_CASE(Material_AutoBindings);
|
||||||
ADD_TEST_CASE(Material_setTechnique);
|
ADD_TEST_CASE(Material_setTechnique);
|
||||||
ADD_TEST_CASE(Material_clone);
|
ADD_TEST_CASE(Material_clone);
|
||||||
ADD_TEST_CASE(Material_MultipleSprite3D);
|
ADD_TEST_CASE(Material_MultipleMeshRenderer);
|
||||||
ADD_TEST_CASE(Material_Sprite3DTest);
|
ADD_TEST_CASE(Material_MeshRendererTest);
|
||||||
ADD_TEST_CASE(Material_parsePerformance);
|
ADD_TEST_CASE(Material_parsePerformance);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -57,30 +57,30 @@ std::string MaterialSystemBaseTest::title() const
|
||||||
|
|
||||||
// MARK: Tests start here
|
// MARK: Tests start here
|
||||||
|
|
||||||
void Material_Sprite3DTest::onEnter()
|
void Material_MeshRendererTest::onEnter()
|
||||||
{
|
{
|
||||||
MaterialSystemBaseTest::onEnter();
|
MaterialSystemBaseTest::onEnter();
|
||||||
|
|
||||||
auto sprite = Sprite3D::create("Sprite3DTest/boss1.obj");
|
auto mesh = MeshRenderer::create("MeshRendererTest/boss1.obj");
|
||||||
sprite->setScale(8.f);
|
mesh->setScale(8.f);
|
||||||
sprite->setTexture("Sprite3DTest/boss.png");
|
mesh->setTexture("MeshRendererTest/boss.png");
|
||||||
this->addChild(sprite);
|
this->addChild(mesh);
|
||||||
sprite->setPositionNormalized(Vec2(0.5f, 0.5f));
|
mesh->setPositionNormalized(Vec2(0.5f, 0.5f));
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string Material_Sprite3DTest::subtitle() const
|
std::string Material_MeshRendererTest::subtitle() const
|
||||||
{
|
{
|
||||||
return "Material System on Sprite3D";
|
return "Material System on MeshRenderer";
|
||||||
}
|
}
|
||||||
|
|
||||||
void Material_MultipleSprite3D::onEnter()
|
void Material_MultipleMeshRenderer::onEnter()
|
||||||
{
|
{
|
||||||
MaterialSystemBaseTest::onEnter();
|
MaterialSystemBaseTest::onEnter();
|
||||||
|
|
||||||
const char* names[] = {
|
const char* names[] = {
|
||||||
"Sprite3DTest/ReskinGirl.c3b", "Sprite3DTest/ReskinGirl.c3b", "Sprite3DTest/ReskinGirl.c3b",
|
"MeshRendererTest/ReskinGirl.c3b", "MeshRendererTest/ReskinGirl.c3b", "MeshRendererTest/ReskinGirl.c3b",
|
||||||
"Sprite3DTest/ReskinGirl.c3b", "Sprite3DTest/ReskinGirl.c3b", "Sprite3DTest/ReskinGirl.c3b",
|
"MeshRendererTest/ReskinGirl.c3b", "MeshRendererTest/ReskinGirl.c3b", "MeshRendererTest/ReskinGirl.c3b",
|
||||||
"Sprite3DTest/ReskinGirl.c3b", "Sprite3DTest/ReskinGirl.c3b",
|
"MeshRendererTest/ReskinGirl.c3b", "MeshRendererTest/ReskinGirl.c3b",
|
||||||
};
|
};
|
||||||
|
|
||||||
const int totalNames = sizeof(names) / sizeof(names[0]);
|
const int totalNames = sizeof(names) / sizeof(names[0]);
|
||||||
|
@ -89,14 +89,14 @@ void Material_MultipleSprite3D::onEnter()
|
||||||
|
|
||||||
for (int i = 0; i < totalNames; i++)
|
for (int i = 0; i < totalNames; i++)
|
||||||
{
|
{
|
||||||
auto sprite = Sprite3D::create(names[i]);
|
auto mesh = MeshRenderer::create(names[i]);
|
||||||
this->addChild(sprite);
|
this->addChild(mesh);
|
||||||
sprite->setPosition(Vec2((size.width / (totalNames + 1)) * (i + 1), size.height / 4));
|
mesh->setPosition(Vec2((size.width / (totalNames + 1)) * (i + 1), size.height / 4));
|
||||||
sprite->setScale(3);
|
mesh->setScale(3);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string Material_MultipleSprite3D::subtitle() const
|
std::string Material_MultipleMeshRenderer::subtitle() const
|
||||||
{
|
{
|
||||||
return "Sprites with multiple meshes";
|
return "Sprites with multiple meshes";
|
||||||
}
|
}
|
||||||
|
@ -115,40 +115,40 @@ void Material_2DEffects::onEnter()
|
||||||
|
|
||||||
Material* mat1 = Material::createWithProperties(properties);
|
Material* mat1 = Material::createWithProperties(properties);
|
||||||
|
|
||||||
auto spriteBlur = Sprite::create("Images/grossini.png");
|
auto meshBlur = Sprite::create("Images/grossini.png");
|
||||||
spriteBlur->setPositionNormalized(Vec2(0.2f, 0.5f));
|
meshBlur->setPositionNormalized(Vec2(0.2f, 0.5f));
|
||||||
this->addChild(spriteBlur);
|
this->addChild(meshBlur);
|
||||||
spriteBlur->setProgramState(mat1->getTechniqueByName("blur")->getPassByIndex(0)->getProgramState());
|
meshBlur->setProgramState(mat1->getTechniqueByName("blur")->getPassByIndex(0)->getProgramState());
|
||||||
|
|
||||||
auto spriteOutline = Sprite::create("Images/grossini.png");
|
auto meshOutline = Sprite::create("Images/grossini.png");
|
||||||
spriteOutline->setPositionNormalized(Vec2(0.4f, 0.5f));
|
meshOutline->setPositionNormalized(Vec2(0.4f, 0.5f));
|
||||||
this->addChild(spriteOutline);
|
this->addChild(meshOutline);
|
||||||
spriteOutline->setProgramState(mat1->getTechniqueByName("outline")->getPassByIndex(0)->getProgramState());
|
meshOutline->setProgramState(mat1->getTechniqueByName("outline")->getPassByIndex(0)->getProgramState());
|
||||||
|
|
||||||
auto spriteNoise = Sprite::create("Images/grossini.png");
|
auto meshNoise = Sprite::create("Images/grossini.png");
|
||||||
spriteNoise->setPositionNormalized(Vec2(0.6f, 0.5f));
|
meshNoise->setPositionNormalized(Vec2(0.6f, 0.5f));
|
||||||
this->addChild(spriteNoise);
|
this->addChild(meshNoise);
|
||||||
spriteNoise->setProgramState(mat1->getTechniqueByName("noise")->getPassByIndex(0)->getProgramState());
|
meshNoise->setProgramState(mat1->getTechniqueByName("noise")->getPassByIndex(0)->getProgramState());
|
||||||
|
|
||||||
auto spriteEdgeDetect = Sprite::create("Images/grossini.png");
|
auto meshEdgeDetect = Sprite::create("Images/grossini.png");
|
||||||
spriteEdgeDetect->setPositionNormalized(Vec2(0.8f, 0.5f));
|
meshEdgeDetect->setPositionNormalized(Vec2(0.8f, 0.5f));
|
||||||
this->addChild(spriteEdgeDetect);
|
this->addChild(meshEdgeDetect);
|
||||||
spriteEdgeDetect->setProgramState(mat1->getTechniqueByName("edge_detect")->getPassByIndex(0)->getProgramState());
|
meshEdgeDetect->setProgramState(mat1->getTechniqueByName("edge_detect")->getPassByIndex(0)->getProgramState());
|
||||||
|
|
||||||
timeUniforms.clear();
|
timeUniforms.clear();
|
||||||
|
|
||||||
#define FETCH_CCTIME_LOCATION(sprite) \
|
#define FETCH_CCTIME_LOCATION(mesh) \
|
||||||
do \
|
do \
|
||||||
{ \
|
{ \
|
||||||
auto programState = sprite->getProgramState(); \
|
auto programState = mesh->getProgramState(); \
|
||||||
auto location = programState->getUniformLocation("u_Time"); \
|
auto location = programState->getUniformLocation("u_Time"); \
|
||||||
timeUniforms.emplace_back(programState, location); \
|
timeUniforms.emplace_back(programState, location); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
FETCH_CCTIME_LOCATION(spriteBlur);
|
FETCH_CCTIME_LOCATION(meshBlur);
|
||||||
FETCH_CCTIME_LOCATION(spriteOutline);
|
FETCH_CCTIME_LOCATION(meshOutline);
|
||||||
FETCH_CCTIME_LOCATION(spriteNoise);
|
FETCH_CCTIME_LOCATION(meshNoise);
|
||||||
FETCH_CCTIME_LOCATION(spriteEdgeDetect);
|
FETCH_CCTIME_LOCATION(meshEdgeDetect);
|
||||||
|
|
||||||
schedule(CC_SCHEDULE_SELECTOR(Material_2DEffects::updateCCTimeUniforms));
|
schedule(CC_SCHEDULE_SELECTOR(Material_2DEffects::updateCCTimeUniforms));
|
||||||
|
|
||||||
|
@ -245,27 +245,27 @@ void Material_AutoBindings::onEnter()
|
||||||
|
|
||||||
Material* mat1 = Material::createWithProperties(properties);
|
Material* mat1 = Material::createWithProperties(properties);
|
||||||
|
|
||||||
auto spriteBlur = Sprite::create("Images/grossini.png");
|
auto meshBlur = Sprite::create("Images/grossini.png");
|
||||||
spriteBlur->setPositionNormalized(Vec2(0.2f, 0.5f));
|
meshBlur->setPositionNormalized(Vec2(0.2f, 0.5f));
|
||||||
this->addChild(spriteBlur);
|
this->addChild(meshBlur);
|
||||||
spriteBlur->setProgramState(mat1->getTechniqueByName("blur")->getPassByIndex(0)->getProgramState());
|
meshBlur->setProgramState(mat1->getTechniqueByName("blur")->getPassByIndex(0)->getProgramState());
|
||||||
|
|
||||||
auto spriteOutline = Sprite::create("Images/grossini.png");
|
auto meshOutline = Sprite::create("Images/grossini.png");
|
||||||
spriteOutline->setPositionNormalized(Vec2(0.4f, 0.5f));
|
meshOutline->setPositionNormalized(Vec2(0.4f, 0.5f));
|
||||||
this->addChild(spriteOutline);
|
this->addChild(meshOutline);
|
||||||
spriteOutline->setProgramState(mat1->getTechniqueByName("outline")->getPassByIndex(0)->getProgramState());
|
meshOutline->setProgramState(mat1->getTechniqueByName("outline")->getPassByIndex(0)->getProgramState());
|
||||||
|
|
||||||
auto spriteNoise = Sprite::create("Images/grossini.png");
|
auto meshNoise = Sprite::create("Images/grossini.png");
|
||||||
spriteNoise->setPositionNormalized(Vec2(0.6f, 0.5f));
|
meshNoise->setPositionNormalized(Vec2(0.6f, 0.5f));
|
||||||
this->addChild(spriteNoise);
|
this->addChild(meshNoise);
|
||||||
spriteNoise->setProgramState(mat1->getTechniqueByName("noise")->getPassByIndex(0)->getProgramState());
|
meshNoise->setProgramState(mat1->getTechniqueByName("noise")->getPassByIndex(0)->getProgramState());
|
||||||
|
|
||||||
auto spriteEdgeDetect = Sprite::create("Images/grossini.png");
|
auto meshEdgeDetect = Sprite::create("Images/grossini.png");
|
||||||
spriteEdgeDetect->setPositionNormalized(Vec2(0.8f, 0.5f));
|
meshEdgeDetect->setPositionNormalized(Vec2(0.8f, 0.5f));
|
||||||
this->addChild(spriteEdgeDetect);
|
this->addChild(meshEdgeDetect);
|
||||||
spriteEdgeDetect->setProgramState(mat1->getTechniqueByName("edge_detect")->getPassByIndex(0)->getProgramState());
|
meshEdgeDetect->setProgramState(mat1->getTechniqueByName("edge_detect")->getPassByIndex(0)->getProgramState());
|
||||||
|
|
||||||
_noiseProgramState = spriteNoise->getProgramState();
|
_noiseProgramState = meshNoise->getProgramState();
|
||||||
_locationTime = _noiseProgramState->getUniformLocation("u_Time");
|
_locationTime = _noiseProgramState->getUniformLocation("u_Time");
|
||||||
|
|
||||||
schedule(CC_SCHEDULE_SELECTOR(Material_AutoBindings::updateUniformTime));
|
schedule(CC_SCHEDULE_SELECTOR(Material_AutoBindings::updateUniformTime));
|
||||||
|
@ -292,14 +292,14 @@ void Material_setTechnique::onEnter()
|
||||||
{
|
{
|
||||||
MaterialSystemBaseTest::onEnter();
|
MaterialSystemBaseTest::onEnter();
|
||||||
|
|
||||||
auto sprite = Sprite3D::create("Sprite3DTest/boss1.obj");
|
auto mesh = MeshRenderer::create("MeshRendererTest/boss1.obj");
|
||||||
sprite->setScale(6);
|
mesh->setScale(6);
|
||||||
this->addChild(sprite);
|
this->addChild(mesh);
|
||||||
sprite->setPositionNormalized(Vec2(0.5f, 0.5f));
|
mesh->setPositionNormalized(Vec2(0.5f, 0.5f));
|
||||||
_sprite = sprite;
|
_mesh = mesh;
|
||||||
|
|
||||||
Material* mat = Material::createWithFilename("Materials/3d_effects.material");
|
Material* mat = Material::createWithFilename("Materials/3d_effects.material");
|
||||||
sprite->setMaterial(mat);
|
mesh->setMaterial(mat);
|
||||||
|
|
||||||
// lights
|
// lights
|
||||||
auto light1 = AmbientLight::create(Color3B::RED);
|
auto light1 = AmbientLight::create(Color3B::RED);
|
||||||
|
@ -313,7 +313,7 @@ void Material_setTechnique::onEnter()
|
||||||
|
|
||||||
auto rot = RotateBy::create(5, Vec3(30.0f, 60.0f, 270.0f));
|
auto rot = RotateBy::create(5, Vec3(30.0f, 60.0f, 270.0f));
|
||||||
auto repeat = RepeatForever::create(rot);
|
auto repeat = RepeatForever::create(rot);
|
||||||
sprite->runAction(repeat);
|
mesh->runAction(repeat);
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string Material_setTechnique::subtitle() const
|
std::string Material_setTechnique::subtitle() const
|
||||||
|
@ -327,13 +327,13 @@ void Material_setTechnique::changeMaterial(float dt)
|
||||||
switch (_techniqueState)
|
switch (_techniqueState)
|
||||||
{
|
{
|
||||||
case 0:
|
case 0:
|
||||||
_sprite->getMaterial(0)->setTechnique("lit");
|
_mesh->getMaterial(0)->setTechnique("lit");
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
_sprite->getMaterial(0)->setTechnique("normal");
|
_mesh->getMaterial(0)->setTechnique("normal");
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
_sprite->getMaterial(0)->setTechnique("outline");
|
_mesh->getMaterial(0)->setTechnique("outline");
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
|
@ -349,40 +349,40 @@ void Material_clone::onEnter()
|
||||||
{
|
{
|
||||||
MaterialSystemBaseTest::onEnter();
|
MaterialSystemBaseTest::onEnter();
|
||||||
|
|
||||||
auto sprite = Sprite3D::create("Sprite3DTest/boss1.obj");
|
auto mesh = MeshRenderer::create("MeshRendererTest/boss1.obj");
|
||||||
sprite->setScale(3);
|
mesh->setScale(3);
|
||||||
this->addChild(sprite);
|
this->addChild(mesh);
|
||||||
sprite->setPositionNormalized(Vec2(0.25f, 0.5f));
|
mesh->setPositionNormalized(Vec2(0.25f, 0.5f));
|
||||||
|
|
||||||
Material* mat = Material::createWithFilename("Materials/3d_effects.material");
|
Material* mat = Material::createWithFilename("Materials/3d_effects.material");
|
||||||
sprite->setMaterial(mat);
|
mesh->setMaterial(mat);
|
||||||
|
|
||||||
auto rot = RotateBy::create(5, Vec3(360.0f, 240.0f, 120.0f));
|
auto rot = RotateBy::create(5, Vec3(360.0f, 240.0f, 120.0f));
|
||||||
auto repeat = RepeatForever::create(rot);
|
auto repeat = RepeatForever::create(rot);
|
||||||
sprite->runAction(repeat);
|
mesh->runAction(repeat);
|
||||||
|
|
||||||
// sprite 2... using same material
|
// mesh 2... using same material
|
||||||
auto sprite2 = Sprite3D::create("Sprite3DTest/boss1.obj");
|
auto mesh2 = MeshRenderer::create("MeshRendererTest/boss1.obj");
|
||||||
sprite2->setScale(3);
|
mesh2->setScale(3);
|
||||||
this->addChild(sprite2);
|
this->addChild(mesh2);
|
||||||
sprite2->setPositionNormalized(Vec2(0.5f, 0.5f));
|
mesh2->setPositionNormalized(Vec2(0.5f, 0.5f));
|
||||||
sprite2->setMaterial(mat);
|
mesh2->setMaterial(mat);
|
||||||
sprite2->runAction(repeat->clone());
|
mesh2->runAction(repeat->clone());
|
||||||
|
|
||||||
// sprite 3... using cloned material
|
// mesh 3... using cloned material
|
||||||
auto sprite3 = Sprite3D::create("Sprite3DTest/boss1.obj");
|
auto mesh3 = MeshRenderer::create("MeshRendererTest/boss1.obj");
|
||||||
sprite3->setScale(3);
|
mesh3->setScale(3);
|
||||||
this->addChild(sprite3);
|
this->addChild(mesh3);
|
||||||
sprite3->setPositionNormalized(Vec2(0.75f, 0.5f));
|
mesh3->setPositionNormalized(Vec2(0.75f, 0.5f));
|
||||||
auto mat2 = mat->clone();
|
auto mat2 = mat->clone();
|
||||||
sprite3->setMaterial(mat2);
|
mesh3->setMaterial(mat2);
|
||||||
sprite3->runAction(repeat->clone());
|
mesh3->runAction(repeat->clone());
|
||||||
|
|
||||||
// testing clone
|
// testing clone
|
||||||
// should affect both sprite 1 and sprite 2
|
// should affect both mesh 1 and mesh 2
|
||||||
mat->setTechnique("outline");
|
mat->setTechnique("outline");
|
||||||
|
|
||||||
// should affect only sprite 3
|
// should affect only mesh 3
|
||||||
// mat2->setTechnique("normal");
|
// mat2->setTechnique("normal");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -39,19 +39,19 @@ public:
|
||||||
virtual std::string title() const override;
|
virtual std::string title() const override;
|
||||||
};
|
};
|
||||||
|
|
||||||
class Material_Sprite3DTest : public MaterialSystemBaseTest
|
class Material_MeshRendererTest : public MaterialSystemBaseTest
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(Material_Sprite3DTest);
|
CREATE_FUNC(Material_MeshRendererTest);
|
||||||
|
|
||||||
virtual void onEnter() override;
|
virtual void onEnter() override;
|
||||||
virtual std::string subtitle() const override;
|
virtual std::string subtitle() const override;
|
||||||
};
|
};
|
||||||
|
|
||||||
class Material_MultipleSprite3D : public MaterialSystemBaseTest
|
class Material_MultipleMeshRenderer : public MaterialSystemBaseTest
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(Material_MultipleSprite3D);
|
CREATE_FUNC(Material_MultipleMeshRenderer);
|
||||||
|
|
||||||
virtual void onEnter() override;
|
virtual void onEnter() override;
|
||||||
virtual std::string subtitle() const override;
|
virtual std::string subtitle() const override;
|
||||||
|
@ -110,7 +110,7 @@ public:
|
||||||
private:
|
private:
|
||||||
void changeMaterial(float dt);
|
void changeMaterial(float dt);
|
||||||
|
|
||||||
cocos2d::Sprite3D* _sprite;
|
cocos2d::MeshRenderer* _mesh;
|
||||||
int _techniqueState;
|
int _techniqueState;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -31,7 +31,7 @@
|
||||||
namespace cocos2d
|
namespace cocos2d
|
||||||
{
|
{
|
||||||
class Animate3D;
|
class Animate3D;
|
||||||
class Sprite3D;
|
class MeshRenderer;
|
||||||
class Delay;
|
class Delay;
|
||||||
class Ray;
|
class Ray;
|
||||||
class DrawNode3D;
|
class DrawNode3D;
|
||||||
|
@ -39,53 +39,53 @@ class GLProgramState;
|
||||||
class MotionStreak3D;
|
class MotionStreak3D;
|
||||||
} // namespace cocos2d
|
} // namespace cocos2d
|
||||||
|
|
||||||
DEFINE_TEST_SUITE(Sprite3DTests);
|
DEFINE_TEST_SUITE(MeshRendererTests);
|
||||||
|
|
||||||
class Sprite3DTestDemo : public TestCase
|
class MeshRendererTestDemo : public TestCase
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
// overrides
|
// overrides
|
||||||
virtual std::string title() const override;
|
virtual std::string title() const override;
|
||||||
|
|
||||||
virtual ~Sprite3DTestDemo();
|
virtual ~MeshRendererTestDemo();
|
||||||
};
|
};
|
||||||
|
|
||||||
class Sprite3DForceDepthTest : public Sprite3DTestDemo
|
class MeshRendererForceDepthTest : public MeshRendererTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(Sprite3DForceDepthTest);
|
CREATE_FUNC(MeshRendererForceDepthTest);
|
||||||
Sprite3DForceDepthTest();
|
MeshRendererForceDepthTest();
|
||||||
virtual std::string title() const override;
|
virtual std::string title() const override;
|
||||||
virtual std::string subtitle() const override;
|
virtual std::string subtitle() const override;
|
||||||
};
|
};
|
||||||
|
|
||||||
class Sprite3DEmptyTest : public Sprite3DTestDemo
|
class MeshRendererEmptyTest : public MeshRendererTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(Sprite3DEmptyTest);
|
CREATE_FUNC(MeshRendererEmptyTest);
|
||||||
Sprite3DEmptyTest();
|
MeshRendererEmptyTest();
|
||||||
virtual std::string title() const override;
|
virtual std::string title() const override;
|
||||||
virtual std::string subtitle() const override;
|
virtual std::string subtitle() const override;
|
||||||
};
|
};
|
||||||
|
|
||||||
class Sprite3DBasicTest : public Sprite3DTestDemo
|
class MeshRendererBasicTest : public MeshRendererTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(Sprite3DBasicTest);
|
CREATE_FUNC(MeshRendererBasicTest);
|
||||||
Sprite3DBasicTest();
|
MeshRendererBasicTest();
|
||||||
virtual std::string title() const override;
|
virtual std::string title() const override;
|
||||||
virtual std::string subtitle() const override;
|
virtual std::string subtitle() const override;
|
||||||
|
|
||||||
void addNewSpriteWithCoords(cocos2d::Vec2 p);
|
void addNewMeshWithCoords(cocos2d::Vec2 p);
|
||||||
void onTouchesEnded(const std::vector<cocos2d::Touch*>& touches, cocos2d::Event* event);
|
void onTouchesEnded(const std::vector<cocos2d::Touch*>& touches, cocos2d::Event* event);
|
||||||
};
|
};
|
||||||
|
|
||||||
class Sprite3DUVAnimationTest : public Sprite3DTestDemo
|
class MeshRendererUVAnimationTest : public MeshRendererTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(Sprite3DUVAnimationTest);
|
CREATE_FUNC(MeshRendererUVAnimationTest);
|
||||||
Sprite3DUVAnimationTest();
|
MeshRendererUVAnimationTest();
|
||||||
virtual ~Sprite3DUVAnimationTest();
|
virtual ~MeshRendererUVAnimationTest();
|
||||||
virtual std::string title() const override;
|
virtual std::string title() const override;
|
||||||
virtual std::string subtitle() const override;
|
virtual std::string subtitle() const override;
|
||||||
|
|
||||||
|
@ -101,7 +101,7 @@ protected:
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
class Sprite3DFakeShadowTest : public Sprite3DTestDemo
|
class MeshRendererFakeShadowTest : public MeshRendererTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
enum State
|
enum State
|
||||||
|
@ -111,9 +111,9 @@ public:
|
||||||
State_Move = 0x02,
|
State_Move = 0x02,
|
||||||
State_Rotate = 0x04
|
State_Rotate = 0x04
|
||||||
};
|
};
|
||||||
CREATE_FUNC(Sprite3DFakeShadowTest);
|
CREATE_FUNC(MeshRendererFakeShadowTest);
|
||||||
Sprite3DFakeShadowTest();
|
MeshRendererFakeShadowTest();
|
||||||
virtual ~Sprite3DFakeShadowTest();
|
virtual ~MeshRendererFakeShadowTest();
|
||||||
virtual std::string title() const override;
|
virtual std::string title() const override;
|
||||||
virtual std::string subtitle() const override;
|
virtual std::string subtitle() const override;
|
||||||
void Move(cocos2d::Ref* sender, int value);
|
void Move(cocos2d::Ref* sender, int value);
|
||||||
|
@ -129,8 +129,8 @@ private:
|
||||||
cocos2d::Camera* _camera;
|
cocos2d::Camera* _camera;
|
||||||
cocos2d::Vec3 _targetPos;
|
cocos2d::Vec3 _targetPos;
|
||||||
unsigned int _curState;
|
unsigned int _curState;
|
||||||
cocos2d::Sprite3D* _plane;
|
cocos2d::MeshRenderer* _plane;
|
||||||
cocos2d::Sprite3D* _orc;
|
cocos2d::MeshRenderer* _orc;
|
||||||
cocos2d::backend::ProgramState* _state = nullptr;
|
cocos2d::backend::ProgramState* _state = nullptr;
|
||||||
|
|
||||||
#if (CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID)
|
#if (CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID)
|
||||||
|
@ -138,12 +138,12 @@ private:
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
class Sprite3DLightMapTest : public Sprite3DTestDemo
|
class MeshRendererLightMapTest : public MeshRendererTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(Sprite3DLightMapTest);
|
CREATE_FUNC(MeshRendererLightMapTest);
|
||||||
Sprite3DLightMapTest();
|
MeshRendererLightMapTest();
|
||||||
virtual ~Sprite3DLightMapTest();
|
virtual ~MeshRendererLightMapTest();
|
||||||
virtual std::string title() const override;
|
virtual std::string title() const override;
|
||||||
virtual std::string subtitle() const override;
|
virtual std::string subtitle() const override;
|
||||||
void onTouchesMoved(const std::vector<cocos2d::Touch*>& touches, cocos2d::Event* event);
|
void onTouchesMoved(const std::vector<cocos2d::Touch*>& touches, cocos2d::Event* event);
|
||||||
|
@ -152,12 +152,12 @@ private:
|
||||||
cocos2d::Camera* _camera;
|
cocos2d::Camera* _camera;
|
||||||
};
|
};
|
||||||
|
|
||||||
class Sprite3DBasicToonShaderTest : public Sprite3DTestDemo
|
class MeshRendererBasicToonShaderTest : public MeshRendererTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(Sprite3DBasicToonShaderTest);
|
CREATE_FUNC(MeshRendererBasicToonShaderTest);
|
||||||
Sprite3DBasicToonShaderTest();
|
MeshRendererBasicToonShaderTest();
|
||||||
virtual ~Sprite3DBasicToonShaderTest();
|
virtual ~MeshRendererBasicToonShaderTest();
|
||||||
virtual std::string title() const override;
|
virtual std::string title() const override;
|
||||||
virtual std::string subtitle() const override;
|
virtual std::string subtitle() const override;
|
||||||
|
|
||||||
|
@ -169,62 +169,62 @@ protected:
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
class Sprite3DHitTest : public Sprite3DTestDemo
|
class MeshRendererHitTest : public MeshRendererTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(Sprite3DHitTest);
|
CREATE_FUNC(MeshRendererHitTest);
|
||||||
Sprite3DHitTest();
|
MeshRendererHitTest();
|
||||||
virtual std::string title() const override;
|
virtual std::string title() const override;
|
||||||
virtual std::string subtitle() const override;
|
virtual std::string subtitle() const override;
|
||||||
};
|
};
|
||||||
|
|
||||||
class Sprite3DEffectTest : public Sprite3DTestDemo
|
class MeshRendererEffectTest : public MeshRendererTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(Sprite3DEffectTest);
|
CREATE_FUNC(MeshRendererEffectTest);
|
||||||
Sprite3DEffectTest();
|
MeshRendererEffectTest();
|
||||||
virtual ~Sprite3DEffectTest();
|
virtual ~MeshRendererEffectTest();
|
||||||
virtual std::string title() const override;
|
virtual std::string title() const override;
|
||||||
virtual std::string subtitle() const override;
|
virtual std::string subtitle() const override;
|
||||||
|
|
||||||
void addNewSpriteWithCoords(cocos2d::Vec2 p);
|
void addNewMeshWithCoords(cocos2d::Vec2 p);
|
||||||
|
|
||||||
void onTouchesEnded(const std::vector<cocos2d::Touch*>& touches, cocos2d::Event* event);
|
void onTouchesEnded(const std::vector<cocos2d::Touch*>& touches, cocos2d::Event* event);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
std::vector<cocos2d::Sprite3D*> _sprites;
|
std::vector<cocos2d::MeshRenderer*> _meshes;
|
||||||
|
|
||||||
#if (CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID)
|
#if (CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID)
|
||||||
cocos2d::EventListenerCustom* _backToForegroundListener;
|
cocos2d::EventListenerCustom* _backToForegroundListener;
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
class AsyncLoadSprite3DTest : public Sprite3DTestDemo
|
class AsyncLoadMeshRendererTest : public MeshRendererTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(AsyncLoadSprite3DTest);
|
CREATE_FUNC(AsyncLoadMeshRendererTest);
|
||||||
AsyncLoadSprite3DTest();
|
AsyncLoadMeshRendererTest();
|
||||||
virtual ~AsyncLoadSprite3DTest();
|
virtual ~AsyncLoadMeshRendererTest();
|
||||||
virtual std::string title() const override;
|
virtual std::string title() const override;
|
||||||
virtual std::string subtitle() const override;
|
virtual std::string subtitle() const override;
|
||||||
|
|
||||||
void menuCallback_asyncLoadSprite(cocos2d::Ref* sender);
|
void menuCallback_asyncLoadMesh(cocos2d::Ref* sender);
|
||||||
|
|
||||||
void asyncLoad_Callback(cocos2d::Sprite3D* sprite, void* param);
|
void asyncLoad_Callback(cocos2d::MeshRenderer* mesh, void* param);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
std::vector<std::string> _paths; // model paths to be loaded
|
std::vector<std::string> _paths; // model paths to be loaded
|
||||||
};
|
};
|
||||||
|
|
||||||
class Sprite3DWithSkinTest : public Sprite3DTestDemo
|
class MeshRendererWithSkinTest : public MeshRendererTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(Sprite3DWithSkinTest);
|
CREATE_FUNC(MeshRendererWithSkinTest);
|
||||||
Sprite3DWithSkinTest();
|
MeshRendererWithSkinTest();
|
||||||
virtual std::string title() const override;
|
virtual std::string title() const override;
|
||||||
virtual std::string subtitle() const override;
|
virtual std::string subtitle() const override;
|
||||||
|
|
||||||
void addNewSpriteWithCoords(cocos2d::Vec2 p);
|
void addNewMeshWithCoords(cocos2d::Vec2 p);
|
||||||
|
|
||||||
void switchAnimationQualityCallback(cocos2d::Ref* sender);
|
void switchAnimationQualityCallback(cocos2d::Ref* sender);
|
||||||
void onTouchesEnded(const std::vector<cocos2d::Touch*>& touches, cocos2d::Event* event);
|
void onTouchesEnded(const std::vector<cocos2d::Touch*>& touches, cocos2d::Event* event);
|
||||||
|
@ -232,33 +232,33 @@ public:
|
||||||
std::string getAnimationQualityMessage() const;
|
std::string getAnimationQualityMessage() const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::vector<cocos2d::Sprite3D*> _sprits;
|
std::vector<cocos2d::MeshRenderer*> _meshes;
|
||||||
int _animateQuality;
|
int _animateQuality;
|
||||||
cocos2d::MenuItemFont* _menuItem;
|
cocos2d::MenuItemFont* _menuItem;
|
||||||
};
|
};
|
||||||
|
|
||||||
class Sprite3DWithSkinOutlineTest : public Sprite3DTestDemo
|
class MeshRendererWithSkinOutlineTest : public MeshRendererTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(Sprite3DWithSkinOutlineTest);
|
CREATE_FUNC(MeshRendererWithSkinOutlineTest);
|
||||||
Sprite3DWithSkinOutlineTest();
|
MeshRendererWithSkinOutlineTest();
|
||||||
virtual ~Sprite3DWithSkinOutlineTest();
|
virtual ~MeshRendererWithSkinOutlineTest();
|
||||||
virtual std::string title() const override;
|
virtual std::string title() const override;
|
||||||
virtual std::string subtitle() const override;
|
virtual std::string subtitle() const override;
|
||||||
|
|
||||||
void addNewSpriteWithCoords(cocos2d::Vec2 p);
|
void addNewMeshWithCoords(cocos2d::Vec2 p);
|
||||||
|
|
||||||
void onTouchesEnded(const std::vector<cocos2d::Touch*>& touches, cocos2d::Event* event);
|
void onTouchesEnded(const std::vector<cocos2d::Touch*>& touches, cocos2d::Event* event);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
std::vector<cocos2d::Sprite3D*> _sprites;
|
std::vector<cocos2d::MeshRenderer*> _meshes;
|
||||||
|
|
||||||
#if (CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID)
|
#if (CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID)
|
||||||
cocos2d::EventListenerCustom* _backToForegroundListener;
|
cocos2d::EventListenerCustom* _backToForegroundListener;
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
class Animate3DTest : public Sprite3DTestDemo
|
class Animate3DTest : public MeshRendererTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(Animate3DTest);
|
CREATE_FUNC(Animate3DTest);
|
||||||
|
@ -272,7 +272,7 @@ public:
|
||||||
virtual void update(float dt) override;
|
virtual void update(float dt) override;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void addSprite3D();
|
void addMeshRenderer();
|
||||||
|
|
||||||
enum class State
|
enum class State
|
||||||
{
|
{
|
||||||
|
@ -286,7 +286,7 @@ protected:
|
||||||
|
|
||||||
void renewCallBack();
|
void renewCallBack();
|
||||||
|
|
||||||
cocos2d::Sprite3D* _sprite;
|
cocos2d::MeshRenderer* _mesh;
|
||||||
|
|
||||||
cocos2d::Action* _swim;
|
cocos2d::Action* _swim;
|
||||||
cocos2d::Animate3D* _hurt;
|
cocos2d::Animate3D* _hurt;
|
||||||
|
@ -298,7 +298,7 @@ protected:
|
||||||
cocos2d::MoveTo* _moveAction;
|
cocos2d::MoveTo* _moveAction;
|
||||||
};
|
};
|
||||||
|
|
||||||
class AttachmentTest : public Sprite3DTestDemo
|
class AttachmentTest : public MeshRendererTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(AttachmentTest);
|
CREATE_FUNC(AttachmentTest);
|
||||||
|
@ -308,22 +308,22 @@ public:
|
||||||
|
|
||||||
void onTouchesEnded(const std::vector<cocos2d::Touch*>& touches, cocos2d::Event* event);
|
void onTouchesEnded(const std::vector<cocos2d::Touch*>& touches, cocos2d::Event* event);
|
||||||
|
|
||||||
void addNewSpriteWithCoords(cocos2d::Vec2 p);
|
void addNewMeshWithCoords(cocos2d::Vec2 p);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
bool _hasWeapon;
|
bool _hasWeapon;
|
||||||
cocos2d::Sprite3D* _sprite;
|
cocos2d::MeshRenderer* _mesh;
|
||||||
};
|
};
|
||||||
|
|
||||||
class Sprite3DReskinTest : public Sprite3DTestDemo
|
class MeshRendererReskinTest : public MeshRendererTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(Sprite3DReskinTest);
|
CREATE_FUNC(MeshRendererReskinTest);
|
||||||
Sprite3DReskinTest();
|
MeshRendererReskinTest();
|
||||||
virtual std::string title() const override;
|
virtual std::string title() const override;
|
||||||
virtual std::string subtitle() const override;
|
virtual std::string subtitle() const override;
|
||||||
void onTouchesEnded(const std::vector<cocos2d::Touch*>& touches, cocos2d::Event* event);
|
void onTouchesEnded(const std::vector<cocos2d::Touch*>& touches, cocos2d::Event* event);
|
||||||
void addNewSpriteWithCoords(cocos2d::Vec2 p);
|
void addNewMeshWithCoords(cocos2d::Vec2 p);
|
||||||
|
|
||||||
void menuCallback_reSkin(cocos2d::Ref* sender);
|
void menuCallback_reSkin(cocos2d::Ref* sender);
|
||||||
|
|
||||||
|
@ -344,19 +344,19 @@ protected:
|
||||||
|
|
||||||
std::vector<std::string> _skins[(int)SkinType::MAX_TYPE]; // all skins
|
std::vector<std::string> _skins[(int)SkinType::MAX_TYPE]; // all skins
|
||||||
int _curSkin[(int)SkinType::MAX_TYPE]; // current skin index
|
int _curSkin[(int)SkinType::MAX_TYPE]; // current skin index
|
||||||
cocos2d::Sprite3D* _sprite;
|
cocos2d::MeshRenderer* _mesh;
|
||||||
};
|
};
|
||||||
|
|
||||||
class Sprite3DWithOBBPerformanceTest : public Sprite3DTestDemo
|
class MeshRendererWithOBBPerformanceTest : public MeshRendererTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(Sprite3DWithOBBPerformanceTest);
|
CREATE_FUNC(MeshRendererWithOBBPerformanceTest);
|
||||||
Sprite3DWithOBBPerformanceTest();
|
MeshRendererWithOBBPerformanceTest();
|
||||||
virtual std::string title() const override;
|
virtual std::string title() const override;
|
||||||
virtual std::string subtitle() const override;
|
virtual std::string subtitle() const override;
|
||||||
virtual void update(float dt) override;
|
virtual void update(float dt) override;
|
||||||
void addNewOBBWithCoords(cocos2d::Vec2 p);
|
void addNewOBBWithCoords(cocos2d::Vec2 p);
|
||||||
void addNewSpriteWithCoords(cocos2d::Vec2 p);
|
void addNewMeshWithCoords(cocos2d::Vec2 p);
|
||||||
void onTouchesBegan(const std::vector<cocos2d::Touch*>& touches, cocos2d::Event* event);
|
void onTouchesBegan(const std::vector<cocos2d::Touch*>& touches, cocos2d::Event* event);
|
||||||
void onTouchesEnded(const std::vector<cocos2d::Touch*>& touches, cocos2d::Event* event);
|
void onTouchesEnded(const std::vector<cocos2d::Touch*>& touches, cocos2d::Event* event);
|
||||||
void onTouchesMoved(const std::vector<cocos2d::Touch*>& touches, cocos2d::Event* event);
|
void onTouchesMoved(const std::vector<cocos2d::Touch*>& touches, cocos2d::Event* event);
|
||||||
|
@ -366,7 +366,7 @@ public:
|
||||||
void delOBBWithCount(float value);
|
void delOBBWithCount(float value);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
cocos2d::Sprite3D* _sprite;
|
cocos2d::MeshRenderer* _mesh;
|
||||||
std::vector<cocos2d::OBB> _obb;
|
std::vector<cocos2d::OBB> _obb;
|
||||||
cocos2d::DrawNode3D* _drawOBB;
|
cocos2d::DrawNode3D* _drawOBB;
|
||||||
cocos2d::Label* _labelCubeCount;
|
cocos2d::Label* _labelCubeCount;
|
||||||
|
@ -386,23 +386,23 @@ protected:
|
||||||
void calculateRayByLocationInView(cocos2d::Ray* ray, const cocos2d::Vec2& location);
|
void calculateRayByLocationInView(cocos2d::Ray* ray, const cocos2d::Vec2& location);
|
||||||
};
|
};
|
||||||
|
|
||||||
class Sprite3DMirrorTest : public Sprite3DTestDemo
|
class MeshRendererMirrorTest : public MeshRendererTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(Sprite3DMirrorTest);
|
CREATE_FUNC(MeshRendererMirrorTest);
|
||||||
Sprite3DMirrorTest();
|
MeshRendererMirrorTest();
|
||||||
virtual std::string title() const override;
|
virtual std::string title() const override;
|
||||||
virtual std::string subtitle() const override;
|
virtual std::string subtitle() const override;
|
||||||
|
|
||||||
void addNewSpriteWithCoords(cocos2d::Vec2 p);
|
void addNewMeshWithCoords(cocos2d::Vec2 p);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
bool _hasWeapon;
|
bool _hasWeapon;
|
||||||
cocos2d::Sprite3D* _sprite;
|
cocos2d::MeshRenderer* _mesh;
|
||||||
cocos2d::Sprite3D* _mirrorSprite;
|
cocos2d::MeshRenderer* _mirrorMesh;
|
||||||
};
|
};
|
||||||
|
|
||||||
class QuaternionTest : public Sprite3DTestDemo
|
class QuaternionTest : public MeshRendererTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(QuaternionTest);
|
CREATE_FUNC(QuaternionTest);
|
||||||
|
@ -410,22 +410,22 @@ public:
|
||||||
virtual std::string title() const override;
|
virtual std::string title() const override;
|
||||||
virtual std::string subtitle() const override;
|
virtual std::string subtitle() const override;
|
||||||
|
|
||||||
void addNewSpriteWithCoords(cocos2d::Vec2 p);
|
void addNewMeshWithCoords(cocos2d::Vec2 p);
|
||||||
virtual void update(float delta) override;
|
virtual void update(float delta) override;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
cocos2d::Sprite3D* _sprite;
|
cocos2d::MeshRenderer* _mesh;
|
||||||
float _arcSpeed;
|
float _arcSpeed;
|
||||||
float _radius;
|
float _radius;
|
||||||
float _accAngle;
|
float _accAngle;
|
||||||
};
|
};
|
||||||
|
|
||||||
// 3d + 2d use case
|
// 3d + 2d use case
|
||||||
class UseCaseSprite3D : public Sprite3DTestDemo
|
class UseCaseMeshRenderer : public MeshRendererTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(UseCaseSprite3D);
|
CREATE_FUNC(UseCaseMeshRenderer);
|
||||||
UseCaseSprite3D();
|
UseCaseMeshRenderer();
|
||||||
virtual std::string title() const override;
|
virtual std::string title() const override;
|
||||||
virtual std::string subtitle() const override;
|
virtual std::string subtitle() const override;
|
||||||
|
|
||||||
|
@ -448,7 +448,7 @@ protected:
|
||||||
};
|
};
|
||||||
|
|
||||||
// node animation test, cocos2d-x supports both skeletal animation and node animation
|
// node animation test, cocos2d-x supports both skeletal animation and node animation
|
||||||
class NodeAnimationTest : public Sprite3DTestDemo
|
class NodeAnimationTest : public MeshRendererTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(NodeAnimationTest);
|
CREATE_FUNC(NodeAnimationTest);
|
||||||
|
@ -456,10 +456,10 @@ public:
|
||||||
virtual std::string title() const override;
|
virtual std::string title() const override;
|
||||||
virtual std::string subtitle() const override;
|
virtual std::string subtitle() const override;
|
||||||
|
|
||||||
void addNewSpriteWithCoords(cocos2d::Vec2 p);
|
void addNewMeshWithCoords(cocos2d::Vec2 p);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
std::vector<cocos2d::Sprite3D*> _sprites;
|
std::vector<cocos2d::MeshRenderer*> _meshes;
|
||||||
int _vectorIndex;
|
int _vectorIndex;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -469,23 +469,23 @@ class TextureCube;
|
||||||
class Skybox;
|
class Skybox;
|
||||||
} // namespace cocos2d
|
} // namespace cocos2d
|
||||||
|
|
||||||
class Sprite3DCubeMapTest : public Sprite3DTestDemo
|
class MeshRendererCubeMapTest : public MeshRendererTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(Sprite3DCubeMapTest);
|
CREATE_FUNC(MeshRendererCubeMapTest);
|
||||||
Sprite3DCubeMapTest();
|
MeshRendererCubeMapTest();
|
||||||
~Sprite3DCubeMapTest();
|
~MeshRendererCubeMapTest();
|
||||||
virtual std::string title() const override;
|
virtual std::string title() const override;
|
||||||
virtual std::string subtitle() const override;
|
virtual std::string subtitle() const override;
|
||||||
|
|
||||||
void addNewSpriteWithCoords(cocos2d::Vec2);
|
void addNewMeshWithCoords(cocos2d::Vec2);
|
||||||
|
|
||||||
void onTouchesMoved(const std::vector<cocos2d::Touch*>& touches, cocos2d::Event* event);
|
void onTouchesMoved(const std::vector<cocos2d::Touch*>& touches, cocos2d::Event* event);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
cocos2d::TextureCube* _textureCube;
|
cocos2d::TextureCube* _textureCube;
|
||||||
cocos2d::Skybox* _skyBox;
|
cocos2d::Skybox* _skyBox;
|
||||||
cocos2d::Sprite3D* _teapot;
|
cocos2d::MeshRenderer* _teapot;
|
||||||
cocos2d::Camera* _camera;
|
cocos2d::Camera* _camera;
|
||||||
|
|
||||||
#if (CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID)
|
#if (CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID)
|
||||||
|
@ -494,7 +494,7 @@ protected:
|
||||||
};
|
};
|
||||||
|
|
||||||
/// issue 9767 setGLProgram
|
/// issue 9767 setGLProgram
|
||||||
class Issue9767 : public Sprite3DTestDemo
|
class Issue9767 : public MeshRendererTestDemo
|
||||||
{
|
{
|
||||||
enum class ShaderType
|
enum class ShaderType
|
||||||
{
|
{
|
||||||
|
@ -513,21 +513,21 @@ public:
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
ShaderType _shaderType;
|
ShaderType _shaderType;
|
||||||
cocos2d::Sprite3D* _sprite;
|
cocos2d::MeshRenderer* _mesh;
|
||||||
};
|
};
|
||||||
|
|
||||||
/// Clipping Sprite3D
|
/// Clipping MeshRenderer
|
||||||
class Sprite3DClippingTest : public Sprite3DTestDemo
|
class MeshRendererClippingTest : public MeshRendererTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(Sprite3DClippingTest);
|
CREATE_FUNC(MeshRendererClippingTest);
|
||||||
Sprite3DClippingTest();
|
MeshRendererClippingTest();
|
||||||
~Sprite3DClippingTest();
|
~MeshRendererClippingTest();
|
||||||
virtual std::string title() const override;
|
virtual std::string title() const override;
|
||||||
virtual std::string subtitle() const override;
|
virtual std::string subtitle() const override;
|
||||||
};
|
};
|
||||||
|
|
||||||
class Animate3DCallbackTest : public Sprite3DTestDemo
|
class Animate3DCallbackTest : public MeshRendererTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(Animate3DCallbackTest);
|
CREATE_FUNC(Animate3DCallbackTest);
|
||||||
|
@ -537,10 +537,10 @@ public:
|
||||||
virtual std::string subtitle() const override;
|
virtual std::string subtitle() const override;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
cocos2d::Sprite3D* _sprite3d;
|
cocos2d::MeshRenderer* _meshRenderer;
|
||||||
};
|
};
|
||||||
|
|
||||||
class CameraBackgroundClearTest : public Sprite3DTestDemo
|
class CameraBackgroundClearTest : public MeshRendererTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(CameraBackgroundClearTest);
|
CREATE_FUNC(CameraBackgroundClearTest);
|
||||||
|
@ -555,24 +555,24 @@ protected:
|
||||||
cocos2d::Label* _label;
|
cocos2d::Label* _label;
|
||||||
};
|
};
|
||||||
|
|
||||||
class Sprite3DVertexColorTest : public Sprite3DTestDemo
|
class MeshRendererVertexColorTest : public MeshRendererTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(Sprite3DVertexColorTest);
|
CREATE_FUNC(MeshRendererVertexColorTest);
|
||||||
Sprite3DVertexColorTest();
|
MeshRendererVertexColorTest();
|
||||||
virtual std::string title() const override;
|
virtual std::string title() const override;
|
||||||
virtual std::string subtitle() const override;
|
virtual std::string subtitle() const override;
|
||||||
|
|
||||||
virtual ~Sprite3DVertexColorTest();
|
virtual ~MeshRendererVertexColorTest();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
cocos2d::Sprite3D* _sprite;
|
cocos2d::MeshRenderer* _mesh;
|
||||||
#if (CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID)
|
#if (CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID)
|
||||||
cocos2d::EventListenerCustom* _backToForegroundListener;
|
cocos2d::EventListenerCustom* _backToForegroundListener;
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
class MotionStreak3DTest : public Sprite3DTestDemo
|
class MotionStreak3DTest : public MeshRendererTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(MotionStreak3DTest);
|
CREATE_FUNC(MotionStreak3DTest);
|
||||||
|
@ -582,27 +582,27 @@ public:
|
||||||
virtual void update(float delta) override;
|
virtual void update(float delta) override;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
cocos2d::Sprite3D* _sprite;
|
cocos2d::MeshRenderer* _mesh;
|
||||||
cocos2d::MotionStreak3D* _streak;
|
cocos2d::MotionStreak3D* _streak;
|
||||||
};
|
};
|
||||||
|
|
||||||
class Sprite3DNormalMappingTest : public Sprite3DTestDemo
|
class MeshRendererNormalMappingTest : public MeshRendererTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(Sprite3DNormalMappingTest);
|
CREATE_FUNC(MeshRendererNormalMappingTest);
|
||||||
Sprite3DNormalMappingTest();
|
MeshRendererNormalMappingTest();
|
||||||
virtual std::string title() const override;
|
virtual std::string title() const override;
|
||||||
virtual std::string subtitle() const override;
|
virtual std::string subtitle() const override;
|
||||||
virtual void update(float dt) override;
|
virtual void update(float dt) override;
|
||||||
|
|
||||||
virtual ~Sprite3DNormalMappingTest();
|
virtual ~MeshRendererNormalMappingTest();
|
||||||
};
|
};
|
||||||
|
|
||||||
class Sprite3DPropertyTest : public Sprite3DTestDemo
|
class MeshRendererPropertyTest : public MeshRendererTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(Sprite3DPropertyTest);
|
CREATE_FUNC(MeshRendererPropertyTest);
|
||||||
Sprite3DPropertyTest();
|
MeshRendererPropertyTest();
|
||||||
virtual std::string title() const override;
|
virtual std::string title() const override;
|
||||||
virtual std::string subtitle() const override;
|
virtual std::string subtitle() const override;
|
||||||
virtual void update(float delta) override;
|
virtual void update(float delta) override;
|
||||||
|
@ -611,15 +611,15 @@ public:
|
||||||
void removeUsedTexture(cocos2d::Ref* sender);
|
void removeUsedTexture(cocos2d::Ref* sender);
|
||||||
void resetTexture(cocos2d::Ref* sender);
|
void resetTexture(cocos2d::Ref* sender);
|
||||||
|
|
||||||
void refreshSpriteRender();
|
void refreshMeshRender();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
cocos2d::Sprite3D* _sprite;
|
cocos2d::MeshRenderer* _mesh;
|
||||||
cocos2d::Texture2D* _meshTex;
|
cocos2d::Texture2D* _meshTex;
|
||||||
std::string _texFile;
|
std::string _texFile;
|
||||||
};
|
};
|
||||||
|
|
||||||
class Issue16155Test : public Sprite3DTestDemo
|
class Issue16155Test : public MeshRendererTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(Issue16155Test);
|
CREATE_FUNC(Issue16155Test);
|
|
@ -146,10 +146,10 @@ void NavMeshBaseTestDemo::initScene()
|
||||||
rbDes.shape = Physics3DShape::createMesh(&trianglesList[0], (int)trianglesList.size() / 3);
|
rbDes.shape = Physics3DShape::createMesh(&trianglesList[0], (int)trianglesList.size() / 3);
|
||||||
auto rigidBody = Physics3DRigidBody::create(&rbDes);
|
auto rigidBody = Physics3DRigidBody::create(&rbDes);
|
||||||
auto component = Physics3DComponent::create(rigidBody);
|
auto component = Physics3DComponent::create(rigidBody);
|
||||||
auto sprite = Sprite3D::create("NavMesh/scene.obj");
|
auto mesh = MeshRenderer::create("NavMesh/scene.obj");
|
||||||
sprite->addComponent(component);
|
mesh->addComponent(component);
|
||||||
sprite->setCameraMask((unsigned short)CameraFlag::USER1);
|
mesh->setCameraMask((unsigned short)CameraFlag::USER1);
|
||||||
this->addChild(sprite);
|
this->addChild(mesh);
|
||||||
setPhysics3DDebugCamera(_camera);
|
setPhysics3DDebugCamera(_camera);
|
||||||
|
|
||||||
auto navMesh = NavMesh::create("NavMesh/all_tiles_tilecache.bin", "NavMesh/geomset.txt");
|
auto navMesh = NavMesh::create("NavMesh/all_tiles_tilecache.bin", "NavMesh/geomset.txt");
|
||||||
|
@ -168,13 +168,13 @@ void NavMeshBaseTestDemo::initScene()
|
||||||
|
|
||||||
void NavMeshBaseTestDemo::createAgent(const Vec3& pos)
|
void NavMeshBaseTestDemo::createAgent(const Vec3& pos)
|
||||||
{
|
{
|
||||||
std::string filePath = "Sprite3DTest/girl.c3b";
|
std::string filePath = "MeshRendererTest/girl.c3b";
|
||||||
NavMeshAgentParam param;
|
NavMeshAgentParam param;
|
||||||
param.radius = 2.0f;
|
param.radius = 2.0f;
|
||||||
param.height = 8.0f;
|
param.height = 8.0f;
|
||||||
param.maxSpeed = 8.0f;
|
param.maxSpeed = 8.0f;
|
||||||
auto agent = NavMeshAgent::create(param);
|
auto agent = NavMeshAgent::create(param);
|
||||||
auto agentNode = Sprite3D::create(filePath);
|
auto agentNode = MeshRenderer::create(filePath);
|
||||||
agent->setOrientationRefAxes(Vec3(-1.0f, 0.0f, 1.0f));
|
agent->setOrientationRefAxes(Vec3(-1.0f, 0.0f, 1.0f));
|
||||||
AgentUserData* data = new AgentUserData{0.0f};
|
AgentUserData* data = new AgentUserData{0.0f};
|
||||||
agent->setUserData(data);
|
agent->setUserData(data);
|
||||||
|
@ -201,7 +201,7 @@ void NavMeshBaseTestDemo::createAgent(const Vec3& pos)
|
||||||
void NavMeshBaseTestDemo::createObstacle(const Vec3& pos)
|
void NavMeshBaseTestDemo::createObstacle(const Vec3& pos)
|
||||||
{
|
{
|
||||||
auto obstacle = NavMeshObstacle::create(2.0f, 8.0f);
|
auto obstacle = NavMeshObstacle::create(2.0f, 8.0f);
|
||||||
auto obstacleNode = Sprite3D::create("Sprite3DTest/cylinder.c3b");
|
auto obstacleNode = MeshRenderer::create("MeshRendererTest/cylinder.c3b");
|
||||||
obstacleNode->setPosition3D(pos + Vec3(0.0f, -0.5f, 0.0f));
|
obstacleNode->setPosition3D(pos + Vec3(0.0f, -0.5f, 0.0f));
|
||||||
obstacleNode->setRotation3D(Vec3(-90.0f, 0.0f, 0.0f));
|
obstacleNode->setRotation3D(Vec3(-90.0f, 0.0f, 0.0f));
|
||||||
obstacleNode->setScale(0.3f);
|
obstacleNode->setScale(0.3f);
|
||||||
|
|
|
@ -48,7 +48,7 @@ Particle3DTests::Particle3DTests()
|
||||||
ADD_TEST_CASE(Particle3DCanOfWormsDemo);
|
ADD_TEST_CASE(Particle3DCanOfWormsDemo);
|
||||||
ADD_TEST_CASE(Particle3DRibbonTrailDemo);
|
ADD_TEST_CASE(Particle3DRibbonTrailDemo);
|
||||||
ADD_TEST_CASE(Particle3DWeaponTrailDemo);
|
ADD_TEST_CASE(Particle3DWeaponTrailDemo);
|
||||||
ADD_TEST_CASE(Particle3DWithSprite3DDemo);
|
ADD_TEST_CASE(Particle3DWithMeshRendererDemo);
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string Particle3DTestDemo::title() const
|
std::string Particle3DTestDemo::title() const
|
||||||
|
@ -63,7 +63,7 @@ bool Particle3DTestDemo::init()
|
||||||
|
|
||||||
FileUtils::getInstance()->addSearchPath("Particle3D/materials");
|
FileUtils::getInstance()->addSearchPath("Particle3D/materials");
|
||||||
FileUtils::getInstance()->addSearchPath("Particle3D/scripts");
|
FileUtils::getInstance()->addSearchPath("Particle3D/scripts");
|
||||||
FileUtils::getInstance()->addSearchPath("Sprite3DTest");
|
FileUtils::getInstance()->addSearchPath("MeshRendererTest");
|
||||||
// FileUtils::getInstance()->addSearchPath("Particle3D/textures");
|
// FileUtils::getInstance()->addSearchPath("Particle3D/textures");
|
||||||
|
|
||||||
Size size = Director::getInstance()->getWinSize();
|
Size size = Director::getInstance()->getWinSize();
|
||||||
|
@ -427,18 +427,18 @@ bool Particle3DWeaponTrailDemo::init()
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string Particle3DWithSprite3DDemo::subtitle() const
|
std::string Particle3DWithMeshRendererDemo::subtitle() const
|
||||||
{
|
{
|
||||||
return "Particle3DWithSprite3D";
|
return "Particle3DWithMeshRenderer";
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Particle3DWithSprite3DDemo::init()
|
bool Particle3DWithMeshRendererDemo::init()
|
||||||
{
|
{
|
||||||
if (!Particle3DTestDemo::init())
|
if (!Particle3DTestDemo::init())
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
std::string c3bfileName = "Sprite3DTest/orc.c3b";
|
std::string c3bfileName = "MeshRendererTest/orc.c3b";
|
||||||
auto sprite = Sprite3D::create(c3bfileName);
|
auto sprite = MeshRenderer::create(c3bfileName);
|
||||||
this->addChild(sprite);
|
this->addChild(sprite);
|
||||||
sprite->setPosition3D(Vec3(-20.0f, 0.0f, 0.0f));
|
sprite->setPosition3D(Vec3(-20.0f, 0.0f, 0.0f));
|
||||||
sprite->setRotation3D(Vec3(0, 180, 0));
|
sprite->setRotation3D(Vec3(0, 180, 0));
|
||||||
|
|
|
@ -223,12 +223,12 @@ public:
|
||||||
virtual bool init() override;
|
virtual bool init() override;
|
||||||
};
|
};
|
||||||
|
|
||||||
class Particle3DWithSprite3DDemo : public Particle3DTestDemo
|
class Particle3DWithMeshRendererDemo : public Particle3DTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CREATE_FUNC(Particle3DWithSprite3DDemo);
|
CREATE_FUNC(Particle3DWithMeshRendererDemo);
|
||||||
Particle3DWithSprite3DDemo(){};
|
Particle3DWithMeshRendererDemo(){};
|
||||||
virtual ~Particle3DWithSprite3DDemo(){};
|
virtual ~Particle3DWithMeshRendererDemo(){};
|
||||||
|
|
||||||
virtual std::string subtitle() const override;
|
virtual std::string subtitle() const override;
|
||||||
|
|
||||||
|
|
|
@ -196,25 +196,25 @@ void Physics3DTestDemo::shootBox(const cocos2d::Vec3& des)
|
||||||
rbDes.originalTransform.translate(_camera->getPosition3D());
|
rbDes.originalTransform.translate(_camera->getPosition3D());
|
||||||
rbDes.mass = 1.f;
|
rbDes.mass = 1.f;
|
||||||
rbDes.shape = Physics3DShape::createBox(Vec3(0.5f, 0.5f, 0.5f));
|
rbDes.shape = Physics3DShape::createBox(Vec3(0.5f, 0.5f, 0.5f));
|
||||||
auto sprite = PhysicsSprite3D::create("Sprite3DTest/box.c3t", &rbDes);
|
auto mesh = PhysicsMeshRenderer::create("MeshRendererTest/box.c3t", &rbDes);
|
||||||
sprite->setTexture("Images/Icon.png");
|
mesh->setTexture("Images/Icon.png");
|
||||||
|
|
||||||
auto rigidBody = static_cast<Physics3DRigidBody*>(sprite->getPhysicsObj());
|
auto rigidBody = static_cast<Physics3DRigidBody*>(mesh->getPhysicsObj());
|
||||||
rigidBody->setLinearFactor(Vec3::ONE);
|
rigidBody->setLinearFactor(Vec3::ONE);
|
||||||
rigidBody->setLinearVelocity(linearVel);
|
rigidBody->setLinearVelocity(linearVel);
|
||||||
rigidBody->setAngularVelocity(Vec3::ZERO);
|
rigidBody->setAngularVelocity(Vec3::ZERO);
|
||||||
rigidBody->setCcdMotionThreshold(0.5f);
|
rigidBody->setCcdMotionThreshold(0.5f);
|
||||||
rigidBody->setCcdSweptSphereRadius(0.4f);
|
rigidBody->setCcdSweptSphereRadius(0.4f);
|
||||||
|
|
||||||
this->addChild(sprite);
|
this->addChild(mesh);
|
||||||
sprite->setPosition3D(_camera->getPosition3D());
|
mesh->setPosition3D(_camera->getPosition3D());
|
||||||
sprite->setScale(0.5f);
|
mesh->setScale(0.5f);
|
||||||
sprite->syncNodeToPhysics();
|
mesh->syncNodeToPhysics();
|
||||||
|
|
||||||
// optimize, only sync node to physics
|
// optimize, only sync node to physics
|
||||||
sprite->setSyncFlag(Physics3DComponent::PhysicsSyncFlag::PHYSICS_TO_NODE); // sync node to physics
|
mesh->setSyncFlag(Physics3DComponent::PhysicsSyncFlag::PHYSICS_TO_NODE); // sync node to physics
|
||||||
|
|
||||||
sprite->setCameraMask((unsigned short)CameraFlag::USER1);
|
mesh->setCameraMask((unsigned short)CameraFlag::USER1);
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string BasicPhysics3DDemo::subtitle() const
|
std::string BasicPhysics3DDemo::subtitle() const
|
||||||
|
@ -232,8 +232,8 @@ bool BasicPhysics3DDemo::init()
|
||||||
rbDes.mass = 0.0f;
|
rbDes.mass = 0.0f;
|
||||||
rbDes.shape = Physics3DShape::createBox(Vec3(60.0f, 1.0f, 60.0f));
|
rbDes.shape = Physics3DShape::createBox(Vec3(60.0f, 1.0f, 60.0f));
|
||||||
|
|
||||||
auto floor = PhysicsSprite3D::create("Sprite3DTest/box.c3t", &rbDes);
|
auto floor = PhysicsMeshRenderer::create("MeshRendererTest/box.c3t", &rbDes);
|
||||||
floor->setTexture("Sprite3DTest/plane.png");
|
floor->setTexture("MeshRendererTest/plane.png");
|
||||||
floor->setScaleX(60);
|
floor->setScaleX(60);
|
||||||
floor->setScaleZ(60);
|
floor->setScaleZ(60);
|
||||||
this->addChild(floor);
|
this->addChild(floor);
|
||||||
|
@ -242,7 +242,7 @@ bool BasicPhysics3DDemo::init()
|
||||||
// static object sync is not needed
|
// static object sync is not needed
|
||||||
floor->setSyncFlag(Physics3DComponent::PhysicsSyncFlag::NONE);
|
floor->setSyncFlag(Physics3DComponent::PhysicsSyncFlag::NONE);
|
||||||
|
|
||||||
// create several boxes using PhysicsSprite3D
|
// create several boxes using PhysicsMeshRenderer
|
||||||
rbDes.mass = 1.f;
|
rbDes.mass = 1.f;
|
||||||
rbDes.shape = Physics3DShape::createBox(Vec3(0.8f, 0.8f, 0.8f));
|
rbDes.shape = Physics3DShape::createBox(Vec3(0.8f, 0.8f, 0.8f));
|
||||||
float start_x = START_POS_X - ARRAY_SIZE_X / 2;
|
float start_x = START_POS_X - ARRAY_SIZE_X / 2;
|
||||||
|
@ -259,14 +259,14 @@ bool BasicPhysics3DDemo::init()
|
||||||
float y = 5.0 + 1.0 * k + start_y;
|
float y = 5.0 + 1.0 * k + start_y;
|
||||||
float z = 1.0 * j + start_z;
|
float z = 1.0 * j + start_z;
|
||||||
|
|
||||||
auto sprite = PhysicsSprite3D::create("Sprite3DTest/box.c3t", &rbDes);
|
auto mesh = PhysicsMeshRenderer::create("MeshRendererTest/box.c3t", &rbDes);
|
||||||
sprite->setTexture("Images/CyanSquare.png");
|
mesh->setTexture("Images/CyanSquare.png");
|
||||||
sprite->setPosition3D(Vec3(x, y, z));
|
mesh->setPosition3D(Vec3(x, y, z));
|
||||||
sprite->syncNodeToPhysics();
|
mesh->syncNodeToPhysics();
|
||||||
sprite->setSyncFlag(Physics3DComponent::PhysicsSyncFlag::PHYSICS_TO_NODE);
|
mesh->setSyncFlag(Physics3DComponent::PhysicsSyncFlag::PHYSICS_TO_NODE);
|
||||||
sprite->setCameraMask((unsigned short)CameraFlag::USER1);
|
mesh->setCameraMask((unsigned short)CameraFlag::USER1);
|
||||||
sprite->setScale(0.8f);
|
mesh->setScale(0.8f);
|
||||||
this->addChild(sprite);
|
this->addChild(mesh);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -295,8 +295,8 @@ bool Physics3DKinematicDemo::init()
|
||||||
Physics3DRigidBodyDes rbDes;
|
Physics3DRigidBodyDes rbDes;
|
||||||
rbDes.mass = 0.0f;
|
rbDes.mass = 0.0f;
|
||||||
rbDes.shape = Physics3DShape::createBox(Vec3(60.0f, 1.0f, 60.0f));
|
rbDes.shape = Physics3DShape::createBox(Vec3(60.0f, 1.0f, 60.0f));
|
||||||
auto floor = PhysicsSprite3D::create("Sprite3DTest/box.c3t", &rbDes);
|
auto floor = PhysicsMeshRenderer::create("MeshRendererTest/box.c3t", &rbDes);
|
||||||
floor->setTexture("Sprite3DTest/plane.png");
|
floor->setTexture("MeshRendererTest/plane.png");
|
||||||
floor->setScaleX(60);
|
floor->setScaleX(60);
|
||||||
floor->setScaleZ(60);
|
floor->setScaleZ(60);
|
||||||
floor->setPosition3D(Vec3(0.f, -1.f, 0.f));
|
floor->setPosition3D(Vec3(0.f, -1.f, 0.f));
|
||||||
|
@ -312,18 +312,18 @@ bool Physics3DKinematicDemo::init()
|
||||||
rbDes.mass = 0.f; // kinematic objects. zero mass so that it can not be affected by other dynamic objects
|
rbDes.mass = 0.f; // kinematic objects. zero mass so that it can not be affected by other dynamic objects
|
||||||
rbDes.shape = Physics3DShape::createBox(Vec3(2.0f, 2.0f, 2.0f));
|
rbDes.shape = Physics3DShape::createBox(Vec3(2.0f, 2.0f, 2.0f));
|
||||||
|
|
||||||
auto sprite = PhysicsSprite3D::create("Sprite3DTest/box.c3t", &rbDes);
|
auto mesh = PhysicsMeshRenderer::create("MeshRendererTest/box.c3t", &rbDes);
|
||||||
sprite->setTexture("Images/CyanSquare.png");
|
mesh->setTexture("Images/CyanSquare.png");
|
||||||
sprite->setCameraMask((unsigned short)CameraFlag::USER1);
|
mesh->setCameraMask((unsigned short)CameraFlag::USER1);
|
||||||
auto rigidBody = static_cast<Physics3DRigidBody*>(sprite->getPhysicsObj());
|
auto rigidBody = static_cast<Physics3DRigidBody*>(mesh->getPhysicsObj());
|
||||||
rigidBody->setKinematic(true);
|
rigidBody->setKinematic(true);
|
||||||
|
|
||||||
this->addChild(sprite);
|
this->addChild(mesh);
|
||||||
|
|
||||||
sprite->setScale(2.0f);
|
mesh->setScale(2.0f);
|
||||||
sprite->setPosition3D(Vec3(-15.0f, 0.0f, 15.0f - 15.0f * i));
|
mesh->setPosition3D(Vec3(-15.0f, 0.0f, 15.0f - 15.0f * i));
|
||||||
auto moveby = MoveBy::create(2.0f + i, Vec3(30.0f, 0.0f, 0.0f));
|
auto moveby = MoveBy::create(2.0f + i, Vec3(30.0f, 0.0f, 0.0f));
|
||||||
sprite->runAction(RepeatForever::create(Sequence::create(moveby, moveby->reverse(), nullptr)));
|
mesh->runAction(RepeatForever::create(Sequence::create(moveby, moveby->reverse(), nullptr)));
|
||||||
}
|
}
|
||||||
|
|
||||||
// create Dynamic
|
// create Dynamic
|
||||||
|
@ -347,15 +347,15 @@ bool Physics3DKinematicDemo::init()
|
||||||
rbDes.originalTransform.setIdentity();
|
rbDes.originalTransform.setIdentity();
|
||||||
rbDes.originalTransform.translate(x, y, z);
|
rbDes.originalTransform.translate(x, y, z);
|
||||||
|
|
||||||
auto sprite = PhysicsSprite3D::create("Sprite3DTest/sphere.c3b", &rbDes);
|
auto mesh = PhysicsMeshRenderer::create("MeshRendererTest/sphere.c3b", &rbDes);
|
||||||
sprite->setTexture("Sprite3DTest/plane.png");
|
mesh->setTexture("MeshRendererTest/plane.png");
|
||||||
sprite->setCameraMask((unsigned short)CameraFlag::USER1);
|
mesh->setCameraMask((unsigned short)CameraFlag::USER1);
|
||||||
sprite->setScale(1.0f / sprite->getContentSize().width);
|
mesh->setScale(1.0f / mesh->getContentSize().width);
|
||||||
this->addChild(sprite);
|
this->addChild(mesh);
|
||||||
sprite->setPosition3D(Vec3(x, y, z));
|
mesh->setPosition3D(Vec3(x, y, z));
|
||||||
sprite->syncNodeToPhysics();
|
mesh->syncNodeToPhysics();
|
||||||
|
|
||||||
sprite->setSyncFlag(Physics3DComponent::PhysicsSyncFlag::PHYSICS_TO_NODE);
|
mesh->setSyncFlag(Physics3DComponent::PhysicsSyncFlag::PHYSICS_TO_NODE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -370,11 +370,11 @@ bool Physics3DConstraintDemo::init()
|
||||||
if (!Physics3DTestDemo::init())
|
if (!Physics3DTestDemo::init())
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
// PhysicsSprite3D = Sprite3D + Physics3DComponent
|
// PhysicsMeshRenderer = MeshRenderer + Physics3DComponent
|
||||||
Physics3DRigidBodyDes rbDes;
|
Physics3DRigidBodyDes rbDes;
|
||||||
rbDes.disableSleep = true;
|
rbDes.disableSleep = true;
|
||||||
// create box
|
// create box
|
||||||
auto sprite = Sprite3D::create("Sprite3DTest/orc.c3b");
|
auto mesh = MeshRenderer::create("MeshRendererTest/orc.c3b");
|
||||||
rbDes.mass = 10.f;
|
rbDes.mass = 10.f;
|
||||||
rbDes.shape = Physics3DShape::createBox(Vec3(5.0f, 5.0f, 5.0f));
|
rbDes.shape = Physics3DShape::createBox(Vec3(5.0f, 5.0f, 5.0f));
|
||||||
auto rigidBody = Physics3DRigidBody::create(&rbDes);
|
auto rigidBody = Physics3DRigidBody::create(&rbDes);
|
||||||
|
@ -382,11 +382,11 @@ bool Physics3DConstraintDemo::init()
|
||||||
Quaternion::createFromAxisAngle(Vec3(0.f, 1.f, 0.f), CC_DEGREES_TO_RADIANS(180), &quat);
|
Quaternion::createFromAxisAngle(Vec3(0.f, 1.f, 0.f), CC_DEGREES_TO_RADIANS(180), &quat);
|
||||||
auto component = Physics3DComponent::create(rigidBody, Vec3(0.f, -3.f, 0.f), quat);
|
auto component = Physics3DComponent::create(rigidBody, Vec3(0.f, -3.f, 0.f), quat);
|
||||||
|
|
||||||
sprite->addComponent(component);
|
mesh->addComponent(component);
|
||||||
addChild(sprite);
|
addChild(mesh);
|
||||||
sprite->setCameraMask((unsigned short)CameraFlag::USER1);
|
mesh->setCameraMask((unsigned short)CameraFlag::USER1);
|
||||||
sprite->setScale(0.4f);
|
mesh->setScale(0.4f);
|
||||||
sprite->setPosition3D(Vec3(-20.f, 5.f, 0.f));
|
mesh->setPosition3D(Vec3(-20.f, 5.f, 0.f));
|
||||||
// sync node position to physics
|
// sync node position to physics
|
||||||
component->syncNodeToPhysics();
|
component->syncNodeToPhysics();
|
||||||
// physics controlled, we will not set position for it, so we can skip sync node position to physics
|
// physics controlled, we will not set position for it, so we can skip sync node position to physics
|
||||||
|
@ -403,14 +403,14 @@ bool Physics3DConstraintDemo::init()
|
||||||
rbDes.shape = Physics3DShape::createBox(Vec3(8.0f, 8.0f, 1.f));
|
rbDes.shape = Physics3DShape::createBox(Vec3(8.0f, 8.0f, 1.f));
|
||||||
rigidBody = Physics3DRigidBody::create(&rbDes);
|
rigidBody = Physics3DRigidBody::create(&rbDes);
|
||||||
component = Physics3DComponent::create(rigidBody);
|
component = Physics3DComponent::create(rigidBody);
|
||||||
sprite = Sprite3D::create("Sprite3DTest/box.c3t");
|
mesh = MeshRenderer::create("MeshRendererTest/box.c3t");
|
||||||
sprite->setTexture("Sprite3DTest/plane.png");
|
mesh->setTexture("MeshRendererTest/plane.png");
|
||||||
sprite->setScaleX(8.f);
|
mesh->setScaleX(8.f);
|
||||||
sprite->setScaleY(8.f);
|
mesh->setScaleY(8.f);
|
||||||
sprite->setPosition3D(Vec3(5.f, 0.f, 0.f));
|
mesh->setPosition3D(Vec3(5.f, 0.f, 0.f));
|
||||||
sprite->addComponent(component);
|
mesh->addComponent(component);
|
||||||
sprite->setCameraMask((unsigned short)CameraFlag::USER1);
|
mesh->setCameraMask((unsigned short)CameraFlag::USER1);
|
||||||
this->addChild(sprite);
|
this->addChild(mesh);
|
||||||
component->syncNodeToPhysics();
|
component->syncNodeToPhysics();
|
||||||
rigidBody->setAngularVelocity(Vec3(0, 3, 0));
|
rigidBody->setAngularVelocity(Vec3(0, 3, 0));
|
||||||
constraint = Physics3DHingeConstraint::create(rigidBody, Vec3(4.f, 4.f, 0.5f), Vec3(0.f, 1.f, 0.f));
|
constraint = Physics3DHingeConstraint::create(rigidBody, Vec3(4.f, 4.f, 0.5f), Vec3(0.f, 1.f, 0.f));
|
||||||
|
@ -421,14 +421,14 @@ bool Physics3DConstraintDemo::init()
|
||||||
rbDes.shape = Physics3DShape::createBox(Vec3(3.0f, 2.0f, 3.f));
|
rbDes.shape = Physics3DShape::createBox(Vec3(3.0f, 2.0f, 3.f));
|
||||||
rigidBody = Physics3DRigidBody::create(&rbDes);
|
rigidBody = Physics3DRigidBody::create(&rbDes);
|
||||||
component = Physics3DComponent::create(rigidBody);
|
component = Physics3DComponent::create(rigidBody);
|
||||||
sprite = Sprite3D::create("Sprite3DTest/box.c3t");
|
mesh = MeshRenderer::create("MeshRendererTest/box.c3t");
|
||||||
sprite->setTexture("Sprite3DTest/plane.png");
|
mesh->setTexture("MeshRendererTest/plane.png");
|
||||||
sprite->setScaleX(3.f);
|
mesh->setScaleX(3.f);
|
||||||
sprite->setScaleZ(3.f);
|
mesh->setScaleZ(3.f);
|
||||||
sprite->setPosition3D(Vec3(30.f, 15.f, 0.f));
|
mesh->setPosition3D(Vec3(30.f, 15.f, 0.f));
|
||||||
sprite->addComponent(component);
|
mesh->addComponent(component);
|
||||||
sprite->setCameraMask((unsigned short)CameraFlag::USER1);
|
mesh->setCameraMask((unsigned short)CameraFlag::USER1);
|
||||||
this->addChild(sprite);
|
this->addChild(mesh);
|
||||||
component->syncNodeToPhysics();
|
component->syncNodeToPhysics();
|
||||||
rigidBody->setLinearVelocity(Vec3(0, 3, 0));
|
rigidBody->setLinearVelocity(Vec3(0, 3, 0));
|
||||||
|
|
||||||
|
@ -436,13 +436,13 @@ bool Physics3DConstraintDemo::init()
|
||||||
rbDes.shape = Physics3DShape::createBox(Vec3(3.0f, 3.0f, 3.f));
|
rbDes.shape = Physics3DShape::createBox(Vec3(3.0f, 3.0f, 3.f));
|
||||||
auto rigidBodyB = Physics3DRigidBody::create(&rbDes);
|
auto rigidBodyB = Physics3DRigidBody::create(&rbDes);
|
||||||
component = Physics3DComponent::create(rigidBodyB);
|
component = Physics3DComponent::create(rigidBodyB);
|
||||||
sprite = Sprite3D::create("Sprite3DTest/box.c3t");
|
mesh = MeshRenderer::create("MeshRendererTest/box.c3t");
|
||||||
sprite->setTexture("Sprite3DTest/plane.png");
|
mesh->setTexture("MeshRendererTest/plane.png");
|
||||||
sprite->setScale(3.f);
|
mesh->setScale(3.f);
|
||||||
sprite->setPosition3D(Vec3(30.f, 5.f, 0.f));
|
mesh->setPosition3D(Vec3(30.f, 5.f, 0.f));
|
||||||
sprite->addComponent(component);
|
mesh->addComponent(component);
|
||||||
sprite->setCameraMask((unsigned short)CameraFlag::USER1);
|
mesh->setCameraMask((unsigned short)CameraFlag::USER1);
|
||||||
this->addChild(sprite);
|
this->addChild(mesh);
|
||||||
component->syncNodeToPhysics();
|
component->syncNodeToPhysics();
|
||||||
|
|
||||||
Mat4 frameInA, frameInB;
|
Mat4 frameInA, frameInB;
|
||||||
|
@ -460,13 +460,13 @@ bool Physics3DConstraintDemo::init()
|
||||||
rbDes.shape = Physics3DShape::createBox(Vec3(3.f, 3.f, 3.f));
|
rbDes.shape = Physics3DShape::createBox(Vec3(3.f, 3.f, 3.f));
|
||||||
rigidBody = Physics3DRigidBody::create(&rbDes);
|
rigidBody = Physics3DRigidBody::create(&rbDes);
|
||||||
component = Physics3DComponent::create(rigidBody);
|
component = Physics3DComponent::create(rigidBody);
|
||||||
sprite = Sprite3D::create("Sprite3DTest/box.c3t");
|
mesh = MeshRenderer::create("MeshRendererTest/box.c3t");
|
||||||
sprite->setTexture("Sprite3DTest/plane.png");
|
mesh->setTexture("MeshRendererTest/plane.png");
|
||||||
sprite->setScale(3.f);
|
mesh->setScale(3.f);
|
||||||
sprite->setPosition3D(Vec3(-10.f, 5.f, 0.f));
|
mesh->setPosition3D(Vec3(-10.f, 5.f, 0.f));
|
||||||
sprite->addComponent(component);
|
mesh->addComponent(component);
|
||||||
sprite->setCameraMask((unsigned short)CameraFlag::USER1);
|
mesh->setCameraMask((unsigned short)CameraFlag::USER1);
|
||||||
this->addChild(sprite);
|
this->addChild(mesh);
|
||||||
component->syncNodeToPhysics();
|
component->syncNodeToPhysics();
|
||||||
|
|
||||||
Mat4::createRotationZ(CC_DEGREES_TO_RADIANS(90), &frameInA);
|
Mat4::createRotationZ(CC_DEGREES_TO_RADIANS(90), &frameInA);
|
||||||
|
@ -483,13 +483,13 @@ bool Physics3DConstraintDemo::init()
|
||||||
rbDes.shape = Physics3DShape::createBox(Vec3(3.0f, 3.0f, 3.f));
|
rbDes.shape = Physics3DShape::createBox(Vec3(3.0f, 3.0f, 3.f));
|
||||||
rigidBody = Physics3DRigidBody::create(&rbDes);
|
rigidBody = Physics3DRigidBody::create(&rbDes);
|
||||||
component = Physics3DComponent::create(rigidBody);
|
component = Physics3DComponent::create(rigidBody);
|
||||||
sprite = Sprite3D::create("Sprite3DTest/box.c3t");
|
mesh = MeshRenderer::create("MeshRendererTest/box.c3t");
|
||||||
sprite->setTexture("Sprite3DTest/plane.png");
|
mesh->setTexture("MeshRendererTest/plane.png");
|
||||||
sprite->setScale(3.f);
|
mesh->setScale(3.f);
|
||||||
sprite->setPosition3D(Vec3(30.f, -5.f, 0.f));
|
mesh->setPosition3D(Vec3(30.f, -5.f, 0.f));
|
||||||
sprite->addComponent(component);
|
mesh->addComponent(component);
|
||||||
sprite->setCameraMask((unsigned short)CameraFlag::USER1);
|
mesh->setCameraMask((unsigned short)CameraFlag::USER1);
|
||||||
this->addChild(sprite);
|
this->addChild(mesh);
|
||||||
component->syncNodeToPhysics();
|
component->syncNodeToPhysics();
|
||||||
frameInA.setIdentity();
|
frameInA.setIdentity();
|
||||||
constraint = Physics3D6DofConstraint::create(rigidBody, frameInA, false);
|
constraint = Physics3D6DofConstraint::create(rigidBody, frameInA, false);
|
||||||
|
@ -617,30 +617,30 @@ bool Physics3DTerrainDemo::init()
|
||||||
float y = 5.0 + 1.0 * k + start_y;
|
float y = 5.0 + 1.0 * k + start_y;
|
||||||
float z = 1.0 * j + start_z;
|
float z = 1.0 * j + start_z;
|
||||||
|
|
||||||
auto sprite = PhysicsSprite3D::create("Sprite3DTest/sphere.c3b", &rbDes);
|
auto mesh = PhysicsMeshRenderer::create("MeshRendererTest/sphere.c3b", &rbDes);
|
||||||
sprite->setTexture("Sprite3DTest/plane.png");
|
mesh->setTexture("MeshRendererTest/plane.png");
|
||||||
sprite->setCameraMask((unsigned short)CameraFlag::USER1);
|
mesh->setCameraMask((unsigned short)CameraFlag::USER1);
|
||||||
sprite->setScale(1.0f / sprite->getContentSize().width);
|
mesh->setScale(1.0f / mesh->getContentSize().width);
|
||||||
sprite->setPosition3D(Vec3(x, y, z));
|
mesh->setPosition3D(Vec3(x, y, z));
|
||||||
this->addChild(sprite);
|
this->addChild(mesh);
|
||||||
sprite->syncNodeToPhysics();
|
mesh->syncNodeToPhysics();
|
||||||
sprite->setSyncFlag(Physics3DComponent::PhysicsSyncFlag::PHYSICS_TO_NODE);
|
mesh->setSyncFlag(Physics3DComponent::PhysicsSyncFlag::PHYSICS_TO_NODE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// create mesh
|
// create mesh
|
||||||
std::vector<Vec3> trianglesList = Bundle3D::getTrianglesList("Sprite3DTest/boss.c3b");
|
std::vector<Vec3> trianglesList = Bundle3D::getTrianglesList("MeshRendererTest/boss.c3b");
|
||||||
|
|
||||||
colliderDes.shape = Physics3DShape::createMesh(&trianglesList[0], (int)trianglesList.size() / 3);
|
colliderDes.shape = Physics3DShape::createMesh(&trianglesList[0], (int)trianglesList.size() / 3);
|
||||||
|
|
||||||
auto sprite = PhysicsSprite3D::createWithCollider("Sprite3DTest/boss.c3b", &colliderDes);
|
auto mesh = PhysicsMeshRenderer::createWithCollider("MeshRendererTest/boss.c3b", &colliderDes);
|
||||||
sprite->setRotation3D(Vec3(-90.0f, 0.0f, 0.0f));
|
mesh->setRotation3D(Vec3(-90.0f, 0.0f, 0.0f));
|
||||||
sprite->setPosition3D(Vec3(0.0f, 15.0f, 0.0f));
|
mesh->setPosition3D(Vec3(0.0f, 15.0f, 0.0f));
|
||||||
sprite->setCameraMask(2);
|
mesh->setCameraMask(2);
|
||||||
this->addChild(sprite);
|
this->addChild(mesh);
|
||||||
sprite->syncNodeToPhysics();
|
mesh->syncNodeToPhysics();
|
||||||
sprite->setSyncFlag(Physics3DComponent::PhysicsSyncFlag::NONE);
|
mesh->setSyncFlag(Physics3DComponent::PhysicsSyncFlag::NONE);
|
||||||
|
|
||||||
std::vector<std::pair<Physics3DShape*, Mat4>> shapeList;
|
std::vector<std::pair<Physics3DShape*, Mat4>> shapeList;
|
||||||
{
|
{
|
||||||
|
@ -668,13 +668,13 @@ bool Physics3DTerrainDemo::init()
|
||||||
rbDes.shape = Physics3DShape::createCompoundShape(shapeList);
|
rbDes.shape = Physics3DShape::createCompoundShape(shapeList);
|
||||||
auto rigidBody = Physics3DRigidBody::create(&rbDes);
|
auto rigidBody = Physics3DRigidBody::create(&rbDes);
|
||||||
component = Physics3DComponent::create(rigidBody);
|
component = Physics3DComponent::create(rigidBody);
|
||||||
auto sprite = Sprite3D::create("Sprite3DTest/orc.c3b");
|
auto mesh = MeshRenderer::create("MeshRendererTest/orc.c3b");
|
||||||
sprite->addComponent(component);
|
mesh->addComponent(component);
|
||||||
sprite->setRotation3D(Vec3(0.0f, 180.0f, 0.0f));
|
mesh->setRotation3D(Vec3(0.0f, 180.0f, 0.0f));
|
||||||
sprite->setPosition3D(Vec3(-5.0f, 20.0f, 0.0f));
|
mesh->setPosition3D(Vec3(-5.0f, 20.0f, 0.0f));
|
||||||
sprite->setScale(0.4f);
|
mesh->setScale(0.4f);
|
||||||
sprite->setCameraMask(2);
|
mesh->setCameraMask(2);
|
||||||
this->addChild(sprite);
|
this->addChild(mesh);
|
||||||
}
|
}
|
||||||
|
|
||||||
physicsScene->setPhysics3DDebugCamera(_camera);
|
physicsScene->setPhysics3DDebugCamera(_camera);
|
||||||
|
@ -700,7 +700,7 @@ bool Physics3DCollisionCallbackDemo::init()
|
||||||
Physics3DRigidBodyDes rbDes;
|
Physics3DRigidBodyDes rbDes;
|
||||||
|
|
||||||
float scale = 2.0f;
|
float scale = 2.0f;
|
||||||
std::vector<Vec3> trianglesList = Bundle3D::getTrianglesList("Sprite3DTest/boss.c3b");
|
std::vector<Vec3> trianglesList = Bundle3D::getTrianglesList("MeshRendererTest/boss.c3b");
|
||||||
for (auto& it : trianglesList)
|
for (auto& it : trianglesList)
|
||||||
{
|
{
|
||||||
it *= scale;
|
it *= scale;
|
||||||
|
@ -710,12 +710,12 @@ bool Physics3DCollisionCallbackDemo::init()
|
||||||
rbDes.shape = Physics3DShape::createMesh(&trianglesList[0], (int)trianglesList.size() / 3);
|
rbDes.shape = Physics3DShape::createMesh(&trianglesList[0], (int)trianglesList.size() / 3);
|
||||||
auto rigidBody = Physics3DRigidBody::create(&rbDes);
|
auto rigidBody = Physics3DRigidBody::create(&rbDes);
|
||||||
auto component = Physics3DComponent::create(rigidBody);
|
auto component = Physics3DComponent::create(rigidBody);
|
||||||
auto sprite = Sprite3D::create("Sprite3DTest/boss.c3b");
|
auto mesh = MeshRenderer::create("MeshRendererTest/boss.c3b");
|
||||||
sprite->addComponent(component);
|
mesh->addComponent(component);
|
||||||
sprite->setRotation3D(Vec3(-90.0f, 0.0f, 0.0f));
|
mesh->setRotation3D(Vec3(-90.0f, 0.0f, 0.0f));
|
||||||
sprite->setScale(scale);
|
mesh->setScale(scale);
|
||||||
sprite->setCameraMask((unsigned short)CameraFlag::USER1);
|
mesh->setCameraMask((unsigned short)CameraFlag::USER1);
|
||||||
this->addChild(sprite);
|
this->addChild(mesh);
|
||||||
// preload
|
// preload
|
||||||
//
|
//
|
||||||
rigidBody->setCollisionCallback([=](const Physics3DCollisionInfo& ci) {
|
rigidBody->setCollisionCallback([=](const Physics3DCollisionInfo& ci) {
|
||||||
|
@ -766,15 +766,15 @@ bool Physics3DColliderDemo::init()
|
||||||
auto playerBody = Physics3DRigidBody::create(&rbDes);
|
auto playerBody = Physics3DRigidBody::create(&rbDes);
|
||||||
auto component = Physics3DComponent::create(playerBody);
|
auto component = Physics3DComponent::create(playerBody);
|
||||||
playerBody->setKinematic(true);
|
playerBody->setKinematic(true);
|
||||||
auto sprite = Sprite3D::create("Sprite3DTest/box.c3t");
|
auto mesh = MeshRenderer::create("MeshRendererTest/box.c3t");
|
||||||
sprite->setTexture("Sprite3DTest/plane.png");
|
mesh->setTexture("MeshRendererTest/plane.png");
|
||||||
sprite->setScale(3.f);
|
mesh->setScale(3.f);
|
||||||
sprite->setPosition3D(Vec3(0.0f, 0.f, 30.f));
|
mesh->setPosition3D(Vec3(0.0f, 0.f, 30.f));
|
||||||
sprite->addComponent(component);
|
mesh->addComponent(component);
|
||||||
sprite->setCameraMask((unsigned short)CameraFlag::USER1);
|
mesh->setCameraMask((unsigned short)CameraFlag::USER1);
|
||||||
auto moveby = MoveBy::create(5.0f, Vec3(0.0f, 0.0f, -60.0f));
|
auto moveby = MoveBy::create(5.0f, Vec3(0.0f, 0.0f, -60.0f));
|
||||||
sprite->runAction(RepeatForever::create(Sequence::create(moveby, moveby->reverse(), nullptr)));
|
mesh->runAction(RepeatForever::create(Sequence::create(moveby, moveby->reverse(), nullptr)));
|
||||||
this->addChild(sprite);
|
this->addChild(mesh);
|
||||||
|
|
||||||
{
|
{
|
||||||
Physics3DColliderDes colliderDes;
|
Physics3DColliderDes colliderDes;
|
||||||
|
@ -793,8 +793,8 @@ bool Physics3DColliderDemo::init()
|
||||||
auto rigidBody = Physics3DRigidBody::create(&rbDes);
|
auto rigidBody = Physics3DRigidBody::create(&rbDes);
|
||||||
component = Physics3DComponent::create(rigidBody);
|
component = Physics3DComponent::create(rigidBody);
|
||||||
rigidBody->setKinematic(true);
|
rigidBody->setKinematic(true);
|
||||||
auto doorLeft = Sprite3D::create("Sprite3DTest/box.c3t");
|
auto doorLeft = MeshRenderer::create("MeshRendererTest/box.c3t");
|
||||||
doorLeft->setTexture("Sprite3DTest/plane.png");
|
doorLeft->setTexture("MeshRendererTest/plane.png");
|
||||||
doorLeft->setScaleX(10.0f);
|
doorLeft->setScaleX(10.0f);
|
||||||
doorLeft->setScaleY(10.0f);
|
doorLeft->setScaleY(10.0f);
|
||||||
doorLeft->setScaleZ(1.0f);
|
doorLeft->setScaleZ(1.0f);
|
||||||
|
@ -808,8 +808,8 @@ bool Physics3DColliderDemo::init()
|
||||||
rigidBody = Physics3DRigidBody::create(&rbDes);
|
rigidBody = Physics3DRigidBody::create(&rbDes);
|
||||||
component = Physics3DComponent::create(rigidBody);
|
component = Physics3DComponent::create(rigidBody);
|
||||||
rigidBody->setKinematic(true);
|
rigidBody->setKinematic(true);
|
||||||
auto doorRight = Sprite3D::create("Sprite3DTest/box.c3t");
|
auto doorRight = MeshRenderer::create("MeshRendererTest/box.c3t");
|
||||||
doorRight->setTexture("Sprite3DTest/plane.png");
|
doorRight->setTexture("MeshRendererTest/plane.png");
|
||||||
doorRight->setScaleX(10.0f);
|
doorRight->setScaleX(10.0f);
|
||||||
doorRight->setScaleY(10.0f);
|
doorRight->setScaleY(10.0f);
|
||||||
doorRight->setScaleZ(1.0f);
|
doorRight->setScaleZ(1.0f);
|
||||||
|
|
|
@ -37,7 +37,6 @@ RenderTextureTests::RenderTextureTests()
|
||||||
ADD_TEST_CASE(SpriteRenderTextureBug);
|
ADD_TEST_CASE(SpriteRenderTextureBug);
|
||||||
ADD_TEST_CASE(RenderTexturePartTest);
|
ADD_TEST_CASE(RenderTexturePartTest);
|
||||||
ADD_TEST_CASE(Issue16113Test);
|
ADD_TEST_CASE(Issue16113Test);
|
||||||
// ADD_TEST_CASE(RenderTextureWithSprite3DIssue16894); this Test makes no sense
|
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -811,94 +810,3 @@ std::string Issue16113Test::subtitle() const
|
||||||
{
|
{
|
||||||
return "aaa.png file without white border on iOS";
|
return "aaa.png file without white border on iOS";
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
|
||||||
// RenderTextureWithSprite3DIssue16894
|
|
||||||
//
|
|
||||||
RenderTextureWithSprite3DIssue16894::RenderTextureWithSprite3DIssue16894()
|
|
||||||
{
|
|
||||||
auto visibleSize = Director::getInstance()->getVisibleSize();
|
|
||||||
Vec2 origin = Director::getInstance()->getVisibleOrigin();
|
|
||||||
|
|
||||||
for (int i = 0; i < 3; ++i)
|
|
||||||
{
|
|
||||||
// Ship - Model is from cocos2d-x test project
|
|
||||||
auto ship = Sprite3D::create("Sprite3DTest/boss.c3b");
|
|
||||||
ship->setScale(6);
|
|
||||||
ship->setRotation3D(Vec3(180.0f, 45.0f, 0.0f));
|
|
||||||
ship->setPosition(Vec2(visibleSize.width / 4 + origin.x, visibleSize.height / 2 + origin.y));
|
|
||||||
ship->setForce2DQueue(true);
|
|
||||||
ship->retain();
|
|
||||||
|
|
||||||
if (i == 0)
|
|
||||||
{
|
|
||||||
addChild(ship, 1);
|
|
||||||
//// Rotate Ship
|
|
||||||
auto spin = RotateBy::create(4, Vec3(0.0f, 180.0f, 0.0f));
|
|
||||||
auto repeatspin = RepeatForever::create(spin);
|
|
||||||
ship->runAction(repeatspin);
|
|
||||||
}
|
|
||||||
_ship[i] = ship;
|
|
||||||
}
|
|
||||||
|
|
||||||
// RenderTextures
|
|
||||||
_renderTexDefault = RenderTexture::create(visibleSize.width, visibleSize.height, backend::PixelFormat::RGBA8);
|
|
||||||
_renderTexDefault->setKeepMatrix(true);
|
|
||||||
addChild(_renderTexDefault);
|
|
||||||
_renderTexDefault->setPosition(visibleSize.width / 4 * 3, visibleSize.height / 2);
|
|
||||||
|
|
||||||
_renderTexWithBuffer = RenderTexture::create(visibleSize.width, visibleSize.height, backend::PixelFormat::RGBA8,
|
|
||||||
backend::PixelFormat::D24S8);
|
|
||||||
_renderTexWithBuffer->setKeepMatrix(true);
|
|
||||||
addChild(_renderTexWithBuffer);
|
|
||||||
_renderTexWithBuffer->setPosition(visibleSize.width / 4 * 4, visibleSize.height / 2);
|
|
||||||
|
|
||||||
// Update
|
|
||||||
scheduleUpdate();
|
|
||||||
|
|
||||||
auto label1 = Label::createWithTTF("Normal Sprite3D\n", "fonts/arial.ttf", 10);
|
|
||||||
label1->setPosition(Vec2(visibleSize.width / 4 * 1, 60.0f));
|
|
||||||
this->addChild(label1, 1);
|
|
||||||
|
|
||||||
auto label2 = Label::createWithTTF("RenderTexture\nDefault - No depth buffer", "fonts/arial.ttf", 10);
|
|
||||||
label2->setPosition(Vec2(visibleSize.width / 4 * 2, 60.0f));
|
|
||||||
this->addChild(label2, 1);
|
|
||||||
|
|
||||||
auto label3 = Label::createWithTTF("RenderTexture\nGL_DEPTH24_STENCIL8", "fonts/arial.ttf", 10);
|
|
||||||
label3->setPosition(Vec2(visibleSize.width / 4 * 3, 60.0f));
|
|
||||||
this->addChild(label3, 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
RenderTextureWithSprite3DIssue16894::~RenderTextureWithSprite3DIssue16894()
|
|
||||||
{
|
|
||||||
for (int i = 0; i < 3; ++i)
|
|
||||||
{
|
|
||||||
_ship[i]->release();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void RenderTextureWithSprite3DIssue16894::visit(Renderer* renderer, const Mat4& parentTransform, uint32_t parentFlags)
|
|
||||||
{
|
|
||||||
RenderTextureTest::visit(renderer, parentTransform, parentFlags);
|
|
||||||
|
|
||||||
_ship[1]->setRotation3D(_ship[0]->getRotation3D());
|
|
||||||
_ship[2]->setRotation3D(_ship[0]->getRotation3D());
|
|
||||||
|
|
||||||
_renderTexDefault->beginWithClear(0, 0, 0, 0, 0, 0);
|
|
||||||
_ship[1]->visit(Director::getInstance()->getRenderer(), Mat4::IDENTITY, 0);
|
|
||||||
_renderTexDefault->end();
|
|
||||||
|
|
||||||
_renderTexWithBuffer->beginWithClear(0, 0, 0, 0, 1, 0);
|
|
||||||
_ship[2]->visit(Director::getInstance()->getRenderer(), Mat4::IDENTITY, 0);
|
|
||||||
_renderTexWithBuffer->end();
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string RenderTextureWithSprite3DIssue16894::title() const
|
|
||||||
{
|
|
||||||
return "Issue16894: Render Sprite3D to texture";
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string RenderTextureWithSprite3DIssue16894::subtitle() const
|
|
||||||
{
|
|
||||||
return "3 ships, 1st & 3rd are the same";
|
|
||||||
}
|
|
||||||
|
|
|
@ -182,25 +182,4 @@ public:
|
||||||
virtual std::string subtitle() const override;
|
virtual std::string subtitle() const override;
|
||||||
};
|
};
|
||||||
|
|
||||||
class RenderTextureWithSprite3DIssue16894 : public RenderTextureTest
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CREATE_FUNC(RenderTextureWithSprite3DIssue16894);
|
|
||||||
RenderTextureWithSprite3DIssue16894();
|
|
||||||
virtual ~RenderTextureWithSprite3DIssue16894();
|
|
||||||
|
|
||||||
virtual void visit(cocos2d::Renderer* renderer,
|
|
||||||
const cocos2d::Mat4& parentTransform,
|
|
||||||
uint32_t parentFlags) override;
|
|
||||||
|
|
||||||
virtual std::string title() const override;
|
|
||||||
virtual std::string subtitle() const override;
|
|
||||||
|
|
||||||
private:
|
|
||||||
cocos2d::Sprite3D* _ship[3];
|
|
||||||
|
|
||||||
cocos2d::RenderTexture* _renderTexDefault;
|
|
||||||
cocos2d::RenderTexture* _renderTexWithBuffer;
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -136,7 +136,7 @@ TerrainWalkThru::TerrainWalkThru()
|
||||||
|
|
||||||
_terrain->setSkirtHeightRatio(3);
|
_terrain->setSkirtHeightRatio(3);
|
||||||
_terrain->setLODDistance(64, 128, 192);
|
_terrain->setLODDistance(64, 128, 192);
|
||||||
_player = Player::create("Sprite3DTest/girl.c3b", _camera, _terrain);
|
_player = Player::create("MeshRendererTest/girl.c3b", _camera, _terrain);
|
||||||
_player->setCameraMask(2);
|
_player->setCameraMask(2);
|
||||||
_player->setScale(0.08f);
|
_player->setScale(0.08f);
|
||||||
_player->setPositionY(_terrain->getHeight(_player->getPositionX(), _player->getPositionZ()) + PLAYER_HEIGHT);
|
_player->setPositionY(_terrain->getHeight(_player->getPositionX(), _player->getPositionZ()) + PLAYER_HEIGHT);
|
||||||
|
@ -154,7 +154,7 @@ TerrainWalkThru::TerrainWalkThru()
|
||||||
billboard->setCameraMask((unsigned short)CameraFlag::USER1);
|
billboard->setCameraMask((unsigned short)CameraFlag::USER1);
|
||||||
_player->addChild(billboard);
|
_player->addChild(billboard);
|
||||||
|
|
||||||
auto animation = Animation3D::create("Sprite3DTest/girl.c3b", "Take 001");
|
auto animation = Animation3D::create("MeshRendererTest/girl.c3b", "Take 001");
|
||||||
if (animation)
|
if (animation)
|
||||||
{
|
{
|
||||||
auto animate = Animate3D::create(animation);
|
auto animate = Animate3D::create(animation);
|
||||||
|
@ -210,7 +210,7 @@ bool Player::isDone() const
|
||||||
|
|
||||||
void Player::update(float dt)
|
void Player::update(float dt)
|
||||||
{
|
{
|
||||||
auto player = (Sprite3D*)this;
|
auto player = (MeshRenderer*)this;
|
||||||
switch (_playerState)
|
switch (_playerState)
|
||||||
{
|
{
|
||||||
case PLAYER_STATE_IDLE:
|
case PLAYER_STATE_IDLE:
|
||||||
|
@ -301,7 +301,7 @@ void Player::backward()
|
||||||
|
|
||||||
void Player::updateState()
|
void Player::updateState()
|
||||||
{
|
{
|
||||||
auto player = (Sprite3D*)this;
|
auto player = (MeshRenderer*)this;
|
||||||
switch (_playerState)
|
switch (_playerState)
|
||||||
{
|
{
|
||||||
case PLAYER_STATE_FORWARD:
|
case PLAYER_STATE_FORWARD:
|
||||||
|
@ -323,18 +323,18 @@ void Player::updateState()
|
||||||
Player* Player::create(const char* file, Camera* cam, Terrain* terrain)
|
Player* Player::create(const char* file, Camera* cam, Terrain* terrain)
|
||||||
{
|
{
|
||||||
//
|
//
|
||||||
auto sprite = new Player();
|
auto player = new Player();
|
||||||
if (sprite->initWithFile(file))
|
if (player->initWithFile(file))
|
||||||
{
|
{
|
||||||
sprite->_headingAngle = 0;
|
player->_headingAngle = 0;
|
||||||
sprite->_playerState = PLAYER_STATE_IDLE;
|
player->_playerState = PLAYER_STATE_IDLE;
|
||||||
sprite->_cam = cam;
|
player->_cam = cam;
|
||||||
sprite->_terrain = terrain;
|
player->_terrain = terrain;
|
||||||
sprite->autorelease();
|
player->autorelease();
|
||||||
sprite->scheduleUpdate();
|
player->scheduleUpdate();
|
||||||
return sprite;
|
return player;
|
||||||
}
|
}
|
||||||
CC_SAFE_DELETE(sprite);
|
CC_SAFE_DELETE(player);
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -26,7 +26,7 @@
|
||||||
|
|
||||||
#include "../BaseTest.h"
|
#include "../BaseTest.h"
|
||||||
|
|
||||||
# include "3d/CCSprite3D.h"
|
#include "3d/CCMeshRenderer.h"
|
||||||
#include "3d/CCTerrain.h"
|
#include "3d/CCTerrain.h"
|
||||||
#include "2d/CCCamera.h"
|
#include "2d/CCCamera.h"
|
||||||
#include "2d/CCAction.h"
|
#include "2d/CCAction.h"
|
||||||
|
@ -59,7 +59,7 @@ protected:
|
||||||
# define PLAYER_STATE_FORWARD 3
|
# define PLAYER_STATE_FORWARD 3
|
||||||
# define PLAYER_STATE_BACKWARD 4
|
# define PLAYER_STATE_BACKWARD 4
|
||||||
|
|
||||||
class Player : public cocos2d::Sprite3D
|
class Player : public cocos2d::MeshRenderer
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
static Player* create(const char* file, cocos2d::Camera* cam, cocos2d::Terrain* terrain);
|
static Player* create(const char* file, cocos2d::Camera* cam, cocos2d::Terrain* terrain);
|
||||||
|
|
|
@ -102,7 +102,7 @@ public:
|
||||||
addTest("Node: Scene", []() { return new SceneTests(); });
|
addTest("Node: Scene", []() { return new SceneTests(); });
|
||||||
addTest("Node: Spine", []() { return new SpineTests(); });
|
addTest("Node: Spine", []() { return new SpineTests(); });
|
||||||
addTest("Node: Sprite", []() { return new SpriteTests(); });
|
addTest("Node: Sprite", []() { return new SpriteTests(); });
|
||||||
addTest("Node: Sprite3D", []() { return new Sprite3DTests(); });
|
addTest("Node: MeshRenderer", []() { return new MeshRendererTests(); });
|
||||||
addTest("Node: SpritePolygon", []() { return new SpritePolygonTest(); });
|
addTest("Node: SpritePolygon", []() { return new SpritePolygonTest(); });
|
||||||
addTest("Node: Terrain", []() { return new TerrainTests(); });
|
addTest("Node: Terrain", []() { return new TerrainTests(); });
|
||||||
addTest("Node: FastTileMap", []() { return new FastTileMapTests(); });
|
addTest("Node: FastTileMap", []() { return new FastTileMapTests(); });
|
||||||
|
|
|
@ -101,7 +101,7 @@
|
||||||
#include "ShaderTest/ShaderTest.h"
|
#include "ShaderTest/ShaderTest.h"
|
||||||
#include "ShaderTest/ShaderTest2.h"
|
#include "ShaderTest/ShaderTest2.h"
|
||||||
#include "SpineTest/SpineTest.h"
|
#include "SpineTest/SpineTest.h"
|
||||||
#include "Sprite3DTest/Sprite3DTest.h"
|
#include "MeshRendererTest/MeshRendererTest.h"
|
||||||
#include "SpritePolygonTest/SpritePolygonTest.h"
|
#include "SpritePolygonTest/SpritePolygonTest.h"
|
||||||
#include "SpriteTest/SpriteTest.h"
|
#include "SpriteTest/SpriteTest.h"
|
||||||
#include "TerrainTest/TerrainTest.h"
|
#include "TerrainTest/TerrainTest.h"
|
||||||
|
|
Loading…
Reference in New Issue