2012-03-20 01:57:42 +01:00
|
|
|
#include "lc_global.h"
|
2011-09-07 23:06:51 +02:00
|
|
|
#include "object.h"
|
|
|
|
|
2014-05-01 20:42:11 +02:00
|
|
|
lcObject::lcObject(lcObjectType ObjectType)
|
2014-08-31 02:53:12 +02:00
|
|
|
: mObjectType(ObjectType)
|
2011-09-07 23:06:51 +02:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2014-05-01 20:42:11 +02:00
|
|
|
lcObject::~lcObject()
|
2011-09-07 23:06:51 +02:00
|
|
|
{
|
|
|
|
}
|
2021-01-05 20:26:01 +01:00
|
|
|
|
|
|
|
template class lcObjectKeyArray<float>;
|
|
|
|
template class lcObjectKeyArray<lcVector3>;
|
|
|
|
template class lcObjectKeyArray<lcVector4>;
|
|
|
|
template class lcObjectKeyArray<lcMatrix33>;
|
|
|
|
|
|
|
|
template<typename T>
|
|
|
|
void lcObjectKeyArray<T>::SaveKeysLDraw(QTextStream& Stream, const char* KeyName) const
|
|
|
|
{
|
|
|
|
const int Count = sizeof(T) / sizeof(float);
|
|
|
|
|
|
|
|
for (const lcObjectKey<T>& Key : mKeys)
|
|
|
|
{
|
|
|
|
Stream << QLatin1String("0 !LEOCAD ") << KeyName << Key.Step << ' ';
|
|
|
|
|
|
|
|
for (int ValueIdx = 0; ValueIdx < Count; ValueIdx++)
|
|
|
|
Stream << ((float*)&Key.Value)[ValueIdx] << ' ';
|
|
|
|
|
|
|
|
Stream << QLatin1String("\r\n");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
template<typename T>
|
|
|
|
void lcObjectKeyArray<T>::LoadKeysLDraw(QTextStream& Stream)
|
|
|
|
{
|
|
|
|
QString Token;
|
|
|
|
Stream >> Token;
|
|
|
|
|
|
|
|
int Step = Token.toInt();
|
|
|
|
T Value;
|
|
|
|
|
|
|
|
const int Count = sizeof(T) / sizeof(float);
|
|
|
|
|
|
|
|
for (int ValueIdx = 0; ValueIdx < Count; ValueIdx++)
|
|
|
|
Stream >> ((float*)&Value)[ValueIdx];
|
|
|
|
|
|
|
|
ChangeKey(Value, Step, true);
|
|
|
|
}
|
|
|
|
|
|
|
|
template<typename T>
|
|
|
|
const T& lcObjectKeyArray<T>::CalculateKey(lcStep Step) const
|
|
|
|
{
|
|
|
|
const lcObjectKey<T>* PreviousKey = &mKeys[0];
|
|
|
|
|
|
|
|
for (const lcObjectKey<T>& Key : mKeys)
|
|
|
|
{
|
|
|
|
if (Key.Step > Step)
|
|
|
|
break;
|
|
|
|
|
|
|
|
PreviousKey = &Key;
|
|
|
|
}
|
|
|
|
|
|
|
|
return PreviousKey->Value;
|
|
|
|
}
|
|
|
|
|
|
|
|
template<typename T>
|
|
|
|
void lcObjectKeyArray<T>::ChangeKey(const T& Value, lcStep Step, bool AddKey)
|
|
|
|
{
|
2021-01-06 00:19:53 +01:00
|
|
|
for (typename std::vector<lcObjectKey<T>>::iterator KeyIt = mKeys.begin(); KeyIt != mKeys.end(); KeyIt++)
|
2021-01-05 20:26:01 +01:00
|
|
|
{
|
2021-01-05 21:27:45 +01:00
|
|
|
if (KeyIt->Step < Step)
|
|
|
|
continue;
|
2021-01-05 20:26:01 +01:00
|
|
|
|
2021-01-05 21:27:45 +01:00
|
|
|
if (KeyIt->Step == Step)
|
|
|
|
KeyIt->Value = Value;
|
|
|
|
else if (AddKey)
|
|
|
|
mKeys.insert(KeyIt, lcObjectKey<T>{ Step, Value });
|
|
|
|
else if (KeyIt == mKeys.begin())
|
|
|
|
KeyIt->Value = Value;
|
|
|
|
else
|
2021-01-05 20:26:01 +01:00
|
|
|
{
|
2021-01-05 21:27:45 +01:00
|
|
|
KeyIt = KeyIt - 1;
|
|
|
|
KeyIt->Value = Value;
|
2021-01-05 20:26:01 +01:00
|
|
|
}
|
|
|
|
|
2021-01-05 21:27:45 +01:00
|
|
|
return;
|
2021-01-05 20:26:01 +01:00
|
|
|
}
|
|
|
|
|
2021-01-05 21:27:45 +01:00
|
|
|
if (AddKey || mKeys.empty())
|
|
|
|
mKeys.emplace_back(lcObjectKey<T>{ Step, Value });
|
2021-01-05 20:26:01 +01:00
|
|
|
else
|
2021-01-05 21:27:45 +01:00
|
|
|
mKeys.back().Value = Value;
|
2021-01-05 20:26:01 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
template<typename T>
|
|
|
|
void lcObjectKeyArray<T>::InsertTime(lcStep Start, lcStep Time)
|
|
|
|
{
|
|
|
|
bool EndKey = false;
|
|
|
|
|
2021-01-06 00:19:53 +01:00
|
|
|
for (typename std::vector<lcObjectKey<T>>::iterator KeyIt = mKeys.begin(); KeyIt != mKeys.end();)
|
2021-01-05 20:26:01 +01:00
|
|
|
{
|
2021-01-05 21:27:45 +01:00
|
|
|
if ((KeyIt->Step < Start) || (KeyIt->Step == 1))
|
|
|
|
{
|
|
|
|
KeyIt++;
|
2021-01-05 20:26:01 +01:00
|
|
|
continue;
|
2021-01-05 21:27:45 +01:00
|
|
|
}
|
2021-01-05 20:26:01 +01:00
|
|
|
|
|
|
|
if (EndKey)
|
|
|
|
{
|
2021-01-05 21:27:45 +01:00
|
|
|
KeyIt = mKeys.erase(KeyIt);
|
2021-01-05 20:26:01 +01:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2021-01-05 21:27:45 +01:00
|
|
|
if (KeyIt->Step >= LC_STEP_MAX - Time)
|
2021-01-05 20:26:01 +01:00
|
|
|
{
|
2021-01-05 21:27:45 +01:00
|
|
|
KeyIt->Step = LC_STEP_MAX;
|
2021-01-05 20:26:01 +01:00
|
|
|
EndKey = true;
|
|
|
|
}
|
|
|
|
else
|
2021-01-05 21:27:45 +01:00
|
|
|
KeyIt->Step += Time;
|
|
|
|
|
|
|
|
KeyIt++;
|
2021-01-05 20:26:01 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
template<typename T>
|
|
|
|
void lcObjectKeyArray<T>::RemoveTime(lcStep Start, lcStep Time)
|
|
|
|
{
|
2021-01-06 00:19:53 +01:00
|
|
|
for (typename std::vector<lcObjectKey<T>>::iterator KeyIt = mKeys.begin(); KeyIt != mKeys.end();)
|
2021-01-05 20:26:01 +01:00
|
|
|
{
|
2021-01-05 21:27:45 +01:00
|
|
|
if ((KeyIt->Step < Start) || (KeyIt->Step == 1))
|
|
|
|
{
|
|
|
|
KeyIt++;
|
2021-01-05 20:26:01 +01:00
|
|
|
continue;
|
2021-01-05 21:27:45 +01:00
|
|
|
}
|
2021-01-05 20:26:01 +01:00
|
|
|
|
2021-01-05 21:27:45 +01:00
|
|
|
if (KeyIt->Step < Start + Time)
|
2021-01-05 20:26:01 +01:00
|
|
|
{
|
2021-01-05 21:27:45 +01:00
|
|
|
KeyIt = mKeys.erase(KeyIt);
|
2021-01-05 20:26:01 +01:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2021-01-05 21:27:45 +01:00
|
|
|
KeyIt->Step -= Time;
|
|
|
|
KeyIt++;
|
2021-01-05 20:26:01 +01:00
|
|
|
}
|
|
|
|
}
|