.. _tiletypes-here: .. _tiletypes-here-point: tiletypes ========= .. dfhack-tool:: :summary: Paints tiles of specified types onto the map. :tags: adventure fort armok map .. dfhack-command:: tiletypes-command :summary: Run tiletypes commands. .. dfhack-command:: tiletypes-here :summary: Paint map tiles starting from the cursor. .. dfhack-command:: tiletypes-here-point :summary: Paint the map tile under the cursor. You can use the `probe` command to discover properties of existing tiles that you'd like to copy. If you accidentally paint over a vein that you want back, `fixveins` may help. The tool works with a brush, a filter, and a paint specification. The brush determines the shape of the area to affect, the filter selects which tiles to affect, and the paint specification determines how to affect those tiles. Both paint and filter can have many different properties, like general shape (WALL, FLOOR, etc.), general material (SOIL, STONE, MINERAL, etc.), specific materials (MICROCLINE, MARBLE, etc.), state of 'designated', 'hidden', and 'light' flags, and many others. Usage ----- ``tiletypes`` Start the interactive terminal prompt where you can iteratively modify the brush, filter, and paint specification and get help on syntax elements. When in the interactive prompt, type ``quit`` to get out. ``tiletypes-command <command> [; <command> ...]`` Run ``tiletypes`` commands from outside the interactive prompt. You can use this form from hotkeys or `dfhack-run` to set specific tiletypes properties. You can run multiple commands on one line by separating them with :literal:`\ ; \ ` -- that's a semicolon with a space on either side. See the Commands_ section below for an overview of commands you can run. ``tiletypes-here [<options>]`` Apply the current options set in ``tiletypes`` and/or ``tiletypes-command`` at the in-game cursor position, including the brush. Can be used from a hotkey. ``tiletypes-here-point [<options>]`` Apply the current options set in ``tiletypes`` and/or ``tiletypes-command`` at the in-game cursor position to a single tile (ignoring brush settings). Can be used from a hotkey. Examples -------- ``tiletypes-command filter material STONE ; f shape WALL ; paint shape FLOOR`` Turn all stone walls into floors, preserving the material. ``tiletypes-command p any ; p s wall ; p sp normal`` Clear the paint specification and set it to unsmoothed walls. ``tiletypes-command f any ; p stone marble ; p sh wall ; p sp normal ; r 10 10`` Prepare to paint a 10x10 area of marble walls, ready for harvesting for flux. ``tiletypes-command f any ; f designated 1 ; p any ; p hidden 0 ; block ; run`` Set the filter to match designated tiles, the paint specification to unhide them, and the brush to cover all tiles in the current block. Then run itThis is useful for unhiding tiles you wish to dig out of an aquifer so the game doesn't pause and undesignate adjacent tiles every time a new damp tile is "discovered". Options ------- ``-c``, ``--cursor <x>,<y>,<z>`` Use the specified map coordinates instead of the current cursor position. If this option is specified, then an active game map cursor is not necessary. ``-q``, ``--quiet`` Suppress non-error status output. Commands -------- Commands can set the brush or modify the filter or paint options. When at the interactive ``tiletypes>`` prompt, the command ``run`` (or hitting enter on an empty line) will apply the current filter and paint specification with the current brush at the current cursor position. The command ``quit`` will exit. Brush commands `````````````` ``p``, ``point`` Use the point brush. ``r``, ``range <width> <height> [<depth>]`` Use the range brush with the specified width, height, and depth. If not specified, depth is 1, meaning just the current z-level. The range starts at the position of the cursor and goes to the east, south and up (towards the sky). ``block`` Use the block brush, which includes all tiles in the 16x16 block that includes the cursor. ``column`` Use the column brush, which ranges from the current cursor position to the first solid tile above it. This is useful for filling the empty space in a cavern. Filter and paint commands ````````````````````````` The general forms for modifying the filter or paint specification are: ``f``, ``filter <options>`` Modify the filter. ``p``, ``paint <options>`` Modify the paint specification. The options identify the property of the tile and the value of that property: ``any`` Reset to default (no filter/paint). ``s``, ``sh``, ``shape <shape>`` Tile shape information. Run ``:lua @df.tiletype_shape`` to see valid shapes, or use a shape of ``any`` to clear the current setting. ``m``, ``mat``, ``material <material>`` Tile material information. Run ``:lua @df.tiletype_material`` to see valid materials, or use a material of ``any`` to clear the current setting. ``sp``, ``special <special>`` Tile special information. Run ``:lua @df.tiletype_special`` to see valid special values, or use a special value of ``any`` to clear the current setting. ``v``, ``var``, ``variant <variant>`` Tile variant information. Run ``:lua @df.tiletype_variant`` to see valid variant values, or use a variant value of ``any`` to clear the current setting. ``a``, ``all [<shape>] [<material>] [<special>] [<variant>]`` Set values for any or all of shape, material, special, and/or variant, in any order. ``d``, ``designated 0|1`` Only useful for the filter, since you can't "paint" designations. ``h``, ``hidden 0|1`` Whether a tile is hidden. A value of ``0`` means "revealed". ``l``, ``light 0|1`` Whether a tile is marked as "Light". A value of ``0`` means "dark". ``st``, ``subterranean 0|1`` Whether a tile is marked as "Subterranean". ``sv``, ``skyview 0|1`` Whether a tile is marked as "Outside". A value of ``0`` means "inside". ``aqua``, ``aquifer 0|1`` Whether a tile is marked as an aquifer. ``stone <stone type>`` Set a particular type of stone, creating veins as required. To see a list of valid stone types, run: ``:lua for _,mat in ipairs(df.global.world.raws.inorganics) do if mat.material.flags.IS_STONE and not mat.material.flags.NO_STONE_STOCKPILE then print(mat.id) end end`` Note that this command paints under ice and constructions, instead of overwriting them. Also note that specifying a specific ``stone`` will cancel out anything you have specified for ``material``, and vice-versa. ``veintype <vein type>`` Set a particular vein type for the ``stone`` option to take advantage of the different boulder drop rates. To see valid vein types, run ``:lua @df.inclusion_type``, or use vein type ``CLUSTER`` to reset to the default.