mirror of
https://github.com/m1k1o/neko.git
synced 2024-07-24 14:40:50 +12:00
edit broadcast.
This commit is contained in:
parent
507fce7862
commit
7fb977faa4
@ -7,14 +7,14 @@ import (
|
|||||||
func (manager *CaptureManagerCtx) StartBroadcastPipeline() {
|
func (manager *CaptureManagerCtx) StartBroadcastPipeline() {
|
||||||
var err error
|
var err error
|
||||||
|
|
||||||
if manager.IsBoradcasting() || manager.broadcast_url == "" {
|
if manager.broadcast != nil || !manager.BroadcastEnabled() {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
manager.logger.Info().
|
manager.logger.Info().
|
||||||
Str("audio_device", manager.config.Device).
|
Str("audio_device", manager.config.Device).
|
||||||
Str("video_display", manager.config.Display).
|
Str("video_display", manager.config.Display).
|
||||||
Str("rtmp_pipeline_src", manager.broadcast.Src).
|
Str("broadcast_pipeline", manager.config.BroadcastPipeline).
|
||||||
Msgf("Creating broadcast pipeline...")
|
Msgf("Creating broadcast pipeline...")
|
||||||
|
|
||||||
manager.broadcast, err = gst.CreateRTMPPipeline(
|
manager.broadcast, err = gst.CreateRTMPPipeline(
|
||||||
@ -33,26 +33,28 @@ func (manager *CaptureManagerCtx) StartBroadcastPipeline() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (manager *CaptureManagerCtx) StopBroadcastPipeline() {
|
func (manager *CaptureManagerCtx) StopBroadcastPipeline() {
|
||||||
if !manager.IsBoradcasting() {
|
if manager.broadcast == nil {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
manager.broadcast.DestroyPipeline()
|
manager.broadcast.DestroyPipeline()
|
||||||
|
manager.logger.Info().Msgf("Stopping broadcast pipeline...")
|
||||||
manager.broadcast = nil
|
manager.broadcast = nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (manager *CaptureManagerCtx) StartBroadcast(url string) {
|
func (manager *CaptureManagerCtx) StartBroadcast(url string) {
|
||||||
manager.broadcast_url = url
|
manager.broadcast_url = url
|
||||||
|
manager.broadcasting = true
|
||||||
manager.StartBroadcastPipeline()
|
manager.StartBroadcastPipeline()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (manager *CaptureManagerCtx) StopBroadcast() {
|
func (manager *CaptureManagerCtx) StopBroadcast() {
|
||||||
manager.broadcast_url = ""
|
manager.broadcasting = false
|
||||||
manager.StopBroadcastPipeline()
|
manager.StopBroadcastPipeline()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (manager *CaptureManagerCtx) IsBoradcasting() bool {
|
func (manager *CaptureManagerCtx) BroadcastEnabled() bool {
|
||||||
return manager.broadcast != nil
|
return manager.broadcasting
|
||||||
}
|
}
|
||||||
|
|
||||||
func (manager *CaptureManagerCtx) BroadcastUrl() string {
|
func (manager *CaptureManagerCtx) BroadcastUrl() string {
|
||||||
|
@ -21,6 +21,7 @@ type CaptureManagerCtx struct {
|
|||||||
shutdown chan bool
|
shutdown chan bool
|
||||||
emmiter events.EventEmmiter
|
emmiter events.EventEmmiter
|
||||||
streaming bool
|
streaming bool
|
||||||
|
broadcasting bool
|
||||||
broadcast_url string
|
broadcast_url string
|
||||||
desktop types.DesktopManager
|
desktop types.DesktopManager
|
||||||
}
|
}
|
||||||
@ -32,6 +33,7 @@ func New(desktop types.DesktopManager, config *config.Capture) *CaptureManagerCt
|
|||||||
emmiter: events.New(),
|
emmiter: events.New(),
|
||||||
config: config,
|
config: config,
|
||||||
streaming: false,
|
streaming: false,
|
||||||
|
broadcasting: false,
|
||||||
broadcast_url: "",
|
broadcast_url: "",
|
||||||
desktop: desktop,
|
desktop: desktop,
|
||||||
}
|
}
|
||||||
|
@ -24,6 +24,6 @@ type CaptureManager interface {
|
|||||||
// broacast
|
// broacast
|
||||||
StartBroadcast(url string)
|
StartBroadcast(url string)
|
||||||
StopBroadcast()
|
StopBroadcast()
|
||||||
IsBoradcasting() bool
|
BroadcastEnabled() bool
|
||||||
BroadcastUrl() string
|
BroadcastUrl() string
|
||||||
}
|
}
|
||||||
|
@ -45,7 +45,7 @@ func (h *MessageHandlerCtx) boradcastStatus(session types.Session) error {
|
|||||||
if err := session.Send(
|
if err := session.Send(
|
||||||
message.BroadcastStatus{
|
message.BroadcastStatus{
|
||||||
Event: event.BORADCAST_STATUS,
|
Event: event.BORADCAST_STATUS,
|
||||||
IsActive: h.capture.IsBoradcasting(),
|
IsActive: h.capture.BroadcastEnabled(),
|
||||||
URL: h.capture.BroadcastUrl(),
|
URL: h.capture.BroadcastUrl(),
|
||||||
}); err != nil {
|
}); err != nil {
|
||||||
h.logger.Warn().Err(err).Msgf("sending event %s has failed", event.BORADCAST_STATUS)
|
h.logger.Warn().Err(err).Msgf("sending event %s has failed", event.BORADCAST_STATUS)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user