2017-07-07 11:46:20 -05:00
|
|
|
package audio
|
|
|
|
|
|
|
|
import "time"
|
|
|
|
|
2017-07-12 15:43:55 -05:00
|
|
|
// Ctrl allows for pausing and tracking a Streamer.
|
|
|
|
//
|
|
|
|
// Wrap a Streamer in a Ctrl.
|
|
|
|
//
|
|
|
|
// ctrl := &audio.Ctrl{Streamer: s}
|
|
|
|
//
|
|
|
|
// Then, we can pause the streaming (this will cause Ctrl to stream silence).
|
|
|
|
//
|
|
|
|
// ctrl.Paused = true
|
|
|
|
//
|
|
|
|
// And we can check how much has already been streamed. Position is not incremented when the Ctrl is
|
|
|
|
// paused.
|
|
|
|
//
|
|
|
|
// fmt.Println(ctrl.Position)
|
|
|
|
//
|
|
|
|
// To completely stop a Ctrl before the wrapped Streamer is drained, just set the wrapped Streamer
|
|
|
|
// to nil.
|
|
|
|
//
|
|
|
|
// ctrl.Streamer = nil
|
|
|
|
//
|
|
|
|
// If you're playing a Streamer wrapped in a Ctrl through the speaker, you need to lock and unlock
|
|
|
|
// the speaker when modifying the Ctrl to avoid race conditions.
|
|
|
|
//
|
|
|
|
// speaker.Play(ctrl)
|
|
|
|
// // ...
|
|
|
|
// speaker.Lock()
|
|
|
|
// ctrl.Paused = true
|
|
|
|
// speaker.Unlock()
|
|
|
|
// // ...
|
|
|
|
// speaker.Lock()
|
|
|
|
// fmt.Println(ctrl.Position)
|
|
|
|
// speaker.Unlock()
|
2017-07-07 11:46:20 -05:00
|
|
|
type Ctrl struct {
|
|
|
|
Streamer Streamer
|
|
|
|
Paused bool
|
2017-07-11 13:01:15 -05:00
|
|
|
Position time.Duration
|
2017-07-07 11:46:20 -05:00
|
|
|
}
|
|
|
|
|
2017-07-12 15:43:55 -05:00
|
|
|
// Stream streams the wrapped Streamer, if not nil. If the Streamer is nil, Ctrl acts as drained.
|
|
|
|
// When paused, Ctrl streams silence.
|
2017-07-07 11:46:20 -05:00
|
|
|
func (c *Ctrl) Stream(samples [][2]float64) (n int, ok bool) {
|
|
|
|
if c.Streamer == nil {
|
|
|
|
return 0, false
|
|
|
|
}
|
|
|
|
if c.Paused {
|
|
|
|
for i := range samples {
|
|
|
|
samples[i] = [2]float64{}
|
|
|
|
}
|
|
|
|
return len(samples), true
|
|
|
|
}
|
|
|
|
n, ok = c.Streamer.Stream(samples)
|
2017-07-11 13:01:15 -05:00
|
|
|
c.Position += time.Duration(n) * time.Second / time.Duration(SampleRate)
|
2017-07-07 11:46:20 -05:00
|
|
|
return n, ok
|
|
|
|
}
|
2017-07-11 16:42:57 -05:00
|
|
|
|
2017-07-12 15:43:55 -05:00
|
|
|
// Err returns the error of the wrapped Streamer, if not nil.
|
2017-07-11 16:42:57 -05:00
|
|
|
func (c *Ctrl) Err() error {
|
|
|
|
if c.Streamer == nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
return c.Err()
|
|
|
|
}
|