Game Audio Development with Unity 5.X
上QQ阅读APP看书,第一时间看更新

Introduction to scripting in Unity

In this section, our goal is to understand how Unity scripts integrate as components on top of GameObjects. If you recall from Chapter 1, Introducing Game Audio in Unity, all the functionality built into Unity is in the form of components and components are just scripts and code. Take a look at the following diagram, which should demonstrate the basic concepts of a GameObject and Component:

A simplistic view of how components combine to create various game objects

As the diagram shows, all objects are derived from GameObject, which means, they all essentially share the same base level object. If you look at the bottom of the objects in the diagram, you will see a component called MonoBehaviour with Transform. As we will see, MonoBehaviour is the base component, that we will generally derive other components or scripts from.

Not all components have to be attached to a single GameObject. In fact, in most cases, a complex object will be made of multiple GameObjects with numerous components attached to each child GameObject.

Perhaps, it will be helpful if we took a look at what the basic structure of one of these scripts looks like, as follows:

Screenshot from MonoDevelop showing framework of starting script

The preceding screenshot shows a starting Unity C# script in the MonoDevelop editor. It is the default scripting editor for Unity. We will see how to launch MonoDevelop or other script editors later, when we get our hands on scripting.

From the Example.cs script, you can see that there are four main sections in the starting script. At the top, we define any external libraries the script may need to import. The UnityEngine library, for instance, covers most of the core game engines functionality and will almost always be a requirement.

Next, we have the class definition. You can think of a class as a template or the blueprint of a component. As we mentioned before, a GameObject may use multiple components or scripts to describe its functionality. The naming syntax of Example : MonoBehaviour denotes that the class is called Example and it derives from MonoBehaviour. In most cases, your scripts will derive from MonoBehaviour.

After that, we have a couple of methods defined. One for carrying out object initialization (Start) and the other for running every frame (Update). There are several other methods Unity provides for interacting with the game engine but certainly the most common are Start and Update.

Let's carry out an exercise which should help demonstrate some of the preceding concepts further and get us prepared to write a simple script. Follow the instructions to get started:

  1. Open up the Unity editor to the GameAudioBasics project we created in the last chapter or create a new project called GameAudioBasics. If you are unsure on how to create a new project, you should refer back to Chapter 1, Introducing Game Audio in Unity.
  2. Create a new scene by selecting File | New Scene from the menu. If you are prompted to save the scene, then go ahead and do so.
  3. The new scene should only have a Main Camera and Directional Light, as shown in the screenshot of the Hierarchy window as follows:
New scene contents
  1. Create a new GameObject by selecting GameObject | Create New from the menu. Rename the new object VirtualKeyboard and reset the Transform Position to 0,0,0 as shown in the screenshot of the Inspector window here:
Setting Transform position to 0,0,0 or 0 Transform
  1. At this point, if you look in the Scene or Game view, the new object will not be visible and that is expected. After all, the object is empty and does not contain any component to render a mesh.
  2. Click on the Add Component button at the bottom of the Inspector window. Type audio source in the search textbox. This will filter the list to just show the Audio Source component. Select that component to add it to the object.
  3. Click on the Add Component button at the bottom of the Inspector window, again. This time, type New Script in the search field. Select the arrow icon beside the New Script option to open the New Script panel as shown here:
Creating a new script called Keyboard
  1. Enter the name of Keyboard as shown in the preceding screenshot. When you are done editing, click on the Create and Add button at the bottom of the panel.
  2. Click on the gear icon beside the new Keyboard component, and from the context menu, select the Edit Script option as shown in the following screenshot:
Editing the Keyboard component script
  1. If you are new to Unity, then MonoDevelop; the default script editor will open with the new Keyboard (script). This script, aside from the name, will resemble the example script we already saw earlier.
There are a number of different editors available for developing scripts in Unity. Visual Studio or Visual Studio Code are great editors that provide many additional features over MonoDevelop. For this book, we will continue to use MonoDevelop for the few exercises we will be carrying out scripting with. If you are working with more than a couple of scripts, you will certainly want to upgrade to a fully- featured editor.
  1. Take a quick look around the MonoDevelop editor. The editor is like any other text editor you may have used before but with a number of added coding features. If you are new to scripting, don't be intimated. For the most part, we are only going to use this editor to write and edit a few lines of code.

That completes our very brief introduction to Unity scripting. In the next section, we are going to get hands-on and write a script to control audio playback in an interesting manner.