시퀀스 이벤트, 순간 및 브로드캐스트 메시지

이 문서에서는 시퀀스 구조체에 추가할 수 있는 특별한 "액션" 속성에 대해 설명합니다. 이러한 액션 속성은 이벤트, 순간 및 브로드캐스트 메시지의 세 가지 유형으로 나뉘며, 각 유형에 대해 자세히 설명하겠습니다.

시퀀스 이벤트

시퀀스 객체에는 이벤트를 추가할 수 있으며, 이러한 이벤트는 객체 자산에서 사용하는 이벤트와 유사합니다. 시퀀스 객체에 할당된 이벤트는 시퀀스 생명 주기에서 정의된 순간에 한 번 발생하거나 시퀀스가 실행되는 매 프레임마다 발생합니다. 다음은 사용 가능한 이벤트 목록입니다:

이벤트 이름 설명
Create 레이어에 시퀀스 인스턴스가 생성될 때 트리거됩니다.
Destroy 레이어에 시퀀스 인스턴스가 파괴될 때 트리거됩니다.
Clean-up 시퀀스 인스턴스가 가비지 컬렉션될 때 트리거됩니다.
Step 일반 객체 Step 이벤트 직전에 트리거됩니다.
Begin Step 객체 Begin Step 이벤트 직전에 트리거됩니다.
End Step 객체 End Step 이벤트 직전에 트리거됩니다.
Async System 모든 객체 비동기 시스템 이벤트 핸들러와 동일하게 트리거됩니다.
Broadcast Message 시퀀스 업데이트 중 브로드캐스트 메시지 키프레임이 발견될 때 트리거됩니다.

이벤트를 설정하려면, 메서드 변수를 올바른 이름의 속성에 할당해야 합니다. 다음은 구문입니다:

<sequence_struct>.<event_property> = method(<sequence_struct>, <function_name>);

활용 예제

마우스 왼쪽 버튼 클릭 시 시퀀스 방향을 반전시키는 예제입니다.

/// @function seq_reverse();
function seq_reverse() {
    if (mouse_check_button_pressed(mb_left)) {
        if (self.headDirection == seqdir_right) {
            self.headDirection = seqdir_left;
        } else {
            self.headDirection = seqdir_right;
        }
    }
}

var _seq = sequence_get(Sequence1);
_seq.event_step = method(_seq, seq_reverse);

순간

시퀀스 순간은 시퀀스가 재생되는 동안 특정 프레임에서 발생하는 고유한 코드 액션입니다. 이러한 코드 순간은 미리 정의된 메서드 변수로, 주어진 프레임에서 트리거됩니다. 예를 들어, 특정 프레임에서 "총알" 인스턴스를 생성하려면 다음과 같은 함수를 만들어야 합니다.

/// @function seq_shoot();
seq_shoot = function() {
    instance_create_layer(sequence.xorigin, sequence.yorigin, "Instances", obj_Bullet);
}

이 함수를 시퀀스 구조체의 momentKeyframes 속성에 추가합니다.

활용 예제

다음 코드는 60, 120, 180 프레임에서 seq_shoot 메서드를 호출하도록 설정합니다.

var _seq = sequence_get(my_Seq);
var _k = array_create(3);
_k[0] = sequence_keyframe_new(seqtracktype_moment);
_k[0].frame = 60;
_k[1] = sequence_keyframe_new(seqtracktype_moment);
_k[1].frame = 120;
_k[2] = sequence_keyframe_new(seqtracktype_moment);
_k[2].frame = 180;

var _d = array_create(1);
_d[0] = sequence_keyframedata_new(seqtracktype_moment);
_d[0].channel = 0;
_d[0].event = method(_d[0], seq_shoot);

_k[0].channels = _d;
_k[1].channels = _d;
_k[2].channels = _d;
_seq.momentKeyframes = _k;

브로드캐스트 메시지

시퀀스는 브로드캐스트 메시지를 생성할 수 있습니다. 이는 애니메이션 타임라인의 특정 프레임에 추가된 문자열로, 해당 타임라인 지점에 도달하면 문자열이 모든 객체 인스턴스에 전송됩니다. 브로드캐스트 메시지를 생성하려면 messageEventKeyframes 속성에 추가합니다.

활용 예제

다음 코드는 60, 120 프레임에서 브로드캐스트 메시지를 설정합니다.

var _seq = sequence_get(my_Seq);
var _k = array_create(2);
_k[0] = sequence_keyframe_new(seqtracktype_message);
_k[0].frame = 60;
_k[1] = sequence_keyframe_new(seqtracktype_message);
_k[1].frame = 120;

var _m1 = array_create(2);
_m1[0] = "Hello";
_m1[1] = "World";

var _m2 = array_create(1);
_m2[0] = "This is a Broadcast Message";

var _d1 = array_create(1);
_d1[0] = sequence_keyframedata_new(seqtracktype_message);
_d1[0].channel = 0;
_d1[0].events = _m1;

var _d2 = array_create(1);
_d2[0] = sequence_keyframedata_new(seqtracktype_message);
_d2[0].channel = 0;
_d2[0].events = _m2;

_k[0].channels = _d1;
_k[1].channels = _d2;
_seq.messageEventKeyframes = _k;

이 코드는 메시지 텍스트를 키프레임 데이터 채널에 배열로 전달합니다. 이는 동일한 프레임에서 여러 메시지를 브로드캐스트할 수 있도록 합니다.

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