API In Go
Normal mode (即 normalMode)
func NewBMFGraph(mode BMFGraphMode, option interface{}) *BMFGraph
Para:
- mode: 枚举类型,即 BMF 的运行模式,有以下选项:
- Normal mode(最常用)
- Server:预构建模式
- Generator:生成器模式
- SubGraph:子图模式
- Update:动态增删流场景
- option: interface{} 类型,BMF 的全局参数,通常可以填空值 nil
Return:
- *BMFGraph: 结构体指针类型,全局 Graph 指针
func (g *BMFGraph) Decode(decodePara interface{}, controlStream *BMFStream) *BMFNode
Para:
- decodePara: interface{} 类型,解码模块的参数,可以用 map[string]interface{} 数据结构来表示
- controlStream: 结构体指针类型,通常为空 nil
Return:
- *BMFNode: 结构体指针类型,指向解码节点的指针
func (n *BMFNode) Stream(id interface{}) *BMFStream
Para:
- id: 整数,表示该节点的 stream number(stream number 通常从 0 开始)
Return:
- *BMFStream: 结构体指针类型,指向流结构体的指针
func (g *BMFGraph) Encode(videoStream *BMFStream, audioStream *BMFStream, encoderPara interface{}) *BMFNode
Para:
- videoStream: 结构体指针类型,视频流的结构体指针
- audioStream: 结构体指针类型,音频流的结构体指针
- encoderPara: interface{} 类型,解码模块的参数,可以用 map[string]interface{} 数据结构来表示
Return:
- *BMFNode: 结构体指针类型,编码节点指针
func (g *BMFGraph) Module(inputs []*BMFStream, moduleName string, moduleType BMFModuleType, modulePath string, moduleEntry string, option interface{}, preModule *BMFModuleInstance) *BMFNode
Para:
- inputs: BMFStream 结构指针的 slice 结构,代表模块的所有输入流
- moduleName: 字符串类型,模块名称
- moduleType: 枚举类型,有以下选项: -Python -Cpp -Go
- modulePath: 字符串类型,模块文件所在路径
- moduleEntry: 字符串类型,模块入口
- option: interface{} 类型,模块参数
- preModule: BMFModuleInstance 的结构体指针,预加载模块,如果没有则为 nil
Return:
- *BMFNode: 结构体指针类型,模块对应节点的指针
func (g *BMFGraph) Run(needMerge bool) *CBMFGraph
Para:
- needMerge: Boolean 类型,是否合并图中的 ffmpeg filter 节点,通常为 true
Return:
- *CBMFGraph: 结构体指针类型,是指向 C 语言 Graph 对象的封装结构体的指针
func (bgp *CBMFGraph) Close() error
Return:
- error: error类型,当 C graph 结构为空时,会报错
preload mode (即 premoduleMode)
func NewCBMFModule(moduleName string, option interface{}, moduleType BMFModuleType, modulePath, moduleEntry string) (*CBMFModule, error)
Para:
- moduleName: 字符串类型,模块名称
- option: interface{} 类型,模块参数
- moduleType: 枚举类型,具有以下选项: -Python -Cpp -Go
- modulePath: 字符串类型,模块文件所在的路径
- moduleEntry: 字符串类型,模块入口
Return:
- *BMFModuleInstance: 结构体指针类型,是指向 C 语言模块对象的封装结构体的指针
- error: error 类型,当 C Graph 结构为空时,会报错
func (s *BMFStream) Module(inputs []*BMFStream, moduleName string, moduleType BMFModuleType, modulePath string, moduleEntry string, option interface{}, preModule *CBMFModule) *BMFNode
注意: 该接口与普通模式下的模块接口的区别在于调用者是 BMFStream 而不是 BMFGraph。 当调用者为 BMFStream 时,与调用者对应的流将与输入中的其他流合并,共同用作模块的输入流。
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: 字符串类型,模块类型(Python,C++,Go)
- Path: 字符串类型,对应模块实施文件的路径
- entry: 字符串类型,模块入口
- ninputs: int32 类型,指定输入流的数量
- nooutputs: int32 类型,注定输出流的数量
Return:
- *Modulefunctor: 实例化的 Modulefunctor
- error: 错误信息,默认为 nil
func (self *Modulefunctor) Execute(inputs []*Packet, cleanup bool) (bool, error)
Para:
- inputs: *Packet 是元素类型的 slice structure,其中包含要处理的输入数据包
- cleanup : bool 类型,控制是否清除所有未获取结果
Return:
- bool: 操作是否成功,1 表示成功,0 表示失败
- error: 错误信息,默认为 nil
func (self *Modulefunctor) Fetch(index int) ([]*Packet, error)
Para:
- inputs: *Packet 是元素类型的 slice structure,其中包含要处理的输入数据包
- cleanup : bool 类型,控制是否清除所有未获取结果
Return:
- []*Packet: 同步模式模块处理的数据包列表
- error: 错误信息,默认为 nil
func (self *Modulefunctor) Call(inputs []*Packet) ([]*Packet, error)
Para:
- inputs: *Packet 是元素类型的 slice structure,其中包含要处理的输入数据包
Return:
- []*Packet: 同步模式模块处理的数据包列表
- error: 错误信息,默认为 nil
func deleteModulefunctor(o *Modulefunctor)
Para:
- o: *Modulefunctor,指向将被释放的 Modulefunctor 实例
最后修改
July 16, 2024
: update the macos building doc (6d093eb)