비동기 버퍼 그룹 종료 함수 설명

buffer_async_group_end 함수는 비동기 버퍼 그룹의 정의를 마무리하는 함수입니다. 이 함수를 사용하기 위해서는 먼저 buffer_async_group_begin 함수를 호출하여 그룹을 시작해야 하며, 그 후에 저장할 파일마다 buffer_save_async 또는 불러올 파일마다 buffer_load_async 함수를 호출해야 합니다. 마지막으로 이 함수를 호출하면 파일 저장이 시작됩니다. 이 함수는 저장에 대한 고유한 ID 값을 반환하며, 이 ID는 비동기 저장/불러오기 이벤트에서 결과를 파싱하는 데 사용됩니다.

문법

buffer_async_group_end();

반환값

  • 비동기 요청 ID

예제

buffer_async_group_end 함수는 어떤 이벤트에서든 호출할 수 있으며, 비동기적이기 때문에 콜백이 거의 즉시 발생할 수도 있고 몇 초가 걸릴 수도 있습니다. 함수를 호출하는 것은 간단하며 다음과 같은 형태로 작성할 수 있습니다:

buffer_async_group_begin("SaveGame");
save1 = buffer_save_async(buff1, "Player_Save1.sav", 0, 16384);
save2 = buffer_save_async(buff2, "Player_Save2.sav", 0, 16384);
save3 = buffer_save_async(buff3, "Player_Save3.sav", 0, 16384);
save4 = buffer_save_async(buff4, "Player_Save4.sav", 0, 16384);
save_id = buffer_async_group_end();

위 코드는 버퍼 그룹을 시작한 후 4개의 파일을 비동기적으로 저장하도록 설정합니다. 그룹 정의가 끝나면 저장이 시작되며, 함수 호출의 ID가 save_id 변수에 저장됩니다. 저장이 완료되면 비동기 저장/불러오기 이벤트가 트리거되고, 다음과 같이 async_load 맵에서 올바른 ID를 파싱할 수 있습니다:

if (ds_map_find_value(async_load, "id") == save_id) {
    if (ds_map_find_value(async_load, "status") == false) {
        show_debug_message("Save failed!");
    }
}

위 코드는 async_load DS 맵의 ID가 buffer_async_group_end 호출로 반환된 ID와 같은지 확인한 후, 콜백의 상태를 체크하고 문제가 있을 경우 디버그 메시지를 출력합니다.

활용 예제

예제 번호 설명
1 게임 진행 상황을 저장하는 기능 구현
2 여러 파일을 동시에 불러오는 기능 구현
3 저장 완료 후 사용자에게 알림 표시
4 저장 실패 시 재시도 기능 구현
5 비동기 저장 상태를 UI에 표시하는 기능 구현

예제 코드 스니펫

  1. 게임 진행 상황 저장
buffer_async_group_begin("SaveGame");
save1 = buffer_save_async(player_data, "Player_Data.sav", 0, 16384);
save_id = buffer_async_group_end();
  1. 여러 파일 불러오기
buffer_async_group_begin("LoadGame");
load1 = buffer_load_async("Player_Data.sav", 0);
load2 = buffer_load_async("Settings_Data.sav", 0);
load_id = buffer_async_group_end();
  1. 저장 완료 알림
if (ds_map_find_value(async_load, "status") == true) {
    show_debug_message("Save completed successfully!");
}
  1. 저장 실패 재시도
if (ds_map_find_value(async_load, "status") == false) {
    // 재시도 로직
}
  1. 비동기 저장 상태 표시
if (ds_map_find_value(async_load, "status") == true) {
    // UI 업데이트
}

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