mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-13 20:42:07 +01:00
audio: Bug fix: total num of buffers should be 8 for each source
This commit is contained in:
parent
49751eb954
commit
3638ac6ad8
@ -131,16 +131,19 @@ func (p *player) proceed() error {
|
|||||||
func (p *player) play() error {
|
func (p *player) play() error {
|
||||||
const bufferMaxNum = 8
|
const bufferMaxNum = 8
|
||||||
// TODO: What if play is already called?
|
// TODO: What if play is already called?
|
||||||
emptyBytes := make([]byte, bufferSize)
|
|
||||||
m.Lock()
|
m.Lock()
|
||||||
n := bufferMaxNum - int(p.alSource.BuffersQueued())
|
n := bufferMaxNum - int(p.alSource.BuffersQueued()) - len(p.alBuffers)
|
||||||
if 0 < n {
|
if 0 < n {
|
||||||
bufs := al.GenBuffers(n)
|
p.alBuffers = append(p.alBuffers, al.GenBuffers(n)...)
|
||||||
for _, buf := range bufs {
|
}
|
||||||
|
if 0 < len(p.alBuffers) {
|
||||||
|
emptyBytes := make([]byte, bufferSize)
|
||||||
|
for _, buf := range p.alBuffers {
|
||||||
// Note that the third argument of only the first buffer is used.
|
// Note that the third argument of only the first buffer is used.
|
||||||
buf.BufferData(al.FormatStereo16, emptyBytes, int32(p.sampleRate))
|
buf.BufferData(al.FormatStereo16, emptyBytes, int32(p.sampleRate))
|
||||||
p.alSource.QueueBuffers(buf)
|
p.alSource.QueueBuffers(buf)
|
||||||
}
|
}
|
||||||
|
p.alBuffers = []al.Buffer{}
|
||||||
}
|
}
|
||||||
al.PlaySources(p.alSource)
|
al.PlaySources(p.alSource)
|
||||||
m.Unlock()
|
m.Unlock()
|
||||||
|
Loading…
Reference in New Issue
Block a user