//- // ========================================================================== // Copyright (C) 1995 - 2005 Alias Systems Corp. and/or its licensors. All // rights reserved. // // The coded instructions, statements, computer programs, and/or related // material (collectively the "Data") in these files are provided by Alias // Systems Corp. ("Alias") and/or its licensors for the exclusive use of the // Customer (as defined in the Alias Software License Agreement that // accompanies this Alias software). Such Customer has the right to use, // modify, and incorporate the Data into other products and to distribute such // products for use by end-users. // // THE DATA IS PROVIDED "AS IS". ALIAS HEREBY DISCLAIMS ALL WARRANTIES // RELATING TO THE DATA, INCLUDING, WITHOUT LIMITATION, ANY AND ALL EXPRESS OR // IMPLIED WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY AND/OR FITNESS FOR A // PARTICULAR PURPOSE. IN NO EVENT SHALL ALIAS BE LIABLE FOR ANY DAMAGES // WHATSOEVER, WHETHER DIRECT, INDIRECT, SPECIAL, OR PUNITIVE, WHETHER IN AN // ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, OR IN EQUITY, // ARISING OUT OF ACCESS TO, USE OF, OR RELIANCE UPON THE DATA. // ========================================================================== //+ #include #include #include #include #include #include #include #include #include #include #include #include #include class arcLen : public MPxNode { public: arcLen(); virtual ~arcLen(); virtual MStatus compute( const MPlug& plug, MDataBlock& data ); static void* creator(); static MStatus initialize(); public: static MObject inputCurve; // The input curve. static MObject output; // The output value. static MTypeId id; // The IFF type id }; MTypeId arcLen::id( 0x80001 ); MObject arcLen::inputCurve; MObject arcLen::output; arcLen::arcLen() {} arcLen::~arcLen() {} void* arcLen::creator() { return new arcLen(); } MStatus arcLen::compute( const MPlug& plug, MDataBlock& data ) { MStatus status; if( plug == output ) { MDataHandle inputData = data.inputValue( inputCurve, &status ); if( !status ) { status.perror("ERROR getting data"); } else { MObject curve = inputData.asNurbsCurveTransformed(); MFnNurbsCurve curveFn( curve, &status ); if( !status ) { status.perror("ERROR creating curve function set"); } else { double result = curveFn.length(); MDataHandle outputHandle = data.outputValue( arcLen::output ); outputHandle.set( result ); data.setClean(plug); } } } else { return MS::kUnknownParameter; } return MS::kSuccess; } MStatus arcLen::initialize() { MFnNumericAttribute numericAttr; MFnTypedAttribute typedAttr; MStatus status; inputCurve = typedAttr.create( "inputCurve", "in", MFnData::kNurbsCurve, &status ); if( !status ) { status.perror("ERROR creating arcLen curve attribute"); return status; } output = numericAttr.create( "output", "out", MFnNumericData::kDouble, 0.0, &status ); if( !status ) { status.perror("ERROR creating arcLen output attribute"); return status; } numericAttr.setWritable(false); status = addAttribute( inputCurve ); if( !status ) { status.perror("addAttribute(inputCurve)"); return status; } status = addAttribute( output ); if( !status ) { status.perror("addAttribute(output)"); return status; } status = attributeAffects( inputCurve, output ); if( !status ) { status.perror("attributeAffects(inputCurve, output)"); return status; } return MS::kSuccess; } MStatus initializePlugin( MObject obj ) { MStatus status; MFnPlugin plugin( obj, "Alias", "3.0", "Any"); status = plugin.registerNode( "arcLen", arcLen::id, arcLen::creator, arcLen::initialize); if (!status) { status.perror("registerNode"); return status; } return status; } MStatus uninitializePlugin( MObject obj) { MStatus status; MFnPlugin plugin( obj ); status = plugin.deregisterNode( arcLen::id ); if (!status) { status.perror("deregisterNode"); return status; } return status; }