EstimateOutputBitRate Method

Summary
Gets the estimated conversion output bit rate, in bits per second.
Syntax
C#
C++/CLI
public virtual int EstimateOutputBitRate() 
public: 
virtual int EstimateOutputBitRate();  

Return Value

Estimated conversion output bit rate, in bits per second.

Remarks

The retrieved bit rate depends on the state of the convert object. If the object is in the running state, the retrieved bit rate is related to the actual number of bytes written. If the object is not running, the retrieved bit rate is a theoretical value dependent on the conversion settings and the chosen encoding settings.

Example
C#
using Leadtools; 
using Leadtools.Multimedia; 
using LeadtoolsMultimediaExamples.Fixtures; 
 
 
public bool _result = false; 
public ConvertCtrlForm _form = new ConvertCtrlForm(); 
public ConvertCtrl _convertctrl; 
public int _estBitRate = 0; 
public double _estFileSize = 0.0; 
 
public void EstimateExample() 
{ 
   // reference the convert control 
   _convertctrl = _form.ConvertCtrl; 
 
   // input and output files 
   string inFile = Path.Combine(LEAD_VARS.MediaDir, "ConvertCtrl_Source.avi"); 
   string outFile = Path.Combine(LEAD_VARS.MediaDir, "ConvertCtrl_EstimateOutputBitRateExample.avi"); 
 
   try 
   { 
      // set the source video 
      _convertctrl.SourceFile = inFile; 
 
      // set video and audio compressors 
      _convertctrl.VideoCompressors.H264.Selected = true; 
      _convertctrl.AudioCompressors.AC3.Selected = true; 
 
      // subscribe to the progress event 
      _convertctrl.Progress += new ProgressEventHandler(ConvertCtrl_Progress); 
 
      // set the capture target file 
      _convertctrl.TargetFile = outFile; 
 
      // set the capture mode to still and start 
      _convertctrl.StartConvert(); 
 
      // we'll loop on the state and pump messages for this example. 
      // but you should not need to if running from a Windows Forms application. 
      while (_convertctrl.State == ConvertState.Running) 
         Application.DoEvents(); 
 
      // set the result to what we expect 
      _result = (_estBitRate != 0 && _estFileSize != 0.0); 
   } 
   catch (Exception) 
   { 
      _result = false; 
   } 
} 
 
void ConvertCtrl_Progress(object sender, ProgressEventArgs e) 
{ 
   // get the bit rate estimate 
   // we will get called multiple time throughout the conversion process 
   // but for this example it is ok just to use the last received estimate 
   _estBitRate = _convertctrl.EstimateOutputBitRate(); 
 
   // get the file size estimate 
   _estFileSize = _convertctrl.EstimateOutputSize((double)e.time); 
} 
 
static class LEAD_VARS 
{ 
   public const string MediaDir = @"C:\LEADTOOLS23\Media"; 
} 
Requirements

Target Platforms

Help Version 23.0.2024.2.29
Products | Support | Contact Us | Intellectual Property Notices
© 1991-2024 LEAD Technologies, Inc. All Rights Reserved.

Leadtools.Multimedia Assembly
Products | Support | Contact Us | Intellectual Property Notices
© 1991-2023 LEAD Technologies, Inc. All Rights Reserved.