#include "MayaPointPrimitiveWriter.h"
#include "MayaUtility.h"
MayaPointPrimitiveWriter::MayaPointPrimitiveWriter(
double iFrame,
MDagPath & iDag, Alembic::AbcGeom::OObject & iParent,
Alembic::Util::uint32_t iTimeIndex,
const JobArgs & iArgs) :
mIsAnimated(false), mDagPath(iDag)
{
name = util::stripNamespaces(name, iArgs.stripNamespace);
Alembic::AbcGeom::OPoints obj(iParent, name.
asChar(),
iTimeIndex);
mSchema = obj.getSchema();
Alembic::Abc::OCompoundProperty cp;
Alembic::Abc::OCompoundProperty up;
if (AttributesWriter::hasAnyAttr(particle, iArgs))
{
cp = mSchema.getArbGeomParams();
up = mSchema.getUserProperties();
}
mAttrs = AttributesWriterPtr(new AttributesWriter(cp, up, obj, particle,
iTimeIndex, iArgs));
if (iTimeIndex != 0 && util::isAnimated(object))
{
mIsAnimated = true;
}
else
{
iTimeIndex = 0;
}
write(iFrame);
}
void MayaPointPrimitiveWriter::write(double iFrame)
{
std::vector<float> position;
std::vector<float> velocity;
std::vector< Alembic::Util::uint64_t > particleIds;
std::vector<float> width;
bool runupFromStart = false;
particle.evaluateDynamics(to, runupFromStart);
unsigned int size = particle.count();
Alembic::AbcGeom::OPointsSchema::Sample samp;
if (size == 0)
{
samp.setPositions(Alembic::Abc::V3fArraySample(NULL, 0));
samp.setVelocities(Alembic::Abc::V3fArraySample(NULL, 0));
samp.setIds(Alembic::Abc::UInt64ArraySample(NULL, 0));
mSchema.set(samp);
return;
}
position.reserve(size*3);
velocity.reserve(size*3);
particleIds.reserve(size);
width.reserve(size);
particle.position(posArray);
for (unsigned int i = 0; i < size; i++)
{
position.push_back(static_cast<float>(vec.
x));
position.push_back(static_cast<float>(vec.
y));
position.push_back(static_cast<float>(vec.
z));
}
samp.setPositions(
Alembic::Abc::V3fArraySample((const Imath::V3f *) &position.front(),
position.size() / 3) );
particle.velocity(vecArray);
for (unsigned int i = 0; i < size; i++)
{
velocity.push_back(static_cast<float>(vec.
x));
velocity.push_back(static_cast<float>(vec.
y));
velocity.push_back(static_cast<float>(vec.
z));
}
if (!velocity.empty())
{
samp.setVelocities(
Alembic::Abc::V3fArraySample((const Imath::V3f *) &velocity.front(),
velocity.size() / 3) );
}
particle.particleIds(idArray);
for (unsigned int i = 0; i < size; i++)
{
particleIds.push_back(idArray[i]);
}
samp.setIds(
Alembic::Abc::UInt64ArraySample(&(particleIds.front()),
particleIds.size()) );
particle.radius(radiusArray);
for (unsigned int i = 0; i < size; i++)
{
float radius = static_cast<float>(radiusArray[i]);
width.push_back(radius);
}
}
unsigned int MayaPointPrimitiveWriter::getNumCVs()
{
return particle.count();
}
bool MayaPointPrimitiveWriter::isAnimated() const
{
return mIsAnimated;
}