convertBumpCmd.cpp
#include <maya/MPxCommand.h>
#include <maya/MStatus.h>
#include <maya/MArgList.h>
#include <maya/MFnPlugin.h>
#include <maya/MObject.h>
#include <maya/MGlobal.h>
#include <maya/MString.h>
#include <maya/MPoint.h>
#include <maya/MImage.h>
#include <maya/MIOStream.h>
#define IFFCHECKERR(stat, call) \
if (!stat) { \
        MString string = reader.errorString(); \
    string += " in method "; \
        string += #call; \
    displayError (string); \
        return MS::kFailure; \
}
class convertBump : public MPxCommand
{
public:
                convertBump();
    virtual     ~convertBump();
    MStatus     doIt ( const MArgList& args );
    bool        isUndoable() const;
    static      void* creator();
};
convertBump::convertBump()
{
}
convertBump::~convertBump() {}
void* convertBump::creator()
{
    return new convertBump;
}
bool convertBump::isUndoable() const
{
    return false;
}
MString itoa (int n)
{
        char buffer [256];
        sprintf (buffer, "%d", n);
        return MString (buffer);
}
MStatus convertBump::doIt( const MArgList& args )
{
        
        if (!MImage::filterExists(MImage::kHeightFieldBumpFormat, MImage::kNormalMapBumpFormat))
        {
                displayError ("Fatal Error! The required filter (kHeightFieldBumpFormat -> kNormalMapBumpFormat) isn't supported!");
                return MS::kFailure;
        }
        if (args.length () < 2 || args.length () > 4) 
        {
                displayError ("Syntax: convertBump inputFile outputFile [outputFormat [bumpScale]]");
                displayError ("(eg: convertBump \"C:/bump.tga\" \"C:/bump_norm.tga\" \"tga\" 1.0)");
                return MS::kFailure;
        }
        double bumpScale = 1.0;
        MString inputFilename, outputFilename;
        MString outputFormat = "iff";
        args.get(0, inputFilename);
        args.get(1, outputFilename);
        if (args.length() > 2)
                args.get(2, outputFormat);
        
        if (args.length() == 4)
        {
                MString lastArg;
                args.get (3, bumpScale);
        }
        MImage image;
        MStatus stat = image.readFromFile(inputFilename);
        if (!stat)
        {
                displayError ("Unable to open input file \"" + inputFilename + "\".");
                return MS::kFailure;
        }
        
        unsigned int width, height;
        stat = image.getSize(width, height);
        if (!stat)
        {
                displayError ("Unable to get size.");
                return MS::kFailure;
        }
        
        stat = image.filter(MImage::kHeightFieldBumpFormat, MImage::kNormalMapBumpFormat, bumpScale);
        if (!stat)
        {
                displayError ("Unable to apply the filter from height field to normal map bump format.");
                return MS::kFailure;
        }
        
        stat = image.writeToFile(outputFilename, outputFormat);
        if (!stat)
        {
                displayError ("Unable to write to output file \"" + outputFilename + "\" using output format " + outputFormat + 
                        ". (read-only? disk full? invalid path?)");
                return MS::kFailure;
        }
    return MS::kSuccess;
}
MStatus initializePlugin( MObject obj )
{
        MStatus status;
    MFnPlugin plugin( obj, PLUGIN_COMPANY, "4.0.1", "Any");
    status = plugin.registerCommand( "convertBump", convertBump::creator );
        if (!status)
                status.perror("registerCommand");
    return status;
}
MStatus uninitializePlugin( MObject obj )
{
        MStatus status;
    MFnPlugin plugin( obj );
    status = plugin.deregisterCommand( "convertBump" );
        if (!status)
                status.perror("deregisterCommand");
    return status;
}