|  IntroductionTorque 3D's Material Editor allows an artist to quickly create and
                  edit a game object's materials without ever touching a line of code.
                  This tool can preview and edit materials mapped to an object in real
                  time from the World Editor. Materials are categorized for ease of
                  organization, and the editor is designed to be backwards-compatible
                  with any existing script files. Materials are defined within script files named materials.cs  
  Typical UseThe Material Editor quickly comes into play when you are building
                  your level by placing objects into the scene. As an example situation,
                  let us assume you have a light fixture you or another artist has
                  exported for use in Torque 3D. The creation of this object was a
                  multi-step process.  The object's geometry had to be created in a 3D modeling
                  app, such as 3DS Max, Maya or Blender. Once the geometry was finished, a 2D
                  graphical application was used to create the various textures that make
                  up the high quality appearance: base texture (diffuse map), normal map,
                  detail map, etc.
 The rendered view of this object looks fine in the originating application, 
                  which leads you to believe it is ready to be imported into
                  your game's level. When you drop the lighting fixture into the world,
                  there is a good chance it will fit right in based on your existing design.
                  The theme and color scheme are likely a match.
 However, once your object is in the level you might notice
                  something is off. While the stand alone object viewed in an external
                  tool looked great, the object now seems out of sync with your level's
                  lighting, tone, or specific room theme.
 This is not the fault of the artist or design. What has
                  happened is the materials for your object have either not been assigned
                  or need to be tweaked to perfection in specific instances. Instead of
                  going back into the art tool or adjusting properties in code, you can
                  use the Material Editor to edit the appearance of your object by
                  adjusting the texture maps and their properties.
  Setup
                  While running the World Editor, object by using the Object Editor (F1) 
                  (a lighting fixture in this situation). The next step is to open the
                  Material Editor by choosing from the menu "Editors -> Material Editor", or with the hotkey (F4). The
                  following image is an example of an object being edited with the
                  Material Editor.  (click to enlarge)
  
 Before you begin your editing, read on to learn about the interface and usage of the Material Editor.
 
  Interface
                To switch to the Material Editor press the F4 key or from the main menu select Editors -> Material Editor.
                 Each major section of the Material Editor is separated via a header,
                  such as Lighting Properties or Animation Properties. The fields found in
                  these sections directly manipulate a materials properties in real time.
                  Hover your mouse over each section in the following image to get a
                  description of fields and how they are adjusted:
 Main Editor:
 (hover mouse for details)
   
   
   
   
   
   
   
   
   
   
 Material Selector:
 When you wish to swap the material mapped to an object or create
                  a new material, you will use the Material Selector. To change the material on an object, 
                  it must first be selected. If you do not know how to select an object, refer to the 
                  Object Editor 
                  documentation, then switch back to the Material Editor (F4). The Material Properties pane on the 
                  right side of the screen displays the properties that describe the material of the selected object. 
  
 
                At the top-right of the pane there is a value named Material. Click on the globe 
                 to the right side of it. This will bring up the Material Selector window.
 (click to enlarge)
  
 The center section of this dialog displays a list of all materials currently loaded in the game. 
                  OClicking on any material selects it which will cause the panes on the right to update and display 
                  information about the material. This information is limited to a preview of the material’s Diffuse 
                  texture, the name of the diffuse texture, and a list of filter tags.
 On the left is a list of filters. The filter system is used to organize your materials for ease of use, 
                  and contains types and tags. To create a new tag, click the new tag button:
 
  
 The Create New Tag dialog will pop up:
 
  
 Enter a name for your new the tag then click the Create button. In this example, you will be grouping all 
                  the materials related to cliffs. Whenever a 
                  material is selected, the Material Tags section on the right will be updated to show 
                  all the tags that you have created, each with a checkbox. Clicking 
                  the box of a specific tag will associate that tag with the current material. Clicking a checked box 
                  will dissociate the tag from the material.
 
  
 The list of materials can be filtered using the tags assigned to them. 
                  To filter the material list use the tags section on the far 
                  left. When you click on the check box for tag it tells the system to include materials 
                  that have that tag in the list. Any materials that do not have at least one of 
                  the checked tags will be filtered out of the list.
 
  Editing an Existing MaterialYour game's levels can potentially contain thousands of different
                  objects with varying purposes: explosive barrels, ammo crates, static
                  light fixtures, solid walls, etc. Each one will have a material that
                  might need subtle tweaking to fit in, such as a glowing light bulb.  In this example, you will adjust the properties of this bridge materials.
 
  
 Remember that you can preview the changes in the scene as
                  well as the preview box in the Material Editor. You will start by toggling
                  the Specular property of the material used for the metal pipe. Without
                  Specular enabled, an object will not have a shine and will thus appear flat.
 (click to enlarge)
  
 When the Specular property is enabled, the cube in the preview
                  box will have a shiny appearance. In the
                  scene, the metal will also be shinier due to the lighting reflection.  (click to enlarge)
  
 The specularity can be adjusted further by specifying a
                  color. Clicking the box next to the Specular property will open a color
                  picker. In this dialog, you can change the color shading and alpha level which dictates how transparent the shading will be.
 (click to enlarge)
  
 The green tint selected in this example will make the specular change more apparent in the preview window.
  
 In your level, this specularity change gives you a better
                  idea of how lighting is affecting the object and where it is the shiniest.
 (click to enlarge)
  
 Enabling the Glow property will result in a dramatic change
                  in appearance. The light reflected off the pipe is now much more
                  intense and blurred. While this is a nice affect, it may not be
                  appropriate for every material. Even though this pipe can now glow, it
                  is not an actual source of light.
 (click to enlarge)
  
 The final lighting property is the Emissive toggle. The
                  toggle causes an object to not be affected by lights. This is excellent
                  for materials on light source objects, but toggling it on just any material
                  can have an odd effect.
 (click to enlarge)
  
 To get a better idea of how to effectively use the lighting
                  properties, another material on the mesh should be studied. A single
                  object can have multiple materials mapped to it. Switching assigned
                  materials is as simple as clicking the drop-down box next to the
                  object's file name:
 
  
 This material affects the surface associated with the object's light source, such as a light bulb.
 (click to enlarge)
  
 With all of the lighting properties disabled, the light will look like any other object in the level.
 (click to enlarge)
  
 Enabling the Specular property will cause the more reflective areas to give off subtle light bounce.  (click to enlarge)
  
 Enabling the emissive property causes the material to ignore
                  lighting calculations, which returns the bright colors of the diffuse
                  texture.  (click to enlarge)
  
 
 
 Enabling the Glow property simulates a light emission effect, similar to how a light bulb would appear.  (click to enlarge)
  
 Showing the material's animation effects is difficult with still images. If you 
                    experiment with Rotation, Scroll, and Wave animation properties you will 
                    immediately see how they affect your material. The following is a still image 
                    captured while the
                  texture is being scaled in a triangular pattern using the Wave
                  Animation.
 (click to enlarge)
  
 
  Creating a New MaterialWhile developing your game, you will most likely be using your own
                  assets. When you add a model to the scene, it will be assigned the
                  default “No Material” texture which serves as a warning to the designer 
                  that no material has been assigned to an object. This material is 
                  automatically used for all assets before they have a mapped materials.  (click to enlarge)
  
 
 
 If you have already created the textures for your object,
                  creating and assigning a material is a simple process. Start by
                  clicking the globe symbol next to the Material name box.   
 
 
 The Material Selector dialog will appear:   
 Click the Create New Unmapped Material button found at the top right of the Material section’s header. A new material will be added to the
                  list with a name similar to newMaterial_0. Click on the material to
                  view it in the Diffuse Preview section.   
 
 
 Click the Select button to use that selected material for the object you are editing. 
                  After the Material Selector closes, you will be prompted to save
                  any material changes that you may have made before entering the Material Selector. 
                  Do so if you wish to retain any
                  changes that you made prior to creating the material.   
 
 
 Your new material will have replaced the material selection in the Material Properties pane back in the 
                Material Editor and should now be displayed in the Material field. Type in the real name you want for your 
                new material to be known by then press the Enter key. In this example, the name of the material is "boxxy."   
 
 
 Before editing anything else, click the Save Material button, represented by the floppy disk symbol to save the new material.  NOTE: You MUST press the Enter key after typing the material name BEFORE clicking the Save Material button or the material will not be properly saved.  
 
 
 Now, scroll down to the Texture Maps section of the Material Editor. This is where you will be adding the actual texture files that define this new material.   
 
 
 Click on the Diffuse Map preview or the Edit button in that section to open a file
                  browser. Navigate to your diffuse texture, or sometimes referred to as the base texture. 
                  Select the file that you want to use as for this new material then click the Open button.  (click to enlarge)
  
 
 
 Your preview window and scene should immediately be updated to reflect the addition of your texture.  (click to enlarge)
  
 
 
 
 Repeat the process to add your Normal map. Click on the preview or edit button in the Normal Map section. When the file
                  browser appears, select your normal map texture.  (click to enlarge)
  
 
 
 Once again, your scene will be updated to reflect the changes
                  that have been made to the material. Click the save button to retain
                  these changes.  (click to enlarge)
  
 
 
 If you open the Material Selector again, you will notice your
                  new material has been saved in the list. This material is now 
                  available to be assigned to any other meshes within the project 
                  without having to go through the whole
                  process of redefining it again.  
  ConclusionThis article covered the basics of using Torque 3D's powerful
                  Material Editor. As with any other editing tool, remember to
                  save and save often. Take some time to experiment with
                  existing materials provided in our demos, or work with your own
                  materials to get a feel for the the utility. |