If you like our article, do take some time to check out the rest of our site! We have plenty of Unity-related posts, tutorials and even some content on web development!
One of the biggest perks of using Microsoft’s Visual Studio to write your Unity scripts is IntelliSense β a code completion aid in Visual Studio that offers suggestions as you write your code, and contextually presents you with information about classes, properties and methods that you are working with.
Given Unity’s enormous scripting API, IntelliSense is a tremendously helpful feature, especially for coders who are beginning their foray into developing games and software with Unity; and while we’d love to say that IntelliSense is automatically set up and linked to Unity’s API when you install it with the Unity Editor, sometimes that’s just not the case. So, if you’ve got both Unity and Visual Studio set up, but find that IntelliSense is still not offering Unity API suggestions, then this guide is for you.
There can be many reasons why IntelliSense is failing to work properly on your device, and we are assuming that you’ve already scoured the Internet a fair bit before stumbling on our article. Hence, we’ve put together a table of contents of sorts below, so if you’ve already tried some of the solutions we have, you can skip right through them.
If you prefer watching a video instead of reading, do check out our video guide for this post too.
1. Is my IntelliSense not working?
For IntelliSense to detect and work with Unity’s API, Visual Studio needs to:
- Be linked to the Unity Editor, and;
- Have the appropriate extensions installed (read further to find out what they are)
If you’ve installed Visual Studio via Unity Hub, this can have been automatically set up, but not always. Due to the bevy of ways which you can install Unity and Visual Studio, misconfigurations can happen, and you might end up with Visual Studio not integrating itself into Unity, and an IntelliSense feature that is not properly linked to Unity’s API.
We’ve found that, when installing some versions of Unity 2019 and 2020, Visual Studio does not always integrate with Unity’s API by default. So if things are not working properly, it might not be caused by misconfiguration on your end.
To check if IntelliSense is properly set up, open any script from the Unity Editor, and look out for 2 things:
- Whether the top-left dropdown says Miscellaneous Files. If it does, then IntelliSense is not set up (it has to say Assembly-Csharp.
- Try declaring a Unity variable, like a
GameObject
. If IntelliSense is properly set up, Visual Studio should have an auto-complete suggestion for you before you finish typing.
2. Getting IntelliSense working
So if IntelliSense isn’t working for you, what should you do?
a. Open your scripts from Unity
Before you try anything else from here, first make sure that your scripts are opened from within Unity, i.e. whenever you want to edit your scripts, double-click on them in the Unity Editor so that Visual Studio is opened by Unity.
If IntelliSense still doesn’t work when you do this, then continue onto the steps below:
b. Setting Unity’s External Script Editor
From the Unity Editor, access the Preferences window from Edit > Preferences. Then, click on 1) the External Tools tab.
Set 2) the External Script Editor to the version of Visual Studio that you installed alongside Unity, then click on 3) the Regenerate project files button (if it’s there).
Once that’s done, restart Visual Studio and see if IntelliSense now works. If it still doesn’t, then you might be missingβ¦
If Visual Studio doesn’t appear on the dropdown, you will have to use the Browseβ¦ option (pictured above) to find it. It’s typically under C:\Program Files (x86)\Microsoft Visual Studio\2019\Community\Common7\IDE\devenv.exe
for Windows devices.
c. Visual Studio Tools for Unity
To install this, open Visual Studio and go to Tools > Get Tools and Features.
Note: You’ll need administrator permissions to open this window, as it makes changes to the Visual Studio installation on your computer.
Once the installer is open, go to Workloads and find Game development with Unity. Check the box, and then click on the Modify button on the bottom-right corner to begin installation.
A popup may ask you to close certain processes before beginning installation. If this happens, close your Visual Studio project and the Unity Editor application.
When installation completes, restart both Unity and Visual Studio, then check to see if IntelliSense now works.
The Games development with Unity workload actually installs 2 additional Visual Studio components β Visual Studio Tools for Unity and C# and Visual Basic. You can install both modules individually by going to the Individual components tab, and checking both components in the list that is shown.
d. Check your .NET API compatibility level
If IntelliSense still refuses to work, you can open the Unity Editor and head to Edit > Project Settings and access the Player (or Player Settings) tab. Scroll down to the Other Settings sub-tab, and find the Api Compatibility Level dropdown under the Configuration heading.
You want to set the Api Compatibility Level to a different option, and see which is the one that works for your device.
e. Check if the Assembly-Csharp solution is loaded
If you have tried all of the above steps, but your Intellisense still doesn’t work, then it may be because you have accidentally unloaded the solution (i.e. what Visual Studio calls their project setting files) for your project. To check if that is the case:
- In Visual Studio, go to View > Solution Explorer.
- The Solution window should pop up by the side of Visual Studio. Check if there is a tab that says Assembly-Csharp (unloaded). If there isn’t, you likely have not set your external script editor, or downloaded Visual Studio Tools for Unity.
- Right-click on Assembly-Csharp (unloaded) and select Reload project. The dropdown on the top left corner of Visual Studio should change from Miscellaneous Files to Assembly-Csharp. If that happens, congratulations! IntelliSense should now be working.
- If (3) fails, close Visual Studio and reopen it again.
Below is a GIF demonstrating the steps above.
f. Manually regenerating your Unity project files
If the above solutions we’ve proposed did not work for you, you can also try this solution from one of our comment contributions.
Note: Back up your Unity project before trying this, as we are deleting some essential project files and letting Unity regenerate them.
- Close both Visual Studio and Unity on your device.
- Remove all
.sln
and.csproj
files in your Unity project folder. - Remove the
.vs
andLibrary
folders in your Unity project folder. - Re-open the project in Unity, then go to Assets > Open C# Project to open Visual Studio.
3. Conclusion
As with the other articles on the blog, we’d love if you leave a comment below, especially if you:
- Find any errors in this article, or;
- Find an IntelliSense fix that is not listed in this article
Your comments will add on to the information that is already here, and help other future readers!
4. Video guide
Is this post not visual enough? Perhaps our video guide of this post can help.
If you do all the steps but still doesn’t work like me, you can try to delete Visual Studio through the Visual Studio installer and reinstall it. You need to do step 2 again.
Got all the way down to e) then that fixed it. Thank you so much for improving my day!
Hi Bill, glad to hear that it helped!
God bless this blog post, and may the author find success in all of their endeavors. We salute you.
THANK YOU BRO LITTERALLY LET ME HAVE YOUR CHILDREN
πΌπΌπ₯
Very helpful! Only thing I would add is that if you’re using perforce or a similar version control system, you need to check out the Assembly-CSharp.csproj in order to change the player api compatability level which ended up fixing my issue. Almost didn’t realize that was the issue, but I caught the error message
I had to right click on the project in VS and choose “Resolve Errors”. Wish everything was that easy.
Yeah step e. was what what finally fixed it for me. What I was move my game project folder to my desktop for easy access but the .vs and other solution file paths were pointing to the old folder location which was causing intellisense to not work. So if you move your project folder to another destination, follow step e. and ensure the previous steps were already tried too.
Thank you so much. It works! I had been trying a lot. But nothing worked until your way, thanks!
Thank you!! That worked very well for me!
This works for me! I had been trying a lot of possible solutions but nothing worked until your post, thanks!
Thank you! Mine has been broken for YEARS!
ps. I found a solution for me, and probably for a lot of Mac users too.
You have to go in VSCode into settings and search for “useGlobalMono” and then change the “Omnisharp: Use Global Mono” setting from “auto” to “always”.
here’s the video I got it from
https://www.youtube.com/watch?v=KJYrRv9cShY
I’ve tried all the proposed solutions, but it still does not work.
I couldn’t try the “Games development with Unity” because on Mac I didn’t find the tab “Get Tools and Features”.
Right click the solution explorer in visual studio, the solution also worked for me
I thought I had selected Visual Stuio as my External Script Editor – but apparently I hadn’t, and when I did it worked :)
Thank you very much!
I already has VS2019 16.11.1 installed and working perfectly and also the Unity tools.
I installed Unity from a download link in a tutorial which pointed to 2017.1.0f. Unity changed this to the latest free version 2020.3.16f and I had the problem described.
Even though the Unity objects did not highlight and had no auto-complete, the scripts worked fine?
All I had to do was set the external editor in Unity and then close VS.
The next time, I opened the script from Unity, which opened VS and magically everything now works.
Great tips, thanks
Thanks for the article. Point e (e. Regenerating your Unity project files) was the final step I had to do.
Thank you! Your instructions were concise, easy-to-follow, and in my case completely solved this problem. Much appreciated.
I followed this guide and about 5 others that where exactly the same and nothing worked.
what did work, was right clicking the project and clicking “reload with dependencies”.. This literally fixed it right away.
Might be worth putting this into the guide.. Because I just nearly started eating my keyboard.
Hey Chris,
Thanks for taking time out to post this. Is the “reload with dependencies” option in Unity, or in Visual Studio? I want to add your tip into the article, but I don’t know where to find this.
I figured this out taking the hint from the original poster. You right click the project in VS, and select “Load Direct Dependencies of Project” and it instantly worked for me too.
Hey Justin, thanks for the heads up!
Thanks you for your article.
I met this problem and top-left dropdown says Miscellaneous Files in my VS.
then I follow steps from https://developercommunity.visualstudio.com/t/unity3d-miscellaneous-files/416851#T-N427220 deleting all my project file and re-open both VS and Unity, the it works well.
Hi xigou, thanks for the comment! We’ve added your solution into our article.