Skip to content

elfnor/mesh_maze

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

34 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

maze

This add-on has been updated to Blender 4.1 in the master branch (tested on 4.1.1), the Blender 2.7 version is now in a separate branch.

This Blender add-on runs a recursive back tracker maze algorithm over the selected part of any mesh to produce a maze.

round cube maze

A Blender mesh structure can be seen as equivalent to the grid of cells and list of links used as the data structure for 2D mazes (for example by Jamis Buck in his book "Mazes for Programmers").

Here the mesh vertices are equivalent to cells and the mesh edge connections define the cell neighbors. A maze carving function can then return a subset of the edges that define the path of a maze through the mesh.

maze

I originally realized this concept as a scripted node for the Sverchok add-on but have now completely rewritten the code into this separate standalone add-on for Blender.

The add-on can be installed in the normal way by downloading the zip file from the github repository, then Edit -> User Preferences -> Add-ons -> Install from File...

Once installed and enabled the add-on can be found in Edit Mode on the Mesh menu, or using the F3 menu to search for maze.

After carving the maze along the edges, the add-on (by default) bevels all the edges in the selection to give the maze path some width and then extrudes the walls of the mesh outward to give the maze some height.

moebius maze

Maze Parameters

Changing the Random Seed parameter will recalculate a different maze on the same selection.

The Braid defines whether the maze has dead ends. The higher the value of Braid the less dead ends and the more loops or alternative paths in the maze.

The Boundary Wall Type is only applicable if part of the mesh is selected to run the maze on, or the mesh has a boundary (for example a grid mesh). This parameter sets the outer wall of the maze to Thin, Thick or None.

Advanced Options adds some extra parameters to the Path and Wall Parameters that effect the bevel and extrude operators.

Path Parameters

Bevel Amount Type sets how the amount slider effects the bevel or path width. See the bevel operator documentation for details.

The Path Width sets the width of the path. If set to zero only the edges of the maze within the original mesh are selected, no bevel or extrude takes place.

The Clamp Overlay and Loop Slide parameters are passed straight to the bevel operator.

Wall Parameters

Offset Relative - scales the offset relative to the surrounding geometry.

Extrude - gives the height of the maze walls.

Offset Even - scales the offset to give more even thickness to the top width of the walls.

Thickness - narrows the top of the wall to give a tapered profile.

Outset - if the walls are tapered the tapered part extends into the path area.

hedge maze

Large meshes

The mesh maze add-on takes about 8 seconds (on my machine) to generate a maze on an icosphere with ~10 000 vertices. It has been optimized so that the maze path is regenerated if the random seed or braiding values are changed but not for changes to the path width or wall height.

3D mazes

maze 3d

The add-on can be run on 3D networks of vertices and edges to produce 3D mazes. These networks should have no faces. In this case the edges that are part of the maze will be remain selected after the add-on is run. When a mesh has no faces the path and wall parameters are ignored. It is up to the user to invert the selection and delete the edges not in the maze. The edges can then given shape with a skin modifier.

For example:

Add a 5 x 5 grid

5x5 grid

Delete only faces in edit mode

delete faces

Extrude 5 times and delete only faces again

3d grid

Run the mesh maze

3d maze

This leaves the edges in the maze selected.

In edge mode, invert the selection and delete those edges.

Add a skin modifier , and decrease the vertex radius.

skin modifier

Mark one of the maze path ends as the root.
Add a subdivision surface modifier.

sub division