opus_encode method

int opus_encode(
  1. Pointer<OpusEncoder> st,
  2. Pointer<Int16> pcm,
  3. int frame_size,
  4. Pointer<Uint8> data,
  5. int max_data_bytes,
)

Encodes an Opus frame. @param in st OpusEncoder*: Encoder state @param in pcm opus_int16*: Input signal (interleaved if 2 channels). length is frame_sizechannelssizeof(opus_int16) @param in frame_size int: Number of samples per channel in the input signal. This must be an Opus frame size for the encoder's sampling rate. For example, at 48 kHz the permitted values are 120, 240, 480, 960, 1920, and 2880. Passing in a duration of less than 10 ms (480 samples at 48 kHz) will prevent the encoder from using the LPC or hybrid modes. @param out data unsigned char*: Output payload. This must contain storage for at least a max_data_bytes. @param in max_data_bytes opus_int32: Size of the allocated memory for the output payload. This may be used to impose an upper limit on the instant bitrate, but should not be used as the only bitrate control. Use #OPUS_SET_BITRATE to control the bitrate. @returns The length of the encoded packet (in bytes) on success or a negative error code (see @ref opus_errorcodes) on failure.

Implementation

int opus_encode(
  ffi.Pointer<OpusEncoder> st,
  ffi.Pointer<ffi.Int16> pcm,
  int frame_size,
  ffi.Pointer<ffi.Uint8> data,
  int max_data_bytes,
) {
  return _opus_encode(st, pcm, frame_size, data, max_data_bytes);
}