SDF 렌더링을 위한 폰트 설정 가이드

이 문서는 SDF(Signed Distance Field) 렌더링을 사용하여 폰트를 설정하고 활용하는 방법에 대해 설명합니다. 간단하게 말해, 이 기능은 주어진 폰트에 대해 SDF 렌더링을 활성화하거나 비활성화하는 것입니다. 이 폰트는 font_add() 함수를 사용해 추가한 후 폰트 파일에서 로드되어야 합니다. 스프라이트 폰트나 IDE를 통해 추가한 폰트에는 사용할 수 없습니다.

함수 사용법

문법

font_enable_sdf(ind, enable);

인수 설명

인수 유형 설명
ind Font Asset SDF 렌더링 기능을 활성화/비활성화할 폰트의 인덱스
enable Boolean 폰트에 대해 SDF 렌더링을 활성화할지 여부

반환 값

N/A

기본 예제

예를 들어, 다음과 같이 SDF 렌더링을 활성화할 수 있습니다:

// 생성 이벤트
new_font = font_add("STENCIL.TTF", 32, false, false, 32, 128);
font_enable_sdf(new_font, true);

// 그리기 이벤트
draw_set_font(new_font);
draw_set_halign(fa_center);
draw_set_valign(fa_middle);
var _sinval = dsin(current_time / 4);
var _scale = 4 * (1 + _sinval * 0.3);
draw_text_transformed(500, 400, "Hello World! (animated version)", _scale, _scale, 0);

위의 코드는 객체의 생성 이벤트와 그리기 이벤트를 보여줍니다. 생성 이벤트에서 font_add()를 사용하여 사용자 정의 폰트를 추가하고 인스턴스 변수인 new_font에 저장합니다. font_enable_sdf를 호출하여 폰트에 대해 SDF 렌더링을 활성화합니다. 그리기 이벤트에서는 폰트를 new_font로 설정하고 텍스트 정렬을 중앙으로 맞추며, 텍스트 스케일을 애니메이션하기 위해 몇 가지 값을 계산합니다. 마지막으로 draw_text_transformed를 사용하여 스케일이 조정된 텍스트를 그립니다. SDF가 활성화된 폰트를 사용하므로 이 텍스트는 크기가 조정되더라도 선명하게 유지됩니다.

활용 예제

이제 SDF 렌더링을 활용하여 다양한 애니메이션 효과를 추가해 봅시다.

예제 1: 색상 변화 애니메이션

// 그리기 이벤트
var _time = current_time mod 1000;
var _color = make_color_hsl(_time % 360, 255, 128); // 색상 변환
draw_set_color(_color);
draw_text_transformed(500, 400, "Color Changing Text", 1, 1, 0);

이 예제에서는 시간이 경과함에 따라 텍스트 색상이 변화합니다.

예제 2: 회전하는 텍스트

// 그리기 이벤트
var _angle = current_time * 0.1; // 시간에 따라 각도 증가
draw_text_transformed(500, 400, "Rotating Text", 1, 1, _angle);

이 예제는 텍스트가 회전하는 효과를 보여줍니다.

예제 3: 크기와 위치 애니메이션

// 그리기 이벤트
var _sinval = dsin(current_time / 20);
var _size = 1 + (_sinval * 0.2);
var _pos_x = 500 + (_sinval * 50);
draw_text_transformed(_pos_x, 400, "Moving and Scaling Text", _size, _size, 0);

이 예제는 텍스트의 크기와 위치를 조정하여 움직이고 확대/축소되는 효과를 제공합니다.

요약

SDF 렌더링을 활용하여 폰트를 보다 선명하게 표현하고 다양한 애니메이션 효과를 적용할 수 있습니다. 이러한 기능을 통해 게임에서 시각적으로 더 매력적인 텍스트를 생성할 수 있습니다.

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