이미지 로드 이벤트 설명

이 문서에서는 GameMaker에서 이미지를 로드할 때 발생하는 Image Loaded 이벤트에 대해 설명합니다. 이 이벤트는 HTML5에서 이미지를 로드하거나 URL을 통해 이미지를 로드할 때 트리거됩니다.

기본 사용법

예를 들어, 스프라이트 이미지를 로드하고, 이미지가 로드된 후에만 현재 인스턴스의 스프라이트를 새 스프라이트로 변경하고 싶다고 가정해 보겠습니다. 다음과 같은 코드를 Create 이벤트(또는 다른 이벤트)에서 사용할 수 있습니다.

var _url = "http://www.angusgames.com/game/background1.png";
spr = sprite_add(_url, 0, false, false, 0, 0);

위 코드는 이미지를 장치나 브라우저에 로드하기 시작하지만, 파일이 로드될 때까지 GameMaker의 실행을 차단하지 않습니다. 대신, GameMaker는 이미지가 로드될 때까지 정상적으로 실행됩니다. 이미지가 로드되면 Image Loaded Event가 호출되고, 이때 async_load라는 특별한 변수에 DS 맵이 생성되어 저장됩니다.

DS 맵 정보

생성된 DS 맵에는 다음과 같은 정보가 포함됩니다:

설명
filename 요청한 파일의 전체 경로
id 로드한 리소스의 ID
status 오류가 있을 경우 0보다 작은 값을 반환

이벤트에서 새로 로드된 이미지를 스프라이트에 할당하려면 다음과 같은 코드를 사용할 수 있습니다.

if (ds_map_find_value(async_load, "id") == spr) {
    if (ds_map_find_value(async_load, "status") >= 0) {
        sprite_index = spr;
    }
}

위 코드는 먼저 생성된 DS 맵의 id를 확인한 다음, 콜백의 status를 확인합니다. 값이 0 이상이면(성공을 나타냄) 콜백의 결과를 사용하여 스프라이트 인덱스를 새로 로드된 이미지로 설정합니다.

활용 예제

예제 1: 여러 이미지 로드하기

여러 이미지를 동시에 로드하고 각각의 스프라이트에 할당하는 방법입니다.

var _url1 = "http://www.example.com/image1.png";
var _url2 = "http://www.example.com/image2.png";
spr1 = sprite_add(_url1, 0, false, false, 0, 0);
spr2 = sprite_add(_url2, 0, false, false, 0, 0);

예제 2: 로드 상태 확인하기

이미지가 로드된 후 상태를 확인하고, 로드 실패 시 대체 이미지를 사용하는 방법입니다.

if (ds_map_find_value(async_load, "status") < 0) {
    spr = sprite_add("http://www.example.com/placeholder.png", 0, false, false, 0, 0);
}

예제 3: 로드 완료 후 애니메이션 시작하기

이미지가 로드된 후 애니메이션을 시작하는 방법입니다.

if (ds_map_find_value(async_load, "status") >= 0) {
    sprite_index = spr;
    // 애니메이션 시작
    image_speed = 1;
}

이와 같은 방법으로 Image Loaded 이벤트를 활용하여 다양한 기능을 구현할 수 있습니다.

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