Advanced 3D Art and Animation

Slides:



Advertisements
Similar presentations
GameCamp! and Game Davis Creating a 2D Platformer in Unity.
Advertisements

Create slices and hotspots Create links in Web pages Create rollovers from slices Create basic animation Add tweening symbol instances to create animation.
HELLO WORLD: YOUR FIRST PROGRAM CHAPTER Topics  Hello World?  Creating a Unity Project –The Unity Project Folder  MonoDevelop: Unity's Code Editor.
Chapter 3 Working with Symbols and Interactivity.
EEC-693/793 Applied Computer Vision with Depth Cameras Lecture 13 Wenbing Zhao
© 2011 Delmar, Cengage Learning Chapter 3 Working with Symbols and Interactivity.
© 2012 Adobe Systems Incorporated. All Rights Reserved. Copyright 2012 Adobe Systems Incorporated. All rights reserved. ® INTRODUCTION TO FLASH ANIMATION.
Main Navigation  Similar to Unity 3D  Unlike Unity it is a right handed coordinate system  Used to determines whether a positive rotation is clockwise.
® Copyright 2010 Adobe Systems Incorporated. All rights reserved. ® ® 1 INTRODUCTION TO ADOBE FLASH PROFESSIONAL CS5.
Alice 2.0 Introductory Concepts and Techniques Project 1 Exploring Alice and Object-Oriented Programming.
Creating a Logo – Lesson 3 1 Creating a Logo Lesson 3.
Web Games Programming An Introduction to Unity 3D.
PowerPoint Basics Tutorial 3: Graphics In this tutorial we’ll be looking at graphics, and the various types of illustrations that can be included in a.
Flash! Macromedia Flash is the key to designing and delivering low-bandwidth animations, presentations, and Web sites. It offers scripting capabilities.
UFCFS D Technologies for the Web Unity 3D: Review of Topics and Related Concepts.
Unity 5 Visual Studio Code * Asset Store * FPS * Terrain.
1. Press the New Layer Button 3. Double click names to re-name Ball & Shadow layers 2. Click to change to 12 fps Step 1.
Learning Unity. Getting Unity
SE 320 – Introduction to Game Development Lecture 3: Unity’s Interface and Concepts Lecturer: Gazihan Alankuş Please look at the last two slides for assignments.
PowerPoint Basics Tutorial 3: Graphics In this tutorial we’ll be looking at graphics, and the various types of illustrations that can be included in a.
UFCEK-20-3Web Games Programming Unity 3D: Review of Topics Publishing for the Web.
LESSON #10: Digital Playtesting & Introduction to Character Animation with Mecanim DGMD E-70 Principles of Game Design.
XP Tutorial 3 Creating Animations. XP New Perspectives on Macromedia Flash MX Elements of Animation Layers are used to organize the content of.
 The terms LMB, MMB, RMB, and mouse wheel (MW).
UFCFSU-30-13D Technologies for the Web An Introduction to Unity 3D.
Design Visualization Software Introduction / Review.
CIS 205—Web Design & Development Flash Chapter 3 Working with Symbols and Interactivity.
Expressive Intelligence Studio // Center for Games and Playable Media // Unity Pro John Murray Expressive.
{ How to Create a Flipchart in ActivInspire Lara Daniel.
INTRO TO UNITY Building your first 3D game. DISCLAIMER  “This website is not affiliated with, maintained, endorsed or sponsored by Unity Technologies.
Yingcai Xiao Game Development with Unity3D Inside/Outside Unity3D.
Welcome to the Basic Microsoft Word Guide. Before you start this Guide, you will need to complete “Basic Computer”; “Basic Windows” and know how to type.
Microsoft® PowerPoint  Entrance. Controls how an object first appears on a slide.  Emphasis. Draws attention to an object that is already.
Game Development with Unity3D
Welcome! Day1, Lesson 1.
Adobe Premiere interface overview
EEC-693/793 Applied Computer Vision with Depth Cameras
COMP 50 Game Design LESSON #11: Digital Playtesting & Introduction to Character Animation with Mecanim.
Quick Intro to Unity Lecture 2.
Game Development with Unity3D Inside/Outside Unity3D
Layers in Adobe After Effect
COMP 50 Game Design LESSON #9: Digital Playtesting & Introduction to 2D Art and 3D Texturing.
3GB3 Game Design Unity 3D Basics.
Character Design for Animation and Games
Character Design for Animation and Games
An Introduction to Alice (Short Version)
EEC-693/793 Applied Computer Vision with Depth Cameras
Flash Interface, Commands and Functions
DGMD E-70 Principles of Game Design
Prezi.
Adding Assignments and Learning Units to Your TSS Course
Assignment 8 Chess Game.
EEC-693/793 Applied Computer Vision with Depth Cameras
MS PowerPoint 2010 Week 2.
INTRODUCTION TO ADOBE FLASH CS4
UNITY TEAM PROJECT TOPICS: [1]. Unity Collaborate
Game Design LESSON #9: Digital Playtesting & Introduction to 2D Art and 3D Texturing.
INTRODUCTION TO FLASH ANIMATION
3D Modelling with Tinkercad
Introduction to 3D Art and Animation
Working with Symbols and Interactivity
So you were told to make a video
DGMD E-70 Principles of Game Design
Narrative Motion Graphics
EEC-693/793 Applied Computer Vision with Depth Cameras
DGMD E-70 Principles of Game Design
Narrative Motion Graphics
Creating a Simple Game in Scratch
Narrative Motion Graphics
Presentation transcript:

Advanced 3D Art and Animation Lesson M (week 13): Revising Motion with Animation Layers Introduction to the Unity Game Engine for Game Artists

Animation Layers: What are they for? Once you have created rough animation for your film character, you are ready to start adding more detailed motions to limbs, body, and face. If you want to try something without changing your original rough motion work, Animation Layers are a perfect solution. Animation Layers store changes to character motion as separate units. Like Photoshop layers, they can be toggled on and off and blended (“weight”). They can be used in animation pipelines in many ways. Film Animators often use them for iteration on character motion. Game Animators will turn one walk cycle into many by adding a pose change in the anim layer, making a normal walk seem tired, or wary, happy, etc. Another good use of Animation layers is to manage looping and non-looping motions. Let us say, for example, we have a character that is walking down a street, and all the while holding a conversation. We can make a layer that animates a few steps and loops that motion. As long as that layer is active, and not suppressed by a higher Override layer, that cycle will continue. On a higher layer we can add animation for the torso, arms, head and face that show specific conversation moments performance. Source notes: https://www.youtube.com/watch?v=QLUdaLrL3Eo

Animation Layers: Basic Function In the Channel Box bottom go to the Anim tab. Click the right-most button (blue ball) to create two layers: Base Animation contains all the objects in the scene and all the keyframes created so far. AnimLayer1 (or other layers created) only contain objects that are selected when AnimLayer is created, or added later (select object, rightclick AnimLayer to Add Selected). Rightclick a layer to set Layer Mode (Additive or Override), Remove Selected objects from a layer, Delete a layer, Merge Layers, etc. Organize new AnimLayers: Name, rightclick red box to set key colors (so the keyframes for each layer are unique). To loop animation: Select one or more objects, and then in the Windows > Animation Editor > Graph Editor select one or more tracks, select a set of keyframes, and in the Graph Editor menu choose Curves > Post Infinity > Cycle (turn off loop: Curves > Post Infinity > Constant) Notes source: https://www.youtube.com/watch?v=PuB6pOX1JnQ

What is Unity? Unity is a game engine, which means it is a system for organizing the development of interactive software with robust features such as physics engines, shaders, and ways to build and test scenes. Unity is one of two Engines used by the majority of professional and hobbyist game developers in the world to make games for all platforms: mobile, PC, Console and the web. The other is Unreal, and both are free for students and small-scale projects. Unity uses C# as the preferred programming language (Unreal uses C++ and the robust visual Blueprints system). A lot can by accomplished in Unity with minimal programming. The Unity Learning site, youtube, and others offer a ton of tutorials for making full games from scratch, including all needed code. Unity itself does not include a coding environment; for that we need an IDE, like Visual Studio (free version downloads with Unity, requires free login after trial period) or Monodevelop.

Creating a Unity Project Download the free “Personal” version of Unity here: https://store.unity.com/products/unity-personal Long-term users can download Unity Hub to help manage multiple versions over multiple years: https://unity3d.com/get-unity/download Once installed, DoubleClick to open and hit New to create a new project. Choose 3D (default) and set to a folder location for your project: a folder on your desktop. Hit [Create Project]. The Unity screen will disappear while Unity builds a project into that folder. It is building a bigger project that we necessarily need; the downside of working with an established engine is that it inefficiently includes functions we might not need in our project. The upside is that we don’t have to build any of the basic function of almost any game ourselves. NOTE: The Unity game engine is normally intended to be used by a collaboration between artists and programmers, so the normal location would be inside of a folder that is set to be read and written to by an online repository, like GitHub.

The Unity Interface There are 6 areas of the interface to begin: PROJECT: RightClick import assets, create folders, Animators, C# scripts, and others. SCENE: Like Maya: navigate [Alt]+Mouse, hit [f] to focus on selected, [Shift] to add to selection, [W][E][R] to transform. HIERARCHY: List of items in Scene. Objects dropped here are placed in Scene center. Select to adjust properties in the Inspector. INSPECTOR: Name, set Transforms and tags, add and change Components, including physics Colliders and Rigidbody. MENUS: GameObject to add non-mesh items: 3D Objects, Empty GOs, lights, VFX. GAME: Hit “Play.” Any changes made in the Scene or Inspector while in Play mode will be reverted/lost when Play is turned off. Note the “Maximize On Play” option. A Prefab is an object that contains multiple items and settings, created by dragging a prepared object from the Hierarchy to the Project (both turn blue). The prefab in the Project can be right-clicked to Export a Package, which can be emailed to project teammates.

Creating Basic First-Person Interaction in Unity To begin exploring 3D interactive spaces in Unity, let’s set-up a ground, a first-person controller, and some stuff to knock around. Create a Cube for a ground: Game Object > 3D Object > Cube. In the Inspector, set height=0.2 and width and length to 30. Name it Ground. NOTE by default it has a Box Collider to block physics-enabled objects. Find Unity Package First Person Controller on the course website and download (can also get from the Unity Asset store as part of the free “Standard Assets” collection). In Unity RightClick the Project window to Import Package > Custom Package and select the FPScontroller. The FPS Controller prefab appears as well as a reduced version of the Standard Assets folder. Drag the FPS Controller into the Hierarchy and in the scene lift it above the ground Cube. In the Hierarchy select and delete “Main Camera” (we only want one camera, the one attached to FP controller). Hit the Play button to walk around with [W][A][S][D] and to move the camera with the mouse. Hit [Esc] to turn off Play.

Creating Basic Physics Interaction in Unity Set the Directional Light darker: select it in the Hierarchy and in the Inspector click the color rectangle to change the color to a darker yellow, so the scene is easier to see. Create a new Cube. In the Inspector, set (a) Size = 0.5, 0.5, 0.5. (b) Name this cube “Stone” and hit [Return]. (c) Hit [Add Component] to choose Physics > RigidBody (which adds gravity and the ability to move). Drag “Stone” from Hierarchy into Project to make a Prefab (both turn blue), so copies will be instances of each other. Make many more copies of Stone to build a wall: select Stone in the Hierarchy, hit [Ctrl/Cm]+[d], and drag the copy up or over in the Scene. Hit Play and try walking into the wall. The Stones will block your way. Hit [Esc] to turn off Play. In the Project, select Stone, and in Inspector, change the RigidBody Mass value from 1 down to 0.1. Because we made the original Prefab, this changes Mass on ALL Stones. Hit Play to channel your inner Kool-Aid Man!

Import Textured 3D Assets from Maya into Unity 1 Exporting assets from Maya to Unity is relatively simple: In Maya, change Windows > Settings/Preferences > Preferences > Settings from Centimeters to Meters (the default units in Unity). Create a character proxy: a Cylinder from the Poly Modeling shelf set to 2 meters (units) tall. Turn on Display > Heads Up Display > Poly Count. Create textured objects using this proxy as size-reference (furniture, doorway, etc). These objects need to have a moderate polygon count: Big objects should usually stay under 1-5k triangles and small objects should stay under 100 triangles (select an object to see its poly count). These numbers should be half or less for VR. Here is a basic tree shape: In Front view, use Mesh Tools > Create Poly to draw a leafless tree-shape twice as tall as the Proxy (4 meters) with wide branches. Hit [Return] to complete. In Perp view hit Modeling Toolkit > [Extrude] and pull out a grey 3D form. Hit [w]. Hit [d] to move the pivot to the tree base. In the ChannelBox name the object “Tree”.

Import Textured 3D Assets from Maya into Unity 2 Add a texture to your objects: Download the TreeBark PNG. Open Windows > Rendering Editors > Hypershade. Create a Blinn material. In Properties name it Tree_m. Click the color checkered square to add a File node. Click the manila envelope icon to add the TreeBark texture. Apply the material: Select the Tree object, RightClickHold the Tree_m material in the library, choose Assign Material to Selection (top option). Hit [6] to see texture in Viewport. Select the Place2D node to increase tiling U and V to 5x5. Place Tree at world center, standing on the Pers grid. Modify > Freeze Transforms and Edit > Delete by Type > History. With just the object selected, go to File > Export Selection. Be sure format is set to FBX. Set file name Tree and locate in the same folder as the downloaded texture. Hit [Export].

Import Textured 3D Assets from Maya into Unity 3 In Unity, RightClick on the Project window to Import New Asset, and select BOTH the Tree FBX and texture PNG. This automatically applies the texture to the 3D object. Drag the Tree FBX into the Hierarchy. Because the Tree was located at world center in Maya with the pivot set to the bottom, the object automatically appear at world center in Unity. Drag away from your FPS Controller. Hit Play. We can walk through the tree because it has no collision applied. Hit [Esc] to turn off Play. With the Hierarchy Tree selected, in the Inspector click [Add Component] to choose Physics > Box Collider. By default, this surrounds the tree, which means we cannot pass under the branches near the trunk; the collision box block will block us. Set the Box Collider size X and Z to much smaller values to only surround the trunk (like 0.2). Hit Play to test, [Esc] to turn off Play. NOTE: We can add another Box Collider to block branches (change size and position) or chose Mesh Collider: each triangle on the mesh becomes a perfect shaped collision but with expensive performance issues . Not recommended for any object more than 100 triangles, especially in VR.

Making Interactive Objects in Unity 1 Make a new Cube and set physics: In Unity create a new GameObject > 3D Object > Cube. Name it Pickup. Lift it so it hovers above the ground, 1-2 meters. In the Inspector set the default box Collider to IsTrigger. Hit [Add Component] to apply Physics > RigidBody. Turn on IsKinematic. Create a new Script and open to add the provided code: RightClick the Project window to make a new C# script. Name it Rotator and hit [Return] to set the name inside the script as well (name must match inside script and on file). Drag the script onto the Pickup Cube. DoubleClick the C# script in the Project panel to open an installed coding environment, and paste the following code to replace the Update function (also available on the course site as a text file):        void Update () {               transform.Rotate (new Vector3 (15, 30, 45) * Time.deltaTime); }  Save and close the coding environment. Hit Play to see the cube rotate in the air. How would you make the cube rotate faster on the Y axis?

Making Interactive Objects in Unity 2 Add Audio: Download the provided Audio .WAV file, import into Unity. Drag the audio file onto Pickup. In the Inspector, under Audio Source, turn off Play on Awake. Modify the FPS Controller: Select the FPSController in the Hierarchy. In the Inspector set Tag to “Player.” [Add Component] Physics > Capsule Collider, and Set to “isTrigger”. Adjust Capsule Collider “Center” forward on Z (try 2.0). DoubleClick the Rotator script to open it again, and paste in the following below the Update function (but above the final bracket):         void OnTriggerEnter(Collider other){               if (other.gameObject.tag == "Player"){                     GetComponent<AudioSource>().Play();                     StartCoroutine(DestroyThis()); } }         IEnumerator DestroyThis(){               yield return new WaitForSeconds(0.5f);               Destroy(gameObject); }

Getting Animated Objects into Unity The easiest way to import an animated object is to make something that is intended to always animate, to loop. Consider the provided wheelbarrow_broken.fbx and wood.png. In Maya the wheel is positioned by its parent Locator and then animated to spin 360 degrees, frames 1-120. In Unity RightClick the Project window to import both the FBX and PNG. Drag the FBX into the Hierarchy. If we hit Play it does not animate, and we can walk through it. Select the FBX in the Project panel and choose the Animation tab in the Inspector. Change the name of the clip from take001 to Spin, click Loop Time, and hit [Apply]. In the Project panel open the wheelbarrow_broken.fbx to reveal the Spin clip.

Getting Animated Objects in Unity RightClick the Project panel to create an Animator Controller, and name it AnimatorWB. DoubleClick AnimatorWB to open the Animator panel. Drag the Spin clip into the Animator panel to make it the default animation state (turns orange, gets a transition arrow from “Entry” node). Finally, select the wheelbarrow in the Hierarchy. Drag AnimatorWB onto it from the Project. Hit Play to see the wheelbarrow animate!

Game Environment Art: 360 Degrees of Awesome 3D Environment Art for Games and Film differ in one critical way that gives rise to many other differences: In a 3D Film we know where the camera is going to look and make just that shot the exact composition we want. In a 3D Game the player can look in any direction, however long they want. The time they spend looking needs to be rewarded. 3D Game Art therefore needs to be (1) interesting in every direction and (2) visually navigate-able.

Game Environment Art: Layers and Contrast Interesting scenery includes: Spaces that are Layered with Dynamic and Contrasting Forms and Surfaces (materials). Layering assets means having a small interactive area surrounded by a wider non-playable area. Each is filled by forms with good positive/ negative shapes that allow us to see around them to what lies beyond. The player wants to see over shorter buildings, through archways and scaffolding, explore into crevices, around lamp-poles, police boxes, and burning wreckage. They want cover and the excitement of discovery. Build with contrasting forms and textures: wide vs thin forms, short/tall, sharp/curved, stone/metal, wood/plastic, glass/cloth.

Game Environment Art: Visually Navigate-able Visually Navigate-able is about helping the player to parse (break-down, understand) the playable area so they feel able to move around it and find what they want, especially to be able to find exits and to return to a place they have been. Theme parks like Disneyland have made a study of helping users navigate large and intense spaces: create a unique tower that can be seen from most locations (called a “weenie”). Make the sides of a playable area include regions with different materials and colors. Light can be used to obscure what is inessential and highlight where we want players to go. Motion and light will attract the user to that area.

Prep a copy of your scene assets for VR next week! Next week we plan to import your assets into Unity to display in VR using the HTC VIVE. Download the sample VR room file provided on the course site. This scene is set to Meters and the objects within are sized to work well in VR. If they are exported together in these locations, they will appear in Unity in the same relative positions. Import your scene into this file to see if your objects are the right size to view in the VIVE. When they are the correct size, hide the Room display layer. Select all of your meshes to Edit > Delete By Type > History and Modify > Freeze Transforms. Finally, File > Export Selection as a single FBX. For next week, in addition to revision progress on your film, please submit a zipped folder called YourName_VRtest including: a Maya file with a copy of your film setting An FBX containing all of your film setting objects All of your film setting textures