방송 메시지 및 순간

방송 메시지

시퀀스와 스프라이트는 애니메이션 타임라인의 특정 프레임에서 방송 메시지를 생성할 수 있습니다. 이 메시지는 간단한 문자열로, 타임라인의 해당 지점에 도달하면 모든 인스턴스에 전송됩니다. 방송 메시지를 수신하는 인스턴스는 "기타" 이벤트 카테고리에서 찾을 수 있는 방송 메시지 이벤트를 가지고 있어야 합니다. 이 이벤트가 타임라인에서 도달하면 메시지 문자열을 수신하게 되며, 그에 따라 코드를 작성하여 반응할 수 있습니다.

시퀀스도 방송 메시지를 수신할 수 있지만, 이를 위해서는 먼저 리스너 메서드를 설정해야 합니다. 자세한 내용은 GML 섹션의 시퀀스 이벤트 및 순간을 참조하세요.

주의 사항

  • 인스턴스의 image_index를 직접 프레임으로 설정하면 해당 프레임에 존재하는 방송 메시지가 트리거되지 않습니다.

방송 메시지 추가하기

시퀀스나 스프라이트 타임라인에 방송 메시지를 추가하려면 버튼을 클릭하여 대화 상자를 열고 메시지를 추가하면 됩니다. 추가된 메시지는 도프 시트 또는 스프라이트 프레임 뷰에 표시됩니다. 메시지를 편집하려면 메시지 아이콘을 오른쪽 클릭하여 해당 프레임에 겹치는 모든 메시지 목록을 열고, 목록에서 선택하여 메시지 대화 상자를 열어 편집하거나 제거할 수 있습니다.

이벤트 데이터

방송 메시지 이벤트가 트리거되면 특별한 DS 맵이 생성되어 내장 변수 event_data에 저장됩니다. 이 변수는 글로벌 스코프 변수이지만, 트리거된 이벤트에서만 DS 맵 데이터를 포함하고 다른 경우에는 -1을 반환합니다.

변수 유형 설명
event_type String 메시지 "sequence event" 또는 "sprite event"
message String 메시지 문자열 수신된 메시지 문자열
element_id Layer Element ID 메시지를 발생시킨 레이어 요소의 ID

방송 메시지 이벤트는 여러 문자열을 수신할 수 있으며, 모든 문자열에 대해 반응할 필요는 없습니다. 그러나 동시에 수신되는 메시지에 대해 여러 인스턴스가 리스닝할 수 있습니다. 이 경우 이벤트가 여러 번 트리거됩니다.

이벤트 체크 예제

if event_data[? "event_type"] == "sequence event" // 또는 "sprite event" 확인
{
    switch (event_data[? "message"])
    {
        case "hit":
            audio_play_sound(snd_hit, 0, false);
            break;
        case "destroy":
            sequence_destroy(event_data[? "element_id"]);
            break;
    }
}

순간

시퀀스 순간은 타임라인에서 함수가 호출될 수 있는 위치입니다. 이는 매개변수가 없는 스크립트 함수로, 타임라인의 해당 프레임에 도달하면 호출됩니다. 순간을 설정하려면 재생 헤드를 원하는 위치로 이동한 후 "Add Moment" 버튼을 클릭하고, 열리는 대화 상자에서 호출할 함수의 이름을 입력하면 됩니다.

함수 추가 시, 지정된 함수가 있는 스크립트로 이동하거나 빈 함수가 준비된 새 스크립트 자산을 생성할 수 있습니다. 또한 순간과 해당 함수 호출을 제거할 수도 있습니다.

활용 예제

// 순간에서 호출할 함수 예제
function myMomentFunction() {
    // 특정 작업 수행
    show_message("순간에 도달했습니다!");
}

// 순간 추가
if (current_frame == 10) {
    myMomentFunction();
}
// 다른 순간에서의 함수 호출 예제
function anotherMomentFunction() {
    // 다른 작업 수행
    audio_play_sound(snd_background, 1, true);
}

// 순간 추가
if (current_frame == 20) {
    anotherMomentFunction();
}
// 여러 순간을 활용한 예제
function multiMomentFunction() {
    // 여러 작업 수행
    show_message("여러 순간에서 호출되었습니다!");
}

// 순간 추가
if (current_frame == 30) {
    multiMomentFunction();
}

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