Unityで音楽プレイヤーを作成してみよう。なお、今回音源はサーバーに配置する。
UIの設定
① Unityで新規プロジェクトを2Dで作成する。今回プロジェクト名はUnityMusicPlayerとした。
② 新規にキャンバスを配置し、以下のように縦長に設定する。
data:image/s3,"s3://crabby-images/0def7/0def7c6fee0a8e2ad80bb8aec70625704abf1fb8" alt=""
③ Canvasの子要素にDropdownを作成し、上方に配置した後、Optionsの値を以下のように書き換える
data:image/s3,"s3://crabby-images/6ecbe/6ecbe343e49a36baaa7046e74c1319a576ef5e91" alt=""
④ Canvasの子要素にButtonを3つ配置し、以下のように設定する
data:image/s3,"s3://crabby-images/72ad9/72ad9a8cbd3f73891b1499103458189c06ae582d" alt=""
⑤ Canvasの子要素にsliderを配置し、VolSliderとリネーム後、初期値のvalueを0.5にしておく
data:image/s3,"s3://crabby-images/8ac4f/8ac4fe1ee1d952522973ad20acffb8fb5375ec59" alt=""
Musicオブジェクトの作成
① CreateEmptyから空のゲームオブジェクトを作成してMusicとリネームする。
data:image/s3,"s3://crabby-images/b3c45/b3c459bd8abb43bea571351ee1b77dd6626ad962" alt=""
② MusicにAudioSourceコンポーネントを付与し、以下のように設定する。
data:image/s3,"s3://crabby-images/ce17c/ce17cd0f79ea32b66de2ece9132fb8436d4a9807" alt=""
③ 新規C#よりMusicControllerスクリプトを作成し、以下のように記述する
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;
using UnityEngine.Networking;
public class MusicController : MonoBehaviour {
//アタッチされたAudioSourceをキャッシュするための変数
AudioSource myAudio;
//スライダーの値をもとにボリュームを調整する
public Slider volSlider;
//選択項目をもとに読み込むファイルを決定する
public Dropdown musicSelect;
//番号とファイルUrlのDictionary
Dictionary<int, string> dict = new Dictionary<int, string>();
void Start() {
dict.Add(0, "https://joytas.net/php/futta-fly3t.wav");
dict.Add(1, "https://joytas.net/php/futta-rainbow3t.wav");
dict.Add(2, "https://joytas.net/php/futta-snowman3t.wav");
myAudio = GetComponent<AudioSource>();
myAudio.volume = volSlider.value;
//1曲目をセット
StartCoroutine(GetAudioClip(dict[0]));
}
IEnumerator GetAudioClip(string musicUrl) {
//音楽ファイルURLを元にuwrインスタンスを生成(今回ファイルタイプはwav)
using (var uwr = UnityWebRequestMultimedia.GetAudioClip(musicUrl, AudioType.WAV)) {
yield return uwr.SendWebRequest();
if (uwr.isNetworkError || uwr.isHttpError) {
Debug.LogError(uwr.error);
yield break;
}
//無事音楽ファイルが取得できたらオーディオソースにセット
myAudio.clip = DownloadHandlerAudioClip.GetContent(uwr);
}
}
public void playBt() {
myAudio.Play();
}
public void pauseBt() {
myAudio.Pause();
}
public void stopBt() {
myAudio.Stop();
}
public void OnVolChange() {
myAudio.volume = volSlider.value;
}
public void ChangeMusic() {
//ドロップダウンの情報を引数にしてコルーチン起動
StartCoroutine(GetAudioClip(dict[musicSelect.value]));
}
}
④ スクリプトをMusicに付与してDropDownとVolSliderを以下のように登録する
data:image/s3,"s3://crabby-images/bf6f4/bf6f49bc74a3b088bae4e2ba620dfd6fd3c6b008" alt=""
各UIの設定
① Dropdownを選択してOnValueChangedにMusicオブジェクトを登録。
Functionの中からMusicController.ChangeMusicを選択する。
data:image/s3,"s3://crabby-images/d9b8a/d9b8ac1113ed67289151b85301cac5a044a35e3b" alt=""
② PlayBtを選択し、OnClickにMusicを登録しfunctionの中からMusicController.playBtを選択する
data:image/s3,"s3://crabby-images/6af60/6af6041a9bd66b6c6fb83925fbd5622b37482731" alt=""
③ 同様にPauseBtにはpauseBtをStopBtにはstopBtを割り付ける
data:image/s3,"s3://crabby-images/4728f/4728fab7a5e5b284e7f341ec86c5b19ac4e3892c" alt=""
data:image/s3,"s3://crabby-images/99311/993112c6ca81b0f62582997e63fb5ff5a6b62bb0" alt=""
④ 最後にVolSliderも同じようにMusicController.OnVolChangeを割り付ける
data:image/s3,"s3://crabby-images/94638/9463810752268319c3fa6f02a96f80626bed56cb" alt=""
完成
以上で完成だ。サーバーからの音源のダウンロード方法とスライダーでの音量調整などを参考にしてもらいたい。
コメント