mirror of
https://github.com/m1k1o/neko.git
synced 2024-07-24 14:40:50 +12:00
add broadcast endpoint & broadcast pipeline return error.
This commit is contained in:
@ -4,10 +4,10 @@ import (
|
||||
"demodesk/neko/internal/capture/gst"
|
||||
)
|
||||
|
||||
func (manager *CaptureManagerCtx) StartBroadcast(url string) {
|
||||
func (manager *CaptureManagerCtx) StartBroadcast(url string) error {
|
||||
manager.broadcast_url = url
|
||||
manager.broadcasting = true
|
||||
manager.createBroadcastPipeline()
|
||||
return manager.createBroadcastPipeline()
|
||||
}
|
||||
|
||||
func (manager *CaptureManagerCtx) StopBroadcast() {
|
||||
@ -23,13 +23,9 @@ func (manager *CaptureManagerCtx) BroadcastUrl() string {
|
||||
return manager.broadcast_url
|
||||
}
|
||||
|
||||
func (manager *CaptureManagerCtx) createBroadcastPipeline() {
|
||||
func (manager *CaptureManagerCtx) createBroadcastPipeline() error {
|
||||
var err error
|
||||
|
||||
if manager.broadcast != nil || !manager.BroadcastEnabled() {
|
||||
return
|
||||
}
|
||||
|
||||
manager.logger.Info().
|
||||
Str("audio_device", manager.config.Device).
|
||||
Str("video_display", manager.config.Display).
|
||||
@ -44,11 +40,12 @@ func (manager *CaptureManagerCtx) createBroadcastPipeline() {
|
||||
)
|
||||
|
||||
if err != nil {
|
||||
manager.logger.Panic().Err(err).Msg("unable to create broadcast pipeline")
|
||||
return err
|
||||
}
|
||||
|
||||
manager.broadcast.Play()
|
||||
manager.logger.Info().Msgf("starting broadcast pipeline")
|
||||
return nil
|
||||
}
|
||||
|
||||
func (manager *CaptureManagerCtx) destroyBroadcastPipeline() {
|
||||
|
@ -46,14 +46,18 @@ func New(desktop types.DesktopManager, config *config.Capture) *CaptureManagerCt
|
||||
}
|
||||
|
||||
func (manager *CaptureManagerCtx) Start() {
|
||||
manager.createBroadcastPipeline()
|
||||
if manager.BroadcastEnabled() {
|
||||
manager.createBroadcastPipeline()
|
||||
}
|
||||
|
||||
manager.desktop.OnBeforeScreenSizeChange(func() {
|
||||
if manager.Streaming() {
|
||||
manager.destroyVideoPipeline()
|
||||
}
|
||||
|
||||
manager.destroyBroadcastPipeline()
|
||||
if manager.BroadcastEnabled() {
|
||||
manager.destroyBroadcastPipeline()
|
||||
}
|
||||
})
|
||||
|
||||
manager.desktop.OnAfterScreenSizeChange(func() {
|
||||
@ -61,7 +65,9 @@ func (manager *CaptureManagerCtx) Start() {
|
||||
manager.createVideoPipeline()
|
||||
}
|
||||
|
||||
manager.createBroadcastPipeline()
|
||||
if manager.BroadcastEnabled() {
|
||||
manager.createBroadcastPipeline()
|
||||
}
|
||||
})
|
||||
|
||||
go func() {
|
||||
@ -85,9 +91,15 @@ func (manager *CaptureManagerCtx) Start() {
|
||||
|
||||
func (manager *CaptureManagerCtx) Shutdown() error {
|
||||
manager.logger.Info().Msgf("capture shutting down")
|
||||
manager.StopStream()
|
||||
|
||||
if manager.Streaming() {
|
||||
manager.StopStream()
|
||||
}
|
||||
|
||||
if manager.BroadcastEnabled() {
|
||||
manager.createBroadcastPipeline()
|
||||
}
|
||||
|
||||
manager.destroyBroadcastPipeline()
|
||||
manager.emit_stop <- true
|
||||
return nil
|
||||
}
|
||||
|
Reference in New Issue
Block a user