비동기 버퍼 저장 함수 설명

buffer_save_async 함수는 버퍼의 일부 내용을 비동기적으로 파일에 저장하는 기능을 제공합니다. 이 함수는 저장된 데이터를 메모리로 다시 읽어오는 데 사용할 수 있는 buffer_load_* 함수와 함께 사용됩니다.

함수 설명

  • offset: 저장을 시작할 버퍼 내 위치(바이트 단위)를 정의합니다.
  • size: 해당 오프셋에서부터 저장할 버퍼 영역의 크기(바이트 단위)를 정의합니다.
  • 이 함수는 비동기적으로 작동하므로, 저장하는 동안 게임은 계속 실행됩니다.

저장된 모든 파일은 "default" 폴더에 위치하게 되며, 비동기 그룹을 사용하는 경우 그룹 이름이 "default"를 대체합니다. 예를 들어, 파일 이름 경로가 Data\Player_Save.sav인 경우 실제로는 default\Data\Player_Save.sav에 저장됩니다. buffer_load_async 함수를 사용하여 파일을 로드할 때도 "default" 부분을 경로에 포함할 필요가 없습니다.

HTML5에서는 "default/"가 자동으로 추가되지 않으므로 코드에서 이를 고려해야 합니다. 데스크탑 플랫폼에서 시스템 샌드박스를 비활성화하면 절대 경로로 버퍼를 저장할 때 "default/"가 추가되지 않습니다.

이 함수는 고유한 ID 값을 반환하며, 비동기 저장/로드 이벤트를 트리거합니다. 반환된 ID를 사용하여 async_load의 ID 값을 확인할 수 있습니다. 이벤트 내의 async_load 맵은 다음 두 개의 키/값 쌍을 포함합니다:

  • "id": 저장 함수에서 반환된 비동기 함수의 ID.
  • "status": 데이터가 올바르게 저장되었으면 true, 그렇지 않으면 false를 반환합니다.

여러 개의 버퍼를 한 번에 저장하려면 이 함수를 여러 번 호출하여 buffer_async_group_beginbuffer_async_group_end 사이에서 사용할 수 있습니다.

함수 구문

buffer_save_async(buffer, filename, offset, size);

매개변수 설명

매개변수 유형 설명
buffer Buffer 저장할 버퍼
filename String 저장할 파일 이름
offset Real 저장할 버퍼 내 오프셋 (바이트 단위)
size Real 저장할 버퍼 영역의 크기 (바이트 단위)

반환값

  • 비동기 요청 ID

활용 예제

다음은 buffer_save_async 함수를 사용하는 간단한 예제입니다:

// 버퍼 내용을 비동기적으로 저장
saveid = buffer_save_async(buff, "Player_Save.sav", 0, 16384);

// 저장 완료 후 상태 확인
if (ds_map_find_value(async_load, "id") == saveid) {
    if (ds_map_find_value(async_load, "status") == false) {
        show_debug_message("저장 실패!");
    }
}

이 코드는 buff라는 버퍼의 내용을 "Player_Save.sav"라는 파일에 저장하고, 저장이 완료된 후 상태를 확인하여 실패 시 디버그 메시지를 출력합니다.

추가 예제:

// 여러 버퍼를 비동기적으로 저장
buffer_async_group_begin();
saveid1 = buffer_save_async(buff1, "Player1_Save.sav", 0, 8192);
saveid2 = buffer_save_async(buff2, "Player2_Save.sav", 0, 8192);
buffer_async_group_end();

이 코드는 두 개의 버퍼를 비동기적으로 저장하는 예제입니다.

// HTML5에서 저장할 때 base64 인코딩 사용
saveid = buffer_save_async(buff, "Player_Save.b64", 0, 16384);

이 코드는 HTML5에서 base64 인코딩된 문자열로 저장하는 예제입니다.

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