0

是否有任何简单的方法可以复制任何类型的 AnimCurve?我看到使用 MFnAnimCurve 它可能会变得非常臃肿。

PS:现在使用 Maya 2013。

4

1 回答 1

3

好吧 - 我知道没有人关心这个问题,因为这个问题对于 99.9999% 的 c0ders 来说是完全不必要的。

答案是NO

这是我选择的 API/C++ 解决方案:

bool copyAnimCurve(MFnDependencyNode &srcDN, MFnDependencyNode &destDN, MObject &destNode)
{
    MFnAnimCurve s( srcDN.object() ), d;
    MAngle a; double w;

    destNode = d.create( s.animCurveType() );
    destDN.setObject( destNode );
    if ( !destNode.isNull() )
    {
        bool unitless( s.isUnitlessInput() ), weighted( s.isWeighted() );
        d.setName( newName( s.name() ) );
        d.setIsWeighted( weighted );
        d.setPreInfinityType( s.preInfinityType() );
        d.setPostInfinityType( s.postInfinityType() );
        // copy keys...
        MFnAnimCurve::TangentType tt[2];
        for ( uint i = 0; i < s.numKeys(); ++i )
        {
            tt[ true ] = s.inTangentType( i );
            tt[ false ] = s.outTangentType( i );
            if ( unitless )
                d.addKey( s.unitlessInput( i ), s.value( i ), tt[ true ], tt[ false ] );
            else
                d.addKey( s.time( i ), s.value( i ), tt[ true ], tt[ false ] );
            // tangents and weights are locked by default - so let's unlock them before setting any values!
            d.setTangentsLocked( i, false );
            d.setWeightsLocked( i, false );
            for ( int j=1; j>=0; --j )  if ( tt[ bool( j ) ] == MFnAnimCurve::TangentType::kTangentFixed )
            {
                // tangents are internally stored using angle and weights - so we'll only use those.
                s.getTangent( i, a, w, bool( j ) );
                d.setTangent( i, a, w, bool( j ) );
            }
            d.setWeightsLocked( i, s.weightsLocked( i ) );
            d.setTangentsLocked( i, s.tangentsLocked( i ) );
            d.setIsBreakdown( i, s.isBreakdown( i ) );
        }
        return true;
    }
    cerr << "\nERROR CREATING AnimCurve COPY OF " << srcDN.name() << endl;
    return false;
}

PS:您需要实现自己的MString newName(const MString& oldName).

于 2015-08-03T12:08:08.830 回答