Hire the top 3% of freelance Unity or Unity3D developers.

Toptal is a marketplace for top Unity or Unity3D developers, engineers, programmers, coders, architects, and consultants. Top companies and start-ups choose Toptal Unity or Unity3D freelancers for their mission-critical software projects.

No-Risk Trial, Pay Only If Satisfied.

We've been blown away by the level of talent we've been able to hire through Toptal.

Brad Rozran, Optimizely

Trusted by leading brands and startups

Our Exclusive Network of Unity or Unity3D Developers

Elliot Pjecha

Unity or Unity3D Developer

Elliot has been developing games for eight years, five of which were spent exclusively in Unity3D. He has done substantial work in extending Unity3D's funct...ionality, robustly implementing traditional C# paradigms via Unity's user interface. He is an articulate, effective communicator who prides himself on his creativity and flexibility throughout all phases of development, and enjoys working on teams of all sizes. 

Hire Elliot

Maicon Brauwers

Unity or Unity3D Developer

Maicon has enjoyed a great passion for computer programming since the age of 15. He is currently focused on building mobile apps. He loves the challenge of... solving complex problems and creating truly innovative solutions. 

Hire Maicon

Michael Tkachuk

Unity or Unity3D Developer

Michael is a responsible, communicative, creative, and innovative person. He loves when he can get jobs done efficiently and in a rational way. He's always... open to new ideas and discussions, and he respects other points of view while always trying to find win-win solutions for existing problems. 

Hire Michael

Antoon Groenewoud

Unity or Unity3D Developer

Antoon is a top programmer and designer with experience ranging from entrepreneur to freelancer to CTO. He is active within the games industry with a knack... for novel, complex solutions, and the ability to quickly integrate into any team and adapt to the problem at hand be it UI/UX or back-end or anything in between. 

Hire Antoon

Alexey Pelykh

Unity or Unity3D Developer

Alexey is a seasoned software engineer with past work in 3D and computer game development as well as extensive R&D experience. Currently, he works mostly wi...th mobile and embedded platforms. He excels in the development of low-level software but does not shy away from UI design. 

Hire Alexey

Eduardo Dias da Costa

Unity or Unity3D Developer

Eduardo is a developer with over a decade of experience focused on client and front-end applications. He is always open to learn and take up new challenges... that can make him handle new languages and/or technologies. He specializes in computer graphics, image processing, game development, tools development (CLI, desktop, etc.), and UI/UX/front-end development. 

Hire Eduardo

Javier Waitzel

Unity or Unity3D Developer

Javier is a top engineer and entrepreneur who is passionate about new technologies and software development. He has experience in mobile application design... and development, and he's worked extensively with multidisciplinary teams bringing innovative ideas to every project. 

Hire Javier

Matias Santiago Pan

Unity or Unity3D Developer

Matias is a 29-year-old Argentinian computer scientist who has been working with iOS since it was launched to the public. He loves working on great-looking... apps that focus on user experience and usability. 

Hire Matias

Jakov Duzevic

Unity or Unity3D Developer

Jakov is a Unity developer with five years of experience. He specializes in 3D game development ranging from gameplay, engine architecture, and networking t...o UI and tools creation. He favors the Microsoft tool stack for development and production and holds a master's degree in computer science. 

Hire Jakov

Luko Gjenero

Unity or Unity3D Developer

Luko is a seasoned developer with contributions to numerous large-scale projects currently in use by Croatian national organizations. He is schooled in elec...trotechnics, and has published several important research papers on a variety of topics. He enjoys being faced with challenging problems. 

Hire Luko

Cory Bechtel

Unity or Unity3D Developer

Cory is a Game Developer who has created addictive, engaging games for the iOS, Android, and Amazon app stores. Highly experienced in C# and the Unity engin...e, his goal is to create great games that users want to play over and over again. 

Hire Cory

Hire Unity or Unity3D Developers Seamlessly with Toptal

Talk to One of Our Industry Experts
A Toptal director of engineering will work you to understand your goals, technical needs, and team dynamics.
Work With Hand-Selected Talent
Within days, we'll introduce you to the right Unity or Unity3D developer for your project. Average time to match is under 24 hours.
The Right Fit, Guaranteed
Work with your new Unity or Unity3D developer for a trial period (pay only if satisfied), ensuring they're the right fit before starting the engagement.


  • How are Toptal Unity or Unity3D developers different?

    At Toptal, we thoroughly screen our Unity or Unity3D developers to ensure we only supply experts of the highest caliber. Of the more than 100,000 people who apply to join the Toptal network each year, we accept fewer than 3%. You'll work with engineering experts (never generalized recruiters or HR reps) to understand your goals, technical needs, and team dynamics. The end result: expertly-matched talent from our network, hand-selected to fit your business needs.

  • What is the no-risk trial period for Unity or Unity3D developers?

    We make sure that each engagement between you and your Unity or Unity3D developer begins with a trial period of up to two weeks. This means that you have time to confirm the engagement will be successful. If you're completely satisfied with the results, we'll bill you for the time and continue the engagement for as long as you'd like. If you're not completely satisfied, you won't be billed. From there, we can either part ways, or we can provide you with another expert who may be a better fit and with whom we will begin a second, no-risk trial.

  • How fast can I hire Unity or Unity3D developers through Toptal?

    Depending on availability and how fast you can progress, you could start your no-risk trial with a Unity or Unity3D developer within 48 hours of signing up. Most of our engagements start within 2 weeks of discussing your project with us.

Tap Into World-Class Talent

  • Trusted Experts Only

    All of our talent are seasoned experts who ramp up quickly, readily contribute as core team members, and work with you to minimize onboarding time.

  • The Right Fit

    We have a knack for matching you with the right fit. Start working with your new hire on a no-risk trial period, paying only if satisfied.

  • Scale as Needed

    Hire in under 2 weeks and scale your team up or down as needed, no strings attached.

  • Seamless Hiring

    We handle all aspects of billing, payments, and NDA’s. Let us take care of the overhead while you focus on building great products.

  • Flexible Engagements

    Choose the engagement type that suits your needs — hourly, part-time, or full-time — with the ability to change anytime.

  • Expert Talent Matching

    Focus on your project and enjoy support from your dedicated account executive and expert talent matcher.

Guide to Hiring a great Unity or Unity3D Developer

Currently, there are 4.5 million registered Unity3D developers, and it is by far the most popular game development software platform. It’s accessible to hobbyists and professionals alike, and thus, you can expect developers of all calibers during your interview process. Finding the right engineer for your specific Unity3D needs can be challenging. This hiring guide will help you pinpoint the ideal developer for your project by showing you not only how to identify the top candidates, but also how to customize your interview process to suit your particular needs.

How to Hire a Great Unity3D Developer

The Challenge

At the moment of writing this guide, there are 4.5 million registered Unity3D developers, and it is far more popular than any other game development software. It is accessible to hobbyist and professionals alike, and thus you can expect developers of all caliber during your interview process. However, that is only half of the battle, as there are a wide array of skillsets within the Unity3D development platform. This guide will not only help you identify a perfect candidate who is a real Unitiy3D expert, but it will also help you ensure that candidate is the perfect fit for your project’s needs.

Unity3D is by far the most popular game development software

Unity3D is by far the most popular game development software

Narrowing Candidates by Requirements

Unity is extremely diverse, and thus being a Unity3D developer can mean having experience in a wide range of topics. This is a critical point to make, since your interviewee could be the top Unity3d developer, but still not be a fit for your needs because their skill set may not align.

Ideally, you will want a candidate who has “done it before”. For example, if you are making a 3D console game, he should have shipped console game before. Alternatively, a candidate may be an excellent 2D mobile developer, and while he could potentially pick up 3D skills quickly that isn’t the point of this discussion. To go even further, even if he has experience on the particular platform you are targeting, you may want to focus even more narrowly on the tasks he performed and compare them to the tasks you require. A Unity3D developer who shipped a major 3D mobile title might sound very impressive, but if his experience was solely UI/UX for that title, he might not be able to help you create the AI or game logic for your upcoming title.

Thus, it is critical for you to define which platforms you are targeting, and what skill sets you will require. Here are some questions to answer internally before you begin your search.

Q: Which Platforms will you be supporting?

Unity3D supports a wide range of platforms, including Mobile, Console, Web, PC, Mac, VR, AR, and more.

While Unity does a good job of making deployment to each platform fairly painless, it is important that the candidate has shipped at least one title on your desired platform, as each platform has particular nuances that will be uncovered during development. For example, some libraries and features are not supported by the WebGL target due to HTML5 canvas security limitations.

Q: Is the project going to be 2D or 3D?

While Unity3D was originally 3D only and 2D with third party plugins, it now supports 2D projects natively. Many developers will have experience in both, but some may be more inclined in one of the two environments, as they each have their technical hurdles. For example, 3D development may involve more extensive cameras, lighting, textures, and models, while 2D development may focus more on sprites, animations, and tweening.

Q: Is it an existing project or a new project, and which language is used?

If you are dealing with an existing project, you will need to figure out if the interviewee is proficient in UnityScript or C#, as Unity3D supports both languages and your source code typically uses one. It is important to test their general C# or UnityScript programming skills, in addition to the questions laid out in this document.

Q: Will the project integrate with a back-end server?

Does the applicant have experience with Unity3D’s NetworkManager class, or experience working with a custom back-end using RESTful API? An example question to verify applicants experience using back-end services could be: “How would you access a RESTful API from Unity3D?” Possible solutions include using Unity’s WWW class, HttpWebRequest, or using Unity3D’s asset store and downloading Best HTTP. The Best HTTP costs money, but it is worth the expense in many cases as the WWW class is missing a few features and HttpWebRequest is not supported on all platforms.

Q: Will the project have a single player AI?

Assessing the extent of someone’s AI abilities are outside the scope of this guide. However, a good starting point may be to ask how they would go about navigating between two squares on a grid. Solutions should include them recursively checking adjacent squares while tracking locations they have already visited until they reach the destination. A follow-up question could be how to ensure the solution finds the shortest distance. In this case, they will need to track the distance traveled during the recursion and ignore any routes that go beyond the minimum distance found.

Q: Will the interviewee be in charge of UI/UX?

There are a variety of UI tools within Unity3D. The question is, which ones do they have the most experience with and which do they prefer? An interviewee should know the pros and cons of each, and be able to describe why they favor one over another.

The latest Unity version 5 offers its own UI uGUI, but in its current form it is somewhat limited and is missing many components that could be considered standard, such as drop down menus. Other highly used UI platforms are NGUI and 2DToolKit. NGUI is probably the most popular alternative, due to the number of widgets that it supports out of the box, but it can be complex. Bottom line, Unity’s native uGUI should be used as long as its fundamental features cover the needs of the project. If it does not, then NGUI is worth considering. Alternatively, if the interviewee has chosen a different toolset, then they should be able to give rational reasons as to why.

Technical Questions

Q: Explain what a prefab is, and when it is used.

A prefab is a template for a GameObject. It contains the object itself, as well as the children and behaviors that are attached to it. Prefabs are useful in that they can be reused, and if you make changes to the prefab, it will update all instances in the project. For example, in the game Asteroids a prefab could be used for the asteroid. The developer could spawn multiple identical asteroids throughout space by referencing the prefab. Later, if the artist wants to change the color of all of the asteroids in the game, it would be as simple as changing one texture in a single prefab.

This should be a straightforward question for a Unity3D developer of any level, but it leads to some more challenging questions below.

Q: In the game Asteroids, when an asteroid explodes, it is replaced by three smaller asteroids. What would be the drawback of instantiating three prefabs for this event?

Instantiating prefabs during runtime within Unity can be very costly on the CPU. In CPU extensive games or meager computer systems, you will see noticeable drops in framerate whenever instantiating occurs. Thus, it is typically poor design to instantiate prefabs in the middle of the action, as when the asteroid explodes the player will experience a hitch or lag.

Q: Explain how you can mitigate the performance limitations of instantiating prefabs.

One acceptable practice for reducing the lag mentioned in the question before is to create object pools. An object pool is an array of objects that are instantiated before being used. This is especially useful when there are a large number of items that will be utilized, such as the asteroids in our example. A script could load up the desired number of objects, and store references to each in the array. As asteroids spawn, they would be removed from the array and made visible in the scene. As asteroids explode, they would be deleted from the scene and stored back in the array to be reused.

An alternative solution would be to have the objects loaded within the scene. This solution typically works best when there are a small number of objects that will be used, and then it is easy to manage the assets in a scene. A good example of this would be a particle explosion every time the player’ ship explodes. An object pool would not make sense here, considering there would only be a need for one such prefab in the scene, assuming your ship can only explode once. But you also want to avoid instantiating the effect at runtime, since it may lag or hitch during the death sequence. Thus, in this scenario, keeping a reference in the scene may be the best option.

Q: Explain the downsides of using object pools, and how can you mitigate them?

The problem that arises with object pools is that each of these objects need to be stored in memory. This can be an issue on low memory devices such as mobile, as you may not be able to store references to everything that could be spawned within the memory allotted.

Mitigating this issue is a balancing act between memory crashes and CPU lag. First and foremost, compile time macros should be used to ensure optimizations and cuts only affect low-end machines, and that object pools are still used to the fullest on high-end machines. On the low-end machines, object pools and caching should be used with caution in that only the high-frequency options should be put in the pool, and at the minimum number of objects possible for a better experience. Low-frequency objects may either need to be spun up at runtime, causing the occasional lag on the low-end device, or design decisions may need to be made to remove those objects for the low-end machine. For example, particle effects and explosions may need to be withdrawn from the low-end experience. A smooth running game without particles is much preferred to a laggy game with them. Cached assets should be cleared as soon as they are no longer used. Some machines provide a low memory warning which can be helpful in determining when the cache needs to be cleared.

Q: Discuss how you would structure the classes of an Asteroids game?

This is a very broad question with many acceptable answers. The point of the question is to focus on when the developer chooses to use composition versus inheritance. If they do not answer adequately enough, you may need to steer them in the right direction, or ask them directly to describe the pros and cons of composition versus inheritance in a Unity environment.

First and foremost, inheritance means a class extends another class. An example would be a class called Orange that could extend a parent class called Fruit. The class Fruit would define the properties such as seed type, for example. Orange inherits properties from the Fruit class, so it has seeds as well, but it also extends the Fruit class with additional properties such as having a peel.

Composition, on the other hand, is used when combining multiple classes. In the Orange example above, there would be no Fruit class. Instead, we could have a class for Seeds and another for Peel. The Orange would then store references to the Seeds class and the Peel class, and thus it would be composed of those classes.

Unity uses composition extensively, as its foundation relies on the entity component or entity behavior architectural pattern. In this regard, everything in a scene is considered a GameObject, or entity. Each GameObject contains a list of behaviors or components that define it, which is by definition composition.

Therefore, back to the original Asteroids question. The interviewee should construct their classes in a way to take advantage of the entity behavior model. In the game Asteroids, there are two types of enemies, asteroids and alien ships. Below we will look at how one could break down these enemy types into classes by comparing implementations using inheritance versus composition.

Inheritance In an inheritance setup, there would most likely be three classes needed. A base class which we will call Enemy, and then two derived classes which we will call Asteroid and AlienShip. The base class would handle all functionality shared by both the Asteroid and AlienShip such as tracking hit points. The derived classes would add additional functionality. For example, the derived AlienShip could handle the ship’s flying and shooting functionality.

Composition In a composition setup, we would most likely start with the same Enemy class that handles the hit points. But instead of extending it, we would use Unity’s entity behavior model to apply additional behaviors (classes) to it that add the functionality we seek. To create the alien ship, we could create a class that handles movement (MovementBehavior) and another that handles shooting (ShootingBehavior). We would then attach all three classes, Enemy, MovementBehavior, and ShootingBehavior to a GameObject to create the alien ship.

At first glance composition seems more intuitive, but as the game design grows in complexity and new features are added, it becomes exceedingly difficult to manage as each change may alter all derived classes. Composition, on the other hand, is immensely flexible and allows developers to create new features, or in this case enemies, just by adding and removing behaviors. That being said, both setups can be appropriate depending on the scenario. The key during the interview is to make sure the interviewee knows that both options exist, and can explain why they chose one over the other.

Q: Explain what Draw Calls are.

Draw Calls are the number of times the processor needs to change materials when rendering the scene. If there are 100 objects in a scene, and each have unique materials, then there would be 100 draw calls. However, if each object used the same material or sprite sheet, then all 100 objects could be drawn in a single draw call.

Q: How can you reduce Draw Calls?

Draw calls can be used by batching images to use the same material or sprite sheet. For example, in a 2D game we could have a character who has sprites for his head, body, and legs. Each sprite is unique, and thus it would take three draw calls to render the character. To reduce this, we could combine all three sprites into a single sprite sheet, and then draw calls would be reduced to one since all three sections could be drawn at once.

A good follow-up question here would be to say the character picks up a cape which appears above the head but behind the body in z-order. The cape is on a different sprite sheet than the character. How many draw calls would it take to render the character and cape on the two sprite sheets? The answer is three. Even though there are two sprite sheets involved, z-order causes three switches to occur. First, the character sprite sheet is used to draw the head. Then, the cape sprite sheet is used to draw the cape. In the end, the character sprite sheet is used to draw the body and legs. The body and legs can not be drawn at the same time as the head since the cape appears between them.

Q: How would you find a memory leak?

The key to this question is to make sure the developer knows the ins and outs of the profiler and uses them often. The profiler has a memory section which allows you to take a detailed snapshot of everything stored in memory. You can then search through this list and look for anything that should be cleaned up. Adding names to items helps distinguish them within the list.


We just scratched the tip of the iceberg of knowledge needed to be a top Unity3D developer. We hope that questions and answers presented in this guide will help you pinpoint the ideal developer for your project, by not only finding top Unity3D developers but finding the best developer for your particular needs.

Top Unity or Unity3D Developers are in high demand.

Get Started