Skip to content

Brickini Brickify

Brickini Brickify Forest

Overview

Brickini

Brickify is the main engine where all the calculation happens. It outputs all necessary data (points with attributes) to build a sculpture out of bricks. To actually instance bricks onto the generated point cloud you need to hook up Brickini Vending Machine. See below.

Info

This separation allows to easily use your own brick geometry without modyfing Brickify engine itself. It also helps to keep your node network flexible. Adjustments to the sculpture generation is handled separately from the appearance of the individual bricks. It's for example possible to inject custom operations before bricks are actually instanced onto the generated point cloud.

Parameters

  • Hollow Input geometry won't be filled with bricks. Only a shell is generated.

  • Orientation Allows to specify orientation of bricks.

    • One Axis (X or Z) looks more organized and might be preferrable for man made structures or an ocean that goes in a certain direction because of wind.
    • Random looks more organic and is more preferrable for landscapes or more sturdy structures.
  • Max Brick Length Limits the length (in studs unit)

  • Slopes Enables the use of slopes


  • Walls Enables the use of walls (bricks taller than one unit)

  • Max Wall Height Limits the height (in bricks unit)

  • Randomize Orientation By default Brickify tries to have walls with a width of 2, aligning it according to the flow of the wall. If enabled, it randomizes orientation resulting in a mix of walls that are 1 or 2 studs wide.


  • Plates Enables the use of plates

  • Force Plate on Top Brickify always aims for the least amount of bricks, therefore the surface might contain a mix of bricks and plates. However, if a smooth surface is desired, enabling this, asks Brickify to add an extra plate on top of a brick, which can then be turned into tiles with the Tiles parameter.

Warning

Due to a limitation in the engine logic this option does not force a 100% coverage. Increasing Plate Layers (see below) can help to force a broader coverage of plates instead of bricks.

  • Max Plate Length Limits the length (in studs unit) a plate can have

  • Plate Layers As soon as 3 plates would be layered, Brickify merges them into bricks. However this can sometimes result in unwanted gaps/holes in the sculpture. Increasing this parameter can help fill those holes.

  • Mask Plates By default if Plates is enabled, there are used exclusively in favor of slopes. Enabling this reveals extra parameters (see below), that allow to control the distribution between plates and slopes

  • Inclination The distribution between plates and slopes is determined by angle. Gentle inclinations favor plates, while steeper inclinations are built with slopes.

  • Inclination Angle Threshold for plate/slope ratio. Higher values mean more plate usage.

  • Plates Attribute Reads plates attribute. This allows to artistically paint - or procedurally generate with standard houdini tools where plates should be used instead of slopes.

Bug

Due to a limitation in the engine logic using the plate attribute can cause intersections between bricks

  • Pebbles Attribute Reads pebbles attribute which replaces regular plates with round plates which can be used to create trails/dirt paths.

  • Tiles Enables the use of tiles. This replaces all plates with tiles by default.

Note

See Force Plate on Top and Plate Layers to get a better tiles coverage

  • Tiles Attribute Only replaces plates with tiles according to tiles attribute.

  • Water Reads the following attributes: water and foam.
  • Water wherever water > 0
  • Foam wherever foam > 0.5

Info

This inconsistent behaviour is for convenience. Foam can easily be created with a noise function which - by default - generates float values between 0-1 and therefore doesn't have to be remaped.

  • Water Max Length Limits the length (in studs unit) water (transparent tiles) can have

  • Color Per Brick Type Random color per brick type which is mostly meant to be used for visulization/troubleshooting purposes. Disable to use point color of input geometry.

  • Favor Color Over Brick Size Usually Brickify attempts to use the biggest bricks possible, however that would result in a very crude color representation of an input model. Therefore, bricks are divided into smaller ones whenever the color of the input model dictates it.

  • Restrict Color Palette Automatically converts the input color into the closest officially available Lego color.

Warning

The transformation math from input color to an official Lego color is not really satisfying at the moment. Until I find a better formula, the parameter below can be of good help.

  • Color Palette Presets for different color palettes.
    • Modern Colors: all colors available nowadays
    • Modern Landscape Colors: all colors available nowadays that make sense for landscapes.
    • 90s Colors: colors available in the 90s. This uses the old greys.

Tip

Due to the limitation mentioned above, sometimes unwated pink/purple colors can sneak into a sculpture. The Modern Landscape Colors palette is a handpicked selection of colors that usually make sense for landscapes and helps to avoid bad color transformations.


  • Time Freeze

    • Off: Default - Input can be animated
    • On: Freezes input, forces a static brick generation
    • Mask: Use freeze attribute to freeze certain parts of your input mesh
  • Frame Specifies frame for time freeze