Wwise SDK 2024.1.1
|
Wwise의 Game-defined Auxiliary Send(게임에서 정의한 보조 전송)는, 게임 내 사운드의 위치에 따라 하나 이상의 환경 효과를 쉽게 적용할 수 있는 방법입니다. 해당 오브젝트 속성이나 여기서 속성을 상속받은 오브젝트에서 'Use game-defined auxiliary sends (게임에서 정의한 보조 전송 사용)' 옵션이 선택돼있어야 합니다.
사운드 디자이너는 Wwise를 이용해 게임에서 사용할 여러 환경을 정의할 수 있습니다. 예를 들어 환경의 예시로 다음과 같은 것들이 있습니다.
각 환경은 다양한 매개 변수를 이용해 환경의 Reverb Effect를 나타냅니다. 그리고 각 환경은 Wwise 프로젝트에서 Auxiliary Bus를 이용해 표현됩니다.
가장 먼저, 각 게임 오브젝트는 어떤 환경으로도 정의돼있지 않은 위치에 있어야 합니다. 사운드가 환경이 아닌 경우 (어떤 Auxiliary Bus로도 라우팅되지 않은 경우) 정상적으로 재생됩니다. 즉, 어떤 환경 Effect도 관여하고 있지 않은 경우입니다.
동일한 Auxiliary Bus 안의 모든 사운드는 Effect가 적용되기 전에 함께 믹스됩니다. 그리고 각 게임 오브젝트에 대해 다양한 음량을 설정할 수 있습니다.
참고: API 범위에서 사용되는 0에서 1 사이 값은 최대 볼륨에 대한 백분율을 나타냅니다. 0은 0이고 1은 100를 뜻합니다. 볼륨을 한 곳 이상에 적용하면 결과 값이 증가합니다. 예를 들어 GAME_OBJECT_ID_HUMAN 게임 오브젝트가 Auxiliary Bus 'Hangar(격납고)'에서 50이고 Auxiliary Bus 'Hangar'는 90로 감쇠되면, 이 게임 오브젝트에서 방사하는 소리는 해당 Effect에 45로 입력됩니다 (0.50f * 0.90 ). |
게임에서 정의한 보조 전송은 다음과 같은 함수로 다룹니다.
Dynamic Auxiliary Bus 라우팅: Auxiliary Bus로 동적 전송하기
Wwise 사운드 엔진의 모든 버스 인스턴스는 게임 오브젝트와 관련돼 있습니다. 보조 전송(Aux Send)을 생성할 때, 특정한 보조 버스(Aux Bus)를 대상으로 사운드 엔진에서 리스너-이미터 관계를 생성하게 됩니다. 음원과 대상 오디오 노드에서 이미터와 리스너 게임 오브젝트 위치를 사용해 사운드를 공간화합니다 (사운드가 저작 도구에서 3D로 설정돼있는 경우). 보조 전송을 정의할 때, 이미 음원 오디오 노드의 직접 출력에 할당된 것처럼 대상 보조 버스에 대해 동일한 리스너를 사용해야 할 경우가 종종 있습니다. 즉, SetListeners()
나 SetDefaultListeners()
를 통해 이미 할당된 리스너를 사용해야 하는 경우입니다. 이러한 작업뿐만 아니라 어느 게임 오브젝트가 어느 리스너와 이미 관련돼있는지 기억하지 않아도 되게끔 하기 위해, 간단히 listenerID
로 AK_INVALID_GAME_OBJECT
를 보내면 됩니다.
참고: AkAuxSendValue 구조체의 listenerID 영역을 입력하는 것을 잊지 마세요. 공란으로 두면 예상치 못한 작동이 일어납니다. |
SDK에서는, SoundBank 안의 구성 요소에 접근할 때 사용하는 문자열과 ID를 이용한 두 가지 방법을 보여줍니다. 문자열을 이용하는 방법은 코드를 더 읽기 쉽게 만들고, 일반적으로 문자열을 사용하는 작업 환경에 더 적합합니다. ID의 사용은 Wwise가 런타임에서 이름을 해시 할 필요가 없게 해줍니다.
ID를 이용해 작업하려면 반드시 뱅크를 Wwise의 Generate SoundBanks 대화 상자에서 'Generate header file' 옵션으로 생성해야 합니다. Wwise_IDs.h라는 이름의 정의 파일은 필요한 모든 ID를 포함합니다. 이 파일은 각각의 뱅크가 생성될 때마다 갱신됩니다.
Wwise에서 뱅크 생성과 관련해 더 많은 정보는 Wwise Help를 참고하세요.
경고: ID로 작업할 때는 새로운 뱅크를 생성할 때마다 .h 파일을 최신으로 유지하는 것이 중요합니다. 그렇지 않으면 ID가 맞지 않거나 컴파일 오류가 발생하게 됩니다. |
여기 아주 간단한 Wwise로 생성된 헤더 파일에 대한 예제가 있습니다.
코드는 수정하지 말고 그대로 두어야 합니다.
Wwise가 생성한 헤더 파일은 대부분 위에 나와있는 내용보다 훨씬 더 많은 정보를 포함하고 있습니다. 이벤트, State, Switch, 버스 등에 대한 입력값이 추가돼있기 때문입니다.
두 가지 방법을 혼합해서 사용할 수도 있습니다. 예를 들어 문자열로 작업함과 동시에 ID를 이용해 환경에 접근할 수 있습니다.
다음에 나오는 방법은 유니코드 문자열에서 ID로의 런타임 변환을 실행합니다. 이 방법을 이용하면 한 환경당 문자열 테이블을 한 번만 조회해 해당 ID를 사용할 수 있습니다.
AK::SoundEngine::SetGameObjectAuxSendValues()
함수를 이용해 보조 버스 라우팅을 동적으로 작동시킬 수 있습니다. 이 함수의 첫 번째 매개 변수는 어떠한 게임 정의 보조 버스 라우팅을 적용할 지에 대한 게임 오브젝트 ID입니다. 두 번째와 세 번째 매개 변수는 AkAuxSendValue
타입의 구조체 배열과 전송할 Auxiliary Bus의 개수를 나타냅니다. 사운드의 'Use game-defined auxiliary sends' 옵션이 활성화돼있지 않은 경우, 이 게임 오브젝트에는 아무 환경도 적용하지 않습니다. 게임 오브젝트가 전송된 각 Auxiliary Bus를 위해서 제어 값은 환경의 적용 백분율을 나타내도록 설정해야 합니다. 컨트롤 값은 0.0f에서 1.0f 사이 값이며, 0은 전송이 전혀 없고 1은 100% 전송을 나타냅니다.
참고: 특정 오브젝트의 보조 전송을 변경할 때, 사운드 엔진이 환경을 보간(interpolate)함으로써 오류를 방지합니다. 따라서 주어진 상황에 따라 예상했던 것 보다 더 많은 Auxiliary Bus와 오브젝트가 연결될 수도 있습니다. |
Hangar Aux 버스를 100로 설정합니다.
컨트롤 값을 이용하면 사운드를 한 환경에서 다른 환경으로 부드럽게 이동시킬 수 있습니다.
작은 정보: 보조 전송 총합이 반드시 100여야할 필요는 없습니다. 예를 들어 특정 게임 오브젝트에 약간의 환경 효과를 설정하려면 한 환경에 대해 게임 오브젝트를 25로 설정하면 됩니다. |
경고: The Wwise sound engine does not limit the number of Auxiliary Busses to be sent to at one time. 다시 말해, 동시에 많은 수의 환경 FX를 처리하도록 요청할 수 있다는 뜻입니다. 일부 환경 FX는 CPU를 많이 소모할 수 있으며, 한 번에 너무 많은 실행을 요청하면 성능 저하를 일으킬 수 있습니다. 따라서, 예컨대 동시에 64개의 사운드를 각각의 환경과 함께 재생하는 것 같은 상황을 만들지 않는 것이 중요합니다. |
다음에 나올 예제에서는 3D 공간에서의 음향 포털을 시뮬레이션하는 데 사용하는 게임 오브젝트가 등록돼 있습니다. 이 게임 오브젝트는 사운드나 주요 리스너가 들어있지 않은 환경을 나타냅니다. listenerID
영역을 유효한 게임 오브젝트 ID로 설정하면, SetListeners()
와 유사한 방식으로 이미터-리스너 관계를 생성하지만, SetListeners()
가 직접 출력에 적용되는 것과는 다르게 오디오 노드의 보조 출력에 적용됩니다. 오디오를 전송하는 오디오 노드는 저작 도구에서 'Use game-defined auxiliary sends (게임에서 정의한 보조 전송 사용)' 플래그를 설정함으로써 제어할 수 있습니다. listenerID
를 설정하여 listenerID
게임 오브젝트에서 auxBusID
로 지정된 버스 인스턴스를 생성하는 과정을 시각적으로 확인하려면, Wwise 저작 도구의 Advanced Profiler(고급 프로파일러)에 있는 보이스 그래프 탭을 확인하세요.
이 예제에서 AK::AUX_BUSSES::TUNNEL_ENV_PORTAL
보조 버스는 Wwise 저작 도구에서 'Enable Positioning'으로 설정돼야 하며 위치 타입을 3D로 설정해 3D 시뮬레이션에서도 사운드를 방사할 수 있도록 합니다.
게임 오브젝트의 Auxiliary Bus를 변경하는 것 외에도, AK::SoundEngine::SetGameObjectOutputBusVolume()
함수를 사용해 여기 해당하는 원본 요소(dry component)를 줄일 수 있습니다. 이 함수는 방해(obstruction)를 시뮬레이션하는 데 사용할 수 있습니다. 각 게임 오브젝트에는 맨 처음 기본적으로 100% (1.0f)로 설정된 원본 레벨(dry level)이 있습니다 (단, 사운드 오브젝트의 속성을 별도로 이와 다르게 지정한 경우는 제외).
작은 정보: 리스너가 리버브만 간신히 들을 수 있을 정도로 멀리서 나는 사운드를 시뮬레이션하려면 원본 레벨을 0로 설정합니다. |
Auxiliary Bus의 출력에 적용할 볼륨은, 다른 일반적인 버스 볼륨이 사용하는 저작 도구나 State, RTPC 등의 Volume 슬라이더를 사용하면 됩니다.
프로젝트를 등록하세요. 아무런 조건이나 의무 사항 없이 빠른 시작을 도와드리겠습니다.
Wwise를 시작해 보세요