물리 피xture 바인딩 (physics_fixture_bind_ext)

물리 피xture를 정의한 후, 이를 인스턴스에 바인딩해야 합니다. 이는 피xture의 속성이 선택된 인스턴스로 전송된다는 것을 의미하며, 실제 피xture 자체가 아닌 인스턴스에 적용됩니다. 따라서 하나의 피xture는 여러 인스턴스에 바인딩될 수 있으며, 이 경우 모든 인스턴스는 동일한 속성을 가집니다.

바인딩 방법

  • 대상 인스턴스 지정: 객체 인덱스를 지정하면, 해당 방에 있는 모든 인스턴스가 피xture의 속성을 받습니다. 단, 나중에 생성된 인스턴스는 제외됩니다.
  • 특수 키워드 사용: otherall 키워드를 사용할 수 있습니다.
  • 부모 객체 지정: 부모 객체를 지정하면, 해당 부모의 모든 자식 인스턴스도 피xture를 받습니다.

피xture가 필요한 모든 인스턴스에 바인딩된 후에는 더 이상 필요하지 않으면 삭제할 수 있습니다. 이 경우 인스턴스는 여전히 피xture의 속성을 유지합니다.

바인딩 위치 조정

일반적으로 피xture는 인스턴스의 질량 중심이 인스턴스의 원점에 위치하도록 바인딩됩니다. 그러나 필요에 따라 x 및 y 위치를 오프셋할 수 있습니다. 여러 오프셋을 추가하는 것은 지원되지 않으므로, 단일 오프셋만 가능합니다.

고유 ID 반환

이 함수는 바인딩된 피xture에 대한 고유한 "id" 값을 반환합니다. 이 값은 physics_remove_fixture 함수를 사용하여 인스턴스에서 물리적 속성을 제거하는 데 사용될 수 있습니다. 이를 통해 객체를 파괴하고 재생성하지 않고도 인스턴스에서 물리적 속성을 추가하거나 제거할 수 있습니다.

메모리 관리

피xture가 더 이상 필요하지 않을 때 삭제해야 합니다. 삭제하지 않으면 메모리 누수가 발생하여 게임이 느려지거나 결국 충돌할 수 있습니다.

문법

physics_fixture_bind_ext(fixture, target, xoffset, yoffset)

인수 설명

인수 유형 설명
fixture Physics Fixture ID 바인딩할 피xture
target Object Instance/Object Asset 피xture를 받을 대상 인스턴스 (인스턴스 ID, 객체 ID, other, all 가능)
xoffset Real x축을 따라 오프셋
yoffset Real y축을 따라 오프셋

반환 값

  • Real

활용 예제

예제 1: 피xture 생성 및 바인딩

var fix, inst;
fix = physics_fixture_create();
physics_fixture_set_circle_shape(fix, 16);
physics_fixture_set_density(fix, 1.0);
inst = instance_create_layer(x, y, "Instances", genericBodyObject);
my_fix = physics_fixture_bind_ext(fix, inst, sprite_width / 2, -(sprite_height / 2));
physics_fixture_delete(fix);

위 코드는 피xture를 생성하고 "fix" 변수에 인덱스를 할당합니다. 그 후 피xture의 형태와 밀도를 정의하고, 인스턴스에 스프라이트의 너비와 높이에 기반한 오프셋으로 바인딩합니다. 바인딩된 피xture의 인덱스는 "my_fix" 변수에 저장됩니다. 마지막으로, 더 이상 필요하지 않으므로 피xture를 삭제하여 메모리 누수를 방지합니다.

예제 2: 부모 객체를 통한 바인딩

var parentInst, childInst;
parentInst = instance_create_layer(x, y, "Instances", parentObject);
childInst = instance_create_layer(x + 50, y, "Instances", childObject);
my_fix = physics_fixture_bind_ext(fix, parentInst, 0, 0);

이 코드는 부모 객체에 피xture를 바인딩하여 모든 자식 인스턴스가 해당 피xture의 속성을 받도록 합니다.

예제 3: 오프셋을 사용한 바인딩

var inst;
inst = instance_create_layer(x, y, "Instances", anotherObject);
my_fix = physics_fixture_bind_ext(fix, inst, 10, -5);

위 코드는 인스턴스에 피xture를 바인딩할 때 x축으로 10, y축으로 -5의 오프셋을 적용합니다.

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