2011-03-19 10:34:26 +08:00
|
|
|
/****************************************************************************
|
|
|
|
Copyright (c) 2009 Sindesso Pty Ltd http://www.sindesso.com/
|
2014-01-07 11:25:07 +08:00
|
|
|
Copyright (c) 2010-2012 cocos2d-x.org
|
|
|
|
CopyRight (c) 2013-2014 Chukong Technologies Inc.
|
2011-03-19 10:34:26 +08:00
|
|
|
|
|
|
|
http://www.cocos2d-x.org
|
|
|
|
|
|
|
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
of this software and associated documentation files (the "Software"), to deal
|
|
|
|
in the Software without restriction, including without limitation the rights
|
|
|
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
copies of the Software, and to permit persons to whom the Software is
|
|
|
|
furnished to do so, subject to the following conditions:
|
|
|
|
|
|
|
|
The above copyright notice and this permission notice shall be included in
|
|
|
|
all copies or substantial portions of the Software.
|
|
|
|
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
|
|
THE SOFTWARE.
|
|
|
|
****************************************************************************/
|
|
|
|
#include "CCActionPageTurn3D.h"
|
|
|
|
|
2012-04-18 18:43:45 +08:00
|
|
|
NS_CC_BEGIN
|
|
|
|
|
2013-06-20 14:13:12 +08:00
|
|
|
PageTurn3D* PageTurn3D::create(float duration, const Size& gridSize)
|
2011-03-19 10:34:26 +08:00
|
|
|
{
|
2013-12-18 17:47:20 +08:00
|
|
|
PageTurn3D *action = new PageTurn3D();
|
2011-03-19 10:34:26 +08:00
|
|
|
|
2013-12-18 17:47:20 +08:00
|
|
|
if (action)
|
2012-04-19 14:35:52 +08:00
|
|
|
{
|
2013-12-18 17:47:20 +08:00
|
|
|
if (action->initWithDuration(duration, gridSize))
|
2012-04-19 14:35:52 +08:00
|
|
|
{
|
2013-12-18 17:47:20 +08:00
|
|
|
action->autorelease();
|
2012-04-19 14:35:52 +08:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2013-12-18 17:47:20 +08:00
|
|
|
CC_SAFE_RELEASE_NULL(action);
|
2012-04-19 14:35:52 +08:00
|
|
|
}
|
|
|
|
}
|
2011-03-19 10:34:26 +08:00
|
|
|
|
2013-12-18 17:47:20 +08:00
|
|
|
return action;
|
2012-04-18 18:43:45 +08:00
|
|
|
}
|
|
|
|
|
2013-06-20 14:13:12 +08:00
|
|
|
PageTurn3D *PageTurn3D::clone() const
|
2013-06-19 06:06:53 +08:00
|
|
|
{
|
|
|
|
// no copy constructor
|
2013-06-20 14:13:12 +08:00
|
|
|
auto a = new PageTurn3D();
|
2013-06-19 06:06:53 +08:00
|
|
|
a->initWithDuration(_duration, _gridSize);
|
|
|
|
a->autorelease();
|
|
|
|
return a;
|
|
|
|
}
|
|
|
|
|
2012-04-18 18:43:45 +08:00
|
|
|
/*
|
|
|
|
* Update each tick
|
|
|
|
* Time is the percentage of the way through the duration
|
|
|
|
*/
|
2013-06-20 14:13:12 +08:00
|
|
|
void PageTurn3D::update(float time)
|
2012-04-18 18:43:45 +08:00
|
|
|
{
|
2012-04-19 14:35:52 +08:00
|
|
|
float tt = MAX(0, time - 0.25f);
|
|
|
|
float deltaAy = (tt * tt * 500);
|
|
|
|
float ay = -100 - deltaAy;
|
|
|
|
|
|
|
|
float deltaTheta = - (float) M_PI_2 * sqrtf( time) ;
|
|
|
|
float theta = /*0.01f */ + (float) M_PI_2 +deltaTheta;
|
|
|
|
|
|
|
|
float sinTheta = sinf(theta);
|
|
|
|
float cosTheta = cosf(theta);
|
|
|
|
|
2013-06-15 14:03:30 +08:00
|
|
|
for (int i = 0; i <= _gridSize.width; ++i)
|
2012-04-19 14:35:52 +08:00
|
|
|
{
|
2013-06-15 14:03:30 +08:00
|
|
|
for (int j = 0; j <= _gridSize.height; ++j)
|
2012-04-19 14:35:52 +08:00
|
|
|
{
|
|
|
|
// Get original vertex
|
2014-04-02 15:06:16 +08:00
|
|
|
Vector3 p = getOriginalVertex(Point(i ,j));
|
2012-04-19 14:35:52 +08:00
|
|
|
|
|
|
|
float R = sqrtf((p.x * p.x) + ((p.y - ay) * (p.y - ay)));
|
|
|
|
float r = R * sinTheta;
|
|
|
|
float alpha = asinf( p.x / R );
|
|
|
|
float beta = alpha / sinTheta;
|
|
|
|
float cosBeta = cosf( beta );
|
|
|
|
|
|
|
|
// If beta > PI then we've wrapped around the cone
|
|
|
|
// Reduce the radius to stop these points interfering with others
|
|
|
|
if (beta <= M_PI)
|
|
|
|
{
|
|
|
|
p.x = ( r * sinf(beta));
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// Force X = 0 to stop wrapped
|
|
|
|
// points
|
|
|
|
p.x = 0;
|
|
|
|
}
|
2010-12-23 16:47:29 +08:00
|
|
|
|
2012-04-18 18:43:45 +08:00
|
|
|
p.y = ( R + ay - ( r * (1 - cosBeta) * sinTheta));
|
2010-12-23 16:47:29 +08:00
|
|
|
|
2012-04-18 18:43:45 +08:00
|
|
|
// We scale z here to avoid the animation being
|
2012-09-17 15:02:24 +08:00
|
|
|
// too much bigger than the screen due to perspective transform
|
2012-04-18 18:43:45 +08:00
|
|
|
p.z = (r * ( 1 - cosBeta ) * cosTheta) / 7;// "100" didn't work for
|
2010-12-23 16:47:29 +08:00
|
|
|
|
2012-04-19 14:35:52 +08:00
|
|
|
// Stop z coord from dropping beneath underlying page in a transition
|
|
|
|
// issue #751
|
|
|
|
if( p.z < 0.5f )
|
|
|
|
{
|
|
|
|
p.z = 0.5f;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Set new coords
|
2013-07-12 14:11:55 +08:00
|
|
|
setVertex(Point(i, j), p);
|
2012-04-19 14:35:52 +08:00
|
|
|
|
|
|
|
}
|
|
|
|
}
|
2012-04-18 18:43:45 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
NS_CC_END
|