거리 조인트 생성 (physics_joint_distance_create)

거리 조인트는 두 인스턴스 간의 거리를 일정하게 유지하는 가장 간단한 조인트 중 하나입니다. 거리 조인트를 지정할 때, 두 인스턴스는 이미 생성되어 있어야 하며, 각각의 조인트에 고정 장치가 할당되어 있어야 합니다. 그런 다음 방 좌표에서 두 개의 앵커 포인트를 정의합니다. 첫 번째 앵커 포인트는 인스턴스 1에 연결되고, 두 번째 앵커 포인트는 인스턴스 2에 연결됩니다. 이 두 포인트 간의 거리가 거리 제약의 길이를 나타냅니다.

아래 이미지는 이 작동 방식을 보여줍니다. 앵커 포인트는 방 좌표로 지정되므로, 특히 인스턴스가 조인트와 동시에 생성될 때는 주의가 필요합니다. 또한, 조인트는 인스턴스의 스프라이트 크기나 부착된 고정 장치의 크기와는 독립적으로 생성됩니다. 따라서 인스턴스의 원점이 아닌 다른 위치에서 거리 조인트를 생성하더라도 유효하며, 생성된 위치에 상대적으로 두 인스턴스를 제약합니다.

"col" 값을 true로 설정하면 두 인스턴스가 서로 상호작용하고 충돌할 수 있지만, 충돌 이벤트가 있어야만 충돌합니다. false로 설정하면 어떤 경우에도 충돌하지 않습니다.

문법

physics_joint_distance_create(inst1, inst2, w_anchor1_x, w_anchor1_y, w_anchor2_x, w_anchor2_y, col)

인수 설명

인수 타입 설명
inst1 Instance ID 조인트에 연결할 첫 번째 인스턴스
inst2 Instance ID 조인트에 연결할 두 번째 인스턴스
w_anchor1_x Real 조인트의 첫 번째 x 좌표 (게임 월드 내)
w_anchor1_y Real 조인트의 첫 번째 y 좌표 (게임 월드 내)
w_anchor2_x Real 조인트의 두 번째 x 좌표 (게임 월드 내)
w_anchor2_y Real 조인트의 두 번째 y 좌표 (게임 월드 내)
col Boolean 두 인스턴스가 충돌할 수 있는지 여부 (true 또는 false)

반환값

  • Physics Joint ID

활용 예제

아래는 거리 조인트를 생성하는 몇 가지 예제 코드입니다.

예제 1: 기본 거리 조인트 생성

var mainFixture, o_id;
mainFixture = physics_fixture_create();
physics_fixture_set_circle_shape(mainFixture, sprite_get_width(sprite_index) / 2);
o_id = instance_create_layer(x + 300, y, "Instances", obj_Rudder);
physics_fixture_bind(mainFixture, id);
physics_fixture_bind(mainFixture, o_id);
physics_joint_distance_create(id, o_id, x + 50, y, o_id.x - 50, o_id.y, true);
physics_fixture_delete(mainFixture);

예제 2: 두 인스턴스 간의 거리 조인트 설정

var fixture1, fixture2;
fixture1 = physics_fixture_create();
fixture2 = physics_fixture_create();
physics_fixture_set_box_shape(fixture1, 32, 32);
physics_fixture_set_box_shape(fixture2, 32, 32);
var instance1 = instance_create_layer(100, 100, "Instances", obj_Box);
var instance2 = instance_create_layer(200, 100, "Instances", obj_Box);
physics_fixture_bind(fixture1, instance1);
physics_fixture_bind(fixture2, instance2);
physics_joint_distance_create(instance1, instance2, 100, 100, 200, 100, false);

예제 3: 충돌 가능성이 있는 거리 조인트 생성

var fixtureA, fixtureB;
fixtureA = physics_fixture_create();
fixtureB = physics_fixture_create();
physics_fixture_set_circle_shape(fixtureA, 16);
physics_fixture_set_circle_shape(fixtureB, 16);
var objA = instance_create_layer(150, 150, "Instances", obj_Circle);
var objB = instance_create_layer(250, 150, "Instances", obj_Circle);
physics_fixture_bind(fixtureA, objA);
physics_fixture_bind(fixtureB, objB);
physics_joint_distance_create(objA, objB, 150, 150, 250, 150, true);

이 예제들은 거리 조인트를 활용하여 인스턴스 간의 거리를 제어하는 방법을 보여줍니다.

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