최근 수정 시각 : 2024-10-16 15:12:47

게임 엔진

게임엔진에서 넘어옴
||<tablebordercolor=#000,#fff><tablewidth=100%><tablebgcolor=#fff,#1c1d1f><bgcolor=#000,#fff> 게임 엔진 ||
{{{#!wiki style="margin: 0 -10px -5px; min-height: calc(1.5em + 5px);"
{{{#!folding [ 펼치기 · 접기 ]
{{{#!wiki style="margin: -5px -1px -11px;"
메이저 상용 게임 엔진
파일:언리얼 엔진 로고.svg파일:언리얼 엔진 로고 화이트.svg 파일:유니티 로고.svg파일:유니티 로고 화이트.svg
언리얼 엔진 유니티
관련 문서: 언리얼 엔진 vs 유니티 엔진
기타 엔진 목록 }}}}}}}}}

1. 개요2. 역사
2.1. 게임 소스 코드의 재활용: 1970년대 ~
2.1.1. 스크립트 언어
2.2. 게임 엔진 태동기: 1990년대 중반 ~2.3. 특정 기술/기능 라이브러리(미들웨어)의 등장: 1990년대 후반 ~2.4. 본격적인 게임 엔진의 등장: 2000년대 중반 이후
3. 기능4. 게임 엔진 목록
4.1. 오픈 소스 엔진4.2. 공개된 상용 엔진4.3. 비공개된 엔진
5. 자체 엔진
5.1. 오래된 엔진은 성능이 떨어진다?5.2. 자체 엔진은 성능이 좋다?
6. 포크7. 게임 엔진을 백엔드 프레임워크로만 사용하는 경우8. 미들웨어 종류/목록
8.1. 물리 엔진8.2. 사운드 엔진8.3. 모션8.4. 기타 미들웨어
9. 관련 문서

1. 개요

비디오 게임, PC 게임의 개발에 기반이 되는 구성 요소들을 가진 필수 구성 요소들인 그래픽 엔진, 물리 엔진, 오디오 엔진, UI 시스템, 게임 플레이 프레임워크 등이 잘 융합된 상태의 소스 코드와 그 기능들을 디자이너들이 사용 가능한 툴을 겸비한 게임 개발 소프트웨어를 일컫는 말이다.

태초의 게임 엔진이 나무도막이나 모래상자 수준이었다면 현대의 게임 엔진은 자동차 생산 라인이라고 봐도 무방할 정도로 많은 기능을 제공한다.

2. 역사

2.1. 게임 소스 코드의 재활용: 1970년대 ~

1990년대 중반 이전에는 게임 엔진이란 명칭도 정립이 되지 않았고 전문적인 게임 엔진도 없던 시절이라 엔진과 결과물이 명확하게 구분되어 연결되지 않는다. 이는 대부분의 게임이 그 게임을 위한 코드 자체로 구성되어 다른 게임에 반복해서 이식될 일이 거의 없었기 때문이다. 당시 미국의 게임 개발자들도 '게임 엔진'과 '게임 라이브러리'를 명확하게 구별하지 않던 시절이었고, 개발자들 사이에서 유통되는 유료화된 라이브러리의 기능범위 역시 상당히 다양했다. 좁게는 화면에 그래픽을 출력하는 기능(나중으로 따지면 DirectX, OpenGL와 같은 역할)들을 잘 엮어서 엔진이라고 판매되는 경우부터, 규모가 있으면 메모리 관리나 데이터 리소스 관리 기능 정도가 포함되면 게임용 엔진으로서 가능한 거의 모든 기능을 포함할 수 있었다.

이때는 게임 엔진이라는 명확한 표현은 없었지만 일단 한번 게임을 성공적으로 개발할 경우 그 게임의 소스 코드를 재활용하여 후속작이나 비슷한 작품을 만드는데에 재활용 하는 것은 지극히 당연한 일이었다. 비단 형태가 비슷한 게임이 아닐지라도, 콘솔게임은 물론이고 IBM-PC 호환기종에서는 얼마나 많은 하드웨어를 지원하느냐에 따라 제작사의 실력이 갈리기도 했었는데, 이러한 하드웨어 제어 엔진 부분의 코드를 공통적으로 돌려쓰는 관습 또한 존재했다.

이를테면 1991년작 Winter Challenge 게임과 동일 개발사의 1992년작 Summer Challenge을 보면 윈터 챌린지에서 계절만 그대로 바꾼 게임이라는 것을 알 수 있다.

비슷하게 1993년작 정글 북과 동일 개발사의 1994년작 라이온 킹의 영상을 비교해도 대충 어떤 느낌인지 쉽게 알 수 있을 것이다.

게임보이 컬러용 루리루리 마작과 에반게리온 마작은 서로 다른 게임임에도 통신 대전이 가능하여 큰 화제를 불러왔는데, 이것은 그야말로 게임의 모든 소스 코드가 동일하고 그림만 다른 게임이라는 것의 증거이다.

이런 점들은 현대적인 게임 엔진이라기 보단, 현재 게임들이 캐릭터 스킨만 바꿔서 돌려막기 하는 것처럼 인기있는 장르의 게임을 그림만 바꿔 돌려막는 것에 더 가까웠다.

2.1.1. 스크립트 언어

그래도 일부 게임제작사들은 아예 특정 코드를 규격화 시킨뒤에 스크립트에 맞춰 코드를 짜면 이후 스크립트가 변환시켜주는 방식을 사용하기도 했다. 루카스아츠의 SCUMM이 대표적. 이런 스크립트 언어의 장점은 일단 해당 스크립트로 게임을 만들면 이후 각각의 플랫폼별로 변환기만 만들면 한번의 제작으로 여러 플랫폼에 게임을 출시할수 있다는 강점이 있어 시에라(AGI, SGI등), 루카스아츠 등의 제작사들이 자주 애용했다. 당시에는 단지 스크립트 언어 혹은 스크립트 엔진등으로 불렸으나, 게임 엔진이라는 말이 대중화 된 이후로는 이런 언어들도 게임 엔진이라 부르게 되었다. 이런 스크립트 언어는 지금도 여전히 중소형 게임 제작사들이 만들어 사용하는 경우가 종종 있는데, 에로게에서는 특히 자주 사용되고 있다.

2.2. 게임 엔진 태동기: 1990년대 중반 ~

게임 엔진이라는 용어의 존재는 현재의 총합패키지와 마케팅적 이미지가 씌워지기 전에도 존재했었다. 도스 게임 시절에는 윈도우와 달리 수많은 하드웨어 파편화에 대응하여 하드웨어를 직접 제어해야 했다. 거기서 제작사의 실력이 많이 갈렸는데, 그러다보니 사운드 블래스터 같은 사실상 표준 기기도 정해지게 되었고 같은 게임 제작사의 다른 게임 혹은 아예 완전히 다른 제작사의 다른 게임이라도 사전에 사운드와 그래픽 따위를 설정하는 부분이 비슷비슷해지는 경우가 많이 있었다. 그런 게임의 핵심 코드를 '엔진'이라고 부르고 사용하였다.

사실상 처음으로 xx 엔진[1]이라는 말이 등장하기 시작한 것은 고전 FPS 게임 이 id tech 엔진으로 그 후속작 둠 2 그리고 파생작인 헤러틱, 헥센 같은 게임들이 제작되며라고 볼 수 있을것이다. 이때에도 현대의 게임 엔진 모습과는 달리 하드웨어를 제어하고 그래픽을 렌더링하는 핵심 기반 소스 코드나 미들웨어 정도의 수준인 것들이 대부분이었으나, 그 자체가 이미 뛰어난 기술력을 보유한 것이었고, 곧 기술력을 자랑하는 마케팅 용도로도 사용되었으며, 타사에 라이센스를 주기도 했다.

본격적으로 게임 엔진이 엔진으로서 활약하게 된 것은 퀘이크가 나올때 부터인데 사실 퀘이크가 2까지 나올때에도 실질적으로 엔진을 사용하여 게임을 만든다는 개념이 그렇게 크지는 않았다. 그러나 그를 사용한 하프라이프가 나오고 대히트 하면서 상황이 반전되고, 에픽은 언리얼 게임을 내놓으며 이드 소프트웨어의 아성을 크게 위협하며 언리얼 엔진의 존재를 부각시켰다. 사실 이때까지도 이들 게임 엔진을 사용하여 만들어진 게임의 수는 손에 꼽을 정도로 적었으나 게임 엔진을 사용했다는 것 자체로 '우리 게임은 첨단 기술을 사용하여 제작되었다'는 마케팅이 되기도 하였다.

이러한 예를 일부 살펴보자면, 빌드 엔진은 1993년부터 1996년까지 3D 렐름에서 개발한 둠 스타일의 2.5D로 단순한 테스트 형태의 FPS 게임 소스와 툴을 담고 있었다. 빌드 엔진은 개발 도중 타사에 라이센스 되어 몇 가지의 FPS 게임들이 출시되었는데 빌드 엔진을 사용한 게임 중 특별한 3개의 게임들[2]은 빌드 엔진 개발자와 해당 게임 개발자가 협업하여 빌드 엔진을 각 해당 게임에 특화하여 변형시켰다. 자세한 사항은 빌드 엔진 문서 참고.

퀘이크 1, 2, 3의 id Tech 엔진은 본격적인 게임 엔진의 사용 사례로 하프라이프를 비롯한 당대의 유명한 3D FPS 게임들은 대부분 퀘이크 엔진을 이용하여 만들어 졌다고 해도 과언이 아니다.

언리얼 엔진은 기존의 다른 엔진들과 다른 유연한 구조와 뛰어난 에디터를 제공해서 소스 코드를 거의 손대지 않고서도 원본 FPS 게임에서 어느 정도 모양새가 다른 게임들을 개발할 수 있었다. 언리얼 엔진 2 부터는 FPS/TPS 뿐만이 아니라 MMORPG 게임을 만드는데도 사용되었다.

리스텍 엔진은 쇼고 모빌 아머 디비전과 블러드 2를 시작으로 주피터 엔진으로 이름을 바꿔 F.E.A.R.를 거쳐 가장 최신 게임인 모르도르까지 이름을 이어오고 있다.

2.3. 특정 기술/기능 라이브러리(미들웨어)의 등장: 1990년대 후반 ~

1990년대 중반 이후부터 본격적으로 3D 게임의 시대가 개막되면서 3D 게임 프로그래밍은 기존에 2D 게임 개발과는 비교 조차도 하기 힘든 수준으로 개발 난이도가 급상승되었고 이런 한계를 극복하고자 소수의 개발자들이 연합하여 3D 그래픽 구현에 관한 다양한 라이브러리를 작성해 인터넷상에 무료 배포했으며 관련 서적들을 출판하고 서적의 부록CD로 해당 3D 그래픽 라이브러리를 포함하는 등 3D 게임 기술의 상향을 위해 노력했었다. 당시 유명했던 것은 John De Goes의 Cutting Edge 3D Game Graphics Engine이다.

이 중 3D 그래픽 라이브러리의 개발 수준이 높아지고 어느 정도의 툴도 갖추면서 이것을 지속적으로 업데이트하며 게임 개발사들을 대상으로 판매를 개시(라이센스)하는 회사도 차차 등장하게 되었는데 당시 유명한 상용 그래픽 라이브러리로는 렌더웨어 그래픽스(RenderWare Graphics)와 넷이머스(Netimmerse) 등이 있었다.

여전히 오픈 소스에 무상으로 개발되는 것들도 있는데 오픈 소스 중 유명한 3D 그래픽 라이브러리로는 오우거 3D(Ogre 3D)가 있다.

이런 그래픽 라이브러리는 순수하게 3D 그래픽을 처리하는 부분의 소스 코드만 있고(또는 그 그래픽을 처리하는 데 필요한 일부 툴도 포함) 나머지 게임에 필요한 모든 파트는 프로그래머가 직접 구현해야 하므로 이런 것은 게임 엔진이라고 불리지는 않고 그래픽 엔진이라고 불렸다. 하지만 당시는 게임 엔진 등 용어에 대한 정립이 명확하게 되어 있지 않았으므로 이것들이 게임 엔진으로 불리기도 했고 또는 특정 게임의 소스를 활용한 것을 가지고 그래픽 엔진을 활용했다고 부르기도 했다.

3D 그래픽 라이브러리만 존재했던 게 아니라 네트워크 라이브러리, 오디오 라이브러리, 물리 연산 라이브러리(현재 물리 엔진이라고 불리는) 등 다양한 분야별 라이브러리가 별도로 개발되고 라이센스 되어 여러게임에 활용된 바 있다.

현대에도 여전히 이런 전문분야 라이브러리, 이른바 미들웨어들이 다양하게 등장했는데 그래픽 컬링만 처리하는 Umbra, GI 라이트맵을 생생하고 동적 객체에 유사 GI 효과를 내주는 Beast, 유사 실시간 GI 효과를 만들어주는 Enlighten, 게임의 UI/UX를 Flash로 처리해주는 Scaleform GFx[3], 다양한 나무를 생성해주는 SpeedTree, 캐릭터 애니메이션 처리를 위한 Morpheme, HumanIK, 페이셜 애니메이션과 립싱크 등을 위한 FaceFX, IKinema 등이 있으며, 뿐만 아니라 사운드 컬링/울림/공간감 등을 위한 오디오 엔진 FMOD, Wwise, 인공지능처리를 위한 A.I. Implant, Kynapse 등 분야별 다양한 라이브러리들이 현대에도 많이 제작되고 있다.

이런 라이브러리들은 개발하는 게임에 융합해서 사용하는 것 뿐만 아니라 현대에서 게임 엔진이라고 불리는 그 엔진들에도 융합되어 사용할 수 있으며 특히 언리얼 엔진에서 IPP(Integrated Partners Program)이라는 명칭으로 다양한 기술들이 통합되었다.

2.4. 본격적인 게임 엔진의 등장: 2000년대 중반 이후

현대의 게임 엔진은 완전한 통합 게임 개발 솔루션을 표방하며 2004년에 등장한 언리얼 엔진 3를 그 대표로 꼽을 수 있다. 언리얼 엔진 3는 엔진의 모든 기능을 커스터마이징이 가능하면서도 상호간에 유기적으로 융합되는 유연한 구조로 기술의 추가나 변형이 용이해 게임의 장르나 플랫폼에 관계없이 어떤 형태의 게임도 개발이 가능하며, 엔진 코드와 게임 코드의 완전한 분리, 필요한 기능만 선택적으로 사용 가능, 하나의 작업물에서 다양한 플랫폼으로 릴리즈, 모드 툴이나 더미 데이터의 포함 여부, 또는 별도의 모드 툴만 작성할 수 있는 한 빌드 시스템 등 하나의 엔진으로 게임 개발에 대한 모든 것이 가능함을 지향했다. 다만 미래지향적이며 새로운 개념이었던 만큼 첫 등장 후 초기 1~2년 간은 몇가지 문제점들을 가지고 있었으나 꾸준한 버전업을 통해 보완되어갔고 새로운 기술 및 툴이 도입되며 전반적인 성능이나 편의성이나 더욱 강화되었다.

언리얼 엔진 3는 프로그래머가 아닌 게임 디자이너 입장에서도 편의성을 크게 강조하기 위한 혁신성을 꾀하며 새로운 시도를 했다. 프로그래머 없이 아티스트가 셰이더를 작성할 수 있는 비주얼 머터리얼 셰이더 에디터, 프로그래머의 도움 없이 레벨의 스크립트를 작성할 수 있는 키스멧, 디자이너가 그래프 노드 기반으로 효과를 조합하는 포스트 프로세스 에디터, 사운드 큐 에디터, 실시간 조합형 파티클 에디터 캐스케이드, 실제 영화 감독의 기능 시뮬레이션 툴 마티네 등 시대를 앞선 여러가지 탁월한 기능들을 성공적으로 정착시켰다. 특히 2009년에는 UDK라는 것을 무료로 개방하고 부터 일반 사용자들에게도 게임 엔진의 저변을 확대하는 데에 크게 일조하였다.

언리얼 엔진 3는 그야말로 한 시대[4]를 지배하다시피 하며 유수의 명작과 대작 AAA급 게임부터 소규모 캐주얼, 인디, 모바일 게임까지, 게임의 규모, 장르, 플랫폼을 가리지 않고 여기도 언리얼, 저기도 언리얼, 너도 나도 언리얼인 세상을 만들어 버렸다. 언리얼 엔진 3를 사용했다고 이 엔진을 사용한 게임들의 느낌이 비슷하지도 않고 게임마다 완전히 다른 느낌으로 구현이 가능한데 초기에는 아웃풋이 다 비슷하다는 오해가 있기도 했다. 그 이유는 언리얼 엔진 항목의 언리얼 엔진 3에 대한 오해 항목 참고.

언리얼 엔진 3의 엄청난 성공 이후 기존 엔진들의 후속버전이나 신규로 등장하는 엔진들 역시 언리얼 엔진 3의 형태를 모방하여 비전 엔진 8, 토크 게임 엔진 어드벤스드, 유니진 엔진 등 다양한 엔진들이 등장했다. 그러나 워낙에 언리얼 엔진 3가 넘볼 수 없을 정도로 높은 수준이기도 하고 기타 엔진들을 사용할 메리트는 오직 가격 뿐이었는데 UDK가 등장하며 그 가격 정책에도 메리트가 사라져서 결국은 많은 게임 엔진들이 그대로 사장되었다. 언리얼 엔진 3의 엄청난 폭풍 속에서 유일하게 살아남은 것은 유니티 엔진 뿐이다.

유니티3D는 언리얼 엔진 3의 복잡성과 라이센스 비용에 대비하여 메리트를 가지고 있었고, 빠른 프로토타이핑에 유리, 에셋 스토어의 도입, 풍부한 사용자 커뮤니티를 통한 생태계 생성을 통해 소규모 인디 게임, 저예산 개발사들에게 큰 인기를 끌었다. 보통 유니티를 경쾌하고 조작성이 좋은 경차에 비유한다면 언리얼은 다재다능한 SUV에 비유한다.

이후 언리얼 엔진 4는 기존의 언리얼 엔진 3보다 훨씬 강화된 다양한 기술/기능에 더해 유니티의 강점이었던 직관성을 도입하며 역시 빠르고 꾸준한 업데이트와 사용자 피드백을 도입했다. 또한 과거 미진했던 소규모 개발자들에게 어필하기 위해 오픈 소스화와 소스 코드를 기여하는 방식으로 모두가 개발에 참여하는 정책으로 선회하고 라이센스 정책도 크게 변화시켰다.

유니티 5는 기존의 유니티의 단점을 보완하여 그래픽적으로 개선을 꾀하고 여러가지 최적화 및 개선사항을 추진하였다. 기존의 유니티가 강세를 보이던 분야인 소규모나 저사양 모바일 게임에서는 여전히 강세이나 모바일이 고사양화 되어가면서 모바일에서도 언리얼 엔진의 입지가 점점 더 커지고, 언리얼 엔진의 라이센스가 소규모 개발사에게도 매력적이게 바뀜에 따라 언리얼 엔진이 과거 유니티의 독점 분야였던 저사양, 인디, 모바일에서도 경합 중.

또한 자체적인 게임 엔진을 만들어 사내에서 돌려 쓰는 경우도 있다. EA DICE프로스트바이트 엔진이 그 대표적인 예. 한국은 로우레벨 프로그래머의 부족[5]으로 자체 엔진을 만들어 쓰는 회사는 거의 없고, 넥슨데브캣 스튜디오, 검은사막을 개발한 펄어비스 정도가 전부이다. 이마저도 넥슨은 사내에서 해당 엔진을 전사적으로 공유하는 것이 아니라 데브캣 내에서만 쓰는 중이다.

3. 기능

  • 미들웨어: 여러 응용소프트웨어와 여러 운영체제 사이를 중개하는 기능으로, 응용 소프트웨어의 관리 콘솔, 인터페이스, 데이터베이스, 모니터링 기능 등으로 구성된다.
  • 물리 엔진
  • 그래픽 렌더링 엔진
  • 애니메이션 처리
  • 쓰레드
  • 스크립트 작성
  • 애니메이션 엔진
  • 사운드 엔진
  • 게임 인공지능
  • 게임 네트워크
  • 메모리 관리

... 등등 여러 기능이 존재한다.

4. 게임 엔진 목록

당연하겠지만 이름조차도 공개되지 않은 엔진도 있어서 이게 모든 게임 엔진의 목록은 아니다. 공개/비공개의 구분은 기업은 물론 일반인도 자유롭게 접근해서 사용이 가능한가의 유무이다. 가령 데시마 엔진의 경우, 호라이즌 제로 던이나 데스 스트랜딩같은 여러 게임들에 사용 되었지만, 소니 파트너에게만 공개되어있으므로 비공개 엔진에 해당된다.

4.1. 오픈 소스 엔진

소스 코드 공개와 때에 따라 소프트웨어가 개량되는 걸 허용하는 엔진이 일부있다. '오픈 소스≠비용이 없다'는 성립할 수 없지만, 제약이 없다는 전제하에 서술한다. 오픈 소스 엔진 대부분 GitHub에 업로드하니 더 많은 엔진을 찾고 싶다면 참고할 것.#

A: 아파치 라이선스 B: BSD 라이선스 M: MIT 허가서 G: GNU 일반 공중 사용 허가서 Z: zlib 라이선스 더이상 지원이 끊긴것은 취소선 표시.
  • Amethyst - A, M
    Rust를 기반으로 한 게임 엔진이었다. 오픈 소스이기는 하나 개발이 중단되었고 후술할 Bevy 엔진을 추천하고 있다.
  • Bevy
    Amethyst의 개발 중단 이후, Amethyst가 공식으로 추천하는 Rust 기반 엔진.
  • Blender Game Engine - G
    과거 3D 그래픽 편집 툴인 Blender에 포함되었으며 2.8 이후 지원이 중단된 엔진. 후술할 UPBGE로 포크되기는 했다.
  • Cocos2d-x - M
  • Defold
    캔디 크러쉬 사가 개발사인 King이 무료로 공개하고 Defold 재단이 소스를 공개한 2D 게임 엔진으로 Lua를 사용한다. - A[6]
  • flame - M
    Flutter에 기반해 만들어진 Dart오픈 소스 게임 엔진.
  • FNA
    후술할 Monogame와 더불어 마이크로소프트가 내놓은 XNA의 오픈 소스 구현판이다.
  • GDevelop - M
    코딩 없이 블럭식으로 하는 게임 엔진. 주변 자료는 한국에서 찾기 힘들다. 입문자들을 위한 공식 위키가 있다. 한국어로도 볼 수 있지만 번역률이 저조하다. 링크
  • Godot Engine - M
    내보내기를 제외하고 하나 정도의 에디터 파일로도 게임 개발이 가능한 GDScript와 C# 기반의 게임 엔진이다. GitHub의 Game Engines 컬렉션 기준 스타 60000개 정도가 있다.
  • id Tech 2 - G
  • jMonkeyEngine - B
  • HaxeFlixel[7]
    크로스 플랫폼 지원이 수월한 오픈 소스 게임 엔진이다.[8]
    Haxe, OpenFL, Flixel등을 기반으로 제작되었으며 이 엔진이 사용된 유명한 게임으로는 Friday Night Funkin'이 있다.
  • 키리키리 엔진
  • libGDX - A
    2D/3D 게임 제작 툴. 다중 플랫폼에 제작 가능하며, 언어는 자바를 사용한다.[9]
  • Love2D - Z
  • Leggiero
    라인게임즈에서 제작한 Protocol:hyperspace Diver에서 사용된 모바일 플랫폼 전용 자체 엔진. 4월 19일에 해당 게임을 개발한 김영수 개발자와 라인게임즈의 협의로 공개되었다.
  • MonoGame
    C# 스크립트 기반. 과거 마이크로소프트가 내놓은 XNA의 오픈 소스 구현판이다. 사실 엔진이라기보단 프레임워크에 가깝다.
  • Monogatari
  • OGRE - M, G[10]
  • 오픈 3D 엔진 - A, M
    아마존 럼버야드 엔진이었다. 럼버야드의 개발이 중지된 후 리눅스 재단에서 인계해 오픈 3D 엔진이 되었다.
  • Panda3D - B
    Platform Agnostic Networked Display Architecture의 약자다. 디즈니 인터렉티브가 VR어트랙션으로 개발한 툴이 엔진으로 확대되었다. 지금은 카네기 멜런 대학교가 유지보수하고 있다.
  • Playground
    러브라이브! 스쿨 아이돌 페스티벌 등을 개발한 KLab 주식회사의 자체 엔진이다.
  • Ren'Py - M
    비주얼 노벨 제작용으로 나온 오픈 소스 게임 엔진.
  • Stride - M
    실리콘 스튜디오에서 개발한 일본산 게임 엔진. 엔진명이 2015년 12월까지는 Paradox라는 명칭이었다가 Xenko로 변경된 뒤, 2020년 4월에 Stride로 바뀌었다. 유니티와 비슷한 엔진으로 완성도가 높다. 엔진 수정은 금지였으나 2018년도부터는 MIT 라이센스 변경으로 오픈 소스가 되었고, 누구나 엔진 소스 수정을 해서 써도 상관없다.[11] 엔진 사용료는 무료며, 로열티도 받지 않는다.[12] 개발 언어는 C#을 사용한다.
  • Solar2D
    후술할 Defold와 비슷한 무료 2D 엔진. 원래 이름은 Corona SDK였으나 코로나19로 인해 Solar2D로 바뀌었다.
  • The Forge
    Confetti Interactive에서 개발한 크로스 플랫폼 렌더링 프레임워크. 스타필드에서 크리에이션 엔진 2에 채용되었다.
  • Twine - G
    비선형적인 대화형 스토리를 전달하기 위한 오픈 소스 도구.
  • UPBGE - G
    개발 중지된 Blender 게임 엔진을 포크한 프로젝트.
  • Wicked Engine
    전술한 FPS Creator의 최신 버전 GameGuru Max의 기반이 된 오픈 소스 게임 엔진.
  • Ursina Engine - M
    엔진이라기보단 게임 개발을 위한 파이썬 라이브러리에 가깝다. 신생 엔진이다 보니 잘 알려지지 않은 엔진.

4.2. 공개된 상용 엔진

  • 게임메이커 스튜디오
    요요 게임즈에서 개발한 통합 개발 환경. 2D 게임 개발에 특화되어있다.
  • 게임브리오
    그래픽 렌더링 전문 엔진.
  • 게임스파크 (Gamesparks)
    영국의 게임 서버 엔진 클라우드. 반다이 남코, 유비소프트 등이 사용하고 있다.
  • 네코노벨 엔진
  • 뒤끝(Backnd)
    한국의 게임 서버 클라우드 엔진. 구글 로그인, 애플 로그인, 영수증 검증, 랭킹, 쿠폰 등의 표준 서버 기능과 실시간 멀티플레이 기능[13]을 제공한다.
  • 락넷 (Raknet)
    캐나다의 오픈 소스 게임 서버 엔진. 한때 상용 엔진이었으나 오큘러스가 인수 후 완전 무료화해버렸다.
  • Roblox Studio
    엄밀히 말하면 로블록스 스튜디오는 게임 엔진이 아닌, 다른 게임 엔진들에서 볼 수 있는 통합 에디터다. 오직 로블록스 스튜디오를 통해서만 로블록스의 게임을 만들 수 있다.
  • 메이플스토리 월드
  • 빅월드 엔진
    빅월드 테크놀러지[14]에서 개발한 엔진. 게임 서버 엔진과 3D 엔진의 통합형 엔진이다. 중국의 많은 MMORPG 개발에 사용되었다. 워게이밍에서도 사용하는 엔진. 월드 오브 워플레인, 월드 오브 워쉽에서 사용된다.[15]
  • 소스(게임 엔진)
    밸브 코퍼레이션에서 개발한 엔진.
  • 소스 2
    밸브 코퍼레이션에서 개발한 엔진인 소스의 후속작.
  • 스카이넷 (Skynet)
    스카이넷이 아니다. 중국의 오픈 소스 게임 서버 엔진이다.
  • 어도비 플래시
    본래 그래픽 소프트웨어지만 5 버전부터 액션스크립트가 추가되어 게임 엔진으로도 사용할 수 있게 되었다. 애초부터 그래픽 소프트웨어였던 만큼 별도의 그래픽 툴 없이 자유롭게 그래픽을 만들어 사용할 수 있다. 2020년 12월 31일 이후로 Adobe가 지원을 종료해 사용이 불가능하다. 플래시 플레이어가 지원 종료된거다. 어도비 플래시의 지원이 종료되자 OpenFLHaxe를 이용해 개발 중인 게임의 포팅을 하는 사례도 있다.
  • 언리얼 엔진
    에픽 게임즈에서 개발한 상용 엔진. 세계 점유율 1위로 가장 많이 사용되고 있다. 실사 영상에 쓰이는 CG 작업용으로도 활용되고 있다.
  • 유니티 엔진
    유니티 테크놀로지에서 개발한 상용 엔진. 세계 점유율 2위로 언리얼 엔진 다음으로 가장 많이 사용되고 있다.
  • 유니진 엔진
    DirectX 11 벤치마크 중 유명 벤치마크 Heaven으로 유명한 유니진에서 만든 엔진.
  • 쯔꾸르
    일본의 KADOKAWA에서 제작한 게임 엔진. RPG 만들기가 대표적이다.
  • 크라이엔진
    크라이텍에서 개발한 엔진으로, 파크라이 시리즈 초기작에 일부 사용되고 크라이시스 시리즈에 전문적으로 사용되는 엔진. 이후 크라이텍이 범용 게임 엔진으로 라이센스를 발급해 여러 게임에서 사용되었다. 아마존 럼버야드 엔진이 크라이엔진 3을 기반으로 제작되었다. 후일 스타 엔진의 기반이 되기도 했다.
  • 테러 엔진
    슬렌더토비 시리즈의 제작사인 Zeoworks가 개발한 엔진이다.
  • 포멜로 (Pomelo)
    중국의 오픈 소스 게임 서버 엔진. 넷이즈에서 공개했다.
  • 플레이팹 (Playfab)
    로그인, 매치메이킹, 리더보드, 인앱결제 기능 뿐만 아니라 유저 매출 통계 분석 기능이 같이 제공되고 있다. 다만 실시간 멀티플레이는 포톤 클라우드에 의존하고 있다.
  • Construct: 2D 게임 제작 툴. 상용 소프트웨어이다. 윈도우 전용. 물리 엔진으로는 Box2D[16]를 사용하며 파이썬으로 스크립트 작성도 가능하다. 지금은 업데이트해서 하나 만들면 모든 플랫폼에 사용 가능하게 업데이트 되었다.
  • Game Editor: 2D 게임 제작 툴. 기본적으로는 GPL이지만 유료 라이센스를 구매하는 경우에 한해 GPL을 따르지 않는 게임 제작이 가능하다. 윈도우, macOS, 리눅스 모두 지원.
  • Evergine
    Plain concepts에서 개발한 산업용 3D 엔진.
  • FPS Creator
    FPS 제작에 특화되어 있는 오픈 소스 엔진. 자세한 것은 항목 참고.
  • Gideros: 모바일 게임 엔진. 물론 윈도우와 macOS 환경도 크로스플랫폼으로 지원한다. 한국에서는 마비노기 듀얼이 이 엔진을 채택했다.
  • id Tech 엔진
    이드 소프트웨어에서 개발한 역사 깊은 게임 엔진. 현재 버전 7까지 나왔으며 이 엔진이 쓰인 대표작은 둠 시리즈둠 리부트 시리즈, 울펜슈타인 시리즈 등등 이드 소프트웨어의 게임 IP 작품들과 베데스다 산하 개발사들의 일부 작품들이 있다. 이드 소프트웨어가 베데스다 산하 개발사가 된 뒤로 id Tech 5를 기반으로 포크되어 STEM ENGINE, VOID ENGINE 등등으로 개조, 개량되어 포크되었다. 후술할 IW 엔진, 골드 소스 엔진 등 이 id Tech에서 포크된 것이다. id Tech 4(둠 3 엔진)까지는 소스 코드까지 공개했으나[17] id Tech 5(레이지 엔진)부터는 타 회사에 라이센스를 하지 않고 있다. 그래서 사실 공개된 상용 엔진 항목과 비공개 항목에 둘 다 들어가야 하는 엔진이다.
  • SRPG Studio
  • Irrlicht 엔진
  • NeoAxis 엔진
  • Path 엔진
    버블파이터 등 대부분의 온라인 게임에 사용되었다. 참고로 그래픽 엔진이 아니다.
  • HPL 엔진
    프릭셔널 게임즈가 자체 개발한 게임 엔진. 2020년 9월 23일에 암네시아 1, 2와 페넘브라 오버츄어의 소스 코드를 공개하면서 HPL 엔진 1, 2의 소스 코드를 깃허브로 공개했다. 하지만 HPL 3이 사용된 게임들과 HPL 3을 풀지 않아서 id Tech 엔진과 같이 비공개된 엔진 목록에도 포함되는 엔진이다.
  • WOLF RPG 에디터

    • 기본적으로 프리웨어지만 일부기능이 추가된 유료판을 별도로 판매중이다.

4.3. 비공개된 엔진

5. 자체 엔진

대부분의 게임 회사들은 언리얼 엔진이나 유니티 같은 상용 게임 엔진을 사용하지만,[26] 상당수의 게임 회사들이 자체적으로 게임 엔진을 만들어서 게임 개발에 사용하고 있다. 하지만 게임 엔진을 만드는 것은 게임을 만드는 것보다 몇 배는 어려운 일이기 때문에, 자체 엔진을 갖고 있다는 것은 기술력을 입증 받는 편이며 홍보 수단이 되기도 한다. 그러나 결국 기술력에 대응되는 영역이기에 개발사의 역량에 따라 자체 엔진 역시 천차만별일 수 밖에 없다.

먼저 자체 엔진을 만드는 이유를 알아야 하는데, 가장 큰 두가지 이유는 수익생산성이다. 언리얼이나 유니티 같은 상용 엔진을 사용 하면 일정 수익 이상부터는 전체 수익의 일정 비율을 로열티로 지불하거나, 로열티 지불을 하지 않기 위해서 억 단위의 커스텀 라이센스 비용을 지불(매출이 수십억 단위로 발생하는 게임들의 경우)[27] 계약하기도 한다. 물론 그 만큼 상용 엔진을 사용해서 생산성을 챙겼으므로 게임 개발시, 어떤 엔진을 사용하느냐는 수익 예측과 절감할 수 있는 개발비를 비교하여 결정 하게 된다. 또한 상용 엔진은 결국 다른 회사에서 범용적인 게임 개발을 위해 개발한 엔진이므로, 자사에서 개발하는 게임에 맞게 기능을 추가하거나 수정하는 등의 개조 과정을 거친다. 그러나 만들고자 하는 게임이 독특하면 독특 할 수록, 많은 기능 추가와 개조를 해야 하므로 엔진을 새로 만드는 것이나 다름 없다. 그러니 결국 게임 엔진을 직접 만들게 되는 것이다.

5.1. 오래된 엔진은 성능이 떨어진다?

그렇지 않다. 오래전에 개발된 게임 엔진이라도 얼마든지 개량하고 업그레이드 해서 최신 엔진에 버금가는 성능을 만들어낼 수 있다. 물론 게임 엔진이 오래전에 개발되었을 경우 최신 기능을 지원하지 못하는 등의 문제가 발생할 수는 있다. 결국 기능을 수정하고 업그레이드하면 해결이 가능하지만 한국에 엔진을 개발할 수 있는 로우레벨 프로그래머가 거의 없으므로 불가능에 가까운 이야기. 그렇기 때문에 오래된 엔진에 대한 사람들의 인식이 좋지 못한 것이다. 게임 성능에 있어서 게임 엔진보다 개발사의 최적화 능력이 더 중요하다.

그렇다면 왜 상당수의 개발사들은 기존의 오래된 엔진을 계속 사용하려고 할까. 이는 신뢰도 때문이다. 게임 엔진은 결국 프로그램이다. 사용할 수록 마모 되는 것이 아니므로, 오래 사용된 엔진은 결국 동작에 대한 신뢰도가 확보된 프로그램이란 말과 같다. 설령 고칠 수 없는 버그가 있다 하더라도 어떤 버그가 있는지 파악되어있는 것이 낫지, 파악 조차 안된 새 프로그램은 신뢰도가 바닥이다. 새로 만든 엔진이 정상적으로 오류 없이 동작할 가능성은 매우 낮으며, 차라리 기존에 정상적으로 동작하는 엔진을 개량해서 사용하는 것이 더 신뢰도가 높기 때문이다.

5.2. 자체 엔진은 성능이 좋다?

개발사의 역량에 따라 다르다. 자체 엔진이란 해당 개발사의 현재 기술력이라고 봐도 무방한 영역이고 상용 엔진과는 다르게 개발사가 추구하는 게임 방향성에 따라 기능을 추가하거나 개조할 수 있는 권한이 있기에 개발에 이를 활용할 수 있는 장점이 있다. 자체 엔진이 성능이 좋다는 인식도 상용 엔진을 뛰어넘는 성능을 보여 준 사례가 있기 때문이고 개발사에 따라 상용 엔진보다 성능이 좋은 자체 엔진도 있다는 것은 분명하다.

국내와 중국에서는 상용 엔진의 비중이 높지만, 해외의 대형 AAA급 개발사들은 자체 엔진을 활용하는 곳도 상당하다. 락스타 게임즈RAGE, 캡콤RE 엔진, 게릴라 게임즈데시마 엔진, 유비소프트앤빌스노우드롭 엔진 등 준수한 성능을 자랑하는 자체 엔진은 꽤나 많고 이름이 붙지 않은 엔진들까지 포함하면 그 수는 훨씬 더 많다. 대표적으로 소니 산하 퍼스트 파티 개발사들이 사용하는 엔진도 대부분 각 자사의 자체 엔진들이다. 다만 이는 충분한 인력과 자원을 갖춘 특출난 예시들이고 대부분의 자체 엔진들의 실상은 이보다 훨씬 열악하다.

제대로 된 개발이나 개량을 거치지 못한 엔진은 뒤쳐지기 마련인데, 게임 엔진 개발이 가능할 정도로 다방면에 월등히 뛰어난 프로그래머는 매우 희귀하다.[28] 그렇기에 이런 인재들을 많이 확보할 수 있는 대형 개발사, 혹은 에픽게임즈나 유니티가 좋은 성능의 게임 엔진을 개발하고 유지하는데 유리한 위치에 있는 것이다.

개발사의 역량이 부족하여 자체 엔진이 발목을 잡는 경우도 있다. 대표적인 사례는 사이버펑크 2077 개발 당시에 CD PROJEKT RED가 사용했던 자체 엔진 REDengine 4. 위쳐 시리즈와 같은 세미 오픈 월드를 만들 때는 문제가 없었으나, 사이버펑크 2077와 같은 하나의 거대한 오픈월드를 만들기에는 엔진이 너무 무거웠고 출시 직후에는 엄청난 버그를 내뿜으며 평가를 땅으로 쳐박히게 만들었다.[29] 스퀘어 에닉스의 자체 엔진인 루미너스 엔진 역시 초창기에는 뛰어난 성능을 자랑했지만, 해당 엔진을 다룰 줄 아는 사람들이 많지 않아 시간이 지날 수록 스퀘어 에닉스 내에서 루미너스 엔진을 제대로 다룰 줄 아는 기술자들은 파이널 판타지 XV의 제작진으로 좁혀졌고 이 때문에 아예 이들을 루미너스 프로덕션으로 분리해 새로운 스튜디오를 만들었다. 루미너스 엔진은 파이널 판타지 XV 시절에는 어느 플랫폼에서든 뛰어난 비주얼을 유지하면서도 준수한 최적화를 보였지만, 정작 프로덕션으로 분리된 후, 계속된 업그레이드를 거치면서 점점 엔진이 무거워지며 Forspoken 개발 시점에서는 최악의 최적화를 보이며 안 그래도 최악인 작품성에서 비주얼마저 살리지 못했다.[30] 펄어비스자체 엔진 또한 검은사막 엔진의 경우, 게임 진행에 방해되는 버그가 아직 남아있는 등 크고 작은 문제가 있는데다, 나온다는 차기 자체 엔진(블랙스페이스 엔진) 기반 신작들[31]도저히 나올 기미조차 보이지 않고 있는 상황이라 역시나 미래가 불투명하다.[32]

라이센스 비용만 지불하면 되는 상용 엔진이 대세로 자리잡으면서, 이 정도의 수준을 유지하기 위해서는 에픽게임즈유니티에서 게임 엔진만을 만들기 위해 근무하는 수백~수천명의 뛰어난 인재들을 상대할 수 있을 정도로 막대한 자원을 쏟아부어야 한다. 더하여, 자체 엔진은 개발자들의 커리어(=기술 스택)에 큰 영향을 미치므로 이직이 잦은 게임 업계에서는 자체 엔진이 개발자를 구직하는 것에 악영향을 끼칠 수 밖에 없다. 따라서, 대형 게임사라고 할지라도 한계를 느끼고 퀄리티는 동등 이상인데 자원 소모는 적고 개발자 모집은 쉬운 상용 엔진을 선택하게 되는 것이다. 결국 2020년대 오면서 자체 엔진의 선천적인 한계로 인해 웬만한 초대형 개발사가 아닌 이상 AAA급에서도 갈수록 상용 엔진을 선호하고 있다.

6. 포크

다른 엔진을 개량하는 것에서 출발하여 더이상 원래 게임 엔진의 코드가 남아있지 않을만큼 개조가 많이 되었을 때 독립적인 게임 엔진의 상표권을 출원하는 경우가 있는데 이를 포크라고 부르기도 한다.

아래는 이렇게 개량의 과정을 거치면서 신규 엔진으로 포크된 사례들.
  • id Tech 2골드 소스 엔진: id Tech 2의 초기 버전인 퀘이크 1 엔진이 기원이긴 하나 퀘이크 엔진과는 엔진의 뼈대부터 다른데 그 이유는 밸브 소프트웨어가 자체 개발한 엔진 기반에 퀘이크 1 엔진 코드의 일부를 적용한 것으로서 사실상 일반적인 id Tech 2(퀘이크 1, 2 엔진) 기반의 게임들과는 그 태생이 다르며 맵툴도 퀘이크 엔진의 공식 맵 에디터인 Radiant 대신 WorldCraft를 사용한다. 그래서 처음부터 타사에 라이센스가 가능하였다.
  • id Tech 3IW 엔진: 콜 오브 듀티 개발 당시 id Tech 3의 후기 버전[33]리턴 투 캐슬 울펜슈타인 엔진을 개조하여 사용하였으며, 콜 오브 듀티 2 개발 시 콜 오브 듀티 1의 소스 코드를 바탕으로 새로운 엔진의 개발을 한 것이다. 파일 시스템 등 id Tech 3의 잔재가 여전히 약간 남아 있는 이유로 크레딧에 매번 이드 소프트웨어를 언급해주긴 하지만, 사실상 인피니티 워드의 자체 개발 엔진으로 분류되고 소유권(Proprietary)도 100% 인피니티 워드가 가지고 있다.
  • id Tech 5 → 보이드 엔진: 이드 소프트웨어의 모회사인 베데스다의 계열사 아케인 스튜디오 리옹에서 디스아너드 2를 개발하면서 id Tech를 바탕으로 고도로 커스터마이징한 엔진. PS3/Xbox 360 세대의 기술을 PS4/Xbox One 세대의 기술로 개량하였으며, 또한 전반적인 게임 시스템이 개조되었는데 스텔스와 전투를 위한 인공지능 시스템, 라이팅, 오밀조밀한 도시환경을 만들 수 있는 그래픽 렌더링을 비롯해 스토리 프레젠테이션 기능 등 모든 부분에서 중대한 향상이 이뤄졌으며 결국 id Tech 엔진 5의 80%이상을 갈아 엎고 새로운 엔진으로 탄생했다.
  • id Tech 5 → STEM 엔진: 베데스다의 또 다른 계열사인 탱고 게임웍스에서 디 이블 위딘 개발에 id Tech 5를 개량해서 사용했는데 디 이블 위딘 2를 개발하면서 id Tech 5를 개량했던 디 이블 위딘의 엔진을 또 개량해서 만든 엔진으로 위의 VOID 엔진과 마찬가지로 기본적으로 PS3/Xbox 360 세대의 기술을 PS4/Xbox One 세대의 기술로 개량하였다.
  • id Tech 6 → MOTOR: 베데스다의 또 다른 계열사인 머신 게임즈에서 울펜슈타인 2: 더 뉴 콜로서스 개발에 id Tech 6를 개량해서 사용했는데 인디아나 존스: 그레이트 서클를 개발하면서 id Tech 6를 개량했던 울펜슈타인 2 더 뉴 콜로서스의 엔진을 또 개량해서 만든 엔진으로 위의 VOID 엔진 및 STEM 엔진과 비슷한 사례에 해당하며 기본적으로 PS4/Xbox One 세대의 기술을 PS5/Xbox Series X\|S 세대의 기술로 개량하였다.
  • 크라이엔진 1 → 듀니아 엔진: 파 크라이 개발 당시 유비소프트크라이텍에게 자금을 지원하면서 파 크라이의 IP와 소스 코드 전반에 관한 소유권을 갖게 되었는데 이후 크라이텍은 유비소프트와 결별했고 유비소프트에 남은 파 크라이 1의 소스 코드(크라이엔진)를 바탕으로 파 크라이 2를 개발하면서 개량에 개량을 거듭해 원본 코드의 2~3%밖에 남지 않았고 그 결과물을 듀니아 엔진이라는 신규 엔진으로 이름지었다. 이걸 이용해서 계속 파 크라이 시리즈를 개발중이다. 하지만 폴더 구조는 크라이 엔진과 듀니아 엔진이 아직도 유사하다.
  • 크라이엔진 3럼버야드: 아마존닷컴이 자체 게임 엔진을 개발하기 위해 자금난에 처한 크라이텍에게 크라이엔진 3를 소스 코드 레벨에서 매입하고 그것을 바탕으로 새로운 엔진을 만든 것이 상기한 럼버야드 엔진이다. 초기 버전은 거의 크라이엔진 3 그대로였으나 버전업되면서 크라이엔진의 코드는 점차 삭제되고 새로운 코드로 대체될 것이라고 했는데 기본 툴 등 개발 파이프라인은 여전히 많은 비판을 받아온 크라이엔진의 형태를 그대로 유지하고 있어서 그리 좋은 평가는 받지 못하고 있다.
  • 럼버야드스타 엔진: 스타 시티즌 개발사 CIG가 스타 시티즌을 개발하기 위해서 크라이엔진을 개조한 엔진 대부분의 소스 코드를 뜯어 고쳤기 때문에 이젠 크라이엔진이라고 부를수 없다고 한다. 스타 엔진이라는 명칭 자체는 내부적인 비공식 명칭이나 스타 엔진 자체의 지적 재산권과 소유권은 CIG 것이라고 법정에서 인정받았기 때문에 거의 준 공식 명칭이자 포크된 엔진이다.
  • 럼버야드오픈 3D 엔진: 아마존이 럼버야드 개발을 포기하면서, 리눅스 재단이 이어 받아 MIT, 아파치 라이선스가 적용된 오픈 소스 프로젝트다.
  • 유니티 엔진 → StoryForge: Life is Strange 시리즈의 외전 게임을 만드는 덱 나인 게임즈에서 유니티를 기반으로 포크한 엔진이다. 하지만 이후 게임사가 유니티의 한계성을 느끼고 언리얼 엔진으로 개발 체계를 변경했다.
  • Godot Engine 3.x → Blind Squirrel Engine: 리마스터 전문 게임사인 Blind Squirrel Games가 고도 엔진 3.x를 기반으로 포크한 엔진이다. 이 엔진이 첫 사용된 소닉 컬러즈 얼티밋에서 원 저작자 표기가 되지 않아 라이선스 문제가 불거져 제작사인 Blind Squirrel Games가 사과하고 업데이트로 원 저작자 표기를 넣을 예정이다.

7. 게임 엔진을 백엔드 프레임워크로만 사용하는 경우

게임 엔진의 모든 요소를 사용하지 않고, 최신 게임 엔진을 백엔드 프레임워크(Backend Framework)로만 사용하고 실제 게임은 과거의 프로그램(엔진 포함) 그대로 사용하는 경우가 드물게 있다. 화면에 보이지 않는 뒷단의 일을 처리하는 부분만을 활용하는 경우로서, 게임 엔진의 플랫폼 지원(Win, Linux, Mac, 콘솔, 모바일 등), 비디오(OpenGL, D3D, Vulkan 같은 API 및 엔진의 기본 셰이더 등)와 오디오(OpenAL 같은 API 및 FMOD, WWISE 등의 사운드 엔진과의 융합 처리)의 출력, 키보드, 마우스, 컨트롤러 등의 입출력을 제어를 관장하는 부분 등으로만 최신 게임 엔진을 활용하는 것이다.

이런 방식을 사용하는 이유는 과거의 게임을 최신 플랫폼(최신 PC, 콘솔 등)에서 과거의 게임을 안정적으로 돌아가게 하는 것이 주목적이다. 이 경우, 실제 게임이 돌아가는 엔진은 원래 과거의 엔진에서 돌아가게 된다. 다음은 몇 가지의 사례다.
  • Mortal Kombat Arcade Kollection (2012) - Windows, Xbox 360, PlayStation 3
    2012년에 발매한 모탈 컴뱃 아케이드 콜렉션은 과거 모탈 컴뱃 1, 2, 3의 아케이드 버전을 에뮬레이터로 실행하는 게임을 윈도우와 콘솔로 발매한 게임이다. 언리얼 엔진 3를 백엔드 프레임워크로 활용하여 그래픽과 오디오 및 컨트롤러 입출력 처리 등을 담당하게 했으며, 실제 언리얼 엔진 3의 성능을 활용하여 간단한 오락실 맵 하나에 오락기 3대가 있는 맵이 하나 존재하기도 한다. 오락기를 선택하면 언리얼 엔진 3의 프레임워크 위에서 에뮬레이터가 구동된다. 최종 화면과 오디오 출력 및 컨트롤 입력 등은 언리얼 엔진 3의 렌더링 엔진 및 API(OpenGL, D3D), 언리얼 엔진 3의 오디오 엔진 및 API(OpenAL, XAudio2), 언리얼 엔진 3의 인풋 시스템에 연결되어 최종 게임을 실행하는 게이머와 상호작용이 이루어진다.
  • 둠 3: BFG 에디션에 포함된 둠 2 (2012) - WIndows, Xbox 360, PlayStation 3
    2012년에 발매한 둠 3 BFG 에디션에 포함된 둠 1, 둠 2의 실행방식은 위의 모탈 컴뱃 아케이드 콜렉션과 거의 유사하다. 둠 3 BFG 에디션이 실행되고 있는 그래픽, 오디오, 컨트롤 입출력을 바탕에 두고 그 위에서 고전 둠 프로그램(고전 둠의 렌더링 코드 그대로)이 구동되며, 데이터 파일도 둠 1, 둠 2의 WAD 파일 그대로 로딩한다.
  • 헤일로: 더 마스터 치프 컬렉션 (2015) - Windows, Xbox One, Xbox Series X|S
    2015년에 발매한 헤일로: 더 마스터 치프 컬렉션은 언리얼 엔진 4를 백엔드 프레임워크로 사용하며, 메인 메뉴의 캐릭터 커스터마이징에는 언리얼 엔진 4의 실제 그래픽 성능을 사용했고, 게임 전체에 걸친 공통 UI[34]에 언리얼 엔진 4의 UMG를 활용했다. 실제 게임은 게임별로 13개의 각기 다른 엔진[35]이 언리얼 엔진 4의 바탕 위에서 구동되며 그래픽, 오디오, 입출력 제어 등의 부분이 언리얼 엔진 4의 시스템에 연결되어 최종 게이머와 상호작용이 이루어지는 식인데 이렇게 만든 이유는, 언리얼 엔진 4를 통해 최신 윈도우와 엑스박스 플랫폼에서 안정적인 구동과, 콜렉션 전체가 하나의 통합된 틀을 갖추기 위한 용도다. 게임의 규모가 크다보니 단순히 백엔드 프레임워크로 사용되는데도 언리얼 엔진 4를 사용하게 된 것이다.
  • , 둠 2의 25주년 기념판 (2019) - Windows, Xbox One, PlayStation 4, Switch, iOS, Android
    2019년에 둠 25주년 기념으로 최신 플랫폼으로 재발매된 버전으로, 유니티 엔진을 백엔드 프레임워크로 사용하며, 실제 게임은 원래 고전 둠의 프로그램(렌더링, 게임플레이 코드 등)을 그대로 사용하고 WAD 파일을 그대로 로딩한다. 둠 3 BFG 에디션에 포함되어 구동된 것과 완전히 똑같은 방식이다. 고전 둠 관련 커뮤니티에서는 유니티 포트나 유니티 버전이라고도 불리는데, 이것은 유니티 엔진으로 처음부터 새로 개발한 게 전혀 아니고 과거의 게임 그대로 돌아가는 것이며, 단지 최신 플랫폼들을 안정적인 지원을 비교적 쉽게 이루기 위해서 최신 플랫폼 지원 용도로 유니티 엔진을 바탕으로 깔아둔 것 뿐이다.
  • 둠 64의 2020년 공식 이식판 (2020) - Windows, Xbox One, Xbox Series X|S, PlayStation 4, Switch
    Nintendo 64 전용으로 출시된 과거 둠 64를 최신 플랫폼에서 구동하기 위한 목적으로 개발사 나이트다이브 스튜디오의 KEX Engine을 백엔드 프레임워크로 사용하고, 둠 64의 과거 프로그램과 WAD 파일을 그대로 로딩하는 방식으로 구동된다.

8. 미들웨어 종류/목록

미들웨어의 종류는 그 분류도 매우 다양하고 나와있는 제품들도 매우 많다.

이런 미들웨어들은 언리얼 엔진이나 유니티 엔진 같은 게임 엔진에 컴포넌트나 플러그인 형식 또는 완전히 결합하여 사용 가능하다. 예로 PhysX 물리 엔진은 언리얼 엔진과 유니티 엔진에 기본 물리 엔진으로 탑재되어 있고 Wwise 같은 오디오 엔진은 추가 플러그인으로 결합 가능하며, 전문 AI 엔진인 Kynapse 같은 것들도 언리얼 엔진 3에 결합해서 사용한 예(메달 오브 아너 등)가 있다.

8.1. 물리 엔진

해당 문서 참고.

8.2. 사운드 엔진

  • uFMOD
  • FMOD
    Firelight Technologies Pty Ltd가 개발한 사운드 엔진.
  • ADX2
    일본의 CRI 미들웨어[37]에서 개발한 사운드 엔진이자 코덱. 이전 버전인 ADX는 사운드 엔진이라기 보다는 광디스크를 사용하는 콘솔 환경에서의 멀티 사운드 스트리밍 & 디코딩을 주요 기능으로 제공하는 미들웨어 코덱이였지만, ADX2에 와서는 총합 사운드 엔진으로써 기능이 확장되었다. 태생이 태생이니 만큼 사용하는 게임은 거의 대부분 일본산 게임이며, 특히 2010년대 일본산 모바일 게임과 PC 게임[38]에 상당히 많이 사용된다. 다만 타 사운드 엔진에 비해 성능 대비 더 좋은 최적화를 위해 음질이 16khz에서 잘린다는 단점이 있다. 모바일 기기에서의 사운드 레이턴시를 줄이기 위해 SonicSync라는 기술을 개발했고 유니티나 언리얼같은 유명 상용 엔진 뿐만 아니라 PC같은 다양한 플랫폼에도 소닉싱크를 적용할 예정이다.
  • ISACT

8.3. 모션

8.4. 기타 미들웨어

9. 관련 문서



[1] 둠 엔진, 퀘이크 엔진 등, 해당 게임의 제목이 붙인 엔진으로 불렸고, 게임 엔진이라는 말로 불리지는 않았다.[2] 자사의 게임 2개인 듀크 뉴켐 3D쉐도우 워리어, 타사의 게임인 블러드.[3] 한때 데드 스페이스 시리즈 등에 쓰이는 등 붐이 일었으나 이후 Flash의 하향세와 함께 내리막길을 걸었다.[4] 플스 3, 엑스박스 360 세대.[5] 이 문제는 C# 스크립팅을 사용하는 유니티 엔진의 점유율 확대로 인해 더욱 심화되었다.[6] 아파치 2.0 기반이지만 엄밀히는 자체 라이센스다. #[7] 사이트가 잠시 접속 불가능하다가 복구되었다.[8] Windows, Linux, macOS, 안드로이드, 어도비 플래시, HTML5 등에 크로스 컴파일 할 수 있다.[9] 단, Cocos 2d-x처럼 순수한 코딩을 해야 한다.[10] 1.6버전까지[11] 실리콘 스튜디오로부터 독립되어 더이상 실리콘 스튜디오가 이 프로그램을 지원하지 않는다. 다만, 기존에 개발을 담당했던 개발자들이 실리콘 스튜디오 업무와 별개로 유지보수 및 버전업을 해주어 프로그램 개발 생태계를 유지하기로 했다고 한다.[12] 패트론으로 후원받는 것 외에는 없다.[13] 채팅, pvp[14] 워게이밍의 자회사였으나 2022년에 라이엇게임즈에서 인수하면서 라이엇의 자회사가 되었다.[15] 워게이밍 3부작이 전부 이 엔진을 사용했지만, 월드 오브 탱크는 이후 독자 엔진으로 갈아탔다.[16] 앵그리 버드가 이 엔진을 사용하는 것으로 알려져 있다.[17] 그래서 해당 엔진을 기반으로 하는 게임 엔진이 많다.[18] 기본적으로 남아있던 크라이엔진의 소스 코드 제외[19] 화이트데이의 맵파일을 골드 소스 엔진 기반 게임에서 실행하면 오류 없이 실행된다, 다만 프롭 배치같은건 다른 시스템을 써서 완전히 불러오지는 못한다. 특이한점이라면 더미데이터로 남아있는 멀티플레이어 맵 하나를 하프라이프에서 실행한다면 무기나 사다리를 탈 수가 있다.[20] 어쌔신 크리드페르시아의 왕자: 타락한 왕의 개발에 사용된 게임 엔진.[21] 어쌔신 크리드 2, 어쌔신 크리드: 브라더후드, 어쌔신 크리드: 레벨레이션에서 사용.[22] 어쌔신 크리드 3, 어쌔신 크리드 4: 블랙 플래그, 어쌔신 크리드: 로그에서 사용.[23] 어쌔신 크리드: 유니티, 어쌔신 크리드: 신디케이트, 어쌔신 크리드 오리진, 어쌔신 크리드 오디세이, 포 아너, 레인보우 식스 시즈, 고스트 리콘 와일드랜드에서 사용.[24] 이하 P.T[25] 현재 서비스가 종료된 소드 코스트 레전드와 개발 진행 중인 Survived by유니티 엔진을 사용하였다.[26] 이 때문에 게임 개발자의 경우 재직 중인 회사가 자체 엔진을 사용하면 타 회사로 이직시 어려움을 겪을 수 있다고 한다.[27] 커스텀 라이센스의 경우에는 조건에 따라 다르지만 일반적으로 1개 프로젝트 당 약 3~5억 정도를 지불하는 대신 매출이 수십~수백억, 또는 그 이상 얼마가 나오더라도 로열티 지불이 없다. 한국/해외 대규모 온라인 게임이나 대형 콘솔/PC 패키지 게임 등은 당연히 커스텀 라이센스로 계약되며, 로열티를 지불하는 계약은 사실상 인디 게임 또는 정말 규모가 작은 소규모 개발사에나 국한되는 정도다.[28] C와 C++, 심지어는 어셈블리어로 프로그램의 밑바탕을 만들어야 되는건데 이걸 할 수 있는 괴물 프로그래머는 거의 없다.[29] 결국 새로운 위쳐 시리즈 작품을 비롯한 차기작들부터는 언리얼 엔진을 사용하는 쪽으로 노선을 바꿨다.[30] 결국 루미너스 프로덕션은 본사에 흡수되고 이 엔진의 정통은 파이널 판타지 XIV에서 쓰였던 파생 엔진이 이어나가는 거나 마찬가지인 상황이 되었다.[31] 붉은사막, 도깨비, 플랜 8.[32] 물론 붉은사막의 경우 PV 영상을 통해 여전히 훌륭한 그래픽과 물리적 상호 작용으로 전 세계 게이머의 이목을 집중하는 데에는 성공했으나 정작 메인퀘스트, 서브퀘스트 등 오픈월드 게임에 필요한 요소들은 출시 이후에 와서야 가늠할 수 있다. 게다가 펄어비스가 차기 자체 엔진(블랙스페이스 엔진) 개발에 매진하는 동안에 상용 엔진인 언리얼 엔진 5는 계속해서 크고 작은 업데이트가 이뤄지고 있는 상황이라 언젠가는 언리얼 엔진이 블랙스페이스 엔진을 따라잡거나 초월할지도 모르는 일이다.[33] 퀘이크 3 엔진(초기) → 퀘이크 3 팀 아레나 엔진(중기) → 리턴 투 캐슬 울펜슈타인 엔진(후기)[34] 마치 Xbox나 PS의 대쉬보드처럼 게임 중 어디서나 불러올 수 있는 UI 메뉴[35] 1. 헤일로 1, 2. 헤일로 2, 3. 헤일로 3, 4. 헤일로 3: ODST, 5. 헤일로 4, 6. 헤일로 리치 싱글 및 멀티, 7. 헤일로 1 애니버서리, 8. 헤일로 2 애니버서리, 9. 헤일로 1 멀티, 10. 헤일로 2 멀티, 11. 헤일로 3 멀티, 12. 헤일로 4 멀티, 13. 헤일로 리치 멀티[36] 원래 FMOD를 사용하였으나, 2014년에 교체하였다.[37] 원래 이 회사는 과거 세가의 모기업이었던 CSK의 소프트웨어 연구개발 계열 자회사 중 하나였다(CRI라는 이름도 구 사명이었던 CSK 기술 연구소에서 따온 것). 그래서 ADX도 그렇고 이 회사에서 개발한 기술들은 모두 세가 하드웨어 독점으로만 제공했으나, 세가가 하드웨어 사업에서 철수, 구조조정, 사미와 합병하는 과정에서 해당 기업도 CSK에서 분리. 현재는 세가와 남남인 기업이 되었다. 그래도 여전히 세가 게임에서 많이 사용중이다.[38] 모바일은 페이트 그랜드 오더, 데레스테, 밀리시타, 방도리 등등, PC는 판타시 스타 온라인 2


파일:CC-white.svg 이 문서의 내용 중 전체 또는 일부는 문서의 r259에서 가져왔습니다. 이전 역사 보러 가기
파일:CC-white.svg 이 문서의 내용 중 전체 또는 일부는 다른 문서에서 가져왔습니다.
[ 펼치기 · 접기 ]
문서의 r259 (이전 역사)
문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

문서의 r (이전 역사)

분류