스켈레탈 애니메이션

스켈레탈 애니메이션 스프라이트

이 섹션에서 설명하는 함수들은 스켈레탈 애니메이션 파일(특히 Spine에서 내보낸 JSON 파일)에서 가져온 스프라이트에만 사용됩니다. 이 함수들은 게임 내 애니메이션 자산에 대한 정보를 얻거나 애니메이션 내 특정 속성을 설정하는 데 사용됩니다. 이러한 함수들은 일반 스프라이트 함수 및 변수를 함께 사용할 수 있어, 예를 들어 두 개의 스켈레톤 애니메이션을 혼합하면서 일반 스프라이트 인스턴스 변수를 사용하여 이미지 스케일을 설정할 수 있습니다. (스프라이트 인스턴스 변수에 대한 더 많은 정보는 여기를 참조하세요.)

대부분의 스켈레탈 스프라이트 함수는 스프라이트나 인스턴스 핸들을 받지 않으며, 현재 인스턴스에 스켈레탈 스프라이트가 할당되어 있다고 가정합니다(IDE를 통해 또는 sprite_index를 설정하여). 이는 다른 컨텍스트(예: 전역 스크립트 또는 생성자)에서 이러한 함수를 실행하면 오류가 발생할 수 있음을 의미합니다. 왜냐하면 현재의 self는 이러한 경우에 스켈레탈 스프라이트를 가지고 있지 않기 때문입니다.

Spine으로 만든 스켈레탈 애니메이션 스프라이트를 가져오는 방법에 대한 추가 정보는 "비트맵 스프라이트 가져오기" 섹션을 참조하세요.

아래 섹션에서 이러한 종류의 스프라이트에 대한 함수에 대해 더 알아볼 수 있습니다:

섹션 설명
애니메이션 애니메이션 관련 함수
스킨 스킨 관련 함수
부착물 부착물 관련 함수
뼈대 뼈대 관련 함수
슬롯 슬롯 관련 함수
그리기 및 기타 그리기 및 기타 함수

검은색 틴트 지원

이 기능은 Spine 스프라이트 슬롯의 어두운 영역을 밝은 영역과 다르게 틴트할 수 있게 해줍니다(이는 Spine IDE 기능입니다. 자세한 내용은 "검은색 틴트" 섹션을 참조하세요). 현재 GameMaker에서 이 기능을 사용하려면, 이를 사용하는 Spine 스프라이트를 그릴 때 사용자 정의 셰이더를 사용해야 합니다. 이 셰이더는 "gm_SpineTintBlackColour"라는 전역 유니폼 변수를 포함하고 있으며, 이는 Spine 데이터에서 자동으로 가져온 현재 틴트-블랙 색상으로 채워집니다.

셰이더 코드

버텍스 셰이더 (기본 패스스루 버텍스 셰이더와 동일)

attribute vec3 in_Position; // (x,y,z)
attribute vec4 in_Colour; // (r,g,b,a)
attribute vec2 in_TextureCoord; // (u,v)
varying vec2 v_vTexcoord;
varying vec4 v_vColour;

void main() {
    vec4 object_space_pos = vec4(in_Position.x, in_Position.y, in_Position.z, 1.0);
    gl_Position = gm_Matrices[MATRIX_WORLD_VIEW_PROJECTION] * object_space_pos;
    v_vColour = in_Colour;
    v_vTexcoord = in_TextureCoord;
}

프래그먼트 셰이더

varying vec2 v_vTexcoord;
varying vec4 v_vColour;
uniform vec4 gm_SpineTintBlackColour; // 틴트-블랙 색상을 포함하는 유니폼

void main() {
    vec4 tb = gm_SpineTintBlackColour;
    vec4 texcol = texture2D(gm_BaseTexture, v_vTexcoord);
    vec4 outcol;
    outcol.rgb = v_vColour.rgb * texcol.rgb;
    outcol.rgb += tb.rgb * ((tb.a * (texcol.a - 1.0)) + (1.0 - texcol.rgb)); // 틴트-블랙 블렌딩 로직
    outcol.a = v_vColour.a * texcol.a;
    gl_FragColor = outcol;
}

사용 예제

이 기능을 사용하려면 먼저 셰이더를 호출하고, 스프라이트를 그린 다음, 셰이더를 리셋하는 방식으로 진행합니다. 예를 들어:

shader_set(shd_spine_tint_black);
draw_self();
shader_reset();

활용 예제

  1. 스켈레탈 애니메이션 혼합: gml // 두 개의 스켈레탈 애니메이션 혼합 skeleton_set_animation(skeleton, "run"); skeleton_set_animation(skeleton2, "jump");
  2. 스프라이트 크기 조정: gml // 스프라이트 크기 조정 image_xscale = 1.5; image_yscale = 1.5;
  3. 애니메이션 속도 조절: gml // 애니메이션 속도 조절 skeleton_set_speed(skeleton, 2.0);
  4. 특정 프레임으로 이동: gml // 특정 프레임으로 이동 skeleton_set_frame(skeleton, 10);
  5. 스킨 변경: gml // 스킨 변경 skeleton_set_skin(skeleton, "new_skin");

이와 같은 다양한 활용을 통해 스켈레탈 애니메이션을 효과적으로 사용할 수 있습니다.

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