[Android & Kotlin] SoundPool で効果音を鳴らす

音を扱うクラスとしてSoundPoolがあり、比較的短いものを遅延が少なく再生できるのでゲームの効果音の再生などに向いています。
 
下はAnimationとsound再生を同時に行った例です。
 
soundpool 01b - [Android & Kotlin] SoundPool で効果音を鳴らす

Android Studio 4.1.3
API 30

 

000000047128 - [Android & Kotlin] SoundPool で効果音を鳴らすimpression?a id=2545324&p id=969&pc id=1263&pl id=47128 - [Android & Kotlin] SoundPool で効果音を鳴らす R904D.E24336V - [Android & Kotlin] SoundPool で効果音を鳴らす

SoundPool

 
Audioの再生にはこのSoundPool以外にもMediaPlayerやAudioTrackがあります。

  • SoundPool
    • 再生可能なフォーマット:mp3, ogg, wav(非圧縮), etc.
    • Audio Mixerのように複数の音源を重ねて再生できる
    • 事前にデコードしてメモリに展開するので低レイテンシー
    • 再生できるのは5秒程度
    • 繰り返し再生
    • 再生スピードを可変できる
    • それぞれの音源に優先度をつけられる
    • ゲームの効果音再生に適している
  • MediaPlayer
    • Supported media formatsおそらくこれらをサポート
    • BGMとしてあるいは楽曲の再生用途で使う
  • AudioTrack
    • メモリに直接展開して再生するので低レイテンシー
    • 細かい操作ができる(してあげないといけない)

 

 

SoundPool

 
SoundPoolはLollipop以降使い方が変わりました。

  1. val audioAttributes = AudioAttributes.Builder()…
  2. val soundPool = SoundPool.Builder()…
  3. soundPool.load(…)
  4. soundPool.play(int soundID, float leftVolume, float rightVolume, int priority, int loop, float rate)
    • soundID: load()で決めたID
    • leftVolume, rightVolume: 左音量, 右音量(range = 0.0 to 1.0)
    • priority: (0 = lowest priority) default 0
    • loop: (0 = no loop, -1 = loop forever)
    • rate: (1.0 = normal playback, range 0.5 to 2.0)

SoundPoolは、事前に音源をロードしておく必要があります。いきなりロード再生ではうまくいきません。そのためアプリとして音源を抱えたままになりかねないため、release, unload等を使って
Out Of memory
に陥らない対策が必要です。
SoundPoolAudioAttributes
 
wavファイルを res/raw/ 以下に置きます。
「res」から「New」「Directory」

soundpool a02 - [Android & Kotlin] SoundPool で効果音を鳴らす

res以下にできたディレクトリーにwavファイルを入れます。参考までに以下wavファイルを名前をつけて保存できます。
one two
soundpool a03 - [Android & Kotlin] SoundPool で効果音を鳴らす

多くの音声ファイルをフォルダ階層で管理したい場合はassetsに置きます。ただし、assetsからのデータ取得はAssetManagerを使う作業が必要です。

 

サンプルコード

 
View Binding を使います
MainActivity.kt

 
activity_main.xml

 
strings.xml

 
View Bindingを使うので設定が必要です
build.gradle

 
ボタンを押してSoundPoolで音を再生し、ボタンを回転させてみました。

References:
SoundPool
AudioAttributes