API In Go

Normal mode (refer to normalMode)

func NewBMFGraph(mode BMFGraphMode, option interface{}) *BMFGraph

Para:

  • mode: Enumeration type, the operation mode of BMF, with the following options:
    • Normal mode (most commonly used)
    • Server pre-built mode
    • Generator generator mode
    • SubGraph subgraph mode
    • Update Dynamic addition and deletion of streaming scenarios
  • option: interface{} type, global Parameter of BMF, usually can be filled with null value nil

Return:

  • *BMFGraph: structure pointer type, global Graph pointer

func (g *BMFGraph) Decode(decodePara interface{}, controlStream *BMFStream) *BMFNode

Para:

  • decodePara: interface{} type, decoding module Parameters, can be represented by map[string]interface{} data structure
  • controlStream: structure pointer type, usually empty nil

Return:

  • *BMFNode: structure pointer type, pointer to decoding node

func (n *BMFNode) Stream(id interface{}) *BMFStream

Para:

  • id: integer, representing the stream number of the node (the stream number usually starts from 0)

Return:

  • *BMFStream: structure pointer type, pointer to stream structure

func (g *BMFGraph) Encode(videoStream *BMFStream, audioStream *BMFStream, encoderPara interface{}) *BMFNode

Para:

  • videoStream: structure pointer type, the structure pointer of the video stream
  • audioStream: structure pointer type, structure pointer of audio stream
  • encoderPara: interface{} type, encoding module Parameters, can be represented by map[string]interface{} data structure

Return:

  • *BMFNode: structure pointer type, coded node pointer

func (g *BMFGraph) Module(inputs []*BMFStream, moduleName string, moduleType BMFModuleType, modulePath string, moduleEntry string, option interface{}, preModule *BMFModuleInstance) *BMFNode

Para:

  • inputs: The slice structure of the BMFStream structure pointer, representing all input streams of the module
  • moduleName: string type, module name
  • moduleType: enumerated type, with the following options: -Python -Cpp
    • Go
  • modulePath: string type, the path where the module file is located
  • moduleEntry: string type, module entry
  • option: interface{} type, module Parameter
  • preModule: structure pointer of BMFModuleInstance, preload module, nil if no

Return:

  • *BMFNode: structure pointer type, the pointer of the corresponding node of the module

func (g *BMFGraph) Run(needMerge bool) *CBMFGraph

Para:

  • needMerge: Boolean type, whether to merge the ffmpeg filter nodes in the graph, usually true

Return:

  • *CBMFGraph: structure pointer type, which is a pointer to the encapsulation structure of the C language graph object

func (bgp *CBMFGraph) Close() error

Return:

  • error: error type, when the C graph structure is empty, an error will be reported

preload mode (refer to premoduleMode)

func NewCBMFModule(moduleName string, option interface{}, moduleType BMFModuleType, modulePath, moduleEntry string) (*CBMFModule, error)

Para:

  • moduleName: string type, module name
  • option: interface{} type, module Parameter
  • moduleType: enumerated type, with the following options: -Python -Cpp
    • Go
  • modulePath: string type, the path where the module file is located
  • moduleEntry: string type, module entry

Return:

  • *BMFModuleInstance: structure pointer type, which is a pointer to the encapsulation structure of the C language module object
  • error: error type, when the C graph structure is empty, an error will be reported

func (s *BMFStream) Module(inputs []*BMFStream, moduleName string, moduleType BMFModuleType, modulePath string, moduleEntry string, option interface{}, preModule *CBMFModule) *BMFNode

Note: The difference between this interface and the Module interface in normal mode is that the caller is BMFStream instead of BMFGraph. When the caller is BMFStream, the stream corresponding to the caller will be merged with other streams in inputs, and they will be used as the input stream of the module together.

Sync mode (see syncMode & syncModeSerial)

func NewModulefunctor(name, tp, path, entry string, option interface{}, ninputs, nooutputs int32) (*Modulefunctor, error)

Para:

  • name: string type, Module name
  • tp: string type, Module type (python, c++, go)
  • Path: string type, corresponding to the path of the module implementation file
  • entry: string type, module entry
  • ninputs: int32 type, specifies the number of input streams
  • nooutputs: int32 type, specifies the number of output streams

Return:

  • *Modulefunctor: the instantiated Modulefunctor
  • error: error message, default is nil

func (self *Modulefunctor) Execute(inputs []*Packet, cleanup bool) (bool, error)

Para:

  • inputs: *Packet is a slice structure of element type, which contains the input Packet to be processed
  • cleanup : bool type, controls whether to clear all un-fetch results

Return:

  • bool: Whether the operation is successful, 1 is success, 0 is failed
  • error: error message, default is nil

func (self *Modulefunctor) Fetch(index int) ([]*Packet, error)

Para:

  • inputs: *Packet is a slice structure of element type, which contains the input Packet to be processed
  • cleanup : bool type, controls whether to clear all un-fetch results

Return:

  • []*Packet: packet list processed by Sync mode module
  • error: error message, default is nil

func (self *Modulefunctor) Call(inputs []*Packet) ([]*Packet, error)

Para:

  • inputs: *Packet is a slice structure of element type, which contains the input Packet to be processed

Return:

  • []*Packet: packet list processed by Sync mode module
  • error: error message, default is nil

func deleteModulefunctor(o *Modulefunctor)

Para:

  • o: *Modulefunctor, pointing to the Modulefunctor instance that will be free

Last modified July 16, 2024 : update the macos building doc (6d093eb)