Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/astrochili/defold-trenchfold
A toolkit to design a level in TrenchBroom and export it to Defold
https://github.com/astrochili/defold-trenchfold
3d defold leveldesign trenchbroom
Last synced: about 7 hours ago
JSON representation
A toolkit to design a level in TrenchBroom and export it to Defold
- Host: GitHub
- URL: https://github.com/astrochili/defold-trenchfold
- Owner: astrochili
- License: mit
- Created: 2022-05-29T14:17:21.000Z (over 2 years ago)
- Default Branch: master
- Last Pushed: 2025-01-01T20:44:03.000Z (20 days ago)
- Last Synced: 2025-01-19T20:33:50.208Z (2 days ago)
- Topics: 3d, defold, leveldesign, trenchbroom
- Language: Lua
- Homepage:
- Size: 511 KB
- Stars: 56
- Watchers: 2
- Forks: 7
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-defold - TrenchFold
README
![logo](https://user-images.githubusercontent.com/4752473/179576684-bea03ccb-0b52-4346-819a-927e4d5d3c0e.jpg)
# TrenchFold
[![Release](https://img.shields.io/github/v/release/astrochili/defold-trenchfold.svg?include_prereleases=&sort=semver&color=blue)](https://github.com/astrochili/defold-trenchfold/releases)
[![License](https://img.shields.io/badge/License-MIT-blue)](https://github.com/astrochili/defold-trenchfold/blob/master/LICENSE)
[![Website](https://img.shields.io/badge/website-gray.svg?&logo=)](https://astronachos.com/)
[![Mastodon](https://img.shields.io/badge/mastodon-gray?&logo=mastodon)](https://mastodon.gamedev.place/@astronachos)
[![Twitter](https://img.shields.io/badge/twitter-gray?&logo=twitter)](https://twitter.com/astronachos)
[![Telegram](https://img.shields.io/badge/telegram-gray?&logo=telegram)](https://t.me/astronachos)
[![Buy me a coffee](https://img.shields.io/badge/buy_me_a_coffee-gray?&logo=buy%20me%20a%20coffee)](https://buymeacoffee.com/astrochili)๐ผ Also in this series:
- ๐ [Kinematic Walker](https://github.com/astrochili/defold-kinematic-walker)
- ๐ฅ [Operator](https://github.com/astrochili/defold-operator)
- ๐ [Illumination](https://github.com/astrochili/defold-illumination)
- ๐ง [Blockout Textures](https://github.com/astrochili/blockout-textures)## Overview
This is a kit of game configuration files and importing scripts to design your level with [TrenchBroom](https://trenchbroom.github.io/) and export it to [Defold](https://defold.com/) as the collection.
TrenchBroom was originally created to design Quake-format levels, but thanks to its flexible game configurations it's suitable for any other game with low-polygon level geometry. It's cross-platform, has a great [manual](https://trenchbroom.github.io/manual/latest/) and usability.
๐ฎ [Play HTML5 demo](https://astronachos.com/defold/trenchbroom).
๐ฌ [Discuss on the forum](https://forum.defold.com/t/trenchfold-trenchbroom-extension-for-defold/71284).
๐งช Look at [Retro Texture Pack](https://little-martian.itch.io/retro-texture-pack) by [Little Martian](https://little-martian.dev/) used in the demo.
## Features
- [x] Convert level geometry to meshes and collision objects.
- [x] Use flag textures and checkboxes to define faces behavior.
- [x] Place triggers, kinematic or dynamic bodies.
- [x] Convert entities to game objects.
- [x] Attach file components to your entities.
- [x] Set custom entity properties and read them from the game logic.
- [x] Define areas and handle their coordinates in scripts.
- [x] Run importing with the editor script or the standalone lua module.
- [x] Expand the game configuration file with your own classes.
- [ ] Request by [adding an issue or contribute](https://github.com/astrochili/defold-trenchfold/issues).## Running the Example
To run the example project, you first need to import the example map.
With the project open in Defold, right click on the [level.map](https://github.com/astrochili/defold-trenchfold/blob/master/example/maps/level/level.map) file then click on `Convert Map to Collection`. This will create a variety of folders and files next to the `.map` file. You can now build and run the example.
## Install
1. Add link to the zip-archive of the latest version of [defold-trenchfold](https://github.com/astrochili/defold-trenchfold/releases) to your Defold project as [dependency](http://www.defold.com/manuals/libraries/).
2. Copy the `trenchfold/assets/trenchbroom/games/Defold` folder according [this instruction](https://trenchbroom.github.io/manual/latest/#game_configuration_files) to TrenchBroom user data folder.
3. Set your game project path as the game path in TrenchBroom preferences when creating the first map.
4. Setup `textel_size` and `material` in the [worldspawn](#worldspawn) entity.## Import
### Editor Script
Find your `.map` file in the resources pane of the editor and right click on it and select the `Convert Map to Collection` action. It does the magic and creates the collection file and all the components files: buffers, meshes, convexshapes, collisionobjects and some scripts.
### Lua Module
There is also the `trenchfold/cli.lua` module to run the import script outside the editor. Just pass it two arguments - `relative/map_folder` and `map_name`.
### VS Code
There is a working example of launch configuration in [`.vscode/launch.json`](.vscode/launch.json). It launches `trenchfold/cli.lua` with the `/example/maps/level` map by using [local-lua-debugger](https://marketplace.visualstudio.com/items?itemName=tomblind.local-lua-debugger-vscode). Requires Lua or LuaJIT to be installed on your computer.
### TrenchBroom
You can create a [compilation profile](https://iroom.github.io/manual/latest/#compiling_maps) inside TrenchBroom with the `Run Tool` step to run [cli.lua](#lua-module). Requires Lua or LuaJIT to be installed on your computer.
## Textures
![](https://user-images.githubusercontent.com/4752473/179556704-78346b90-569b-419d-a5b1-e3ed35555ab4.png)
The game configuration includes marking textures at `flags/textures`. They are handled by the exporting script to provide specific behaviour to the faces without normal textures.
### unused
This face will be skipped when exporting.
Use it to remove useless faces from the geometry.
### clip
Creates a collision object without texture.
Use it to create invisible walls and useful collision geometry.
### trigger
Creates a trigger collision object.
### area
Doesn't create collision objects but its vertices positions will be sent to the object with the `init_area` message.
Use it to process the area programmaticaly.
## Flags
There are few content flags in the face properties.
### ghost
The face isn't solid and doesn't generate a collision object vertices.
Use it on objects that can be passed through or that the player will never reach.
### separated
The face generates a separate plane collision object.
A rare use case is when you have a wall corner with two solid faces and you don't want to create a triangular prism collision shape on its vertices.
## Entities
![](https://user-images.githubusercontent.com/4752473/179557292-05914789-7700-4f4b-931c-51fd5961bf98.png)
There are brush entities and point entities. The difference is that a brush entity contains geometry brushes, while the point entity has only an origin position and rotation.
### worldspawn
The default entity for all the geometry outside of the other entities. Also has some general settings of exporting.
- `textel_size` โ how much Trenchbroom grid units are equal to one unit in Defold metrics.
- `material` โ the relative path to the material that will be used for generated meshes by default.
- `textureN` โ path to the texture where `N` is number from `1` to `7`. See [texture path patterns](#texture-path-patterns).
- `physics_*` โ collision object properties used by default.### static*
A brush entity with the static collision type. The only reason to use it is to attach components and set properties because the `worldspawn` is static by default. To use [areas](#area) or destroy parts of the level, e.g.
- `id` โ the identifier of the game object.
- `#component_id` โ the relative path to the file component that will be attached to this game object as `component_id`.
- `#component_id.property` โ the script component property override.
- `material` โ the relative path to the material that will be set in generated meshes.
- `textureN` โ path to the texture where `N` is number from `1` to `7`. See [texture path patterns](#texture-path-patterns).
- `physics_*` โ collision object properties related to static collision type.### trigger*
To be fair, triggers are created by the [trigger](#trigger) texture, not the entity. But you also need to put scripts and parameters on this trigger, so which is what this entity is for.
If you place brushes with normal textures to this entity they also become triggers.
- `id` โ the identifier of the game object.
- `#component_id` โ the relative path to the file component that will be attached to this game object as `component_id`.
- `#component_id.property` โ the script component property override.
- `physics_*` โ collision object properties related to trigger collision type.### kinematic*
A brush entity with the kinematic collision type. Use it for moving platforms or sliding doors, for example.
- `id` โ the identifier of the game object.
- `#component_id` โ the relative path to the file component that will be attached to this game object as `component_id`.
- `#component_id.property` โ the script component property override.
- `material` โ the relative path to the material that will be set in generated meshes.
- `textureN` โ path to the texture where `N` is number from `1` to `7`. See [texture path patterns](#texture-path-patterns).
- `physics_*` โ collision object properties related to kinematic collision type.### dynamic*
A brush entity with dthe ynamic collision type. This could be, for example, a crate that the player can move.
- `id` โ the identifier of the game object.
- `#component_id` โ the relative path to the file component that will be attached to this game object as `component_id`.
- `#component_id.property` โ the script component property override.
- `material` โ the relative path to the material that will be set in generated meshes.
- `textureN` โ path to the texture where `N` is number from `1` to `7`. See [texture path patterns](#texture-path-patterns).
- `physics_*` โ collision object properties related to dynamic collision type.### go
This is a point entity to add a game object without meshes and collision objects. You can attach any file components to it or replace it with you `.go` file.
- `origin` โ the position of the game object that defined automatically when you place it.
- `angle` โ the Y-axis rotation of the game object that defined automatically when you rotate it.
- `rotation` โ X, Y and Z-axis rotation of the game object. Y-axis will be ignored if the `angle` property exists.
- `id` โ the identifier of the game object.
- `go` โ the relative path to the `.go` file that should replace the entity.
- `#component_id` โ the relative path to the file component that will be attached to this game object as `component_id`. Ignored if the `go` property exists.
- `#component_id.property` โ the script component property override.### illumination, light_point, light_spot
These are helpers for placing ๐ก [Illumination](https://github.com/astrochili/defold-illumination) objects on the map. Don't forget to fill the `go` property with default value.
## Texture Path Patterns
The `textureN` property allows to set additional material textures 1-7. The next patterns are available:
- `/path/to/texture.png` โ a specific texture.
- `/path/to/prefix_*_suffix.png` โ a specific path where * is texture0 original name.
- `/path/to/alternative/*` โ a specific folder with the same texture file name.
- `prefix_*_suffix.png` โ the same folder.
- `prefix_*_suffix` โ the same folder and extension.## Custom Properties
All the custom properties will be a part of the script component with the `properties` identifier that attached to the game object. These properties can be accessed in runtime by calling `go.get()`.
```lua
go.get('#properties', 'property')
```### bool
The values `true` and `false` are converted to boolean.
### number
The value which can be handled with `tonumber()` is converted to number.
If the number is flags value then you can parse it with `utils.flags_from_integer(value)` from the `trenchfold/utils/utils.lua` module.
### vectors
- Value `x y` is converted to `math.vector3(x, y, 0)`.
- Value `x y z` is converted to `math.vector3(x, y, w)`.
- Value `x y z w` is converted to `math.vector4(x, y, z, w)`.### *url
Property ending with `url` is converted to `msg.url('value')`.
### hash
Any other string property is converted to `hash 'value'`.
# Credits
- [TrenchBroom](https://trenchbroom.github.io/) by [Kristian Duske](https://twitter.com/kristianduske).
- [Retro Texture Pack](https://little-martian.itch.io/retro-texture-pack) by [Little Martian](https://little-martian.dev/).