2017-10-20 00:59:26 +08:00
|
|
|
|
#include "..\eactions.h"
|
|
|
|
|
|
#include "..\Win\winbase.h"
|
|
|
|
|
|
|
|
|
|
|
|
e2d::EActionGradual::EActionGradual(float duration)
|
2017-10-21 19:09:31 +08:00
|
|
|
|
: m_fRateOfProgress(0)
|
|
|
|
|
|
, m_fDuration(0)
|
|
|
|
|
|
, m_fTotalDuration(duration * 1000)
|
2017-10-20 00:59:26 +08:00
|
|
|
|
{
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
bool e2d::EActionGradual::_isEnd() const
|
|
|
|
|
|
{
|
2017-10-21 19:09:31 +08:00
|
|
|
|
return m_fDuration >= m_fTotalDuration;
|
2017-10-20 00:59:26 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void e2d::EActionGradual::_init()
|
|
|
|
|
|
{
|
|
|
|
|
|
EAction::_init();
|
|
|
|
|
|
}
|
2017-12-15 21:51:07 +08:00
|
|
|
|
#include <iostream>
|
2017-10-20 00:59:26 +08:00
|
|
|
|
bool e2d::EActionGradual::_isDelayEnough()
|
|
|
|
|
|
{
|
|
|
|
|
|
// <20>ж<EFBFBD>ʱ<EFBFBD><CAB1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ƿ<EFBFBD><C7B7>㹻
|
2017-11-03 12:51:01 +08:00
|
|
|
|
if (m_fTotalDuration == 0)
|
|
|
|
|
|
{
|
|
|
|
|
|
m_fRateOfProgress = 1;
|
|
|
|
|
|
return true;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2017-12-15 21:51:07 +08:00
|
|
|
|
if (IsIntervalFull(m_tLast, m_nAnimationInterval))
|
2017-10-20 00:59:26 +08:00
|
|
|
|
{
|
|
|
|
|
|
// <20><><EFBFBD>¼<EFBFBD>¼ʱ<C2BC><CAB1>
|
2017-12-15 21:51:07 +08:00
|
|
|
|
m_tLast.QuadPart += m_nAnimationInterval.QuadPart;
|
|
|
|
|
|
m_fDuration += static_cast<float>(ToMilliseconds(m_nAnimationInterval.QuadPart));
|
|
|
|
|
|
std::cout << ToMilliseconds(m_nAnimationInterval.QuadPart) << std::endl;
|
2017-10-21 19:09:31 +08:00
|
|
|
|
// <20><><EFBFBD>㶯<EFBFBD><E3B6AF><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
m_fRateOfProgress = m_fDuration / m_fTotalDuration;
|
2017-10-20 00:59:26 +08:00
|
|
|
|
return true;
|
|
|
|
|
|
}
|
|
|
|
|
|
return false;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void e2d::EActionGradual::_reset()
|
|
|
|
|
|
{
|
|
|
|
|
|
EAction::_reset();
|
2017-10-21 19:09:31 +08:00
|
|
|
|
m_fDuration = 0;
|
2017-10-20 00:59:26 +08:00
|
|
|
|
}
|