Hosting and domain costs until October 2024 have been generously sponsored by dumptruck_ds. Thank you!

FTEQW File Formats

From Quake Wiki

This is a list of all the file formats that can be used by FTEQW and some of the other commonly used engines. The engines are: FTEQW, DarkPlaces, Quakespasm, Quakespasm Spiked, VK Quake, Mark V, and EZ-Quake.

Model and/or Animation[edit]

Format Ext FTE DP QS QSS VK MkV EZ Notes
Quake1 (.mdl) Y Y Y Y Y Y Y Echo: These became known as Alias models, even though that‘s not correct. John Carmack always called these Alias models, so the name stuck. Squirmy when animating; maximum one texture per skin.
Quake2 (.md2) Y Y N N N N N Even squirmier than QMDL when animating, due to having per-frame scale and origin. Maximum one texture per skin.
Quake3 (.md3) Y Y N Y N N Y Echo: Support of md3 may be limited in some engines, such as tags and animations. Still squirmy when animating, but has much higher precision than Quake1 MDL or Quake2 MD2, so vertex swimming is only noticeable up close.
Inter-Quake Model (.iqm) Y Y N Y N N N Echo: The best choice for creating models & animations in FTE and DP. Skeletal animation support for 256 joints. Vertex animation and blendshapes are not supported, skeletal only.
Extended Inter-Quake Model (.vvm) Y N N N N N N Superset of iqm models that adds additional info, allowing for animation events, separate hitmesh, geomsets, and region-specific feedback/damage.
DarkPlaces Model (.dpm) Y Y N N N N N No framegroups/animations (just individual poses).
Unreal Interchange Model (.psk) Y Y N N N N N Slow to load (although easy to export). the separate .psa files contain the animation data in an external file.
GLTF2 / GLTF2 Binary (.gltf / .glb) Y N N N N N N Slower to load than iqm files, but more widely exportable and supports PBR materials. The binary .glb files generally embed all textures in a single file. FTE supports most of the spec, though does not fully conform in a few edge cases (which will result in warning messages). Additional format extensions may cause the model to fail to load.
Zymotic Model (.zym) Y Y N N N N N Only one bone influence per vertex.
MD5 Mesh (.md5mesh) Y N N Y Y N N Has no animation data.
MD5 Anim (.md5anim) Y N N Y Y N N Has no mesh data.
QuakeForge 16bit Alias (.md16) Y N N N N N N Echo: The Alias model format (Quake1 .mdl) with 16-bit vertices. This gives models more precision, the vertices will show up in-game positioned more accurately.
Half-Life (GoldSrc) (.mdl) Y N N N N N N Vertex animation and blendshapes are not supported, skeletal only.
Toolchain license issues.
Hexen2MP (.mdl) Y N N N N N N Only used in the missionpack.
External Anim (.???) Y N N N N N N Text format that allows extracting the animation data from numerous models, to combine with extracted mesh data. This allows you to use eg md5 models without using skeletal objects(csqc).
FTE Heightmap Map (.hmp) Y N N N N N N Echo: This format is for creating terrains in FTE, can be used by mappers to make large sandbox-style game levels. Sections are streamed in from disk as required. Models and bsps can be embedded as desired. Entities are really messy right now.
Wavefront (.obj) Y Y N N N N N DP can also use .obj as a map if you provide a .ent file.
Alias Triangle (.tri) N N N N N N N Echo: This is the real Alias model format. Obsolete, but old files exist. The original Quake1 models were converted from .tri to .mdl with the modelgen utility. Listed for informational purposes, no point to load it in engine.

Map Source File (load a .map without compiling it)[edit]

Format Ext FTE DP QS QSS VK MkV EZ Notes
Quake1 (.map) Y N N N N N N Texture alignment+size is dependant upon correct texture sizes. Replacement textures will generally appear zoomed in/wrong - texture wads are expected to follow halflife rules (ie: path is ignored, the wad must be id1/*.wad or moddir/*.wad). Don't expect good performance, especially with rtlights.
Quake2 (.map)  ? N N N N N N
Quake3 (.map) Y N N N N N N FTE will display patches only using their control points.
Quake3 Brush-Plane (.map) N N N N N N N An alternative way of expressing texture coords.
Valve220 (.map) Y N N N N N N valve's 220 format allows more texture coords to be expressed more precisely.

Map Data File[edit]

Format Ext FTE DP QS QSS VK MkV EZ Notes
Quake1 (.bsp) Y Y Y Y Y Y Y BSP29 Quake retail-release.
Hexen2 (.bsp) Y N N Y N N N Expect palette+hull issues when running in quake.
Quake1 2PSB (.bsp) Y Y Y Y Y  ?  ? This format is now obsolete, don‘t use it. BSP2 replaced it.
Quake1 BSP2 (.bsp) Y Y Y Y Y Y Y All 16bit limits increased to 32bit (with the 16bit coords becoming floats).
Quake2 (.bsp) Y Y N N N N N Yellow.
Quake3 (.bsp) Y Y N N N N N So curvacious!
Half-Life (GoldSrc) (.bsp) Y Y N N N N Y Toolchain license issues.
Qfusion (.bsp) Y N N N N N N
SOF2 (.bsp) Y N N N N N N Raven rbsp: Raven changed two lumps in the q3 format in SoF2/JK2/JA (brush sides and draw surfaces)
JK2 (.bsp) Y N N N N N N Raven rbsp: Raven changed two lumps in the q3 format in SoF2/JK2/JA (brush sides and draw surfaces)
JA (.bsp) Y N N N N N N Raven rbsp: Raven changed two lumps in the q3 format in SoF2/JK2/JA (brush sides and draw surfaces)
Quake1 Prerelease (.bsp) Y N N N N N N BSP28 Quake pre-release.
Quake1 Alpha/Pre-Alpha (.bsp) N N N N N N N BSP27 and earlier. Quake alpha-release.
Quake Live (.bsp) N Y N N N N N Spike: This is essentially a Q3 BSP w/ an additional lump for advertisements.
Wavefront (.obj) Y Y N N N N N LH: DP can use .obj as a map if you provide a .ent file with it. You can also use it as a standard model in DP.
BSPX lump: RGBLIGHTING (.bsp) Y N N Y N N Y Allows embedding rgb lighting directly into a q1 bsp without needing an external .lit file. Compile with ericw's light util using the -bspxlit argument. Also supported by ezquake, so be sure to use this for any quakeworld-centric map as the lighting will survive being auto-downloaded.
BSPX lump: LIGHTING_E5BGR9 (.bsp) Y N N Y N N N Shared-exponent floats are slightly larger but allow for more precision as well as significantly more overbrighting. QSS will convert it to ldr on load.
BSPX lump: LIGHTINGDIR (.bsp) Y N N N N N N Equivelent to a .lux file, but embedded into the bsp itself. Compile with ericw's light util using the -bspxlux argument.
BSPX lump: LMSHIFT, LMOFFSET, LMSTYLE (.bsp) Y N N Y N N N Allows per-surface lightmap scaling, for higher resolution lightmaps. This is why .lit2 was basically abandoned.
BSPX lump: VERTEXNORMALS (.bsp) Y N N N N N N Allows rtlights+specular lighting effects to respect 'phong'/edge smoothing. ericw stripped support for this from his tool.
BSPX lump: BRUSHLIST (.bsp) Y N N N N N N Allows an engine to support collisions using arbitrary sizes. Compile with ericw's qbsp using the -wrbrushes argument.

Map Misc. Data File[edit]

Format Ext FTE DP QS QSS VK MkV EZ Notes
Quake1 external lightmap (.lit) Y Y Y Y Y Y Y This is a hack to allow colored lighting in Quake1 maps.
Entity Replacement (.ent) Y Y Y Y Y Y Y LH: DP can use .obj as a map if you provide a .ent file with it. Can be used to fix z-fighting bugs, fix entities in walls, remove quad in small deathmatch maps, etc.
LightDirectionMap (.dlit) Y Y N N N N N LH: allows bumpmapping with lightmaps. Spike: .lux and .dlit are the same thing. Rename the file extension if you want.
DeluxeMap (.lux) Y N N N N N N Echo: DP doesn‘t load .lux so use .dlit the file format is identical.
RealtimeLights (.rtlights) Y Y N N N N N Spike: FTE supports spotlight rtlights and spinning static lights, DP doesn't, which may make format conversions necessary. You can use the spinning light w/ a cubeMap to make it fancy.
Vis Patches (.vis) Y N N N Y Y N These files override the vis data of maps, allowing for transparent water on vanilla maps.

Texture File[edit]

Format Ext FTE DP QS QSS VK MkV EZ Notes
Quake's gfx.wad (.wad) Y Y Y Y Y Y Y
Lump (.lmp) Y Y Y Y Y Y Y
Truevision Targa (.tga) Y Y Y Y Y Y Y
Picture Exchange Image (.pcx) Y Y Y Y Y Y Y
Portable Network Graphics (.png) Y Y N Y N N Y Can be disabled in EZQuake depending on compile settings.
Joint Photograph Exports Group Image (.jpg) Y Y N Y N N Y Can be enabled/disabled in EZQuake depending on compile settings.


Quake2 Wall Texture (.wal) Y Y N N N N N
Quake WAD2 (.wad) Y Y N N N N Y
Half-Life (GoldSrc) WAD3 (.wad) Y Y N N N N Y Like WAD2, but with per-texture palette

Required for halflife bsp support.

DirectDraw Surface (.dds) Y Y N N N N N Spike: FTE supports this for bc1-7/dxt stuff. Allows for properly compressed textures for lower gpu memory usage. May have issues with npot texture mip sizes in opengl engines.
Khronos Texture (.ktx) Y N N N N N N Spike: FTE supports this for bc1-7/dxt/etc1/etc2/hdr. Allows for properly compressed textures even with npot textures for lower gpu memory/bandwidth use.
Microsoft Bitmap (.bmp) Y N N N N N N Not scanned for by default (but can be named explicitly).
Microsoft Icon (.ico) Y N N N N N N Not scanned for by default (but can be named explicitly).
Portable Floatmap (.pfm) Y N N N N N N Simple HDR format. Not scanned for by default (but can be named explicitly).
Gimp document (.xcf) Y N N N N N N HDR or LDR. Many things are not supported, although layers are. Not scanned for by default (but can be named explicitly).
Photoshop Document (.psd) Y N N N N N N Only the base plane will load. Not scanned for by default (but can be named explicitly).
'Radiance' HDR. (.hdr) Y N N N N N N HDR RGBE format. Not scanned for by default (but can be named explicitly).
ILM OpenEXR (.exr) Y N N N N N N HDR format. Requires external libIlmImf library. Not scanned for by default (but can be named explicitly).

Sprite File[edit]

Format Ext FTE DP QS QSS VK MkV EZ Notes
Quake1 Sprite (.spr) Y Y Y Y Y Y Y QS is still buggy with regard to framegroups (fixed in QSS+FTE+DP). Quake defines more types of sprite than the number of sprites it actually shipped with.
Quake2 Sprite (.sp2) Y Y N N N N N Sprite frames stored in separate PCX files; fewer features than Quake 1 and Half-Life sprites.
Quake1 Sprite 32bit (.spr32) Y Y N Y N N N True color variation of Quake 1 SPR
Half-Life (GoldSrc) Sprite (.spr) Y Y N N N N N Like Quake 1 sprites, but with dedicated color palette, and additional translucency modes. No toolchain license issues, unlike most GoldSrc formats.

more info

Particle File[edit]

Format Ext FTE DP QS QSS VK MkV EZ Notes
FTE Particles (.cfg) Y N N Y Y N N Language spec: https://sourceforge.net/p/fteqw/code/HEAD/tree/trunk/specs/particles.txt

example: https://sourceforge.net/p/fteqw/code/HEAD/tree/trunk/engine/partcfgs/

DarkPlaces Particles (.txt) Y Y N Y N N N Echo: It‘s easy to convert a DarkPlaces particleinfo.txt file to be used with FTE, but you must do it manually at the console. FTE and QSS can directly use these only when explcitly configured to do so - either r_particledesc effectinfo or a mod that explicitly calls particleeffectnum("effectinfo.something")

Shader File[edit]

Format Ext FTE DP QS QSS VK MkV EZ Notes
Quake3 (.shader) Y Y N N N N N Technically a list of materials, rather than a true shader.
Q3 shaders were not designed with rtlights in mind but otherwise work correctly in FTE (and are quite explicit, so can result in other effects getting disabled). Not using the fte_program term can result in lower performance in FTE - especially for skeletal models. DP supports single stage shaders only. Many shaders from Q3 will not work in DP due to the multiple stages, and shaders designed only for DP are malformed as far as Q3+FTE are concerned (ie: expect weirdness).
GLSL (.glsl) Y N N N N N N Echo: FTE allows you to create shaders with GLSL. DP only uses GLSL internally. Use Q3 bsp & shader for compat w/ both.

Script File[edit]

Format Ext FTE DP QS QSS VK MkV EZ Notes
Quake Config (.cfg) Y Y Y Y Y Y Y

Sound Effect File[edit]

Format Ext FTE DP QS QSS VK MkV EZ Notes
Waveform (.wav) Y Y Y Y Y Y Y DP+FTE support stereo wav files, QSS will average the channels and load game sounds as mono. FTE supports float wavs, the others do not.
Ogg Vorbis (.ogg) Y Y N Y N N N QS only supports oggs for music, not game sounds.
Ogg Opus (.opus) ffmpeg N N Y N N N QS only supports opus for music, not game sounds. FTE can load this audio formats via its ffmpeg plugin (and pretty much any other too).
MPEG 2 layer 3 (.mp3) Win / ffmpeg N N Y N N N FTE can use MP3 as a sound effect on windows, or via ffmpeg on other systems.

Music Track File[edit]

Format Ext FTE DP QS QSS VK MkV EZ Notes
CD Audio (none) Y Y N N N N N SDL2-based engines cannot support cd audio, and are likely to no longer support the 'cd' command too. FTE requires -cdaudio commandline arg, or 'cd on' arg to actually enable it.
Waveform (.wav) Y Y Y Y Y N N This is specific to MUSIC playback (hence some Ns here). FTE supports float wavs, the others do not. All supporting engines also support stereo wavs, which isn't necessarily also true for game sounds.
Ogg Vorbis (.ogg) Y Y Y Y Y N N QS only supports oggs for music, not game sounds. MkV only plays ogg vorbis music when the files are misnamed as '.mp3', and is dependant upon system codecs, and cannot be inside a pak, so basically doesn't play them. They're otherwise the most widely supported compressed music format.
Ogg Opus (.opus) ffmpeg N Y Y Y N N QS only supports opus for music, not game sounds. FTE can load this audio formats via its ffmpeg plugin. MKV only plays ogg opus music when the files are misnamed as '.mp3', and is dependant upon system codecs, and cannot be inside a pak.
MPEG 2 layer 3 (.mp3) Win / ffmpeg N Y Y Y Y N Engines will load id1/music/*.ogg in preference to mod/music/*.mp3, so this is only useful for users ripping their own fake-track audio. QS only supports mp3s for music, not game sounds. MKV cannot play mp3s inside pak files. FTE can fall back on its ffmpeg plugin for playback on non-windows.
FLAC (.flac) ffmpeg N Y Y Y N N MKV only plays ogg flac music when the files are misnamed as '.mp3', and is dependant upon system codecs, and cannot be inside a pak. So basically doesn't support it.

Video File[edit]

Format Ext FTE DP QS QSS VK MkV EZ Notes
Video (.avi) Y Y N N N N N LH: supported w/ libavw also known as ffmpeg.
Video (.mpg) Y Y N N N N N LH: supported w/ libavw also known as ffmpeg.
Video (.mpeg) Y Y N N N N N LH: supported w/ libavw also known as ffmpeg.
Video (.mp4) Y Y N N N N N LH: supported w/ libavw also known as ffmpeg.
Video (.mpeg4) Y Y N N N N N LH: supported w/ libavw also known as ffmpeg.
Video (.mjpeg) Y Y N N N N N LH: supported w/ libavw also known as ffmpeg.
Video (.mkv) Y Y N N N N N LH: supported w/ libavw also known as ffmpeg.
Video (.webm) Y Y N N N N N LH: supported w/ libavw also known as ffmpeg.
Video (.bik) Y Y N N N N N LH: supported w/ libavw also known as ffmpeg.
Quake3 Video (.roq) Y Y N N N N N Directly supported in FTE. LH: supported w/ libavw also known as ffmpeg.
Quake2 Video (.cin) Y Y N N N N N Directly supported in FTE. LH: supported w/ libavw also known as ffmpeg.
Video (.flv) Y Y N N N N N LH: supported w/ libavw also known as ffmpeg.
Video (.wmv) Y Y N N N N N LH: supported w/ libavw also known as ffmpeg.
Video (.ogv) Y Y N N N N N LH: supported w/ libavw also known as ffmpeg.
Video (.dpv) N Y N N N N N LH: a weird little format I made ages ago for a commercial project that needed ultra-low CPU usage.
Video (.jam) N Y N N N N N LH: videos from the game "Blood Omen: Legacy of Cain" for use in the DP port "Blood Omnicide: Legacy of Cain." Requires an original playstation game disc.

Pathfinding[edit]

Format Ext FTE DP QS QSS VK MkV EZ Notes
Quake3 (.aas) Y N N N N N N Spike: Strictly in there for Q3 bots.
Way (.way) Y N N N N N N Text files that follow a specific syntax.

File Archives[edit]

Format Ext FTE DP QS QSS VK MkV EZ Notes
Quake PAK (.pak) Y Y Y Y Y Y Y Uncompressed.
Quake III PK3 (.pk3) Y  ? N Y  ?  ?  ? Actually a renamed ZIP file.

Can use Deflate compression, or be uncompressed.