Text-based texture UI and Rasterizer.
TextUR is a terminal-based editor for text-based textures or images.
This is a tool for generating textures to be used with DungGine.
 
- Load existing texture : ./textur -f <filename>.
- Create new texture or overwrite existing texture : ./textur -f <filename> -s <num_rows> <num_cols>.
- Trace over another texture : ./textur -f <main_texture_filename> -t <trace_texture_filename>.
- Convert texture made up of bright textels from the textel presets in TextUR to a corresponding dark texture which then can be used for rendering shadows in e.g. DungGine. The program exits when conversion is completed :./textur -f <source_texture_filename> -c <target_texture_filename>.
- WASD(lower case) or arrow keys : navigates the cursor or selects a textel preset in the textel menu. When in the textel menu, left and right (or- Aand- D) scrolls from material to material for quicker navigation among the different textel presets.
- SHIFT + WASD(upper case) keys : scrolls the texture page-wise.
- Space : enter selected textel preset under cursor.
- Z: undo.
- SHIFT + Z: redo.
- C: clear textel under cursor.
- V: toggle drawing of vertical coordinates.
- H: toggle drawing of horizontal coordinates.
- SHIFT + V: toggle drawing of vertical guide line from the horizontal coordinate axis.
- SHIFT + H: toggle drawing of horizontal guide line from the vertical coordinate axis.
- -: toggle hide/show textel presets menu.
- X: export (save) work to current file.
- B: brush-stroke. Forms a circle, filled with the currently selected textel preset.
- SHIFT + B: big brush-stroke.
- R: randomized brush-stroke. Same as the- Bkey, but fills the circle with textels according to a normal random distribution. You can re-generate until you get the desired result.
- SHIFT + R: randomized big brush-stroke. Same as the- SHIFT + Bkey, but fills the circle with textels according to a normal random distribution. You can re-generate until you get the desired result.
- F: fill screen. Fills the texture with the currently selected textel preset where the bounding box of the screen is currently located over the texture.
- P: pick a textel from under the cursor and hilite the corresponding preset in the menu.
- L: show location of cursor.
- G: goto new cursor location. Press backspace to clear the last digit, press tab to toggle between R and C coordinate fields and press enter to confirm. Pressing- Gagain toggles the input box.
- T: toggle show/hide of tracing texture.
- I: toggle inverted textels (i.e. toggle between dark and bright textel presets).
- M: toggle show/hide of material id:s.
- Q: quit.
Add a file named custom_textel_presets.
The file format looks like this:
'<normal-char>', <normal-fg-color>, <normal-bg-color>, <normal-material>
'<shadow-char>', <shadow-fg-color>, <shadow-bg-color>, <shadow-material>
<textel-preset-name>
'<normal-char>', <normal-fg-color>, <normal-bg-color>, <normal-material>
'<shadow-char>', <shadow-fg-color>, <shadow-bg-color>, <shadow-material>
<textel-preset-name>
...etc...
So e.g.
'%', Magenta, Cyan, 28
'%', DarkMagenta, DarkCyan, 28
Magic Stone
produces the following textel preset at the end of the list:
 
Look in the source code for which material number that is appropriate to use for your custom presets.
 
 
 
 
 
 
 
 
 
Bright mode textels (normal mode):
 
Dark mode textels (shadow mode):
 
Dark mode texture (shadow texture):
 
Unsaved changes indicator:
 
Confirmation screen for attempting to quit while there are unsaved changes:
 
Custom textel "Magic Stone":
 
- Small brush stroke using Bkey (upper left corner).
- Big brush stroke using SHIFT + Bkey (lower left corner).
- Small randomized brush stroke using Rkey (upper right corner).
- Big randomized brush stroke using SHIFT + Rkey (lower right corner).
 
There are two options on dealing with repo dependencies:
This method will ensure that you are running the latest stable versions of the dependencies that work with TextUR.
The script fetch-dependencies.py used for this was created by Thibaut Buchert.
fetch-dependencies.py is used in the following scripts below:
After a successful build, the scripts will then prompt you with the question if you want to run the program (it will be run with a demo texture).
When the script has been successfully run for the first time, you can then go to sub-folder TextUR and use the build.sh / build.bat script instead.
Run the following script:
setup_and_build.batRun the following script:
setup_and_build.shIn this method we basically outline the things done in the setup_and_build-scripts in Option 1.
This method is more suitable for development as we're not necessarily working with "locked" dependencies.
You need the following header-only libraries:
Make sure the folder structure looks like this:
<my_source_code_dir>/lib/Core/                   ; Core repo workspace/checkout goes here.
<my_source_code_dir>/lib/Termin8or/              ; Termin8or repo workspace/checkout goes here.
<my_source_code_dir>TextUR/                      ; TextUR repo workspace/checkout goes here.
These repos are not guaranteed to all the time work with the latest version of TextUR. If you want the more stable aproach then look at Option 1 instead.
Then just open <my_source_code_dir>/TextUR/TextUR/TextUR.sln and build and run. That's it!
You can also build it by going to <my_source_code_dir>/TextUR/TextUR/ and build with build.bat.
Then you run by typing x64\Release\textur followed by the appropriate command line arguments.
Goto <my_source_code_dir>/TextUR/TextUR/ and build with ./build.sh.
Then run by typing ./bin/textur and apply the appropriate command line arguments (see beginning of README.md).
Trigger new release. For example:
git tag release-1.0.0.0
git push origin release-1.0.0.0If release workflow failed, you can delete the tag and add it again which then retriggers the release workflow. For example::
# Delete local tag
git tag -d release-1.0.0.0
# Delete remote tag
git push --delete origin release-1.0.0.0
# Re-create the tag locally
git tag release-1.0.0.0
# Push the tag again (this retriggers the workflow)
git push origin release-1.0.0.0But it is best to use the script retag_release.sh for such tasks. E.g.:
./retag_release bump patch "Some tag message."or e.g.:
./retag_release 1.1.5.7 "Some tag message."Note that the tag message is currently not used as release notes, but the last commit message is. I will change this in the future.
When you download a MacOS release then you need to tell the gatekeeper unblock the executable (here: textur), but only if you trust the program of course (check source code + release workflow if you're unsure).
When you feel ready, you can allow the binary to be run by going to the release folder and type the following:
xattr -dr com.apple.quarantine texturOn Windows, you might have to unblock the exe by right-clicking the exe-file and check the Unblock checkbox.