audio: Add Close method

This commit is contained in:
Hajime Hoshi 2016-02-11 19:55:59 +09:00
parent 1fec0d8203
commit 6d3598c057
3 changed files with 46 additions and 25 deletions

View File

@ -37,3 +37,7 @@ func NewPlayer(src io.ReadSeeker, sampleRate int) *Player {
func (p *Player) Play() error {
return p.play()
}
func (p *Player) Close() error {
return p.close()
}

View File

@ -29,6 +29,24 @@ type player struct {
src io.ReadSeeker
sampleRate int
position float64
bufferSource *js.Object
}
func initialize() bool {
// Do nothing in node.js.
if js.Global.Get("require") != js.Undefined {
return false
}
class := js.Global.Get("AudioContext")
if class == js.Undefined {
class = js.Global.Get("webkitAudioContext")
}
if class == js.Undefined {
return false
}
context = class.New()
return true
}
func newPlayer(src io.ReadSeeker, sampleRate int) *Player {
@ -42,6 +60,7 @@ func newPlayer(src io.ReadSeeker, sampleRate int) *Player {
src: src,
sampleRate: sampleRate,
position: context.Get("currentTime").Float(),
bufferSource: nil,
}
return &Player{p}
}
@ -65,6 +84,11 @@ func (p *player) play() error {
if len(buf) == 0 {
return nil
}
// TODO: p.position should be updated
if p.bufferSource != nil {
p.bufferSource.Call("start", p.position)
return nil
}
const channelNum = 2
const bytesPerSample = channelNum * 16 / 8
b := context.Call("createBuffer", channelNum, len(buf)/bytesPerSample, p.sampleRate)
@ -76,27 +100,16 @@ func (p *player) play() error {
l.SetIndex(i, float64(il[i])/max)
r.SetIndex(i, float64(ir[i])/max)
}
s := context.Call("createBufferSource")
s.Set("buffer", b)
s.Call("connect", context.Get("destination"))
s.Call("start", p.position)
p.bufferSource = context.Call("createBufferSource")
p.bufferSource.Set("buffer", b)
p.bufferSource.Call("connect", context.Get("destination"))
p.bufferSource.Call("start", p.position)
p.position += b.Get("duration").Float()
return nil
}
func initialize() bool {
// Do nothing in node.js.
if js.Global.Get("require") != js.Undefined {
return false
}
class := js.Global.Get("AudioContext")
if class == js.Undefined {
class = js.Global.Get("webkitAudioContext")
}
if class == js.Undefined {
return false
}
context = class.New()
return true
func (p *player) close() error {
p.bufferSource.Call("stop")
p.bufferSource.Call("disconnect")
return nil
}

View File

@ -50,4 +50,8 @@ func (p *player) play() error {
return p.Play()
}
func (p *player) close() error {
return p.Close()
}
// TODO: Implement Close method