1 /*---------------------------------------------------------------------------* 2 Project: NintendoWare 3 File: snd_SequenceSoundHandle.h 4 5 Copyright (C)2009-2010 Nintendo Co., Ltd./HAL Laboratory, Inc. All rights reserved. 6 7 These coded instructions, statements, and computer programs contain 8 proprietary information of Nintendo of America Inc. and/or Nintendo 9 Company Ltd., and are protected by Federal copyright law. They may 10 not be disclosed to third parties or copied or duplicated in any form, 11 in whole or in part, without the prior written consent of Nintendo. 12 13 $Revision: 24119 $ 14 *---------------------------------------------------------------------------*/ 15 16 /** 17 * :include nw/snd/snd_SequenceSoundHandle.h 18 * 19 * @file snd_SequenceSoundHandle.h 20 */ 21 22 #ifndef NW_SND_SEQUENCE_SOUND_HANDLE_H_ 23 #define NW_SND_SEQUENCE_SOUND_HANDLE_H_ 24 25 #include <nw/snd/snd_SequenceSound.h> 26 #include <nw/ut/ut_PreProcessor.h> 27 28 namespace nw { 29 namespace snd { 30 31 //--------------------------------------------------------------------------- 32 //! @brief 再生したシーケンスサウンドの操作を行うためのハンドルクラスです。 33 //! 34 //! サウンドは再生時に汎用サウンドハンドル 35 //! @ref SoundHandle と関連付けられますが、 36 //! シーケンスサウンドに固有の処理は汎用サウンドハンドルには実装されていません。 37 //! 38 //! シーケンスサウンドに固有の処理を行いたい場合は、 39 //! 汎用サウンドハンドルを引数にとるコンストラクタを用いて、 40 //! シーケンスサウンドハンドルを生成し、使用してください。 41 //! 42 //! ハンドルの使い方は、汎用サウンドハンドル @ref SoundHandle と同じです。 43 //! 44 //! @see SoundHandle クラス 45 //! 46 //! @date 2010/01/22 初版 47 //--------------------------------------------------------------------------- 48 class SequenceSoundHandle 49 { 50 public: 51 //---------------------------------------- 52 //! @name コンストラクタ/デストラクタ 53 //@{ 54 //--------------------------------------------------------------------------- 55 //! @brief コンストラクタです。 56 //! 57 //! 引数の無いコンストラクタは、 58 //! どのサウンドとも関連付けられていないハンドルを構築します。 59 //! 60 //! @date 2010/01/22 初版 61 //--------------------------------------------------------------------------- SequenceSoundHandle()62 SequenceSoundHandle() : m_pSound( NULL ) { } 63 64 //--------------------------------------------------------------------------- 65 //! @brief コンストラクタです。 66 //! 67 //! 引数付きコンストラクタは、引数 handle 68 //! で指定したサウンドハンドルが参照しているサウンドを用いて、 69 //! シーケンスサウンドハンドルを構築します。 70 //! シーケンスサウンド以外のサウンドがサウンドハンドルに関連付けられているときは、 71 //! 引数の無いコンストラクタと同様に構築します。 72 //! 73 //! 引数付きコンストラクタで構築したときに、 74 //! サウンドが既に別のシーケンスサウンドハンドルと関連付けられている場合は、 75 //! その関連付けが切られる点に注意してください。 76 //! ただし、引数に渡したサウンドハンドルとの関連付けは切れません。 77 //! 78 //! @param[in] handle シーケンスサウンドと関連付けられたサウンドハンドルです。 79 //! 80 //! @see SoundHandle クラス 81 //! 82 //! @date 2010/01/22 初版 83 //--------------------------------------------------------------------------- 84 SequenceSoundHandle( SoundHandle* handle ); 85 86 //--------------------------------------------------------------------------- 87 //! @brief デストラクタです。 88 //! 89 //! @date 2010/01/22 初版 90 //--------------------------------------------------------------------------- ~SequenceSoundHandle()91 ~SequenceSoundHandle() { DetachSound(); } 92 //@} 93 94 // ----------------------------------------------------------------- 95 //! @name 再生/停止/一時停止/再開 96 //@{ 97 98 //--------------------------------------------------------------------------- 99 //! @brief 再生準備の完了を待ってサウンドを再生します。 100 //! 101 //! ハンドルが無効の場合は、何もしません。 102 //! 103 //! サウンドの再生を開始するためには、@ref SoundArchivePlayer::PrepareSound 104 //! を呼び出した後、再生準備が完了していなければなりません。 105 //! この関数は、再生準備が完了したサウンドの再生を開始します。 106 //! 再生準備が完了していないサウンドは、完了するまで待ってから再生を開始します。 107 //! 108 //! @see nw::snd::SoundArchivePlayer::PrepareSound 109 //! 110 //! @date 2010/01/22 初版 111 //--------------------------------------------------------------------------- StartPrepared()112 void StartPrepared() 113 { 114 if ( IsAttachedSound() ) m_pSound->StartPrepared(); 115 } 116 117 //--------------------------------------------------------------------------- 118 //! @brief サウンドを停止します。 119 //! 120 //! ハンドルに関連付けられたサウンドを停止します。 121 //! ハンドルが無効の場合は、何もしません。 122 //! 123 //! fadeFrames で指定したフレーム数をかけてフェードアウトさせることができます。 124 //! 0 を指定した場合はフェードアウトを行わず、 125 //! エンベロープのリリースを発音し全ての減衰が完了した後にサウンドが停止します。 126 //! 127 //! フェードアウトの音量制御は、フェードインと共有されます。 128 //! フェードアウトにかかるフレーム数は、 129 //! 最大音量から音が消えるまでにかかる変化速度を表しますので、 130 //! フェードイン中にフェードアウトを指定した時などは、 131 //! 指定したフレーム数よりも短い時間でフェードアウトが完了する可能性があります。 132 //! 133 //! @param[in] fadeFrames フェードアウトにかけるフレーム数です。 134 //! 135 //! @date 2010/01/22 初版 136 //--------------------------------------------------------------------------- Stop(int fadeFrames)137 void Stop( int fadeFrames ) 138 { 139 if ( IsAttachedSound() ) m_pSound->Stop( fadeFrames ); 140 } 141 142 //--------------------------------------------------------------------------- 143 //! @brief サウンドを一時停止または再開します。 144 //! 145 //! ハンドルに関連付けられたサウンドを一時停止または再開します。 146 //! ハンドルが無効の場合は、何もしません。 147 //! 148 //! fadeFrames で指定したフレーム数をかけてフェードアウトしながら一時停止、 149 //! またはフェードインしながら再開させることができます。 150 //! 0 を指定した場合は、即座に一時停止または再開します。 151 //! 152 //! 一時停止・再開時のフェードは、再生開始時のフェードイン、 153 //! 停止時のフェードアウトとは独立してはたらきます。 154 //! フェードにかかるフレーム数は、最大音量から音が消えるまで、 155 //! あるいは、 156 //! 発音していない状態から最大音量に達するまでにかかる変化速度を表しますので、 157 //! フェード中にさらにフェードを指定した時などは、 158 //! 指定したフレーム数よりも短い時間でフェードが完了する可能性があります。 159 //! 160 //! @param[in] flag true なら一時停止、false なら再開します。 161 //! @param[in] fadeFrames フェードイン・フェードアウトにかけるフレーム数です。 162 //! 163 //! @see IsPause 164 //! 165 //! @date 2010/01/22 初版 166 //--------------------------------------------------------------------------- Pause(bool flag,int fadeFrames)167 void Pause( bool flag, int fadeFrames ) 168 { 169 if ( IsAttachedSound() ) m_pSound->Pause( flag, fadeFrames ); 170 } 171 172 //--------------------------------------------------------------------------- 173 //! @brief サウンドの再生準備が完了しているかどうかを調べます。 174 //! 175 //! @ref SoundArchivePlayer::PrepareSound を呼び出した後、 176 //! そのサウンドの再生準備が完了しているかどうかを調べます。 177 //! 再生準備が完了したサウンドは、@ref StartPrepared を呼び出した際に、 178 //! すぐに再生を始めることができます。 179 //! 180 //! @return サウンドの再生準備が完了していれば true を返します。 181 //! 182 //! @see SoundArchivePlayer::PrepareSound 183 //! @see StartPrepared 184 //! 185 //! @date 2010/01/22 初版 186 //--------------------------------------------------------------------------- IsPrepared()187 bool IsPrepared() const { return IsAttachedSound() && m_pSound->IsPrepared(); } 188 189 //--------------------------------------------------------------------------- 190 //! @brief サウンドが一時停止中かどうかを調べます。 191 //! 192 //! @return サウンドが一時停止状態であれば true を返します。 193 //! 194 //! @see Pause 195 //! 196 //! @date 2010/01/22 初版 197 //--------------------------------------------------------------------------- IsPause()198 bool IsPause() const { return IsAttachedSound() && m_pSound->IsPause(); } 199 200 //--------------------------------------------------------------------------- 201 //! @brief サウンドを再生開始時にフェードインさせます。 202 //! 203 //! この関数でフェードインの指定を行うと、 204 //! @ref SoundArchivePlayer::StartSound または 205 //! @ref StartPrepared を呼び出して再生を開始してから、 206 //! 最初の @ref SoundArchivePlayer::Update 207 //! が呼び出されたときにフェードインが設定されます。 208 //! 209 //! サウンドの再生が開始され、最初の @ref SoundArchivePlayer::Update 210 //! が呼ばれた後に、この関数を呼び出しても効果がありません。 211 //! 212 //! フェードインの音量制御は、停止時のフェードアウトと共有されます。 213 //! 214 //! @param[in] frames フェードインにかけるフレーム数です。 215 //! 216 //! @see SoundArchivePlayer::StartSound 217 //! @see StartPrepared 218 //! 219 //! @date 2010/01/22 初版 220 //--------------------------------------------------------------------------- FadeIn(int frames)221 void FadeIn( int frames ) 222 { 223 if ( IsAttachedSound() ) m_pSound->FadeIn( frames ); 224 } 225 //@} 226 227 // ----------------------------------------------------------------- 228 //! @name パラメータ変更 229 //@{ 230 231 //--------------------------------------------------------------------------- 232 //! @brief サウンドの音量を変更します。 233 //! 234 //! ハンドルに関連付けられたサウンドの音量を変更します。 235 //! ハンドルが無効の場合は、何もしません。 236 //! 237 //! この関数で指定する値は、他のどの音量パラメータとも独立して動作し、 238 //! それらは全て重ね合わされます。 239 //! 240 //! 音量 volume は、0.0 以上の倍率で指定します。 241 //! すなわち、1.0 を指定すると音量に影響を与えません。 242 //! 0.0 を指定すると発音されなくなります。デフォルト値は 1.0 です。 243 //! 244 //! 他の音量パラメータと重ね合わされたあと、 245 //! 最終的な音量は 0.0 ~ 2.0 の範囲でクランプされます。 246 //! この関数で 2.0 を設定したとしても、 247 //! 元の音量の 2 倍にならない可能性があることに注意してください。 248 //! 249 //! 音量の変化は frames で指定したフレーム数をかけて行われます。 250 //! 音量の変化途中にさらにこの関数を呼び出した場合は、 251 //! その時点での変化途中の音量値を基点として、 252 //! 新しく指定したフレーム数をかけて音量を変化させます。 253 //! 254 //! @param[in] volume 変更する音量の倍率 (0.0~) です。 255 //! @param[in] frames 音量変化にかけるフレーム数です。 256 //! 257 //! @date 2010/01/22 初版 258 //--------------------------------------------------------------------------- 259 void SetVolume( f32 volume, int frames = 0 ) 260 { 261 if ( IsAttachedSound() ) m_pSound->SetVolume( volume, frames ); 262 } 263 264 //--------------------------------------------------------------------------- 265 //! @brief サウンドの音程を変更します。 266 //! 267 //! ハンドルに関連付けられたサウンドの音程を変更します。 268 //! ハンドルが無効の場合は、何もしません。 269 //! 270 //! この関数で指定する値は、他のどの音程パラメータとも独立して動作し、 271 //! それらは全て重ね合わされます。 272 //! 273 //! 音程 pitch は、周波数の比率で指定します。 274 //! すなわち、1.0 を指定すると音程に影響を与えません。 275 //! 2.0 を指定すると再生される周波数が 2 倍になり、 276 //! 1 オクターブ高い音程になります。 277 //! 0.5 を指定すると 1 オクターブ低い音程になります。 278 //! デフォルト値は 1.0 です。 279 //! 280 //! @param[in] pitch 変更する音程の周波数比率です。 281 //! 282 //! @date 2010/01/22 初版 283 //--------------------------------------------------------------------------- SetPitch(f32 pitch)284 void SetPitch( f32 pitch ) 285 { 286 if ( IsAttachedSound() ) m_pSound->SetPitch( pitch ); 287 } 288 289 //--------------------------------------------------------------------------- 290 //! @brief サウンドのパン (左右の定位) を変更します。 291 //! 292 //! ハンドルに関連付けられたサウンドのパンを変更します。 293 //! ハンドルが無効の場合は、何もしません。 294 //! 295 //! この関数で指定する値は、他のどのパンパラメータとも独立して動作し、 296 //! それらは全て重ね合わされます。 297 //! 298 //! pan は、定位の相対変化の値を設定します。 299 //! 0.0 を指定するとデータで設定されたパンの値から変化しません。 300 //! 1.0 を指定すると中央に定位していた音が右端に定位するようになり、 301 //! -1.0 を指定すると中央に定位していた音が左端に定位するようになります。 302 //! デフォルト値は 0.0 です。 303 //! 304 //! @param[in] pan 0.0 を基準としたパンの相対変化の値です。 305 //! 306 //! @date 2010/01/22 初版 307 //--------------------------------------------------------------------------- SetPan(f32 pan)308 void SetPan( f32 pan ) 309 { 310 if ( IsAttachedSound() ) m_pSound->SetPan( pan ); 311 } 312 313 #ifdef NW_PLATFORM_RVL 314 //--------------------------------------------------------------------------- 315 //! :private 316 //! 317 //! @brief サウンドのサラウンドパン (前後の定位) を変更します。 318 //! 319 //! ハンドルに関連付けられたサウンドのサラウンドパンを変更します。 320 //! ハンドルが無効の場合は、何もしません。 321 //! 322 //! この関数で指定する値は、他のどのサラウンドパンパラメータとも独立して動作し、 323 //! それらは全て重ね合わされます。 324 //! 325 //! surroundPan は、定位の相対変化の値を設定します。 326 //! 0.0 を指定するとデータで設定されたパンの値から変化しません。 327 //! 1.0 を指定すると最前方に定位していた音が中央に定位するようになり、 328 //! 2.0 を指定すると最前方に定位していた音が最後方に定位するようになります。 329 //! 前方へ定位を移動させたい場合は負の値を指定してください。 330 //! デフォルト値は 0.0 です。 331 //! 332 //! @param[in] surroundPan 0.0 を基準としたサラウンドパンの相対変化の値です。 333 //! 334 //! @date 2010/01/22 初版 335 //--------------------------------------------------------------------------- SetSurroundPan(f32 surroundPan)336 void SetSurroundPan( f32 surroundPan ) 337 { 338 if ( IsAttachedSound() ) m_pSound->SetSurroundPan( surroundPan ); 339 } 340 #endif /* NW_PLATFORM_RVL */ 341 342 //--------------------------------------------------------------------------- 343 //! :private 344 //! 345 //! @brief サウンドのローパスフィルタカットオフ値を変更します。 346 //! 347 //! ハンドルに関連付けられたローパスフィルタカットオフ値を変更します。 348 //! ハンドルが無効の場合は、何もしません。 349 //! 350 //! この関数で指定する値は、 351 //! 他のどのローパスフィルタカットオフパラメータとも独立して動作し、 352 //! それらは全て重ね合わされます。 353 //! 354 //! lpfFreq は、カットオフの相対変化の値を指定します。 355 //! 0.0 を指定するとカットオフの値を変更しません。 356 //! -1.0 を指定すると、フィルタがかかっていない状態から、 357 //! もっともフィルタがかかっている状態 (カットオフ周波数が下がる方向) 358 //! に変更します。 359 //! 360 //! @param[in] lpfFreq 0.0 を基準としたフィルタカットオフの相対変化の値です。 361 //! 362 //! @date 2010/01/22 初版 363 //--------------------------------------------------------------------------- SetLpfFreq(f32 lpfFreq)364 void SetLpfFreq( f32 lpfFreq ) 365 { 366 if ( IsAttachedSound() ) m_pSound->SetLpfFreq( lpfFreq ); 367 } 368 369 //--------------------------------------------------------------------------- 370 //! @brief プレイヤープライオリティを変更します。 371 //! 372 //! ハンドルに関連付けられたサウンドのプレイヤープライオリティを変更します。 373 //! ハンドルが無効の場合は、何もしません。 374 //! 375 //! この関数は、サウンドアーカイブ中のデータで指定されている 376 //! プレイヤープライオリティの値を変更します。 377 //! 378 //! priority の値の範囲は 0~127 で、大きいほど優先度が高くなります。 379 //! 380 //! @param[in] priority プレイヤープライオリティの値です。 381 //! 382 //! @date 2010/01/22 初版 383 //--------------------------------------------------------------------------- SetPlayerPriority(int priority)384 void SetPlayerPriority( int priority ) 385 { 386 if ( IsAttachedSound() ) m_pSound->SetPlayerPriority( priority ); 387 } 388 389 //--------------------------------------------------------------------------- 390 //! @brief サウンドのメインセンド量を変更します。 391 //! 392 //! ハンドルに関連付けられたサウンドのメインセンド量を変更します。 393 //! ハンドルが無効の場合は、何もしません。 394 //! 395 //! この関数で指定する値は、他のどのメインセンド量とも独立して動作し、 396 //! それらは全て重ね合わされます。 397 //! 398 //! メインセンドは、 399 //! 出力に送るサウンドの音量をエフェクトセンドの後で調節するパラメータです。 400 //! 主に、エフェクトのドライ・ウェット成分のバランスを調整するために使用されます。 401 //! 402 //! センド量 send は、相対変化の値を指定します。 403 //! すなわち、0.0 を指定するとセンド量を変更しません。 404 //! -1.0 を指定するとメインバスに最大のセンド量で送られていたサウンドが、 405 //! メインバスに送られないようになります。 デフォルト値は 0.0 です。 406 //! 407 //! @param[in] send 0.0 を基準としたセンド量の相対変化の値です。 408 //! 409 //! @see SetFxSend 410 //! 411 //! @date 2010/06/16 初版 412 //--------------------------------------------------------------------------- SetMainSend(f32 send)413 void SetMainSend( f32 send ) 414 { 415 if ( IsAttachedSound() ) m_pSound->SetMainSend( send ); 416 } 417 418 //--------------------------------------------------------------------------- 419 //! @brief サウンドのエフェクトセンド量を変更します。 420 //! 421 //! ハンドルに関連付けられたサウンドのエフェクトセンド量を変更します。 422 //! ハンドルが無効の場合は、何もしません。 423 //! 424 //! この関数で指定する値は、他のどのエフェクトセンド量とも独立して動作し、 425 //! それらは全て重ね合わされます。 426 //! 427 //! センド量 send は、相対変化の値を指定します。 428 //! すなわち、0.0 を指定するとセンド量を変更しません。 429 //! 1.0 を指定すると AUX バスに送られていなかったサウンドが、 430 //! 最大のセンド量で送られるようになります。 デフォルト値は 0.0 です。 431 //! 432 //! @param[in] bus センド量を設定する AUX のバスです。 433 //! @param[in] send 0.0 を基準としたセンド量の相対変化の値です。 434 //! 435 //! @see AuxBus 436 //! @see SetMainSend 437 //! 438 //! @date 2010/06/16 初版 439 //--------------------------------------------------------------------------- SetFxSend(AuxBus bus,f32 send)440 void SetFxSend( AuxBus bus, f32 send ) 441 { 442 if ( IsAttachedSound() ) m_pSound->SetFxSend( bus, send ); 443 } 444 445 //--------------------------------------------------------------------------- 446 //! @brief 発音プライオリティを変更します。 447 //! 448 //! ハンドルに関連付けられたサウンドの発音プライオリティを変更します。 449 //! ハンドルが無効の場合は、何もしません。 450 //! 451 //! この関数は、 452 //! サウンドアーカイブ中のデータで指定されている、 453 //! 発音プライオリティの値を変更します。 454 //! 455 //! priority の値の範囲は 0~127 で、大きいほど優先度が高くなります。 456 //! 457 //! @param[in] priority 発音プライオリティの値です。 458 //! 459 //! @date 2010/01/22 初版 460 //--------------------------------------------------------------------------- SetChannelPriority(int priority)461 void SetChannelPriority( int priority ) 462 { 463 if ( IsAttachedSound() ) m_pSound->SetChannelPriority( priority ); 464 } 465 466 //--------------------------------------------------------------------------- 467 //! @brief シーケンスサウンドのテンポの倍率を変更します。 468 //! 469 //! ハンドルに関連付けられたシーケンスサウンドのテンポを変更します。 470 //! ハンドルが無効の場合は、何もしません。 471 //! 472 //! テンポ tempoRatio は、シーケンスデータのテンポに対する倍率で指定します。 473 //! すなわち、1.0 を指定するとテンポを変更しません。 474 //! 475 //! @param[in] tempoRatio 変更するテンポの倍率です。 476 //! 477 //! @date 2010/01/22 初版 478 //--------------------------------------------------------------------------- SetTempoRatio(f32 tempoRatio)479 void SetTempoRatio( f32 tempoRatio ) 480 { 481 if ( IsAttachedSound() ) m_pSound->SetTempoRatio( tempoRatio ); 482 } 483 //@} 484 485 // ----------------------------------------------------------------- 486 //! @name シーケンス変数 487 //@{ 488 489 //--------------------------------------------------------------------------- 490 //! @brief シーケンスローカル変数を読み込みます。 491 //! 492 //! 読み込みに成功すると var で指定したアドレスへ変数の値が書き込まれます。 493 //! 494 //! サウンドハンドルが無効の場合は、読み込みに失敗して false を返します。 495 //! 496 //! @param[in] varNo 変数番号 ( 0 ~ 15 ) です。 497 //! @param[out] var 読み込む値を格納する変数へのポインタです。 498 //! 499 //! @return 読み込みに成功したら true を、失敗したら false を返します。 500 //! 501 //! @date 2010/01/22 初版 502 //--------------------------------------------------------------------------- ReadVariable(int varNo,signed short * var)503 bool ReadVariable( int varNo, signed short* var ) const 504 { 505 return IsAttachedSound() && m_pSound->ReadVariable( varNo, var ); 506 } 507 508 //--------------------------------------------------------------------------- 509 //! @brief シーケンスグローバル変数を読み込みます。 510 //! 511 //! 読み込みに成功すると var で指定したアドレスへ変数の値が書き込まれます。 512 //! 513 //! @param[in] varNo 変数番号 ( 0 ~ 15 ) です。 514 //! @param[out] var 読み込む値を格納する変数へのポインタです。 515 //! 516 //! @return 読み込みに成功したら true を、失敗したら false を返します。 517 //! 518 //! @date 2010/01/22 初版 519 //--------------------------------------------------------------------------- ReadGlobalVariable(int varNo,signed short * var)520 static bool ReadGlobalVariable( int varNo, signed short* var ) 521 { 522 return internal::SequenceSound::ReadGlobalVariable( varNo, var ); 523 } 524 525 //--------------------------------------------------------------------------- 526 //! @brief シーケンストラック変数を読み込みます。 527 //! 528 //! 読み込みに成功すると var で指定したアドレスへ変数の値が書き込まれます。 529 //! 530 //! サウンドハンドルが無効の場合は、読み込みに失敗して false を返します。 531 //! 532 //! @param[in] trackNo トラック番号 ( 0 ~ 15 ) です。 533 //! @param[in] varNo 変数番号 ( 0 ~ 15 ) です。 534 //! @param[out] var 読み込む値を格納する変数へのポインタです。 535 //! 536 //! @return 読み込みに成功したら true を、失敗したら false を返します。 537 //! 538 //! @date 2010/01/22 初版 539 //--------------------------------------------------------------------------- ReadTrackVariable(int trackNo,int varNo,signed short * var)540 bool ReadTrackVariable( int trackNo, int varNo, signed short* var ) const 541 { 542 return IsAttachedSound() && m_pSound->ReadTrackVariable( trackNo, varNo, var ); 543 } 544 545 //--------------------------------------------------------------------------- 546 //! @brief シーケンスローカル変数を書き込みます。 547 //! 548 //! サウンドハンドルが無効の場合は、書き込みに失敗して false を返します。 549 //! 550 //! @param[in] varNo 変数番号 ( 0 ~ 15 ) です。 551 //! @param[in] var 書き込む変数値です。 552 //! 553 //! @return 書き込みに成功したら true を、失敗したら false を返します。 554 //! 555 //! @date 2010/01/22 初版 556 //--------------------------------------------------------------------------- WriteVariable(int varNo,signed short var)557 bool WriteVariable( int varNo, signed short var ) 558 { 559 if ( ! IsAttachedSound() ) return false; 560 m_pSound->WriteVariable( varNo, var ); 561 return true; 562 } 563 564 //--------------------------------------------------------------------------- 565 //! @brief シーケンスグローバル変数を書き込みます。 566 //! 567 //! @param[in] varNo 変数番号( 0 ~ 15 ) です。 568 //! @param[in] var 書き込む変数値です。 569 //! 570 //! @return 書き込みに成功したら true を、失敗したら false を返します。 571 //! 572 //! @date 2010/01/22 初版 573 //--------------------------------------------------------------------------- WriteGlobalVariable(int varNo,signed short var)574 static bool WriteGlobalVariable( int varNo, signed short var ) 575 { 576 internal::SequenceSound::WriteGlobalVariable( varNo, var ); 577 return true; 578 } 579 580 //--------------------------------------------------------------------------- 581 //! @brief シーケンストラック変数を書き込みます。 582 //! 583 //! サウンドハンドルが無効の場合は、書き込みに失敗して false を返します。 584 //! 585 //! @param[in] trackNo トラック番号 ( 0 ~ 15 ) です。 586 //! @param[in] varNo 変数番号 ( 0 ~ 15 ) です。 587 //! @param[in] var 書き込む変数値です。 588 //! 589 //! @return 書き込みに成功したら true を、失敗したら false を返します。 590 //! 591 //! @date 2010/01/22 初版 592 //--------------------------------------------------------------------------- WriteTrackVariable(int trackNo,int varNo,signed short var)593 bool WriteTrackVariable( int trackNo, int varNo, signed short var ) 594 { 595 if ( ! IsAttachedSound() ) return false; 596 m_pSound->WriteTrackVariable( trackNo, varNo, var ); 597 return true; 598 } 599 //@} 600 601 // ----------------------------------------------------------------- 602 //! @name トラックパラメータ設定 603 //@{ 604 605 //--------------------------------------------------------------------------- 606 //! @brief シーケンスサウンドのトラックをミュートします。 607 //! または、ミュート状態を解除します。 608 //! 609 //! ハンドルに関連付けられたサウンドのシーケンストラックのミュート状態を変更します。 610 //! サウンドハンドルが無効の場合は、何もしません。 611 //! 612 //! trackBitFlag で、設定するトラックを指定します。 613 //! 下位ビットから順にトラック 0、トラック 1、トラック 2 … を表し、 614 //! ビットが立っているトラック全てに対して、ミュートの設定を変更します。 615 //! 例えば、トラック 2 とトラック 5 のミュート設定を変更したい場合は 616 //! (1 << 2) | (1 << 5) すなわち、0x0024 とします。 617 //! 618 //! トラックをミュートすると、 619 //! それ以降は指定されたトラックでノートオンが行われなくなります。 620 //! 621 //! 発音中の音が停止するかどうかは @ref SeqMute での指定によります。 622 //! ミュートを解除すると発音が行われるようになりますが、 623 //! すぐに音が鳴り出すわけではありません。 624 //! 次のノートオンから鳴り始めることに注意してください。 625 //! 626 //! ミュート状態によく似た、トラックを無音にするサイレント状態 627 //! (@ref SetTrackSilence) があります。 628 //! ミュート状態とサイレント状態はそれぞれ個別に設定できます。 629 //! 両方を設定した場合は、両方を解除するまでトラックは発音しなくなります。 630 //! 631 //! @param[in] trackBitFlag トラックごとのビットフラグです。 632 //! @param[in] mute ミュート状態です。 633 //! 634 //! @see SeqMute 635 //! @see SetTrackSilence 636 //! 637 //! @date 2010/01/22 初版 638 //--------------------------------------------------------------------------- SetTrackMute(u32 trackBitFlag,SeqMute mute)639 void SetTrackMute( u32 trackBitFlag, SeqMute mute ) 640 { 641 if ( IsAttachedSound() ) m_pSound->SetTrackMute( trackBitFlag, mute ); 642 } 643 644 //--------------------------------------------------------------------------- 645 //! @brief シーケンスサウンドのトラックをミュートします。 646 //! または、ミュート状態を解除します。 647 //! 648 //! ハンドルに関連付けられたサウンドのシーケンストラックのミュート状態を変更します。 649 //! サウンドハンドルが無効の場合は、何もしません。 650 //! 651 //! trackBitFlag で、設定するトラックを指定します。 652 //! 下位ビットから順にトラック 0、トラック 1、トラック 2 … を表し、 653 //! ビットが立っているトラック全てに対して、ミュートの設定を変更します。 654 //! 例えば、トラック 2 とトラック 5 のミュート設定を変更したい場合は 655 //! (1 << 2) | (1 << 5) すなわち、0x0024 とします。 656 //! 657 //! トラックをミュートすると、 658 //! それ以降は指定されたトラックでノートオンが行われなくなります。 659 //! 660 //! muteFlag を true にするとシーケンストラックをミュート状態にします。 661 //! 同時に、そのトラックで発音中の音を直ちに停止します 662 //! (@ref SeqMute の MUTE_STOP と同じです)。 663 //! 664 //! muteFlag を false にすると、ミュートを解除します。 665 //! 666 //! ミュートを解除すると発音が行われるようになりますが、 667 //! すぐに音が鳴り出すわけではありません。 668 //! 次のノートオンから鳴り始めることに注意してください。 669 //! 670 //! ミュート状態によく似た、トラックを無音にするサイレント状態 671 //! (@ref SetTrackSilence) があります。 672 //! ミュート状態とサイレント状態はそれぞれ個別に設定できます。 673 //! 両方を設定した場合は、両方を解除するまでトラックは発音しなくなります。 674 //! 675 //! @param[in] trackBitFlag トラックごとのビットフラグです。 676 //! @param[in] muteFlag ミュートするときは true、 677 //! ミュートを解除するときは false を指定します。 678 //! 679 //! @see SeqMute 680 //! @see SetTrackSilence 681 //! 682 //! @date 2010/01/22 初版 683 //--------------------------------------------------------------------------- SetTrackMute(u32 trackBitFlag,bool muteFlag)684 void SetTrackMute( u32 trackBitFlag, bool muteFlag ) 685 { 686 if ( IsAttachedSound() ) m_pSound->SetTrackMute( trackBitFlag, muteFlag ); 687 } 688 689 //--------------------------------------------------------------------------- 690 //! @brief シーケンスサウンドのトラックをサイレント状態にします。 691 //! または、サイレント状態を解除します。 692 //! 693 //! ハンドルに関連付けられたサウンドのシーケンストラックのサイレント状態を変更します。 694 //! サウンドハンドルが無効の場合は、何もしません。 695 //! 696 //! trackBitFlag で、設定するトラックを指定します。 697 //! 下位ビットから順にトラック 0、トラック 1、トラック 2 … を表し、 698 //! ビットが立っているトラック全てに対して、サイレント状態を変更します。 699 //! 例えば、トラック 2 とトラック 5 のサイレント状態を変更したい場合は 700 //! (1 << 2) | (1 << 5) すなわち、0x0024 とします。 701 //! 702 //! サイレント状態はミュート状態 (@ref SetTrackMute) と似ています。 703 //! ミュート状態のトラックではノートオン処理が行われないので、 704 //! そのトラックが発音しないようなります。 705 //! 一方、サイレンス状態のトラックではノートオン処理は行われますが、 706 //! 音量をゼロにすることによって発音しないようになります。 707 //! そのため、サイレンス状態を解除したときに、 708 //! ノートを途中から即座に再生することが可能になります。 709 //! 710 //! fadeTimes は、この関数を呼び出したときに発音中の音に対してのみ、 711 //! 効果があることに注意してください。 712 //! そのためサイレント状態に移行するフェード期間中に、 713 //! 新たに発音した音は、鳴り始めから無音状態になります。 714 //! 715 //! サイレント状態では、 716 //! ノートオンされたボイスが無音の状態で消費されてしまうので注意してください。 717 //! 718 //! ミュート状態とサイレント状態はそれぞれ個別に設定できます。 719 //! 両方を設定した場合は、両方を解除するまでトラックは発音しなくなります。 720 //! 721 //! @param[in] trackBitFlag トラックごとのビットフラグです。 722 //! @param[in] silenceFlag サイレント状態にするときは true、 723 //! サイレント状態を解除する時は false を指定します。 724 //! @param[in] fadeTimes サイレント状態を変更する時にかかるフェードの時間 (ミリ秒) です。 725 //! 726 //! @see SetTrackMute 727 //! 728 //! @date 2010/01/22 初版 729 //--------------------------------------------------------------------------- SetTrackSilence(u32 trackBitFlag,bool silenceFlag,int fadeTimes)730 void SetTrackSilence( u32 trackBitFlag, bool silenceFlag, int fadeTimes ) 731 { 732 if ( IsAttachedSound() ) m_pSound->SetTrackSilence( trackBitFlag, silenceFlag, fadeTimes ); 733 } 734 735 //--------------------------------------------------------------------------- 736 //! @brief シーケンスサウンドのトラックの音量を変更します。 737 //! 738 //! ハンドルに関連付けられたサウンドのシーケンストラックの音量を変更します。 739 //! ハンドルが無効の場合は、何もしません。 740 //! 741 //! この関数で指定する値は、他のどの音量パラメータとも独立して動作し、 742 //! それらは全て重ね合わされます。 743 //! 744 //! trackBitFlag で、設定するトラックを指定します。 745 //! 下位ビットから順にトラック 0、トラック 1、トラック 2 … を表し、 746 //! ビットが立っているトラック全てに対して、音量を変更します。 747 //! 例えば、トラック 2 とトラック 5 の音量を変更したい場合は 748 //! (1 << 2) | (1 << 5) すなわち、0x0024 とします。 749 //! 750 //! 音量 volume は、0.0 以上の倍率で指定します。 751 //! すなわち、1.0 を指定すると音量に影響を与えません。 752 //! 0.0 を指定すると発音されなくなります。デフォルト値は 1.0 です。 753 //! 754 //! 他の音量パラメータと重ね合わされたあと、 755 //! 最終的な音量は 0.0 ~ 2.0 の範囲でクランプされます。 756 //! この関数で 2.0 を設定したとしても、 757 //! 元の音量の 2 倍にならない可能性があることに注意してください。 758 //! 759 //! @param[in] trackBitFlag トラックごとのビットフラグです。 760 //! @param[in] volume 変更する音量の倍率です。 761 //! 762 //! @date 2010/06/25 誤植修正 (サイレント状態→音量) 763 //! @date 2010/01/22 初版 764 //--------------------------------------------------------------------------- SetTrackVolume(u32 trackBitFlag,f32 volume)765 void SetTrackVolume( u32 trackBitFlag, f32 volume ) 766 { 767 if ( IsAttachedSound() ) m_pSound->SetTrackVolume( trackBitFlag, volume ); 768 } 769 770 //--------------------------------------------------------------------------- 771 //! @brief シーケンスサウンドのトラックの音程を変更します。 772 //! 773 //! ハンドルに関連付けられたサウンドのシーケンストラックの音程を変更します。 774 //! ハンドルが無効の場合は、何もしません。 775 //! 776 //! この関数で指定する値は、他のどの音程パラメータとも独立して動作し、 777 //! それらは全て重ね合わされます。 778 //! 779 //! trackBitFlag で、設定するトラックを指定します。 780 //! 下位ビットから順にトラック 0、トラック 1、トラック 2 … を表し、 781 //! ビットが立っているトラック全てに対して、音程を変更します。 782 //! 例えば、トラック 2 とトラック 5 の音程を変更したい場合は 783 //! (1 << 2) | (1 << 5) すなわち、0x0024 とします。 784 //! 785 //! 音程 pitch は、周波数の比率で指定します。 786 //! すなわち、1.0 を指定すると音程に影響を与えません。 787 //! 2.0 を指定すると再生される周波数が 2 倍になり、 788 //! 1 オクターブ高い音程になります。 789 //! 0.5 を指定すると 1 オクターブ低い音程になります。 790 //! デフォルト値は 1.0 です。 791 //! 792 //! @param trackBitFlag トラックごとのビットフラグです。 793 //! @param pitch 変更する音程の周波数比率です。 794 //! 795 //! @date 2010/09/29 誤植修正 (音量パラメータ→音程パラメータ) 796 //! @date 2010/06/25 誤植修正 (サイレント状態→音程) 797 //! @date 2010/01/22 初版 798 //--------------------------------------------------------------------------- SetTrackPitch(u32 trackBitFlag,f32 pitch)799 void SetTrackPitch( u32 trackBitFlag, f32 pitch ) 800 { 801 if ( IsAttachedSound() ) m_pSound->SetTrackPitch( trackBitFlag, pitch ); 802 } 803 804 //--------------------------------------------------------------------------- 805 //! @brief シーケンスサウンドのトラックのパン (左右の定位) を変更します。 806 //! 807 //! ハンドルに関連付けられたサウンドのシーケンストラックのパンを変更します。 808 //! ハンドルが無効の場合は、何もしません。 809 //! 810 //! この関数で指定する値は、他のどのパンパラメータとも独立して動作し、 811 //! それらは全て重ね合わされます。 812 //! 813 //! trackBitFlag で、設定するトラックを指定します。 814 //! 下位ビットから順にトラック 0、トラック 1、トラック 2 … を表し、 815 //! ビットが立っているトラック全てに対して、パンを変更します。 816 //! 例えば、トラック 2 とトラック 5 のパンを変更したい場合は 817 //! (1 << 2) | (1 << 5) すなわち、0x0024 とします。 818 //! 819 //! pan は、定位の相対変化の値を設定します。 820 //! 0.0 を指定するとデータで設定されたパンの値から変化しません。 821 //! 1.0 を指定すると中央に定位していた音が右端に定位するようになり、 822 //! -1.0 を指定すると中央に定位していた音が左端に定位するようになります。 823 //! デフォルト値は 0.0 です。 824 //! 825 //! @param[in] trackBitFlag トラックごとのビットフラグです。 826 //! @param[in] pan 0.0 を基準としたパンの相対変化の値です。 827 //! 828 //! @date 2010/06/25 誤植修正 (サイレント状態→パン) 829 //! @date 2010/01/22 初版 830 //--------------------------------------------------------------------------- SetTrackPan(u32 trackBitFlag,f32 pan)831 void SetTrackPan( u32 trackBitFlag, f32 pan ) 832 { 833 if ( IsAttachedSound() ) m_pSound->SetTrackPan( trackBitFlag, pan ); 834 } 835 836 #ifdef NW_PLATFORM_RVL 837 // トラックサラウンドパンの変更 838 //--------------------------------------------------------------------------- 839 //! :private 840 //! 841 //! @brief シーケンスサウンドのトラックのサラウンドパン (前後の定位) を変更します。 842 //! 843 //! ハンドルに関連付けられたサウンドのシーケンストラックのサラウンドパンを変更します。 844 //! ハンドルが無効の場合は、何もしません。 845 //! 846 //! この関数で指定する値は、他のどのサラウンドパンパラメータとも独立して動作し、 847 //! それらは全て重ね合わされます。 848 //! 849 //! trackBitFlag で、設定するトラックを指定します。 850 //! 下位ビットから順にトラック 0、トラック 1、トラック 2 … を表し、 851 //! ビットが立っているトラック全てに対して、サラウンドパンを変更します。 852 //! 例えば、トラック 2 とトラック 5 のサラウンドパンを変更したい場合は 853 //! (1 << 2) | (1 << 5) すなわち、0x0024 とします。 854 //! 855 //! surroundPan は、定位の相対変化の値を設定します。 856 //! 0.0 を指定するとデータで設定されたパンの値から変化しません。 857 //! 1.0 を指定すると最前方に定位していた音が中央に定位するようになり、 858 //! 2.0 を指定すると最前方に定位していた音が最後方に定位するようになります。 859 //! 前方へ定位を移動させたい場合は負の値を指定してください。 860 //! デフォルト値は 0.0 です。 861 //! 862 //! @param[in] trackBitFlag トラックごとのビットフラグです。 863 //! @param[in] surroundPan 0.0 を基準としたサラウンドパンの相対変化の値です。 864 //! 865 //! @date 2010/06/25 誤植修正 (サイレント状態→サラウンドパン) 866 //! @date 2010/01/22 初版 867 //--------------------------------------------------------------------------- SetTrackSurroundPan(u32 trackBitFlag,f32 surroundPan)868 void SetTrackSurroundPan( u32 trackBitFlag, f32 surroundPan ) 869 { 870 if ( IsAttachedSound() ) m_pSound->SetTrackSurroundPan( trackBitFlag, surroundPan ); 871 } 872 #endif /* NW_PLATFORM_RVL */ 873 874 //--------------------------------------------------------------------------- 875 //! @brief シーケンスサウンドのトラックのバンクを変更します。 876 //! 877 //! ハンドルに関連付けられたサウンドのシーケンストラックのバンクを変更します。 878 //! ハンドルが無効の場合は、何もしません。 879 //! 880 //! この関数で指定する値は、他のどの音量パラメータとも独立して動作し、 881 //! 後着優先で有効になります。 882 //! 883 //! trackBitFlag で、設定するトラックを指定します。 884 //! 下位ビットから順にトラック 0、トラック 1、トラック 2 … を表し、 885 //! ビットが立っているトラック全てに対して、バンクを変更します。 886 //! 例えば、トラック 2 とトラック 5 のバンクを変更したい場合は 887 //! (1 << 2) | (1 << 5) すなわち、0x0024 とします。 888 //! 889 //! バンク番号 bankIndex は、0~3 の数値で指定します。 890 //! 0 ~ 3 は SoundMaker の「マルチバンクの設定」 891 //! で表示されるダイアログ内のリストの行番号に該当します。 892 //! それ以外の番号を指定すると、 893 //! (Debug 版、Development 版) アサートで停止します。 894 //! (Release 版) false を返します。 895 //! 896 //! シーケンス内に bank_select コマンドを入れていた場合、 897 //! 本関数での設定と bank_select コマンドは、 898 //! 後から設定されたものが有効になります。 899 //! 900 //! @param[in] trackBitFlag トラックごとのビットフラグです。 901 //! @param[in] bankIndex 変更するバンクの番号です。 902 //! 903 //! @return bankIndex で指定したバンクが未ロードの場合 false を返します。 904 //! ロード済みの場合 true を返します。 905 //! 906 //! @date 2010/06/25 誤植修正 (サイレント状態→バンク) 907 //! @date 2010/06/17 初版 908 //--------------------------------------------------------------------------- SetTrackBankIndex(u32 trackBitFlag,int bankIndex)909 bool SetTrackBankIndex( u32 trackBitFlag, int bankIndex ) 910 { 911 NW_MINMAXLT_ASSERT( bankIndex, 0, SoundArchive::SEQ_BANK_MAX ); 912 if ( bankIndex < 0 || bankIndex >= SoundArchive::SEQ_BANK_MAX ) 913 { 914 return false; 915 } 916 917 if ( IsAttachedSound() ) m_pSound->SetTrackBankIndex( trackBitFlag, bankIndex ); 918 return true; 919 } 920 921 //@} 922 923 // ----------------------------------------------------------------- 924 //! @name ハンドル操作 925 //@{ 926 927 //--------------------------------------------------------------------------- 928 //! @brief ハンドルにサウンドが関連付けられているかどうかを調べます。 929 //! 930 //! @return ハンドルに関連付けられているサウンドがあれば true を返します。 931 //! 932 //! @date 2010/01/22 初版 933 //--------------------------------------------------------------------------- IsAttachedSound()934 bool IsAttachedSound() const { return m_pSound != NULL; } 935 936 //--------------------------------------------------------------------------- 937 //! @brief ハンドルからサウンドを解放します。 938 //! 939 //! ハンドルから開放されたサウンドは、 940 //! その後ハンドルを通して操作できないようになります。 941 //! 942 //! @date 2010/01/22 初版 943 //--------------------------------------------------------------------------- 944 void DetachSound(); 945 //@} 946 947 // ----------------------------------------------------------------- 948 //! @name 情報設定 / 取得 949 //@{ 950 951 //--------------------------------------------------------------------------- 952 //! @brief サウンドの ID を設定します。 953 //! 954 //! ハンドルに関連付けられたサウンドの ID を設定します。 955 //! ハンドルが無効の場合は、何もしません。 956 //! 957 //! @ref SoundArchivePlayer でサウンドを再生すると、 958 //! 再生開始時にサウンド ID が自動的に設定されます。 959 //! この関数を呼び出すと、ID を上書きして変更します。 960 //! 961 //! 設定した ID を取得するためには @ref GetId を呼び出します。 962 //! 963 //! @param[in] id サウンドを識別する ID です。 964 //! 965 //! @see SoundArchivePlayer クラス 966 //! @see GetId 967 //! 968 //! @date 2010/01/22 初版 969 //--------------------------------------------------------------------------- SetId(u32 id)970 void SetId( u32 id ) 971 { 972 if ( IsAttachedSound() ) m_pSound->SetId( id ); 973 } 974 975 //--------------------------------------------------------------------------- 976 //! @brief サウンドの ID を取得します。 977 //! 978 //! ハンドルに関連付けられたサウンドに設定されている ID を取得します。 979 //! ハンドルが無効の場合は 0xffffffff を返します。 980 //! 981 //! この関数で取得できる ID は @ref SetId で設定された ID です。 982 //! 983 //! @return サウンドに設定されている ID を返します。 984 //! 985 //! @date 2010/01/22 初版 986 //--------------------------------------------------------------------------- GetId()987 u32 GetId() const 988 { 989 if ( IsAttachedSound() ) return m_pSound->GetId(); 990 return internal::BasicSound::INVALID_ID; 991 } 992 993 // TODO: 3D サウンド 994 //--------------------------------------------------------------------------- 995 //! :private 996 //! 997 //! @brief アンビエントパラメータの値を取得します。 998 //! 999 //! 3D サウンドを利用している際は、 1000 //! 3D サウンドで計算された結果がアンビエントパラメータに格納されますので、 1001 //! アンビエントパラメータを取得して 3D 1002 //! サウンドによるサウンドパラメータの値を知ることができます。 1003 //! 1004 //! @return 現在のアンビエントパラメータの値を返します。 1005 //! ハンドルが無効の場合は NULL を返します。 1006 //! 1007 //! @see nw::snd::SoundParam 構造体 1008 //! 1009 //! @date 2010/01/22 初版 1010 //--------------------------------------------------------------------------- GetAmbientParam()1011 const SoundParam* GetAmbientParam() const 1012 { 1013 if ( ! IsAttachedSound() ) return NULL; 1014 return &m_pSound->GetAmbientParam(); 1015 } 1016 1017 //--------------------------------------------------------------------------- 1018 //! @brief 再生開始からのティック数を取得します。 1019 //! 1020 //! サウンドハンドルが無効の場合は、0 を返します。 1021 //! 1022 //! ティック数のカウンタが 32 ビットを越えると、 1023 //! 関数が返す値は 0 に戻ります。 1024 //! 1025 //! @return 再生開始からのティック数を返します。 1026 //! 1027 //! @date 2010/01/22 初版 1028 //--------------------------------------------------------------------------- GetTick()1029 unsigned long GetTick() const { return IsAttachedSound()? m_pSound->GetTick(): 0; } 1030 //@} 1031 1032 1033 // ----------------------------------------------------------------- 1034 // 非公開関数 1035 1036 // ハンドルをサウンドに関連付ける 1037 //! @details :private 1038 void detail_AttachSoundAsTempHandle( internal::SequenceSound* sound ); 1039 1040 //! @details :private detail_GetAttachedSound()1041 internal::SequenceSound* detail_GetAttachedSound() { return m_pSound; } 1042 1043 //! @details :private detail_GetAttachedSound()1044 const internal::SequenceSound* detail_GetAttachedSound() const { return m_pSound; } 1045 1046 private: 1047 NW_DISALLOW_COPY_AND_ASSIGN( SequenceSoundHandle ); 1048 1049 internal::SequenceSound* m_pSound; 1050 }; 1051 1052 } // namespace nw::snd 1053 } // namespace nw 1054 1055 1056 #endif /* NW_SND_SEQUENCE_SOUND_HANDLE_H_ */ 1057 1058