mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-11 19:48:54 +01:00
audio: Add comments, add IsPlaying
This commit is contained in:
parent
2c7430171d
commit
2d5ac9e987
@ -62,7 +62,7 @@ func square(out []float32, volume float64, freq float64, sequence float64) {
|
|||||||
for i := 0; i < len(out); i++ {
|
for i := 0; i < len(out); i++ {
|
||||||
a := float32(volume)
|
a := float32(volume)
|
||||||
if i%length < int(float64(length)*sequence) {
|
if i%length < int(float64(length)*sequence) {
|
||||||
a = 0
|
a = -a
|
||||||
}
|
}
|
||||||
out[i] = a
|
out[i] = a
|
||||||
}
|
}
|
||||||
|
@ -46,9 +46,7 @@ func Queue(channel int, l []float32, r []float32) {
|
|||||||
audio.Queue(channel, l, r)
|
audio.Queue(channel, l, r)
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: Add funciton to append samples to the buffer without adjusting.
|
// IsPlaying returns a boolean value which indicates if the channel buffer has data to play.
|
||||||
|
func IsPlaying(channel int) bool {
|
||||||
// TODO: better name
|
return audio.IsPlaying(channel)
|
||||||
func CurrentTime() int {
|
|
||||||
return audio.CurrentBytes()
|
|
||||||
}
|
}
|
||||||
|
@ -17,8 +17,8 @@ package audio
|
|||||||
const bufferSize = 1024
|
const bufferSize = 1024
|
||||||
const SampleRate = 44100
|
const SampleRate = 44100
|
||||||
|
|
||||||
var nextInsertion = 0
|
var nextInsertionPosition = 0
|
||||||
var currentBytes = 0
|
var currentPosition = 0
|
||||||
|
|
||||||
type channel struct {
|
type channel struct {
|
||||||
l []float32
|
l []float32
|
||||||
@ -55,8 +55,8 @@ func Play(channel int, l []float32, r []float32) bool {
|
|||||||
if ch == nil {
|
if ch == nil {
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
ch.l = append(ch.l, make([]float32, nextInsertion-len(ch.l))...)
|
ch.l = append(ch.l, make([]float32, nextInsertionPosition-len(ch.l))...)
|
||||||
ch.r = append(ch.r, make([]float32, nextInsertion-len(ch.r))...)
|
ch.r = append(ch.r, make([]float32, nextInsertionPosition-len(ch.r))...)
|
||||||
ch.l = append(ch.l, l...)
|
ch.l = append(ch.l, l...)
|
||||||
ch.r = append(ch.r, r...)
|
ch.r = append(ch.r, r...)
|
||||||
return true
|
return true
|
||||||
@ -72,26 +72,21 @@ func Queue(channel int, l []float32, r []float32) {
|
|||||||
ch.r = append(ch.r, r...)
|
ch.r = append(ch.r, r...)
|
||||||
}
|
}
|
||||||
|
|
||||||
func CurrentBytes() int {
|
|
||||||
return currentBytes + nextInsertion
|
|
||||||
}
|
|
||||||
|
|
||||||
func Update() {
|
func Update() {
|
||||||
nextInsertion += SampleRate / 60
|
nextInsertionPosition += SampleRate / 60
|
||||||
}
|
}
|
||||||
|
|
||||||
func channelAt(i int) *channel {
|
func channelAt(i int) *channel {
|
||||||
if i == -1 {
|
if i == -1 {
|
||||||
for _, ch := range channels {
|
for i, _ := range channels {
|
||||||
if len(ch.l) <= nextInsertion {
|
if !IsPlaying(i) {
|
||||||
return ch
|
return channels[i]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
ch := channels[i]
|
if !IsPlaying(i) {
|
||||||
if len(ch.l) <= nextInsertion {
|
return channels[i]
|
||||||
return ch
|
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
@ -122,3 +117,8 @@ func loadChannelBuffers() (l, r []float32) {
|
|||||||
}
|
}
|
||||||
return inputL, inputR
|
return inputL, inputR
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func IsPlaying(channel int) bool {
|
||||||
|
ch := channels[channel]
|
||||||
|
return nextInsertionPosition < len(ch.l)
|
||||||
|
}
|
||||||
|
@ -31,13 +31,13 @@ func initialize() {
|
|||||||
node = context.Call("createScriptProcessor", bufferSize, 0, 2)
|
node = context.Call("createScriptProcessor", bufferSize, 0, 2)
|
||||||
node.Call("addEventListener", "audioprocess", func(e js.Object) {
|
node.Call("addEventListener", "audioprocess", func(e js.Object) {
|
||||||
defer func() {
|
defer func() {
|
||||||
currentBytes += bufferSize
|
currentPosition += bufferSize
|
||||||
}()
|
}()
|
||||||
|
|
||||||
l := e.Get("outputBuffer").Call("getChannelData", 0)
|
l := e.Get("outputBuffer").Call("getChannelData", 0)
|
||||||
r := e.Get("outputBuffer").Call("getChannelData", 1)
|
r := e.Get("outputBuffer").Call("getChannelData", 1)
|
||||||
inputL, inputR := loadChannelBuffers()
|
inputL, inputR := loadChannelBuffers()
|
||||||
nextInsertion -= min(bufferSize, nextInsertion)
|
nextInsertionPosition -= min(bufferSize, nextInsertionPosition)
|
||||||
for i := 0; i < bufferSize; i++ {
|
for i := 0; i < bufferSize; i++ {
|
||||||
// TODO: Use copyFromChannel?
|
// TODO: Use copyFromChannel?
|
||||||
if len(inputL) <= i {
|
if len(inputL) <= i {
|
||||||
|
Loading…
Reference in New Issue
Block a user