3D tree material tutorial - Leaves

4089647680_744eb42ffc_o.jpg

A tutorial on making leaf materials for 3d trees, in this case a sugar maple (in autumn).

20091109 grey_noopacity

Firstly, some observations on opacity mapped leaves vs. geometry leaves. As you can see in the image above, the images in this post were made using opacity mapped leaves. After some tests on my farnsworth house project, I have come to the conclusion that it is quicker in most cases to use opacity mapped leaves. Its true that in simple scenes trees with geometry leaves may render quicker as VRay doesnt have to calculate the opacity of thousands of leaves, but in dealing with complex scenes with millions of polygons the advantage in using (a lot) less RAM is huge. The processes involved in swapping opacity mapped plates for geometry are also very long winded and very tedious!

Exporting from Onyxtree. I went with 4 polygons per leaf so that the leaves aren't just flat. Remember to set the dimensions you want the individual leaves, and change the units when you export. You can also make it export 3 different leaf IDs with varying sizes. I normally export as a .obj file.

onyxtree

Opacity mapping. It's important to make sure the opacity map is just pure black or white, with a sharp edge. The opacity map I used can be found here (its not a great example!). You should also turn off filtering in the bitmap loader options (screenshot).

20091109 grey

As imported to 3dsmax and given grey materials.

VRay2sidedMtl. The vray 2 sided material works best with geometry that has no thickness, which is what onyxtree outputs. It is a very quick way of generating a SSS (sub-surface scattering, think candle wax, skin, milk etc) type look. The image below is rendered using a vray2sidedmtl on all leaves with grey submaterials and a hand drawn image for the vein skeleton.

20091109 grey_transparency
2sided

Front material. The front side material is a basic vraymaterial with a diffuse map and a reflection map. Click here for front vray material set up. The color correction map is to produce slightly different hues of leaf for each of the 3 sub leaf types (you should have got a mult-subobject material when you imported the .obj file). I usually make the first leaf and then copy and paste it to the 2nd and 3rd and just change the hue value slightly. The diffuse map looks like this, and the reflection map is a b&w copy with levels adjusted to make it more contrasty.

20091109 no_2sided

Render showing front leaf material on both sides with no transparency.

Back material. The back material is a copy of the front material but with a different diffuse bitmap and not quite as reflective. Note that I overlaid the veins skeleton jpg on top in photoshop as well. (without it, the veins looked too light when viewed from the underside as they took 100% of the lighter back material)

20091109 no_transparency

Render showing 2sided material with correct front/back materials but no transparency.

Finished result Click image for 800px version. Rendered using vrayphysicalsky and sun, and a vrayphysicalcamera.

Farnsworth House

by Mies van der Rohe

Something I've been working on for the best part of the last year (I previously blogged about the trees in... May, and the grass even before that!). Unfortunately paid work keeps getting in the way, I'm yet to figure out a solution to that problem.

I'm planning a tutorial on how I did the fog, (another) grass tutorial on how I did the mowed lawn and a making-of post summing up the whole process. Can also do one on optimizing the trees and making the tree materials if there is interest. The sketchup model of the house itself will be available on pushpullbar - details to follow in a separate post.

Technical Info:

  • Grass (short, medium & long), clover and plantago major all scattered with vrayscatter as per previous tutorials.
  • Trees are all made with Onyxtree. Species as per previous blog post.
  • The total poly count comes to approx. 10 billion. 1.34 billion for trees, 8.4 billion for grasses, 270k for house, 550k for furniture.
  • Renders took roughly 6 hrs each @ 2200px
  • Rendered with vrayphysicalcamera, vraysun, HDRi environment
  • VRayenvironmentfog was rendered as a separate pass and screened over in photoshop
  • Final colour corrections made in Adobe Lightroom

Vray Dirt Tutorial

3989998180_1b4a33364c_o.jpg

A quick tutorial on adding dirt to specific materials in Vray. A very useful application of the vraydirt shader in Vray is to make materials look dirty/weathered. Used in it's basic form, with default settings, vraydirt can be used to add a general darkening around edges/corners in your 3d model. It can also be modified to affect only areas directly below 3d features.

a - Shows vraydirt using it's default settings (dirt equal on all sides) b - Shows vraydirt using settings to force the dirt to work only in a downward direction c - As b, but with 'invert normal' ticked d - b and c used within a vraycomptex map, set to minimum

By experimenting with the distribution, falloff and z-bias values, I managed to get the downward effect I was looking for (exact settings in screen grab below). I then combine 2 versions of the vraydirt map inside a vraycomptex map. The first version is for concave creases, the other for convex creases by ticking 'invert normal'. The vraycomptex map is set to minimum so that it combines the two maps by always using the darkest rgb value.

3989242985_9228268622_o.jpg

Above is a render with a concrete material demonstrating the effect. In this case, the occluded map is the same as the unoccluded map but darker and with a slight rusty hue (achieved using a color correction map).

The diagram below shows how the material is made up, and shows the values I used:

3990025074_0b63748539_o.jpg

To take this a step further, you could additionally add a map to vary the radius of the vraydirt effect. (Note that the value I used for radius is in mm)

And finally an animated gif showing renders with and without the vraydirt:

bridge - gif

Chelsea Square Day

Chelsea Square kitchen crop

A new project in my vizualisation gallery: Chelsea Square by Wilkinson King Architects. These images were for marketing purposes and were lots of fun to work on. The building was modeled in Sketchup and all textures were made from scratch from photographs. As usual with my projects, there wasn't much post work in photoshop (apart from the cross section).

The caustics in the pool were calculated with all the glass hidden, saved and then the glass was turned back on for the final render. The actual water surface was modeled by dropping a ball into some reactor water, totally over the top I know!

Chelsea Square water crop

I wanted the brick texture to match the existing building as closely as possible so I took photos of the end gable brick (in the shade) and then painted over every brick in photoshop. This was so that the displacement map worked correctly in displacing the bricks outwards while recessing the grout slightly, and also helped in the reflection map to make the grout less reflective. The traced bricks layer was used as a mask to lighten a greyscale copy of the diffuse layer. Painting over bricks in photoshop is as about as boring as it gets, but worth the effort.

k3lt0k.jpg
Chelsea Square stair view crop

vrayRT for Architectural Visualisation

10min demo of VrayRT for Architectural Visualisation

Very impressed with vrayRT so far, looks like it will be really useful for a lot of my work. Here's a 10min (longer than intended!) demonstration on vimeo (no sound). VrayRT is using my macpro (2.8 octo) and a slave i7 920.

3d trees

Sugar Maple Large

A collection of broadleaf trees that I made in onyxtree and further modified in 3dsmax. I'm currently looking at investing in growfx as well, seems to have a bit of a steep learning curve but might eventually suit my workflow better than onyxtree. Large Sugar Maple

Ash 02

Ash

Sugar Maple Young 02

Young Sugar Maple

Sugar Maple 01

Sugar Maple

White Oak 01

White Oak

Vray grass tutorial part 2

cam02_longgrass0000

Before I get on to the material settings for the grass I'm going to show how I used similar techniques as in part 1 to make shorter grass. This time, I made 5 new individual blades, and made them a lot smaller, more random and also gave them a texture.

I made 3 lengths of grass, the longer ones had taller, less curved, blades. These were then scattered about 1000 times onto a 500mm dia. circle using advanced painter in randomize mode. The next step was to attach all blades into one editable mesh/poly and reset the xform, this seems to be vitally important before exporting it as a vrayproxy. Before I did this, the vrayproxy was using huge amounts of memory when rendering.

grass01

Short grass

grass02

Longer grass - some stats: approx 8000 polys per proxy x 1000 proxies = approx 8 million total polygons. 3dsmax uses about 2 gig memory for this scene and each view rendered pretty quickly considering I had vrayfog and depth of field on.

Note: I use vrayscatter (a commercial plugin but well worth the money) to scatter the proxies. There are lots of tutorials for it here. You can also use scatter by Peter Watje, advanced painter, Forest by Itoosoft, Groundwiz Planter or 3dsmax particles.

Material set up:

The main material for the grass is a multi-sub object with 3 materials within it. Each of the original 5 blades of grass were assigned one of these material IDs at random before they were scattered. Each material is a vraymaterial within a vray2sidedmaterial. Hopefully the screenshots are enough to describe the set up. The three sub materials are all essentially the same, and use the same Bitmap, but use a color correction map to subtly shift the colour (hue). The vray2sided material gives the SSS effect, and is the best option for thin geometry (no thickness) like grass and tree leaves.

mat01psd

You can optionally try turning off 'trace reflections' to try speeding things up. This means the grass will still pick up highlights from the sun, but won't pick up proper reflections, like the colour of the sky. I found the speed increase to be hardly noticeable in my tests, and it just didn't look as good.

cam01_longgrass0000
cam01_clover0000
cam02_clover

UPDATE:

There's nothing special about my render settings or scene set up for this scene, just a vraysun & sky, vrayphysical camera and my usual colour mapping settings. To make the renders look a bit more interesting I decided to play a bit with sun and shadow, and also back lit the grass so that the transparent effect was evident. As you can see from the screengrab below, I have the sun coming from slightly behind the brick wall, and it is also very low in the sky. When experimenting with materials it's very important to set your scene up to mimic an effect you would see in the real world.

grass set up

If you are interested in downloading an example scene, please visit the tutorials section of vray.info and navigate to the 2nd part of my grass tutorial.

architectural photography

process

New recently completed project in the photography gallery for Ian Springford Architects.

Typical processing workflow is something like:

- compare all bracketed exposures in Adobe Lightroom, flag the most likely ones, eventually end up with the best one - adjust exposure, white balance - remove chromatic aberration, vignetting - remove sensor dust spots with spotting tool - export tiff to ptlens, correct any distortion & perspective - back to Lightroom, final crop

Thankfully Lightroom takes most of the pain out of doing this to 250 odd shots, I just wish it was possible to do distortion correction on a dng without converting to a tiff.

HDR Skydome Tutorial

For the 7 shots used to make this HDR skydome I used a Canon 1ds mk3 which has superb auto bracketing abilities as well as being very fast and having 21 megapixels. The lens used for these shots was a sigma 8mm fisheye which gives a complete circular image on a full frame dslr. I set the AEB to 7 shots 2 stops apart, which gave exposure times of 0.5s, 1/8, 1/30, 1/125, 1/500, 1/2000 & 1/8000 all at F20. This range of exposures is crucial for capturing the full dynamic range of the sun, which will eventually mean you get good strong shadows when you use the HDR image to light a 3d scene.

3425529413_9271c89b2a_o.jpg

- Process raw files to remove chromatic aberration & to ensure white balance is consistent. I do this in Adobe Lightroom (pictured below), where you can copy the develop settings from the first file, and then batch process the remaining ones to save time.

3429368874_621b4560fe_o (1).jpg

- Export as 16 bit TIFFs

- Load TIFFs into Photomatix or Photoshop to blend into a single HDR, I use Photomatix as it seems to do a better job of removing ghosting artifacts (from moving clouds).

- Load HDR image file into Hugin. Choose lens type as fisheye when importing, and set the Horizontal field of view to 285 degrees (I arrived at this mostly through trial and error!)

- Hugin will complain that more than 1 image is required - ignore.

- Set pitch of image to 90, and adjust yaw so that sun is centred. If you know where the sun is, it helps later on when you come to rotating the skydome in your 3d application.

- in the stitcher tab, I take off soft blending as there is only 1 image, and press the 'calculate optimal size' button. Then hit 'Stitch Now!' (saving as a tif)

- Open 32bit tif in photoshop, clone out anything you dont want (dust in my case), save as 32 bit exr. Image below shows how the HDR should look when you drag the exposure slider in photoshop.

3428555219_cc52f62030_o.jpg
3429376362_4434e6dd48_b.jpg

Sometime, I'll follow this up with something about how I use these in 3dsmax & Vray!