mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-12 20:18:59 +01:00
audio: Add (*Context).NewPlayer and (*Context).NewPlayerFromBytes
Closes #1708
This commit is contained in:
parent
1dc8002689
commit
92bc5c1908
@ -330,8 +330,8 @@ type playerImpl interface {
|
||||
//
|
||||
// A Player doesn't close src even if src implements io.Closer.
|
||||
// Closing the source is src owner's responsibility.
|
||||
func NewPlayer(context *Context, src io.Reader) (*Player, error) {
|
||||
pi, err := context.np.newPlayerImpl(context, src)
|
||||
func (c *Context) NewPlayer(src io.Reader) (*Player, error) {
|
||||
pi, err := c.np.newPlayerImpl(c, src)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
@ -343,15 +343,21 @@ func NewPlayer(context *Context, src io.Reader) (*Player, error) {
|
||||
return p, nil
|
||||
}
|
||||
|
||||
// NewPlayer creates a new player with the given stream.
|
||||
//
|
||||
// Deprecated: as of v2.2. Use (*Context).NewPlayer instead.
|
||||
func NewPlayer(context *Context, src io.Reader) (*Player, error) {
|
||||
return context.NewPlayer(src)
|
||||
}
|
||||
|
||||
// NewPlayerFromBytes creates a new player with the given bytes.
|
||||
//
|
||||
// As opposed to NewPlayer, you don't have to care if src is already used by another player or not.
|
||||
// src can be shared by multiple players.
|
||||
//
|
||||
// The format of src should be same as noted at NewPlayer.
|
||||
func NewPlayerFromBytes(context *Context, src []byte) *Player {
|
||||
b := bytes.NewReader(src)
|
||||
p, err := NewPlayer(context, b)
|
||||
func (c *Context) NewPlayerFromBytes(src []byte) *Player {
|
||||
p, err := c.NewPlayer(bytes.NewReader(src))
|
||||
if err != nil {
|
||||
// Errors should never happen.
|
||||
panic(fmt.Sprintf("audio: %v at NewPlayerFromBytes", err))
|
||||
@ -359,6 +365,13 @@ func NewPlayerFromBytes(context *Context, src []byte) *Player {
|
||||
return p
|
||||
}
|
||||
|
||||
// NewPlayerFromBytes creates a new player with the given bytes.
|
||||
//
|
||||
// Deprecated: as of v2.2. Use (*Context).NewPlayerFromBytes instead.
|
||||
func NewPlayerFromBytes(context *Context, src []byte) *Player {
|
||||
return context.NewPlayerFromBytes(src)
|
||||
}
|
||||
|
||||
func (p *Player) finalize() {
|
||||
runtime.SetFinalizer(p, nil)
|
||||
if !p.IsPlaying() {
|
||||
|
@ -147,7 +147,7 @@ func NewPlayer(game *Game, audioContext *audio.Context, musicType musicType) (*P
|
||||
default:
|
||||
panic("not reached")
|
||||
}
|
||||
p, err := audio.NewPlayer(audioContext, s)
|
||||
p, err := audioContext.NewPlayer(s)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
@ -246,7 +246,7 @@ func (p *Player) playSEIfNeeded() {
|
||||
if !p.shouldPlaySE() {
|
||||
return
|
||||
}
|
||||
sePlayer := audio.NewPlayerFromBytes(p.audioContext, p.seBytes)
|
||||
sePlayer := p.audioContext.NewPlayerFromBytes(p.seBytes)
|
||||
sePlayer.Play()
|
||||
}
|
||||
|
||||
|
@ -64,7 +64,7 @@ func (g *Game) Update() error {
|
||||
// s is still an io.ReadCloser and io.Seeker.
|
||||
s := audio.NewInfiniteLoopWithIntro(oggS, introLengthInSecond*4*sampleRate, loopLengthInSecond*4*sampleRate)
|
||||
|
||||
g.player, err = audio.NewPlayer(g.audioContext, s)
|
||||
g.player, err = g.audioContext.NewPlayer(s)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
@ -78,7 +78,7 @@ func (g *Game) initAudio() {
|
||||
// Wrap the raw audio with the StereoPanStream
|
||||
g.panstream = NewStereoPanStreamFromReader(audio.NewInfiniteLoop(oggS, oggS.Length()))
|
||||
|
||||
g.player, err = audio.NewPlayer(g.audioContext, g.panstream)
|
||||
g.player, err = g.audioContext.NewPlayer(g.panstream)
|
||||
if err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
@ -181,7 +181,7 @@ func (g *Game) init() {
|
||||
if err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
g.jumpPlayer, err = audio.NewPlayer(g.audioContext, jumpD)
|
||||
g.jumpPlayer, err = g.audioContext.NewPlayer(jumpD)
|
||||
if err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
@ -190,7 +190,7 @@ func (g *Game) init() {
|
||||
if err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
g.hitPlayer, err = audio.NewPlayer(g.audioContext, jabD)
|
||||
g.hitPlayer, err = g.audioContext.NewPlayer(jabD)
|
||||
if err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
@ -130,7 +130,7 @@ func (g *Game) playNote(scoreIndex int) rune {
|
||||
square(l, vol, freq, 0.25)
|
||||
square(r, vol, freq, 0.25)
|
||||
|
||||
p := audio.NewPlayerFromBytes(g.audioContext, toBytes(l, r))
|
||||
p := g.audioContext.NewPlayerFromBytes(toBytes(l, r))
|
||||
p.Play()
|
||||
|
||||
return rune(note)
|
||||
|
@ -221,7 +221,7 @@ func (g *Game) Update() error {
|
||||
// playNote plays piano sound with the given frequency.
|
||||
func (g *Game) playNote(freq float64) {
|
||||
f := int(freq)
|
||||
p := audio.NewPlayerFromBytes(g.audioContext, pianoNoteSamples[f])
|
||||
p := g.audioContext.NewPlayerFromBytes(pianoNoteSamples[f])
|
||||
p.Play()
|
||||
}
|
||||
|
||||
|
@ -94,10 +94,10 @@ func (g *Game) Update() error {
|
||||
g.audioContext = audio.NewContext(sampleRate)
|
||||
}
|
||||
if g.player == nil {
|
||||
// Pass the (infinite) stream to audio.NewPlayer.
|
||||
// Pass the (infinite) stream to NewPlayer.
|
||||
// After calling Play, the stream never ends as long as the player object lives.
|
||||
var err error
|
||||
g.player, err = audio.NewPlayer(g.audioContext, &stream{})
|
||||
g.player, err = g.audioContext.NewPlayer(&stream{})
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
@ -68,7 +68,7 @@ func NewGame() (*Game, error) {
|
||||
}
|
||||
|
||||
// Create an audio.Player that has one stream.
|
||||
g.audioPlayer, err = audio.NewPlayer(g.audioContext, d)
|
||||
g.audioPlayer, err = g.audioContext.NewPlayer(d)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user