Nodes: setAdditionalTransform() receives a pointer

and not a const reference.
If the pointer is `NULL`, then it won't use the additionalTransform
This commit is contained in:
Ricardo Quesada 2014-03-01 08:26:54 -08:00
parent 219ef6d897
commit cdc19eea1c
7 changed files with 22 additions and 59 deletions

View File

@ -3,6 +3,7 @@ cocos2d-x-3.0rc0 Feb.?? 2014
[NEW] Action: RotateBy supports 3D rotations [NEW] Action: RotateBy supports 3D rotations
[NEW] Bindings: Using python to automatically generate script bindings [NEW] Bindings: Using python to automatically generate script bindings
[NEW] Bindings: Added JS bindings support for Linux [NEW] Bindings: Added JS bindings support for Linux
[NEW] ccConfig.h: removed support for CC_TEXTURE_ATLAS_USE_TRIANGLE_STRIP
[NEW] Console: Added 'resolution', 'projection' commands. Improved API [NEW] Console: Added 'resolution', 'projection' commands. Improved API
[NEW] Console: Added more commands: director resume|pause|stopanimation|startanimation. [NEW] Console: Added more commands: director resume|pause|stopanimation|startanimation.
[NEW] Console: Added command: 'touch tap|swipe' to simulating touch events. [NEW] Console: Added command: 'touch tap|swipe' to simulating touch events.
@ -48,6 +49,8 @@ cocos2d-x-3.0rc0 Feb.?? 2014
[FIX] EGLView improvements: renamed to GLView, no longer a singleton, easier to customize [FIX] EGLView improvements: renamed to GLView, no longer a singleton, easier to customize
[FIX] Removes samples except testcpp|testjavascript|testlua. Moves sample games to `cocos2d/samples` repo. [FIX] Removes samples except testcpp|testjavascript|testlua. Moves sample games to `cocos2d/samples` repo.
[FIX] cc.BuilderReader.load( path, null, parentSize ); was not allowed. [FIX] cc.BuilderReader.load( path, null, parentSize ); was not allowed.
[FIX] Node: setAdditionalTransform receives a pointer and not a const reference
cocos2d-x-3.0beta2 Jan.24 2014 cocos2d-x-3.0beta2 Jan.24 2014
[All] [All]

View File

@ -122,7 +122,7 @@ void ActionCamera::updateTransform()
// But that operation needs to be done after all the 'updates'. // But that operation needs to be done after all the 'updates'.
// So the Director should emit an 'director_after_update' event. // So the Director should emit an 'director_after_update' event.
// And this object should listen to it // And this object should listen to it
_target->setAdditionalTransform(mv); _target->setAdditionalTransform(&mv);
} }
// //

View File

@ -1361,17 +1361,21 @@ void Node::setNodeToParentTransform(const kmMat4& transform)
void Node::setAdditionalTransform(const AffineTransform& additionalTransform) void Node::setAdditionalTransform(const AffineTransform& additionalTransform)
{ {
CGAffineToGL(additionalTransform, _additionalTransform.mat); kmMat4 tmp;
_transformUpdated = _transformDirty = _inverseDirty = true; CGAffineToGL(additionalTransform, tmp.mat);
_useAdditionalTransform = true; setAdditionalTransform(&tmp);
} }
void Node::setAdditionalTransform(const kmMat4& additionalTransform) void Node::setAdditionalTransform(kmMat4* additionalTransform)
{ {
_additionalTransform = additionalTransform; if(additionalTransform == nullptr) {
_transformUpdated = _transformDirty = _inverseDirty = true; _useAdditionalTransform = false;
} else {
_additionalTransform = *additionalTransform;
_useAdditionalTransform = true; _useAdditionalTransform = true;
} }
_transformUpdated = _transformDirty = _inverseDirty = true;
}
AffineTransform Node::getParentToNodeAffineTransform() const AffineTransform Node::getParentToNodeAffineTransform() const

View File

@ -1347,54 +1347,12 @@ public:
/** /**
* Sets an additional transform matrix to the node. * Sets an additional transform matrix to the node.
* *
* In order to remove it, set the Identity Matrix to the additional transform. * In order to remove it, call it again with the argument `nullptr`
* *
* @note The additional transform will be concatenated at the end of getNodeToParentTransform. * @note The additional transform will be concatenated at the end of getNodeToParentTransform.
* It could be used to simulate `parent-child` relationship between two nodes (e.g. one is in BatchNode, another isn't). * It could be used to simulate `parent-child` relationship between two nodes (e.g. one is in BatchNode, another isn't).
@code
// create a batchNode
SpriteBatchNode* batch= SpriteBatchNode::create("Icon-114.png");
this->addChild(batch);
// create two sprites, spriteA will be added to batchNode, they are using different textures.
Sprite* spriteA = Sprite::createWithTexture(batch->getTexture());
Sprite* spriteB = Sprite::create("Icon-72.png");
batch->addChild(spriteA);
// We can't make spriteB as spriteA's child since they use different textures. So just add it to layer.
// But we want to simulate `parent-child` relationship for these two node.
this->addChild(spriteB);
//position
spriteA->setPosition(Point(200, 200));
// Gets the spriteA's transform.
auto t = spriteA->getNodeToParentTransform();
// Sets the additional transform to spriteB, spriteB's postion will based on its pseudo parent i.e. spriteA.
spriteB->setAdditionalTransform(t);
//scale
spriteA->setScale(2);
// Gets the spriteA's transform.
t = spriteA->getNodeToParentTransform();
// Sets the additional transform to spriteB, spriteB's scale will based on its pseudo parent i.e. spriteA.
spriteB->setAdditionalTransform(t);
//rotation
spriteA->setRotation(20);
// Gets the spriteA's transform.
t = spriteA->getNodeToParentTransform();
// Sets the additional transform to spriteB, spriteB's rotation will based on its pseudo parent i.e. spriteA.
spriteB->setAdditionalTransform(t);
@endcode
*/ */
void setAdditionalTransform(const kmMat4& additionalTransform); void setAdditionalTransform(kmMat4* additionalTransform);
void setAdditionalTransform(const AffineTransform& additionalTransform); void setAdditionalTransform(const AffineTransform& additionalTransform);
/// @} end of Coordinate Converters /// @} end of Coordinate Converters

View File

@ -112,21 +112,18 @@ void TransitionScene::draw(Renderer *renderer, const kmMat4 &transform, bool tra
void TransitionScene::finish() void TransitionScene::finish()
{ {
kmMat4 identity;
kmMat4Identity(&identity);
// clean up // clean up
_inScene->setVisible(true); _inScene->setVisible(true);
_inScene->setPosition(Point(0,0)); _inScene->setPosition(Point(0,0));
_inScene->setScale(1.0f); _inScene->setScale(1.0f);
_inScene->setRotation(0.0f); _inScene->setRotation(0.0f);
_inScene->setAdditionalTransform(identity); _inScene->setAdditionalTransform(nullptr);
_outScene->setVisible(false); _outScene->setVisible(false);
_outScene->setPosition(Point(0,0)); _outScene->setPosition(Point(0,0));
_outScene->setScale(1.0f); _outScene->setScale(1.0f);
_outScene->setRotation(0.0f); _outScene->setRotation(0.0f);
_outScene->setAdditionalTransform(identity); _outScene->setAdditionalTransform(nullptr);
//[self schedule:@selector(setNewScene:) interval:0]; //[self schedule:@selector(setNewScene:) interval:0];
this->schedule(schedule_selector(TransitionScene::setNewScene), 0); this->schedule(schedule_selector(TransitionScene::setNewScene), 0);

View File

@ -93,7 +93,8 @@ void DisplayFactory::updateDisplay(Bone *bone, float dt, bool dirty)
break; break;
default: default:
{ {
display->setAdditionalTransform(bone->getNodeToArmatureTransform()); kmMat4 transform = bone->getNodeToArmatureTransform();
display->setAdditionalTransform(&transform);
} }
break; break;
} }

View File

@ -1107,8 +1107,8 @@ CameraTest2::CameraTest2()
kmMat4 lookupMatrix; kmMat4 lookupMatrix;
kmMat4LookAt(&lookupMatrix, &eye, &center, &up); kmMat4LookAt(&lookupMatrix, &eye, &center, &up);
_sprite1->setAdditionalTransform(lookupMatrix); _sprite1->setAdditionalTransform(&lookupMatrix);
_sprite2->setAdditionalTransform(lookupMatrix); _sprite2->setAdditionalTransform(&lookupMatrix);
} }