Class JSpeexEncoderTask

java.lang.Object
org.apache.tools.ant.ProjectComponent
org.apache.tools.ant.Task
org.xiph.speex.ant.JSpeexEncoderTask
All Implemented Interfaces:
Cloneable

public class JSpeexEncoderTask extends org.apache.tools.ant.Task
Ant Task to Encode an audio file from PCM Wave to Speex. Here is an usage example:
 
 
   
     
       
     
   
 
 
Version:
$Revision: 1.2 $
Author:
Marc Gimpel, Wimba S.A. (mgimpel@horizonwimba.com)
  • Field Summary

    Fields
    Modifier and Type
    Field
    Description
    protected int
    Defines the desired bitrate for the encoded audio.
    protected int
    Defines the number of channels of the audio input (1=mono, 2=stereo).
    protected int
    Defines the encoders algorithmic complexity.
    static final String
    Copyright display String
    static final int
    Print level for messages : Print debug information
    private File
    Directory to place destination files
    private File
    Destination file of decoded audio
    protected int
    Defines File format for output audio file (Raw or Wave).
    protected boolean
    Defines whether or not to use DTX (Discontinuous Transmission).
    static final int
    Print level for messages : Print only errors
    private boolean
     
    static final int
    File format for input or output audio file: Ogg
    static final int
    File format for input or output audio file: Raw
    static final int
    File format for input or output audio file: Wave
    static final int
    Print level for messages : Print basic information
    protected int
    Defines the encoder mode (0=NB, 1=WB and 2-UWB).
    protected boolean
    Whether the mode is manualy set or automatically determined.
    protected int
    Defines the number of frames per speex packet.
    private int
    Print level for messages
    protected int
    Defines the encoder quality setting (integer from 0 to 10).
    private boolean
    Tells the task to suppress all but the most important output
    protected int
    Defines the sampling rate of the audio input.
    private File
    Source file to decode
    private final Vector
    List of source files to decode
    protected int
    Defines File format for input audio file (Raw, Ogg or Wave).
    protected boolean
    Defines whether or not to use VAD (Voice Activity Detection).
    protected boolean
    Defines whether or not to use VBR (Variable Bit Rate).
    protected float
    Defines the encoder VBR quality setting (float from 0 to 10).
    private boolean
    Tells the task to output as much information as possible
    static final String
    Version of the Speex Encoder
    static final int
    Print level for messages : Print only warnings and errors

    Fields inherited from class org.apache.tools.ant.Task

    target, taskName, taskType, wrapper

    Fields inherited from class org.apache.tools.ant.ProjectComponent

    description, location, project
  • Constructor Summary

    Constructors
    Constructor
    Description
     
  • Method Summary

    Modifier and Type
    Method
    Description
    void
    addFileset(org.apache.tools.ant.types.FileSet set)
    Handles the fileset child element.
    private File
    Builds and returns the destination file.
    void
    encode(File srcPath, File destPath)
    Encodes a PCM file to Speex.
    void
    The method executing the task.
    protected static int
    readInt(byte[] data, int offset)
    Converts Little Endian (Windows) bytes to an int (Java uses Big Endian).
    protected static int
    readShort(byte[] data, int offset)
    Converts Little Endian (Windows) bytes to an short (Java uses Big Endian).
    void
    setComplexity(int complexity)
    Handles the complexity attribute.
    void
    Handles the destdir attribute.
    void
    Handles the destfile attribute.
    void
    setDtx(boolean dtx)
    Handles the dtx attribute.
    void
    setFailonerror(boolean failOnError)
    Handles the failonerror attribute.
    void
    Handles the mode attribute.
    void
    setNframes(int nframes)
    Handles the nframes attribute.
    void
    setQuality(float quality)
    Handles the quality attribute.
    void
    setQuiet(boolean quiet)
    Handles the quiet attribute.
    void
    Handles the srcfile attribute.
    private void
    setupTask(File srcPath, File destPath)
    Setup some task variables.
    void
    setVad(boolean vad)
    Handles the vad attribute.
    void
    setVbr(boolean vbr)
    Handles the vbr attribute.
    void
    setVerbose(boolean verbose)
    Handles the verbose attribute.
    void
    Prints the version.

    Methods inherited from class org.apache.tools.ant.Task

    bindToOwner, getOwningTarget, getRuntimeConfigurableWrapper, getTaskName, getTaskType, getWrapper, handleErrorFlush, handleErrorOutput, handleFlush, handleInput, handleOutput, init, isInvalid, log, log, log, log, maybeConfigure, perform, reconfigure, setOwningTarget, setRuntimeConfigurableWrapper, setTaskName, setTaskType

    Methods inherited from class org.apache.tools.ant.ProjectComponent

    clone, getDescription, getLocation, getProject, setDescription, setLocation, setProject

    Methods inherited from class java.lang.Object

    equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
  • Field Details

    • VERSION

      public static final String VERSION
      Version of the Speex Encoder
      See Also:
    • DEBUG

      public static final int DEBUG
      Print level for messages : Print debug information
      See Also:
    • INFO

      public static final int INFO
      Print level for messages : Print basic information
      See Also:
    • WARN

      public static final int WARN
      Print level for messages : Print only warnings and errors
      See Also:
    • ERROR

      public static final int ERROR
      Print level for messages : Print only errors
      See Also:
    • FILE_FORMAT_RAW

      public static final int FILE_FORMAT_RAW
      File format for input or output audio file: Raw
      See Also:
    • FILE_FORMAT_OGG

      public static final int FILE_FORMAT_OGG
      File format for input or output audio file: Ogg
      See Also:
    • FILE_FORMAT_WAVE

      public static final int FILE_FORMAT_WAVE
      File format for input or output audio file: Wave
      See Also:
    • srcFile

      private File srcFile
      Source file to decode
    • srcFileset

      private final Vector srcFileset
      List of source files to decode
    • destFile

      private File destFile
      Destination file of decoded audio
    • destDir

      private File destDir
      Directory to place destination files
    • failOnError

      private boolean failOnError
    • printlevel

      private int printlevel
      Print level for messages
    • quiet

      private boolean quiet
      Tells the task to suppress all but the most important output
    • verbose

      private boolean verbose
      Tells the task to output as much information as possible
    • srcFormat

      protected int srcFormat
      Defines File format for input audio file (Raw, Ogg or Wave).
    • destFormat

      protected int destFormat
      Defines File format for output audio file (Raw or Wave).
    • modeset

      protected boolean modeset
      Whether the mode is manualy set or automatically determined.
    • mode

      protected int mode
      Defines the encoder mode (0=NB, 1=WB and 2-UWB).
    • quality

      protected int quality
      Defines the encoder quality setting (integer from 0 to 10).
    • complexity

      protected int complexity
      Defines the encoders algorithmic complexity.
    • nframes

      protected int nframes
      Defines the number of frames per speex packet.
    • bitrate

      protected int bitrate
      Defines the desired bitrate for the encoded audio.
    • sampleRate

      protected int sampleRate
      Defines the sampling rate of the audio input.
    • channels

      protected int channels
      Defines the number of channels of the audio input (1=mono, 2=stereo).
    • vbr_quality

      protected float vbr_quality
      Defines the encoder VBR quality setting (float from 0 to 10).
    • vbr

      protected boolean vbr
      Defines whether or not to use VBR (Variable Bit Rate).
    • vad

      protected boolean vad
      Defines whether or not to use VAD (Voice Activity Detection).
    • dtx

      protected boolean dtx
      Defines whether or not to use DTX (Discontinuous Transmission).
  • Constructor Details

    • JSpeexEncoderTask

      public JSpeexEncoderTask()
  • Method Details

    • execute

      public void execute() throws org.apache.tools.ant.BuildException
      The method executing the task.
      Overrides:
      execute in class org.apache.tools.ant.Task
      Throws:
      org.apache.tools.ant.BuildException
    • buildDestFile

      private File buildDestFile(File srcFile)
      Builds and returns the destination file.
      Parameters:
      srcFile -
      Returns:
      the destination file.
    • setupTask

      private void setupTask(File srcPath, File destPath)
      Setup some task variables.
      Parameters:
      srcPath - the Speex encoded source file.
      destPath - the destination file.
    • addFileset

      public void addFileset(org.apache.tools.ant.types.FileSet set)
      Handles the fileset child element.
      Parameters:
      set -
    • setSrcfile

      public void setSrcfile(File file)
      Handles the srcfile attribute.
      Parameters:
      file - the attribute value converted to a File.
    • setDestfile

      public void setDestfile(File file)
      Handles the destfile attribute.
      Parameters:
      file - the attribute value converted to a File.
    • setDestdir

      public void setDestdir(File dir)
      Handles the destdir attribute.
      Parameters:
      dir - the attribute value converted to a File.
    • setFailonerror

      public void setFailonerror(boolean failOnError)
      Handles the failonerror attribute.
      Parameters:
      failOnError - the attribute value converted to a boolean.
    • setQuiet

      public void setQuiet(boolean quiet)
      Handles the quiet attribute.
      Parameters:
      quiet - the attribute value converted to a boolean.
    • setVerbose

      public void setVerbose(boolean verbose)
      Handles the verbose attribute.
      Parameters:
      verbose - the attribute value converted to a boolean.
    • setQuality

      public void setQuality(float quality)
      Handles the quality attribute.
      Parameters:
      quality - the attribute value converted to a float.
    • setComplexity

      public void setComplexity(int complexity)
      Handles the complexity attribute.
      Parameters:
      complexity - the attribute value converted to an integer.
    • setNframes

      public void setNframes(int nframes)
      Handles the nframes attribute.
      Parameters:
      nframes - the attribute value converted to an integer.
    • setVbr

      public void setVbr(boolean vbr)
      Handles the vbr attribute.
      Parameters:
      vbr - the attribute value converted to a boolean.
    • setVad

      public void setVad(boolean vad)
      Handles the vad attribute.
      Parameters:
      vad - the attribute value converted to a boolean.
    • setDtx

      public void setDtx(boolean dtx)
      Handles the dtx attribute.
      Parameters:
      dtx - the attribute value converted to a boolean.
    • setMode

      public void setMode(String mode)
      Handles the mode attribute.
      Parameters:
      mode - the attribute value converted to a String.
    • version

      public void version()
      Prints the version.
    • encode

      public void encode(File srcPath, File destPath) throws IOException
      Encodes a PCM file to Speex.
      Parameters:
      srcPath -
      destPath -
      Throws:
      IOException
    • readInt

      protected static int readInt(byte[] data, int offset)
      Converts Little Endian (Windows) bytes to an int (Java uses Big Endian).
      Parameters:
      data - the data to read.
      offset - the offset from which to start reading.
      Returns:
      the integer value of the reassembled bytes.
    • readShort

      protected static int readShort(byte[] data, int offset)
      Converts Little Endian (Windows) bytes to an short (Java uses Big Endian).
      Parameters:
      data - the data to read.
      offset - the offset from which to start reading.
      Returns:
      the integer value of the reassembled bytes.