Toptal is a marketplace for top Unity developers, programmers and coders. CEOs, CTOs, and management at top companies and startups work with Toptal Unity freelancers to augment their development teams for Unity development, mobile app development, web development, and other software development projects to achieve their business needs.
Jayashree is an Android engineer with over eight years of experience building elegant and performant mobile applications, platforms, and SDK tools in AR and spatial computing. She also enjoys building scalable full-stack applications and added features for apps such as Rally Plus which is used by millions of users. Her passion lies in providing the best user experience through beautiful and intuitive UI design. She hopes to impact as many projects as possible through the Toptal community,
Andrew is a hybrid software engineer and designer passionate about building technology products that delight, entertain, and enhance human performance. He has a build-first mentality, always encouraging exploratory prototyping to hone in on where technology can best serve people, culture, and customers. Focused on iOS development, augmented reality (AR), and virtual reality (VR), Andrew has spent over nine years designing and building software at the cutting edge of consumer experience.
David is a software and video game developer who specializes in Unity development. He has worked on various projects, including game development, web development, augmented reality, and virtual reality. David developed shaders and post-process effects using ShaderLab, Cg, and HLSL. He is passionate about graphics and shader development.
Christopher is a developer with over a decade of experience in working on a wide range of projects, from games to business applications, including mobile, PC, and mixed reality solutions such as HoloLens and Vuforia. Two of his apps have reached the top 10 in their category, and one of them, Yumi Story Dice, has also been featured by Apple. Christopher is looking for part-time freelance work in any field using the Unity engine, React, Vue, and CSS.
Marcelo has been working in game development since 2009 and his expertise encompasses mobile game development, Unity3D/Unity, and Starling. Much of Marcelo's experience comes from working with Jam City, a leader in the game industry. At Jam City, Marcelo worked as a senior lead engineer and director of engineering and oversaw/contributed to the release and maintenance of several hit games including Panda Pop, Snoopy Pop, Juice Jam, Sugar Smash, and Family Guy: Another Freakin' Mobile Game.
Mike is a highly experienced individual in the video game industry (15 years) who decided to take the plunge several years ago and went independent. He founded a studio named Principle, Inc., where he develops games using the Unity3D engine, whose primary objective is to be something different. Mike specializes in game design, programming (C#), and tools development (C# and VBA).
Domagoj is a game developer who has contributed to more than ten games (release to the iOS, Android, Amazon, and Steam app stores). He specializes in using the Unity3D game engine and has experience with a wide range of game development challenges such as the implementation of general gameplay, AI, UI, IAP, multiplayer, and shaders.
Andrii is a software developer with eight years of professional experience, including five years of experience in Unity3D for iOS and Android. He is great in a team but also can work on his own as well. Andrii has skills in algorithm programming and good knowledge of mathematics.
Ahmad is a certified Unity expert with more than a decade of experience as a software developer. Most of his experience was as a game developer and virtual reality (VR) specialist. He co-founded a VR agency in 2017, where he led a team of talented developers and artists to create virtual reality games and training experiences that meet the criteria set by his clients. Ahmad believes the true potential of VR is not limited to entertainment but also training and communication.
Kyle is a software developer with over 10 years of experience in software design, development, and integration. He is skilled at Python, Vue.js, and mobile app development, and he also has extensive experience with DevOps. He is experienced in full project life cycle from requirement analytics and design to implementation and integration.
Gareth has been making games professionally for a decade, with a core focus on building robust systems and maintainable architectures for Unity3D C# game titles. He has a strong understanding of C++, which has helped when working with native platform code and building plugins for Unity projects. Some of Gareth's notable work experiences include working on Disney projects such as Club Penguin and Rival Stars: Horse Racing, a successful mobile title.
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.
... allows corporations to quickly assemble teams that have the right skills for specific projects.
Despite accelerating demand for coders, Toptal prides itself on almost Ivy League-level vetting.
Our clients
Creating an app for the game
Leading a digital transformation
Building a cross-platform app to be used worldwide
Drilling into real-time data creates an industry game changer
Testimonials
Tripcents wouldn't exist without Toptal. Toptal Projects enabled us to rapidly develop our foundation with a product manager, lead developer, and senior designer. In just over 60 days we went from concept to Alpha. The speed, knowledge, expertise, and flexibility is second to none. The Toptal team were as part of Tripcents as any in-house team member of Tripcents. They contributed and took ownership of the development just like everyone else. We will continue to use Toptal. As a startup, they are our secret weapon.
Brantley Pace
CEO & Co-Founder
I am more than pleased with our experience with Toptal. The professional I got to work with was on the phone with me within a couple of hours. I knew after discussing my project with him that he was the candidate I wanted. I hired him immediately and he wasted no time in getting to my project, even going the extra mile by adding some great design elements that enhanced our overall look.
Paul Fenley
Director
The developers I was paired with were incredible -- smart, driven, and responsive. It used to be hard to find quality engineers and consultants. Now it isn't.
Ryan Rockefeller
CEO
Toptal understood our project needs immediately. We were matched with an exceptional freelancer from Argentina who, from Day 1, immersed himself in our industry, blended seamlessly with our team, understood our vision, and produced top-notch results. Toptal makes connecting with superior developers and programmers very easy.
Jason Kulik
Co-founder
As a small company with limited resources we can't afford to make expensive mistakes. Toptal provided us with an experienced programmer who was able to hit the ground running and begin contributing immediately. It has been a great experience and one we'd repeat again in a heartbeat.
Stuart Pocknee
Principal
How to Hire Remote Unity or Unity3D Game Developers through Toptal
1
Talk to One of Our Industry Experts
A Toptal director of engineering will work with you to understand your goals, technical needs, and team dynamics.
2
Work With Hand-Selected Talent
Within days, we'll introduce you to the right Unity developer for your project. Average time to match is under 24 hours.
3
The Right Fit, Guaranteed
Work with your new Unity developer for a trial period (pay only if satisfied), ensuring they're the right fit before starting the engagement.
Find Experts With Related Skills
Access a vast pool of skilled developers in our talent network and hire the top 3% within just 48 hours.
Typically, you can hire a Unity developer with Toptal in about 48 hours. For larger teams of talent or Managed Delivery, timelines may vary. Our talent matchers are highly skilled in the same fields they’re matching in—they’re not recruiters or HR reps. They’ll work with you to understand your goals, technical needs, and team dynamics, and match you with ideal candidates from our vetted global talent network.
Once you select your Unity developer, you’ll have a no-risk trial period to ensure they’re the perfect fit. Our matching process has a 98% trial-to-hire rate, so you can rest assured that you’re getting the best fit every time.
How do I hire a Unity developer?
To hire the right Unity developer, it’s important to evaluate a candidate’s experience, technical skills, and communication skills. You’ll also want to consider the fit with your particular industry, company, and project. Toptal’s rigorous screening process ensures that every member of our network has excellent experience and skills, and our team will match you with the perfect Unity developers for your project.
How are Toptal Unity developers different?
At Toptal, we thoroughly screen our Unity developers to ensure we only match you with the highest caliber of talent. Of the more than 200,000 people who apply to join the Toptal network each year, fewer than 3% make the cut.
In addition to screening for industry-leading expertise, we also assess candidates’ language and interpersonal skills to ensure that you have a smooth working relationship.
When you hire with Toptal, you’ll always work with world-class, custom-matched Unity developers ready to help you achieve your goals.
Can you hire Unity developers on an hourly basis or for project-based tasks?
You can hire Unity developers on an hourly, part-time, or full-time basis. Toptal can also manage the entire project from end-to-end with our Managed Delivery offering. Whether you hire an expert for a full- or part-time position, you’ll have the control and flexibility to scale your team up or down as your needs evolve. Our Unity developers can fully integrate into your existing team for a seamless working experience.
What is the no-risk trial period for Toptal Unity developers?
We make sure that each engagement between you and your Unity 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.
Share
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 video game development software. It can create mobile games as well as augmented reality and virtual reality games. It is accessible to hobbyists 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 and hire Unity3D developers, but it will also help you ensure that the game engine developer is the perfect fit for your project’s needs.
Unity3D is by far the most popular game development software
Unity is extremely diverse, and thus being a Unity3D game 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 game development expert, 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 inheritance 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.
Summary
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.