#include //For NULL... #include "nvtt.h" #include "nvtt_wrapper.h" #include "OutputOptions.h" namespace nvttCWrap { //Simple class to re-route calls to the C++ interfaces to C functions struct HandlerProxy : public nvtt::ErrorHandler, public nvtt::OutputHandler { public: HandlerProxy() { errorFunc = NULL; outputFunc = NULL; imageFunc = NULL; } virtual void error(nvtt::Error e) { if(errorFunc != NULL) errorFunc((NvttError)e); } virtual void beginImage(int size, int width, int height, int depth, int face, int miplevel) { if(imageFunc != NULL) imageFunc(size, width, height, depth, face, miplevel); } virtual bool writeData(const void * data, int size) { if(outputFunc != NULL) return (outputFunc(data, size) != NVTT_False); else return true; //Just say we succeed anyway... despite nothing being done, in case the user only set the beginImage() func. } nvttErrorHandler errorFunc; nvttOutputHandler outputFunc; nvttImageHandler imageFunc; }; } // InputOptions class. NvttInputOptions * nvttCreateInputOptions() { return new nvtt::InputOptions(); } void nvttDestroyInputOptions(NvttInputOptions * inputOptions) { delete inputOptions; } void nvttSetInputOptionsTextureLayout(NvttInputOptions * inputOptions, NvttTextureType type, int w, int h, int d) { inputOptions->setTextureLayout((nvtt::TextureType)type, w, h, d); } void nvttResetInputOptionsTextureLayout(NvttInputOptions * inputOptions) { inputOptions->resetTextureLayout(); } NvttBoolean nvttSetInputOptionsMipmapData(NvttInputOptions * inputOptions, const void * data, int w, int h, int d, int face, int mipmap) { return (NvttBoolean)inputOptions->setMipmapData(data, w, h, d, face, mipmap); } void nvttSetInputOptionsFormat(NvttInputOptions * inputOptions, NvttInputFormat format) { inputOptions->setFormat((nvtt::InputFormat)format); } void nvttSetInputOptionsAlphaMode(NvttInputOptions * inputOptions, NvttAlphaMode alphaMode) { inputOptions->setAlphaMode((nvtt::AlphaMode)alphaMode); } void nvttSetInputOptionsGamma(NvttInputOptions * inputOptions, float inputGamma, float outputGamma) { inputOptions->setGamma(inputGamma, outputGamma); } void nvttSetInputOptionsWrapMode(NvttInputOptions * inputOptions, NvttWrapMode mode) { inputOptions->setWrapMode((nvtt::WrapMode)mode); } void nvttSetInputOptionsMipmapFilter(NvttInputOptions * inputOptions, NvttMipmapFilter filter) { inputOptions->setMipmapFilter((nvtt::MipmapFilter)filter); } void nvttSetInputOptionsMipmapGeneration(NvttInputOptions * inputOptions, NvttBoolean enabled, int maxLevel) { inputOptions->setMipmapGeneration(enabled != NVTT_False, maxLevel); } void nvttSetInputOptionsKaiserParameters(NvttInputOptions * inputOptions, float width, float alpha, float stretch) { inputOptions->setKaiserParameters(width, alpha, stretch); } void nvttSetInputOptionsNormalMap(NvttInputOptions * inputOptions, NvttBoolean b) { inputOptions->setNormalMap(b != NVTT_False); } void nvttSetInputOptionsConvertToNormalMap(NvttInputOptions * inputOptions, NvttBoolean convert) { inputOptions->setConvertToNormalMap(convert != NVTT_False); } void nvttSetInputOptionsHeightEvaluation(NvttInputOptions * inputOptions, float redScale, float greenScale, float blueScale, float alphaScale) { inputOptions->setHeightEvaluation(redScale, greenScale, blueScale, alphaScale); } void nvttSetInputOptionsNormalFilter(NvttInputOptions * inputOptions, float small, float medium, float big, float large) { inputOptions->setNormalFilter(small, medium, big, large); } void nvttSetInputOptionsNormalizeMipmaps(NvttInputOptions * inputOptions, NvttBoolean b) { inputOptions->setNormalizeMipmaps(b != NVTT_False); } void nvttSetInputOptionsColorTransform(NvttInputOptions * inputOptions, NvttColorTransform t) { inputOptions->setColorTransform((nvtt::ColorTransform)t); } void nvttSetInputOptionsLinearTransfrom(NvttInputOptions * inputOptions, int channel, float w0, float w1, float w2, float w3) { inputOptions->setLinearTransform(channel, w0, w1, w2, w3); } void nvttSetInputOptionsMaxExtents(NvttInputOptions * inputOptions, int dim) { inputOptions->setMaxExtents(dim); } void nvttSetInputOptionsRoundMode(NvttInputOptions * inputOptions, NvttRoundMode mode) { inputOptions->setRoundMode((nvtt::RoundMode)mode); } // CompressionOptions class. NvttCompressionOptions * nvttCreateCompressionOptions() { return new nvtt::CompressionOptions(); } void nvttDestroyCompressionOptions(NvttCompressionOptions * compressionOptions) { delete compressionOptions; } void nvttSetCompressionOptionsFormat(NvttCompressionOptions * compressionOptions, NvttFormat format) { compressionOptions->setFormat((nvtt::Format)format); } void nvttSetCompressionOptionsQuality(NvttCompressionOptions * compressionOptions, NvttQuality quality) { compressionOptions->setQuality((nvtt::Quality)quality); } void nvttSetCompressionOptionsColorWeights(NvttCompressionOptions * compressionOptions, float red, float green, float blue, float alpha) { compressionOptions->setColorWeights(red, green, blue, alpha); } void nvttSetCompressionOptionsPixelFormat(NvttCompressionOptions * compressionOptions, unsigned int bitcount, unsigned int rmask, unsigned int gmask, unsigned int bmask, unsigned int amask) { compressionOptions->setPixelFormat(bitcount, rmask, gmask, bmask, amask); } void nvttSetCompressionOptionsQuantization(NvttCompressionOptions * compressionOptions, NvttBoolean colorDithering, NvttBoolean alphaDithering, NvttBoolean binaryAlpha, int alphaThreshold) { compressionOptions->setQuantization(colorDithering != NVTT_False, alphaDithering != NVTT_False, binaryAlpha != NVTT_False, alphaThreshold); } // OutputOptions class. NvttOutputOptions * nvttCreateOutputOptions() { nvtt::OutputOptions * outputOptions = new nvtt::OutputOptions(); nvttCWrap::HandlerProxy * handlerProxy = new nvttCWrap::HandlerProxy(); outputOptions->m.cWrapperProxy = handlerProxy; return outputOptions; } void nvttDestroyOutputOptions(NvttOutputOptions * outputOptions) { nvttCWrap::HandlerProxy * handlerProxy = (nvttCWrap::HandlerProxy *)outputOptions->m.cWrapperProxy; delete outputOptions; delete handlerProxy; } void nvttSetOutputOptionsFileName(NvttOutputOptions * outputOptions, const char * fileName) { outputOptions->setFileName(fileName); } void nvttSetOutputOptionsOutputHeader(NvttOutputOptions * outputOptions, NvttBoolean b) { outputOptions->setOutputHeader(b != NVTT_False); } void nvttSetOutputOptionsErrorHandler(NvttOutputOptions * outputOptions, nvttErrorHandler errorHandler) { nvttCWrap::HandlerProxy * handlerProxy = (nvttCWrap::HandlerProxy *)outputOptions->m.cWrapperProxy; handlerProxy->errorFunc = errorHandler; if(errorHandler == NULL) outputOptions->setErrorHandler(NULL); else outputOptions->setErrorHandler(handlerProxy); } void nvttSetOutputOptionsOutputHandler(NvttOutputOptions * outputOptions, nvttOutputHandler outputHandler, nvttImageHandler imageHandler) { nvttCWrap::HandlerProxy * handlerProxy = (nvttCWrap::HandlerProxy *)outputOptions->m.cWrapperProxy; handlerProxy->outputFunc = outputHandler; handlerProxy->imageFunc = imageHandler; if((outputHandler == NULL) && (imageHandler == NULL)) outputOptions->setOutputHandler(NULL); else outputOptions->setOutputHandler(handlerProxy); } // Compressor class. NvttCompressor * nvttCreateCompressor() { return new nvtt::Compressor(); } void nvttDestroyCompressor(NvttCompressor * compressor) { delete compressor; } NvttBoolean nvttCompress(const NvttCompressor * compressor, const NvttInputOptions * inputOptions, const NvttCompressionOptions * compressionOptions, const NvttOutputOptions * outputOptions) { return (NvttBoolean)compressor->process(*inputOptions, *compressionOptions, *outputOptions); } int nvttEstimateSize(const NvttCompressor * compressor, const NvttInputOptions * inputOptions, const NvttCompressionOptions * compressionOptions) { return compressor->estimateSize(*inputOptions, *compressionOptions); } void nvttEnableCudaCompression(NvttCompressor * compressor, NvttBoolean enable) { compressor->enableCudaAcceleration(enable != NVTT_False); } // Global functions. const char * nvttErrorString(NvttError e) { return nvtt::errorString((nvtt::Error)e); } unsigned int nvttVersion() { return nvtt::version(); }