add mutex on streaming and fix "Fail while changing screen size and no users are joined".

This commit is contained in:
Miroslav Šedivý 2020-11-14 23:14:48 +01:00
parent 0d419787bc
commit db706097f6

View File

@ -1,6 +1,8 @@
package capture package capture
import ( import (
"sync"
"github.com/kataras/go-events" "github.com/kataras/go-events"
"github.com/rs/zerolog" "github.com/rs/zerolog"
"github.com/rs/zerolog/log" "github.com/rs/zerolog/log"
@ -12,6 +14,7 @@ import (
type CaptureManagerCtx struct { type CaptureManagerCtx struct {
logger zerolog.Logger logger zerolog.Logger
mu sync.Mutex
video *gst.Pipeline video *gst.Pipeline
audio *gst.Pipeline audio *gst.Pipeline
broadcast *gst.Pipeline broadcast *gst.Pipeline
@ -30,6 +33,7 @@ type CaptureManagerCtx struct {
func New(desktop types.DesktopManager, config *config.Capture) *CaptureManagerCtx { func New(desktop types.DesktopManager, config *config.Capture) *CaptureManagerCtx {
return &CaptureManagerCtx{ return &CaptureManagerCtx{
logger: log.With().Str("module", "capture").Logger(), logger: log.With().Str("module", "capture").Logger(),
mu: sync.Mutex{},
emit_update: make(chan bool), emit_update: make(chan bool),
emit_stop: make(chan bool), emit_stop: make(chan bool),
emmiter: events.New(), emmiter: events.New(),
@ -45,12 +49,18 @@ func (manager *CaptureManagerCtx) Start() {
manager.createBroadcastPipeline() manager.createBroadcastPipeline()
manager.desktop.OnBeforeScreenSizeChange(func() { manager.desktop.OnBeforeScreenSizeChange(func() {
if manager.Streaming() {
manager.destroyVideoPipeline() manager.destroyVideoPipeline()
}
manager.destroyBroadcastPipeline() manager.destroyBroadcastPipeline()
}) })
manager.desktop.OnAfterScreenSizeChange(func() { manager.desktop.OnAfterScreenSizeChange(func() {
if manager.Streaming() {
manager.createVideoPipeline() manager.createVideoPipeline()
}
manager.createBroadcastPipeline() manager.createBroadcastPipeline()
}) })
@ -103,6 +113,9 @@ func (manager *CaptureManagerCtx) OnAudioFrame(listener func(sample types.Sample
} }
func (manager *CaptureManagerCtx) StartStream() { func (manager *CaptureManagerCtx) StartStream() {
manager.mu.Lock()
defer manager.mu.Unlock()
manager.logger.Info().Msgf("starting pipelines") manager.logger.Info().Msgf("starting pipelines")
manager.createVideoPipeline() manager.createVideoPipeline()
@ -111,6 +124,9 @@ func (manager *CaptureManagerCtx) StartStream() {
} }
func (manager *CaptureManagerCtx) StopStream() { func (manager *CaptureManagerCtx) StopStream() {
manager.mu.Lock()
defer manager.mu.Unlock()
manager.logger.Info().Msgf("stopping pipelines") manager.logger.Info().Msgf("stopping pipelines")
manager.destroyVideoPipeline() manager.destroyVideoPipeline()
@ -119,6 +135,9 @@ func (manager *CaptureManagerCtx) StopStream() {
} }
func (manager *CaptureManagerCtx) Streaming() bool { func (manager *CaptureManagerCtx) Streaming() bool {
manager.mu.Lock()
defer manager.mu.Unlock()
return manager.streaming return manager.streaming
} }