Skip to main content

Unity Editor Window (Part 3)

Unity Editor Hello, Unity Dev’s I am back again with Part 3 of Creating custom editor window in unity. In today’s blog we will look around: “How to load Textures files from resource folder and create our buttons.” Step1. Gather some images related to the headers of our sub-toolbars or if you are good at photoshop create some, btw I have zero skills when it comes to photoshop so I am goanna gather images from internet. Once we have are images ready drag them into respected folder under root folder Resources. It will look something like this: Step2. Scripting   Now we need to create a function which will be called once whenever we will switch from sub-tabs. Hmmmm, so how to do that!!! First create a function and name it as per your want’s I have named mine as: “MakeWindow” Then write down these lines: Create two variables a list: to store our loaded texture...

Graphic Raycaster in Unity


Ever wonder how one can click on GUI elements without using any event script on GUI components.
On button click, On value change are some event driven functions of GUI components but what if I want to perform any action without using these event driven function.
Well there are plenty of ways of doing it but the one I am going to discuss today is GRAPHIC RAYCASTER.

Scene Setup
Step1. Create two images, add any sprite to it and change their name to specify them later on. (For this tutorial purpose let’s assume penguin and polar bear)

Put the images adjacent to each other.

Script
Step2. Create a script and attach it to your canvas.
Write down the following code.


Make sure to call all the libraries.
Next is our global variables
Graphical raycaster is used to call the raycaster attach to your canvas,
Eventsystem is also used to call the event system of canvas.
PointereventData is used to know the mouse position.
Initialize both Raycaster and eventsystem in start method.


In update method whenever the user press the mouse button we initialize the pointer event data and its position as mouse position.
To understand this just try to hover your mouse over images and select eventsystem you will notice some value changing in eventsytem that; what all we are accessing with scripting.


Click on any image and boom name of that image is printed on console.
One other thing to notice in this is if you place your images one above each other the Rayacaster will always point to the lower most GUI element.
To get the name of upper GUI element you can use an array to store all the elements the Raycaster hit and then access it from your array.
Step1. Put all the GUI element above each other.


Step2.Add a list in your script globally.



And add the below red marked line to your script.

Step3. Compile and run and you will notice in your script list is formed and on click it initialize the list with GUI elements the Raycaster Hits.



I have made a game using Grapical Raycaster, so i can say that this technique comes really handy soon going to share the whole game tutorial with you guys.
Till than Happy Coding


Comments

  1. Well there you go, solving my life's problems. This turned out to be weirdly difficult to find and here you have a VERY succinct tutorial that is much faster than watching on video. And it worked brilliantly. Finally. THANK YOU!!!!!!!!

    ReplyDelete
  2. Hey is there a way to give random or specific positions to raycast at?
    Like (100,100) on screen or at the center irrespective of the mouse position.
    Thanks in advance.

    ReplyDelete

Post a Comment

Popular posts from this blog

Creating Gamobject, Adding Components and Removing Components using script.

Today we are going to learn about how we can create a gameobject add components to it or remove components from it using script. Open Unity >>Create new project>>create new scene. 1.Creating Gameobject using script Step1.In your scene hierarchy add empty gameobject and name it ScriptManager. Step2. Create a script name it as per your wants, and attach the script to ScriptManager gameobject. Step3. Write the following code:- This will create a gameobject in the hierarchy with the name specified In ” ”. In our case it’s a cube. As you can see the above script creates a gameobject and add transform component when the object is created as all gameobject have transform component attached to it from the start (e.g. Empty gameobject). In next few lines we added a box collider to our object cube, a mesh renderer and a mesh filter. Save the script and run the project. You will see a gameobject is cr...

Unity Editor Window

Editor Window (Part 1) In unity, Editor windows are windows which are created by developers to be used by developers in Editor, it’s more like a plugin for Unity editor made by You. By learning Editor Window scripting, one is able to create any type of windows to ease their work while working in editor. Official Definition: “ Create your own custom editor window that can float free or be docked as a tab, just like the native windows in the Unity interface. ” I am going to start a series which will cover almost all the topics related to EDITOR WINDOW. In this series I am going to make a “LevelDesigner” plugin dittoing the zoo tycoon GUI and functionalities. Fortunately, we will learn about: Creating Editor window, creating all types of GUI, Modifying GUI Skin, Instantiating prefabs loaded from resources, and lots more…. So, tag along with me till the end of this series and let’s see How far we can Go. I have also just started learning Unity Editor Scripting so...