rose89543
Ranked Climber
2
MONTHS
2 2 MONTHS OF SERVICE
LEVEL 1
200 XP
Operating System
Android
Creating Scenes
In the Unity environment you will notice an Untitled object in the Hierarchy area. That is the name of the scenes by default, to change it just simply press ctrl + s and save it as Main Menu.
Creating Controllers
Now that we have the main menu scene we will now create Controllers for the game. The Controllers are game objects that handle some methods that be needed in the game later. To do that just click GameObject tab, then a drop down will show up. Then in the sub menu click Create Empty, a GameObject will appear in the Hierarchy.
Before working on the GameObject make sure to reset its transform to avoid conflict in the future.
Rename your GameObject as Game Controller, then go to the Scripts directory creates a new folder called Game Controllers. Right click the mouse button and select create then choose C# script.
Save it as GameController. The Game Controller handles all the save data of our game.
Note: To avoid script error make sure the name of your script has no space, because C# is white space sensitive. And make sure to save all Controllers inside the Game Controllers folder to avoid misplaced.
Open you’re newly created Script; you notice that there is already a block code in the script. By default the unity engine already created that part to make the developer at ease.
Now that everything is ready, we will now do our coding thing. First import these important modules
Write these variables inside the GameController class:
Then write these blocks of code inside the GameController class.
To make this work attach the script to the GameController GameObject as a component, by dragging this to the Game Controller Inspector or by clicking add component then go to script and locate the GameController script.
Creating Music Controller
The Music Controller handles the background sounds of the game; this is where you put your game sound clip as an array. Just like what you did on the Game Controller, create a new GameObject then name it as Music Controller. Then create a new C# script name it as MusicController.
Note: All the needed sounds are already in the Sounds folder.
Inside the Music Controller script, create a certain variable that we will use for our sounds
Create an instance of the script; this will prevent the script to stop running when going to other scenes.
Then create an awake method, a built in method of unity that call any script first when the game started first, call the CreateInstance() inside the awake method.
Create also ang method that initialize all the needed components InitializeVariables(), then write this code inside. After that call the method inside the Awake() method.
Then write these certain methods to make the sounds work perfectly in the game
Next you need to attach the script to the Music Controller as a component; it is just the same like you did on Game Controller. After that add a new component called AudioSource. It manages the sounds of the game, and uncheck the Play On Wake because it will be done automatically with the script. Then from the Sounds directory drag all the sound into the corresponding script variables.
Creating Main Menu Controller
The Main Menu Controller is the one that handles where you start the game, and also trigger some events that necessary needed in the game. To do this just simply creates a new GameObject name it as Main Menu Controller. Create a script and name it as MainMenuController.
Inside the Main Menu Controller script, create a certain variable that we will use. Write this code inside the Main Menu Controller class.
Next you need to attach the script to the inspector of Main Menu Controller as a component.
Note: When using a UI Components in the script you will just need to import some modules
And for loading some scenes you will also need this
Slicing Sprites
When slicing the sprite sheet into a several images you need to select first your image, then in Sprite Mode choose Multiple after that click Sprite Editor. A new Pop up window will appear from here click the Slice on the menu bar, and then Slice. It will automatically slice the sheet of a sprite.
Note: All the needed sprite in the game are already in Sprites folder.
Main Menu Canvas
The Main Menu UI is a GameObject that hold a several Children component. To Create a UI click the GameObject menu then choose UI then Image. You notice that it automatically create a UI Canvas then your image as a child of it, and also a new object will be created automatically called EventSytem.
Then rename Canvas as Main Menu Canvas, and also Image as Background. In the Main Menu Canvas set the values same as the image shown below.
To make the Background Image locate your sprite from the Sprites directory then add it to the Background GameObject as a component.
Now that we have the image we will now add a button Play and Settings. Then remove the child text of button, then locate and add a sprite to their components.
Then attach the Main Menu Controller script to the Play and Settings Button in the RuntimeController.
Main Menu Canvas - Exit Panel
We will now create the Exit Panel, exit panel take care of the confirmation prompt that closes the app. Create a panel then name it as Exit Panel Background. And create another panel by just right clicking the GameObject then set its name as Exit Panel and set the components as shown in the inspector below.
Exit Panel Background
Exit Panel
Then add a several children (Text, Buttons) for the Exit Panel. Then set the values of each component as shown below.
Text
Buttons
Main Menu Canvas - Settings Panel
We will now create the Settings Panel; it takes care of displaying the settings options to change the gameplay. Create a panel then names it as Settings Panel Background. And create another panel by just right clicking the GameObject then set its name as Settings Panel and set the components as shown in the inspector below.
Settings Panel Background
Settings Panel
Then add a several children (Text, Toggle, Button) for the Settings Panel. Then set the values of each component as shown below.
Text
Button
Toggle
Now that you’re done will the components there is one thing we need to do. Attach all the needed components to the MainController to be able to run the application successfully.
Note: Due to the size or complexity of this submission, the author has submitted it as a .zip file to shorten your download time. After downloading it, you will need a program like Winzip to decompress it.
Virus note: All files are scanned once-a-day by SourceCodester.com for viruses, but new viruses come out every day, so no prevention program can catch 100% of them.
FOR YOUR OWN SAFETY, PLEASE:
1. Re-scan downloaded files using your personal virus checker before using it.
2. NEVER, EVER run compiled files (.exe's, .ocx's, .dll's etc.)--only run source code.
Download
Android
Creating Scenes
In the Unity environment you will notice an Untitled object in the Hierarchy area. That is the name of the scenes by default, to change it just simply press ctrl + s and save it as Main Menu.
data:image/s3,"s3://crabby-images/732db/732db46b4b193e042d77fbbd1c62c01f9a7e0a77" alt="6_1.png"
Creating Controllers
Now that we have the main menu scene we will now create Controllers for the game. The Controllers are game objects that handle some methods that be needed in the game later. To do that just click GameObject tab, then a drop down will show up. Then in the sub menu click Create Empty, a GameObject will appear in the Hierarchy.
data:image/s3,"s3://crabby-images/e1bc4/e1bc45c5952901f34b175fa581a0dbea4b765f93" alt="7_1.png"
Before working on the GameObject make sure to reset its transform to avoid conflict in the future.
data:image/s3,"s3://crabby-images/783c1/783c1b5afcf5195e178fc355ed6f7ac89b442cc9" alt="8_1.png"
Rename your GameObject as Game Controller, then go to the Scripts directory creates a new folder called Game Controllers. Right click the mouse button and select create then choose C# script.
data:image/s3,"s3://crabby-images/c1bf8/c1bf809a17fa764b116c66c7fe3d516e251677ff" alt="9_1.png"
Save it as GameController. The Game Controller handles all the save data of our game.
Note: To avoid script error make sure the name of your script has no space, because C# is white space sensitive. And make sure to save all Controllers inside the Game Controllers folder to avoid misplaced.
Open you’re newly created Script; you notice that there is already a block code in the script. By default the unity engine already created that part to make the developer at ease.
- using
System.Collections
;
- using
System.Collections.Generic
;
- using
UnityEngine
;
- public
class
GameController :
MonoBehaviour {
- // Use this for initialization
- void
Start (
)
{
- }
- // Update is called once per frame
- void
Update (
)
{
- }
- }
Now that everything is ready, we will now do our coding thing. First import these important modules
- using
System
;
- using
System.IO
;
- using
System.Runtime.Serialization.Formatters.Binary
;
Write these variables inside the GameController class:
- public
static
GameController instance;
- public
bool
isMusicOn;
- public
bool
isGameStartedFirstTime;
- public
bool
[
]
levels;
- public
int
[
]
highscore;
- public
int
score;
- public
int
currentLevel;
- private
GameData data;
Then write these blocks of code inside the GameController class.
- void
Awake(
)
{
- CreateInstance (
)
;
- }
- // Use this for initialization
- void
Start (
)
{
- InitializeGameVariables (
)
;
- }
- void
CreateInstance(
)
{
- if
(
instance !=
null
)
{
- Destroy (
gameObject)
;
- }
else
{
- instance =
this
;
- DontDestroyOnLoad (
gameObject)
;
- }
- }
- void
InitializeGameVariables(
)
{
- Load (
)
;
- if
(
data !=
null
)
{
- isGameStartedFirstTime =
data.
GetIsGameStartedFirstTime
(
)
;
- }
else
{
- isGameStartedFirstTime =
true
;
- }
- if
(
isGameStartedFirstTime)
{
- isGameStartedFirstTime =
false
;
- isMusicOn =
true
;
- levels =
new
bool
[
15
]
;
- highscore =
new
int
[
levels.
Length
]
;
- levels [
0
]
=
true
;
- for
(
int
i =
1
;
i <
levels.
Length
;
i++
)
{
- levels [
i]
=
false
;
- }
- for
(
int
i =
0
;
i <
highscore.
Length
;
i++
)
{
- highscore [
i]
=
0
;
- }
- data =
new
GameData (
)
;
- data.
SetIsMusicOn
(
isMusicOn)
;
- data.
SetIsGameStartedFirstTime
(
isGameStartedFirstTime)
;
- data.
SetHighScore
(
highscore)
;
- data.
SetLevels
(
levels)
;
- Save (
)
;
- Load (
)
;
- }
else
{
- isGameStartedFirstTime =
data.
GetIsGameStartedFirstTime
(
)
;
- isMusicOn =
data.
GetIsMusicOn
(
)
;
- highscore =
data.
GetHighScore
(
)
;
- levels =
data.
GetLevels
(
)
;
- }
- }
- public
void
Save(
)
{
- FileStream file =
null
;
- try
{
- BinaryFormatter bf =
new
BinaryFormatter(
)
;
- file =
File.
Create
(
Application.
persistentDataPath
+
"/data.dat"
)
;
- if
(
data !=
null
)
{
- data.
SetIsMusicOn
(
isMusicOn)
;
- data.
SetIsGameStartedFirstTime
(
isGameStartedFirstTime)
;
- data.
SetHighScore
(
highscore)
;
- data.
SetLevels
(
levels)
;
- bf.
Serialize
(
file, data)
;
- }
- }
catch
(
Exception e)
{
- Debug.
LogException
(
e, this
)
;
- }
finally
{
- if
(
file !=
null
)
{
- file.
Close
(
)
;
- }
- }
- }
- public
void
Load(
)
{
- FileStream file =
null
;
- try
{
- BinaryFormatter bf =
new
BinaryFormatter(
)
;
- file =
File.
Open
(
Application.
persistentDataPath
+
"/data.dat"
, FileMode.
Open
)
;
- data =
bf.
Deserialize
(
file)
as
GameData;
- }
catch
(
Exception e)
{
- Debug.
LogException
(
e, this
)
;
- }
finally
{
- if
(
file !=
null
)
{
- file.
Close
(
)
;
- }
- }
- }
- }
- [
Serializable]
- class
GameData{
- private
bool
isGameStartedFirstTime;
- private
bool
isMusicOn;
- private
bool
[
]
levels;
- private
int
[
]
highscore;
- public
void
SetIsGameStartedFirstTime(
bool
isGameStartedFirstTime)
{
- this
.
isGameStartedFirstTime
=
isGameStartedFirstTime;
- }
- public
bool
GetIsGameStartedFirstTime(
)
{
- return
this
.
isGameStartedFirstTime
;
- }
- public
void
SetIsMusicOn(
bool
isMusicOn)
{
- this
.
isMusicOn
=
isMusicOn;
- }
- public
bool
GetIsMusicOn(
)
{
- return
this
.
isMusicOn
;
- }
- public
void
SetHighScore(
int
[
]
highscore)
{
- this
.
highscore
=
highscore;
- }
- public
int
[
]
GetHighScore(
)
{
- return
this
.
highscore
;
- }
- public
void
SetLevels(
bool
[
]
levels)
{
- this
.
levels
=
levels;
- }
- public
bool
[
]
GetLevels(
)
{
- return
this
.
levels
;
- }
To make this work attach the script to the GameController GameObject as a component, by dragging this to the Game Controller Inspector or by clicking add component then go to script and locate the GameController script.
Creating Music Controller
The Music Controller handles the background sounds of the game; this is where you put your game sound clip as an array. Just like what you did on the Game Controller, create a new GameObject then name it as Music Controller. Then create a new C# script name it as MusicController.
Note: All the needed sounds are already in the Sounds folder.
Inside the Music Controller script, create a certain variable that we will use for our sounds
- public
static
MusicController instance;
- public
AudioClip background, gameplay, loseSound, winSound;
- [
HideInInspector]
- public
AudioSource audioSource;
Create an instance of the script; this will prevent the script to stop running when going to other scenes.
- void
CreateInstance(
)
{
- if
(
instance !=
null
)
{
- Destroy (
gameObject)
;
- }
else
{
- instance =
this
;
- DontDestroyOnLoad (
gameObject)
;
- }
- }
Then create an awake method, a built in method of unity that call any script first when the game started first, call the CreateInstance() inside the awake method.
Create also ang method that initialize all the needed components InitializeVariables(), then write this code inside. After that call the method inside the Awake() method.
- void
InitializeVariables(
)
{
- audioSource =
GetComponent<
AudioSource>
(
)
;
- }
- void
Awake(
)
{
- CreateInstance (
)
;
- InitializeVariables (
)
;
- }
Then write these certain methods to make the sounds work perfectly in the game
- // Use this for initialization
- void
Start (
)
{
- }
- // Update is called once per frame
- void
Update (
)
{
- }
- void
CreateInstance(
)
{
- if
(
instance !=
null
)
{
- Destroy (
gameObject)
;
- }
else
{
- instance =
this
;
- DontDestroyOnLoad (
gameObject)
;
- }
- }
- void
InitializeVariables(
)
{
- audioSource =
GetComponent<
AudioSource>
(
)
;
- }
- public
void
PlayBgMusic(
)
{
- if
(
background)
{
- audioSource.
clip
=
background;
- audioSource.
loop
=
true
;
- audioSource.
Play
(
)
;
- }
- }
- public
void
GameplaySound(
)
{
- if
(
gameplay)
{
- audioSource.
clip
=
gameplay;
- audioSource.
loop
=
true
;
- audioSource.
Play
(
)
;
- }
- }
- public
void
StopAllSounds(
)
{
- if
(
audioSource.
isPlaying
)
{
- audioSource.
Stop
(
)
;
- }
- }
Next you need to attach the script to the Music Controller as a component; it is just the same like you did on Game Controller. After that add a new component called AudioSource. It manages the sounds of the game, and uncheck the Play On Wake because it will be done automatically with the script. Then from the Sounds directory drag all the sound into the corresponding script variables.
data:image/s3,"s3://crabby-images/ffb90/ffb90d0bed8f7d50a47664cca4123c9c8a4c8d2b" alt="10_1.png"
Creating Main Menu Controller
The Main Menu Controller is the one that handles where you start the game, and also trigger some events that necessary needed in the game. To do this just simply creates a new GameObject name it as Main Menu Controller. Create a script and name it as MainMenuController.
Inside the Main Menu Controller script, create a certain variable that we will use. Write this code inside the Main Menu Controller class.
- public
GameObject settingsPanel, exitPanel;
- public
Toggle soundToggle;
- // Use this for initialization
- void
Start (
)
{
- if
(
GameController.
instance
!=
null
&&
MusicController.
instance
!=
null
)
{
- if
(
GameController.
instance
.
isMusicOn
)
{
- MusicController.
instance
.
PlayBgMusic
(
)
;
- soundToggle.
isOn
=
true
;
- }
else
{
- MusicController.
instance
.
StopAllSounds
(
)
;
- soundToggle.
isOn
=
false
;
- }
- }
- }
- // Update is called once per frame
- void
Update (
)
{
- if
(
Input.
GetKeyDown
(
KeyCode.
Escape
)
)
{
- if
(
exitPanel.
activeInHierarchy
)
{
- exitPanel.
SetActive
(
false
)
;
- }
else
{
- exitPanel.
SetActive
(
true
)
;
- }
- if
(
settingsPanel.
activeInHierarchy
)
{
- settingsPanel.
SetActive
(
false
)
;
- }
- }
- }
- public
void
PlayButton(
)
{
- SceneManager.
LoadScene
(
"Level Menu"
)
;
- }
- public
void
SettingsButton(
)
{
- settingsPanel.
SetActive
(
true
)
;
- }
- public
void
CloseSettingsButton(
)
{
- settingsPanel.
SetActive
(
false
)
;
- }
- public
void
SoundToggle(
)
{
- if
(
soundToggle.
isOn
)
{
- GameController.
instance
.
isMusicOn
=
true
;
- MusicController.
instance
.
PlayBgMusic
(
)
;
- GameController.
instance
.
Save
(
)
;
- }
else
{
- GameController.
instance
.
isMusicOn
=
false
;
- MusicController.
instance
.
StopAllSounds
(
)
;
- GameController.
instance
.
Save
(
)
;
- }
- }
- public
void
YesButton(
)
{
- Application.
Quit
(
)
;
- }
- public
void
NoButton(
)
{
- exitPanel.
SetActive
(
false
)
;
- }
Next you need to attach the script to the inspector of Main Menu Controller as a component.
Note: When using a UI Components in the script you will just need to import some modules
- using
UnityEngine.SceneManagement
;
And for loading some scenes you will also need this
- using
UnityEngine.UI
;
Slicing Sprites
When slicing the sprite sheet into a several images you need to select first your image, then in Sprite Mode choose Multiple after that click Sprite Editor. A new Pop up window will appear from here click the Slice on the menu bar, and then Slice. It will automatically slice the sheet of a sprite.
data:image/s3,"s3://crabby-images/3a3f0/3a3f01904e6545735c70e4cf531ce9ef02371114" alt="11_1.png"
data:image/s3,"s3://crabby-images/2d8c0/2d8c0d71a0fdda1c74ab9a1110360e298d8c3179" alt="12_1.png"
Note: All the needed sprite in the game are already in Sprites folder.
Main Menu Canvas
The Main Menu UI is a GameObject that hold a several Children component. To Create a UI click the GameObject menu then choose UI then Image. You notice that it automatically create a UI Canvas then your image as a child of it, and also a new object will be created automatically called EventSytem.
data:image/s3,"s3://crabby-images/1f5e8/1f5e8d96e51ff3b41b6cb7dda416705f830ea6b5" alt="13_1.png"
Then rename Canvas as Main Menu Canvas, and also Image as Background. In the Main Menu Canvas set the values same as the image shown below.
data:image/s3,"s3://crabby-images/1bc41/1bc41f94c5749b1fe2cf435d04f5afbf0725e1f8" alt="14_1.png"
To make the Background Image locate your sprite from the Sprites directory then add it to the Background GameObject as a component.
data:image/s3,"s3://crabby-images/196fc/196fc37aa291a88b7635ab2e18ba54d46c588109" alt="15_1.png"
Now that we have the image we will now add a button Play and Settings. Then remove the child text of button, then locate and add a sprite to their components.
Then attach the Main Menu Controller script to the Play and Settings Button in the RuntimeController.
data:image/s3,"s3://crabby-images/9624a/9624a590c77d242938bb6e253e583093f8591387" alt="16_1.png"
data:image/s3,"s3://crabby-images/8a21c/8a21cba963e0f8d7ebd7ece4a5897d7a0ab2a8c2" alt="17_1.png"
Main Menu Canvas - Exit Panel
We will now create the Exit Panel, exit panel take care of the confirmation prompt that closes the app. Create a panel then name it as Exit Panel Background. And create another panel by just right clicking the GameObject then set its name as Exit Panel and set the components as shown in the inspector below.
Exit Panel Background
data:image/s3,"s3://crabby-images/cd51e/cd51ea4ffb697683ed091f0f644ca3b4da366a4d" alt="18_1.png"
Exit Panel
data:image/s3,"s3://crabby-images/6038b/6038b44a1d1011299acf83ec69e38566c4875fa7" alt="19_1.png"
Then add a several children (Text, Buttons) for the Exit Panel. Then set the values of each component as shown below.
Text
data:image/s3,"s3://crabby-images/c6ed0/c6ed0b59fd2334a04fd6a2fc401696a7d9593215" alt="20_2.png"
Buttons
data:image/s3,"s3://crabby-images/b1b76/b1b7646e70e3fd9b6f3e1a13544a759c6829a5da" alt="21_1.png"
Main Menu Canvas - Settings Panel
We will now create the Settings Panel; it takes care of displaying the settings options to change the gameplay. Create a panel then names it as Settings Panel Background. And create another panel by just right clicking the GameObject then set its name as Settings Panel and set the components as shown in the inspector below.
Settings Panel Background
data:image/s3,"s3://crabby-images/41e30/41e3013c00f284339efd4d70c7b8c1f4ae7f92db" alt="22_3.png"
Settings Panel
data:image/s3,"s3://crabby-images/5c80f/5c80f6e6a0623e34be14b75304e93de9ff7c948d" alt="23_1.png"
Then add a several children (Text, Toggle, Button) for the Settings Panel. Then set the values of each component as shown below.
Text
data:image/s3,"s3://crabby-images/48aea/48aeaf99033a95849a89c6d9d4846ef1b22a8979" alt="24_2.png"
Button
data:image/s3,"s3://crabby-images/aed2c/aed2cb87e26a17203d99d4e08138979672612ead" alt="25_2.png"
Toggle
data:image/s3,"s3://crabby-images/184d3/184d3237edac6194928e4024c7e8e580e94e9a98" alt="26_2.png"
data:image/s3,"s3://crabby-images/fe2da/fe2da04f3e90cd9354b34d590db22a02a67f3b45" alt="27_2.png"
data:image/s3,"s3://crabby-images/62ac4/62ac46b7c355464a7ffe5de6c75ebd079bc31219" alt="28_2.png"
Now that you’re done will the components there is one thing we need to do. Attach all the needed components to the MainController to be able to run the application successfully.
data:image/s3,"s3://crabby-images/e5be1/e5be197bcbcacc5750aa0c7c294ad788ea6648e9" alt="29_2.png"
Note: Due to the size or complexity of this submission, the author has submitted it as a .zip file to shorten your download time. After downloading it, you will need a program like Winzip to decompress it.
Virus note: All files are scanned once-a-day by SourceCodester.com for viruses, but new viruses come out every day, so no prevention program can catch 100% of them.
FOR YOUR OWN SAFETY, PLEASE:
1. Re-scan downloaded files using your personal virus checker before using it.
2. NEVER, EVER run compiled files (.exe's, .ocx's, .dll's etc.)--only run source code.
Download
You must upgrade your account or reply in the thread to view the hidden content.