2010-05-20 16 views

Respuesta

8

Una búsqueda rápida en Google dice: no. Pero el example encoder parece que debería traducirse fácilmente a C# utilizando P/Invoke. El Encoder Algorithm Interface parece bastante manejable. Y siempre hay C++/CLI si todo lo demás falla. ¿Quién comienza el proyecto codeplex? :-)

Actualización: A partir de ahora, hay un hackish, rudimentario prototipo de trabajo API .NET. Aquí van:

#include "vpx_codec.h" 

#define VPX_CODEC_DISABLE_COMPAT 1 
#include "vpx_encoder.h" 
#include "vp8cx.h" 

#define vp8iface (&vpx_codec_vp8_cx_algo) 

using namespace System; 

namespace WebM 
{ 
    namespace VP8 
    { 
     namespace Native 
     { 
      public ref class VP8Codec 
      { 
      private: 
       vpx_codec_ctx_t* ctx; 

       VP8Codec(vpx_codec_ctx_t* ctx) 
       { 
        this->ctx = ctx; 
       } 

      public: 
       ~VP8Codec() 
       { 
        vpx_codec_destroy(ctx); 
        delete ctx; 
       } 

       property String^ LastError 
       { 
        String^ get() 
        { 
         return gcnew String(vpx_codec_error(ctx)); 
        } 
       } 

       property String^ LastErrorDetail 
       { 
        String^ get() 
        { 
         return gcnew String(vpx_codec_error_detail(ctx)); 
        } 
       } 

       int Encode() 
       { 
        // TODO: do actual encoding 
        return 
         vpx_codec_encode(ctx, NULL, 0, 1, 0, VPX_DL_REALTIME); 
       } 

       static VP8Codec^ CreateEncoder() // TODO: add 'config' argument 
       { 
        vpx_codec_ctx_t* ctx; 
        vpx_codec_enc_cfg_t cfg; 

        if(vpx_codec_enc_config_default(vp8iface, &cfg, 0)) 
        { 
         return nullptr; // TODO: throw exception 
        } 

        ctx = new vpx_codec_ctx_t; 

        if (vpx_codec_enc_init(ctx, vp8iface, &cfg, 0)) 
        { 
         delete ctx; 
         return nullptr; // TODO: throw exception 
        } 

        return gcnew VP8Codec(ctx); 
       } 

       static property int Version 
       { 
        int get() 
        { 
         return vpx_codec_version(); 
        } 
       } 

       static property String^ VersionString 
       { 
        String^ get() 
        { 
         return gcnew String(vpx_codec_version_str()); 
        } 
       } 

       static property String^ BuildConfig 
       { 
        String^ get() 
        { 
         return gcnew String(vpx_codec_build_config()); 
        } 
       } 

       static String^ GetErrorDescription(int errorCode) 
       { 
        return gcnew String(
         vpx_codec_err_to_string((vpx_codec_err_t)errorCode)); 
       } 

       static property String^ IfaceName 
       { 
        String^ get() 
        { 
         return gcnew String(vpx_codec_iface_name(vp8iface)); 
        } 
       } 
      }; 
     } 
    } 
} 

usted debería ser capaz de vincular esto contra vpxmtd.lib del libvpx Windows build. No pude deshacerme de una advertencia, pero hasta ahora parece funcionar. Mi C++/CLI está un poco oxidado, por lo que puede haber algunas pérdidas de memoria en el código.

Programa de prueba:

namespace WebM.VP8 
{ 
    using System; 

    using WebM.VP8.Native; 

    public class Program 
    { 
     public static void Main() 
     { 
      using (var encoder = VP8Codec.CreateEncoder()) 
      { 
       Console.WriteLine(encoder.Encode()); 
      } 
     } 
    } 
} 
+1

muy útil. Muchas gracias. –

+0

hola! ¿Cómo agregaste la referencia .lib al proyecto? cuando trato de agregar una referencia en vs2010, no toma paquetes .lib: s –

+0

¿Alguien en casa? :) –

Cuestiones relacionadas