From 0959798ff6a26bfa4cb76982bbf9b392d4e2ee65 Mon Sep 17 00:00:00 2001 From: castano Date: Sat, 26 Jan 2008 02:49:00 +0000 Subject: [PATCH] Update bindings. --- .../vc8/Nvidia.TextureTools/TextureTools.cs | 40 ++++++++++++------- 1 file changed, 25 insertions(+), 15 deletions(-) diff --git a/project/vc8/Nvidia.TextureTools/TextureTools.cs b/project/vc8/Nvidia.TextureTools/TextureTools.cs index 812de25..8a09c4c 100644 --- a/project/vc8/Nvidia.TextureTools/TextureTools.cs +++ b/project/vc8/Nvidia.TextureTools/TextureTools.cs @@ -348,9 +348,6 @@ namespace Nvidia.TextureTools [DllImport("nvtt"), SuppressUnmanagedCodeSecurity] private extern static void nvttSetCompressionOptionsColorWeights(IntPtr compressionOptions, float red, float green, float blue, float alpha); - [DllImport("nvtt"), SuppressUnmanagedCodeSecurity] - private extern static void nvttEnableCompressionOptionsCudaCompression(IntPtr compressionOptions, bool enable); - [DllImport("nvtt"), SuppressUnmanagedCodeSecurity] private extern static void nvttSetCompressionOptionsPixelFormat(IntPtr compressionOptions, uint bitcount, uint rmask, uint gmask, uint bmask, uint amask); @@ -389,11 +386,6 @@ namespace Nvidia.TextureTools nvttSetCompressionOptionsColorWeights(options, red, green, blue, alpha); } - public void EnableCudaCompression(bool enable) - { - nvttEnableCompressionOptionsCudaCompression(options, enable); - } - public void SetPixelFormat(uint bitcount, uint rmask, uint gmask, uint bmask, uint amask) { nvttSetCompressionOptionsPixelFormat(options, bitcount, rmask, gmask, bmask, amask); @@ -473,28 +465,46 @@ namespace Nvidia.TextureTools #endregion #region public static class Compressor - public static class Compressor + public class Compressor { #region Bindings [DllImport("nvtt"), SuppressUnmanagedCodeSecurity] - private extern static bool nvttCompress(IntPtr inputOptions, IntPtr compressionOptions, IntPtr outputOptions); + private extern static IntPtr nvttCreateCompressor(); [DllImport("nvtt"), SuppressUnmanagedCodeSecurity] - private extern static int nvttEstimateSize(IntPtr inputOptions, IntPtr compressionOptions); + private extern static void nvttDestroyCompressor(IntPtr compressor); + + [DllImport("nvtt"), SuppressUnmanagedCodeSecurity] + private extern static bool nvttCompress(IntPtr compressor, IntPtr inputOptions, IntPtr compressionOptions, IntPtr outputOptions); + + [DllImport("nvtt"), SuppressUnmanagedCodeSecurity] + private extern static int nvttEstimateSize(IntPtr compressor, IntPtr inputOptions, IntPtr compressionOptions); [DllImport("nvtt"), SuppressUnmanagedCodeSecurity] private static extern IntPtr nvttErrorString(Error error); #endregion - public static bool Compress(InputOptions inputOptions, CompressionOptions compressionOptions, OutputOptions outputOptions) + internal IntPtr compressor; + + public Compressor() { - return nvttCompress(inputOptions.options, compressionOptions.options, outputOptions.options); + compressor = nvttCreateCompressor(); } - public static int EstimateSize(InputOptions inputOptions, CompressionOptions compressionOptions) + ~Compressor() { - return nvttEstimateSize(inputOptions.options, compressionOptions.options); + nvttDestroyCompressor(compressor); + } + + public bool Compress(InputOptions input, CompressionOptions compression, OutputOptions output) + { + return nvttCompress(compressor, input.options, compression.options, output.options); + } + + public int EstimateSize(InputOptions input, CompressionOptions compression) + { + return nvttEstimateSize(compressor, input.options, compression.options); } public static string ErrorString(Error error)