네트워킹 이벤트 설명서

네트워킹 이벤트는 들어오는 네트워크 트래픽에 의해 발생하며, 네트워크 기능과 연결되어 있습니다. 이 이벤트는 특별한 DS 맵을 생성하며, 이 맵은 async_load라는 특별한 변수에 저장됩니다. 이 DS 맵은 생성된 네트워크 이벤트의 유형에 따라 다양한 정보를 포함합니다.

일반 네트워킹 이벤트

모든 수신된 네트워크 기능에 공통적으로 포함되는 키는 다음과 같습니다:

설명
type 아래 표에 나열된 상수 중 하나로 반환되며, 네트워크 이벤트 유형을 지정합니다.
id 이벤트를 수신하는 소켓 ID (실수)입니다. 일반적으로 TCP 또는 UDP 소켓의 ID입니다.
ip 소켓의 IP 주소 (문자열)입니다.
port IP 주소와 관련된 포트입니다 (UDP 작업 시 유용합니다).

"type" 키의 가능한 반환 값

상수 설명
network_type_connect 연결에 의해 발생한 이벤트입니다.
network_type_disconnect 연결 해제에 의해 발생한 이벤트입니다.
network_type_data 들어오는 데이터에 의해 발생한 이벤트입니다.
network_type_non_blocking_connect 비차단으로 설정된 연결에 의해 발생한 이벤트입니다.

연결 및 해제

network_type_connect 또는 network_type_disconnect 유형의 이벤트가 발생하면, async_load 맵에 다음과 같은 추가 키가 포함됩니다:

설명
socket 연결/해제 중인 소켓 ID입니다.

network_type_non_blocking_connect 유형의 경우, 추가적으로 다음 키가 포함됩니다:

설명
succeeded 0 또는 1의 값을 가지며, 0은 연결 타임아웃을 의미하고 1은 성공적으로 연결되었음을 의미합니다.

클라이언트에서 서버가 연결 해제될 때 네트워킹 이벤트는 발생하지 않으며, 클라이언트가 연결된 서버가 해제될 때도 network_type_* 이벤트는 발생하지 않습니다.

데이터 수신

network_type_data 유형의 이벤트가 발생하면, 생성된 맵은 다음과 같은 키를 포함합니다:

설명
buffer 이벤트에 의해 생성된 버퍼의 핸들입니다.
size 수신된 버퍼 데이터의 크기 (바이트)입니다.
message_type (WebSockets 전용) 수신된 메시지가 이진 형식일 경우 network_send_binary, 텍스트 형식일 경우 network_send_text입니다.
server (서버 소켓 전용) 데이터를 수신한 서버 소켓의 ID입니다.

생성된 버퍼는 이러한 이벤트에서만 유효하며, 이벤트가 끝나면 자동으로 해제됩니다.

연결 시도

os_is_network_connected 함수가 false를 반환할 경우, network_connect_active 또는 network_connect_passive를 사용할 때 이 이벤트에서 결과가 비동기적으로 반환됩니다. async_load 맵의 type 키는 다음 값 중 하나가 됩니다:

상수 설명
network_type_up 연결이 성공했습니다.
network_type_up_failed 연결이 실패했습니다.

네트워크가 언제든지 다운되면, 이 이벤트가 다시 발생하며 type 키는 network_type_down으로 설정됩니다.

활용 예제

다음은 네트워킹 이벤트를 활용하는 몇 가지 예제입니다:

// 서버 소켓 생성
var server_socket = network_create_server(port);

// 클라이언트 연결 수신
if (async_load[? "type"] == network_type_connect) {
    var client_id = async_load[? "id"];
    // 클라이언트와의 연결 처리
}

// 데이터 수신 처리
if (async_load[? "type"] == network_type_data) {
    var buffer = async_load[? "buffer"];
    var size = async_load[? "size"];
    // 수신된 데이터 처리
}

// 연결 시도
if (os_is_network_connected()) {
    network_connect_active(server_socket, ip, port);
} else {
    // 연결 실패 처리
}
// 비차단 연결 시도
var result = network_connect_async(ip, port);
if (result == network_type_non_blocking_connect) {
    if (async_load[? "succeeded"] == 1) {
        // 연결 성공
    } else {
        // 연결 실패
    }
}
// 클라이언트 소켓 생성
var client_socket = network_create_socket();

// 데이터 전송
network_send_text(client_socket, "Hello, Server!");

이와 같은 예제를 통해 네트워킹 이벤트를 효과적으로 활용할 수 있습니다.

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