오디오 루프 포인트

오디오 루프 포인트는 오디오 자산의 일부(또는 섹션)를 반복(loop) 재생할 수 있게 해줍니다. 오디오를 수동으로 재생하는 데 사용할 수 있는 audio_sound_get_track_positionaudio_sound_set_track_position을 사용해도 섹션 반복에 대한 정확성을 보장할 수 없습니다. 이는 오디오가 초당 44100 또는 48000번과 같은 훨씬 높은 속도로 처리되기 때문입니다. 따라서 한 함수를 호출하고 다음 함수를 호출하는 사이에 이미 많은 샘플이 재생되었을 수 있습니다.

오디오 루프를 위한 기능을 사용하면 오디오 스레드에서 오디오 속도로 루핑이 수행됩니다. 루프 함수와 함께 버퍼 기반 오디오 큐 또는 오디오 동기화 그룹을 사용할 수 없습니다. 그러나 나머지 모든 종류의 오디오는 문제 없이 사용할 수 있습니다. (buffer soundsstreams 포함)

함수 참조

오디오 루프와 관련된 GML 코드 함수는 다음과 같습니다:

audio_sound_loop
audio_sound_get_loop
audio_sound_loop_start
audio_sound_get_loop_start
audio_sound_loop_end
audio_sound_get_loop_end

루프 섹션

모든 사운드 자산과 사운드 인스턴스는 시작 및 종료 시간이 초(second)로 정의된 단일 루프 섹션을 가지고 있습니다. 루프에 설정된 사운드의 경우 이 시작과 종료 사이의 부분이 반복 재생됩니다.

audio_play_sound 함수 중 하나를 사용하여 재생할 때마다 사운드는 자산에서 기본 루프 시작 및 종료 시간을 가져옵니다. 예를 들어:

audio_sound_loop_start(snd_loop, 2);
audio_sound_loop_end(snd_loop, 6);
ins_sound = audio_play_sound(snd_loop, 100, true);
audio_sound_loop_end(ins_sound, 10);

기본적으로 사운드는 처음부터 끝까지 루프되도록 설정됩니다. 이는 시작 값과 종료 값이 모두 0.0초로 설정됨을 의미합니다.

루프 종료 위치는 루프 시작 위치 이후에 설정해야 하며, 두 값 모두 0.0으로 설정된 경우를 제외합니다(즉, 사운드를 처음부터 끝까지 루프).

루프 활성화/비활성화

사운드 인스턴스의 루프 상태를 설정하는 방법은 두 가지가 있습니다. 첫 번째는 audio_play_sound 또는 기타 오디오 재생 함수 사용 시입니다:

ins_sound = audio_play_sound(snd_loop, 100, true);

두 번째는 이미 재생 중인 사운드에 대해 audio_sound_loop 함수를 호출하는 것입니다:

audio_sound_loop(ins_sound, true);

사운드의 트랙 위치가 루프 종료 위치에 도달하면 GameMaker는 루프를 수행해야 할지 확인합니다. 그 순간 루프 상태가 true로 설정되어 있으면, 사운드는 루프 시작 위치로 되돌아갑니다. 그렇지 않으면 사운드는 끝까지 재생됩니다.

예시

다음은 오디오 루프 포인트를 사용하여 오디오를 반복하는 몇 가지 방법입니다.

인트로 및 아울트로

이 경우, 인트로, 반복되는 중간 섹션, 아울트로가 있는 오디오 파일이 있습니다. 오디오는 처음부터 재생되며 인트로 부분을 먼저 재생한 다음 루프된 부분으로 이동해서 루프가 끝날 때까지 계속 재생합니다. 그 후 루프된 부분이 마지막으로 아울트로 부분으로 전환됩니다.

audio_sound_loop_start(snd_music, 10);
audio_sound_loop_end(snd_music, 20);
ins_sound = audio_play_sound(snd_music, 100, true);  // 사운드 루프 재생

루프 부분이 진행 중일 때 사운드 인스턴스를 더 이상 루프하지 않도록 설정할 수 있습니다:

audio_sound_loop(ins_sound, false);

이 변경 후 루프의 나머지 부분이 재생되고, 이어서 아울트로 부분이 재생됩니다.

다중 루프

모든 사운드는 하나의 루프 섹션을 가집니다. 루프 섹션을 여러 개 추가하려면 이를 구조체에 저장하고 사용하고자 하는 루프 섹션의 시작과 끝을 수동으로 적용할 수 있습니다:

loops = [{start: 0, end: 10},{start: 10, end: 20},{start: 20, end: 30}];
section = 2;
audio_sound_loop_start(snd_several_sections, loops[section].start);
audio_sound_loop_end(snd_several_sections, loops[section].end);
ins_sound = audio_play(snd_several_sections, 200, true);

BPM을 이용한 변환

음악의 BPM을 사용하여 하나의 "비트"가 소요되는 시간을 계산할 수 있습니다. 이렇게 하면 음악의 비트나 마디에 정확히 해당하는 부분을 루프할 수 있습니다:

var _bpm_to_sec = time_bpm_to_seconds(126);
var _beats_per_bar = 4;
var _bars = 4;
audio_sound_loop_start(snd_bgm, _bars * _beats_per_bar);

이 코드는 사운드 자산 snd_bgm의 루프 시작 위치를 다섯 번째 마디의 시작으로 설정합니다.

한계

기능의 한계를 밀어붙일 경우(예: 매우 작은 루프 섹션을 사용 시) 압축된 사운드는 성능 저하를 초래할 수 있습니다. 이런 경우 압축되지 않은 사운드 자산을 사용하는 것이 더 좋습니다.


© 저작권 YoYo Games Ltd. 2023 모든 권리 보유.

Read more

기술 문서 해설 및 활용 예제

이 문서는 특정 기술에 대한 설명과 활용 방법을 다룹니다. 아래에서 내용을 쉽게 이해할 수 있도록 해설하고, 다양한 활용 및 응용 예제를 추가로 제공합니다. 기술 개요 이 기술은 게임 개발에서 자주 사용되는 기능으로, 특정 작업을 자동화하거나 효율적으로 처리하는 데 도움을 줍니다. 주로 게임의 로직을 구성하거나 사용자 인터페이스를 제어하는 데 사용됩니다. 주요

By 이재협/실장/시스템개발실/PHYSIA

키워드 설명서

이 문서는 특정 키워드에 대한 설명과 사용법을 제공합니다. 문법 (arguments); 인수 인수 이름 유형 설명 argument_name 인수에 대한 설명을 여기에 작성합니다. 반환값 (선택적 설명) 예제 code_example() { // 여기에 코드 예제를 설명합니다. } 코드 예제 설명 위의 코드 예제는 특정 기능을 수행하는 함수의 기본 구조를 보여줍니다. 이 함수는 인수를 받아들이고, 특정

By 이재협/실장/시스템개발실/PHYSIA

GameMaker 환경 설정 및 기능

이 문서에서는 GameMaker의 환경 설정 및 다양한 IDE 기능에 대한 정보를 제공합니다. 다음은 주요 항목들입니다: IDE 환경 설정 IDE(통합 개발 환경) 설정은 GameMaker의 전반적인 사용 경험을 조정하는 데 도움을 줍니다. 여기서 사용자는 개인의 필요에 맞게 다양한 옵션을 설정할 수 있습니다. 주요 설정 항목 설정 항목 설명 테마 IDE의 색상

By 이재협/실장/시스템개발실/PHYSIA

GameMaker IDE 설명서

GameMaker IDE는 게임을 만들고 소프트웨어에서 제공하는 모든 기능을 활용하는 주요 인터페이스입니다. 이 프로그램은 시작 화면부터 게임을 만들기 위해 사용하는 모든 편집기 창까지 포함되며, 매뉴얼과 다양한 튜토리얼에서 IDE라고 언급됩니다. IDE의 구성 요소 다음 섹션에서는 IDE에 대한 정보를 다룹니다: 1. 설정 및 기능 IDE의 설정 및 기능은 사용자가 게임 개발을 보다 효율적으로

By 이재협/실장/시스템개발실/PHYSIA