Unity with VS Code
- Install VS Code extensions - C#, Debugger for Unity, Unity tools, Unity code snippets
- Install .NET SDK
- download the script and execute
https://learn.microsoft.com/en-us/dotnet/core/install/linux-scripted-manual#scripted-install - update .bashrc
export DOTNET_ROOT=$HOME/.dotnet
export PATH=$PATH:$HOME/.dotnet:$HOME/.dotnet/tools - reboot
- download the script and execute
- Unity - Edit - Preferences - External Tools - choose VS Code
data:image/s3,"s3://crabby-images/af848/af848437b5257102d718f5d22ee21b06c815e74d" alt=""
Troubleshoot
Q.The .NET Core SDK cannot be located .NET Core debugging will not be enabled. Make sure the .NET Core SDK is installed and is on the path
A-1. (for VSCode to find dotnet) sudo ln -s $HOME/.dotnet/dotnet /usr/local/bin/dotnet
A-2. Close VS Code while installing. (rm -rf ~/.dotnet to delete to reinstall)
WebGL Deploy
Build
HTTP compression can be applied when the artifact is deployed through the following menu:
Project Settings - Build Settings - WebGL - Player Settings... - Publishing Settings - Compression Format > Brotli, Gzip or disabled
data:image/s3,"s3://crabby-images/13500/13500abcef38d47320db62a3d527547a6a4bb968" alt=""
Run
As output, index.html is created with Build, StreamingAssets and TemplateData folders. In Build/ folder, it has 4 files - .data.br, .framework.js.br, .loader.js, .wasm.br (.br becomes .unityweb). Unity Hub itself has a webserver so that it can launch the app by itself, however we suppose we deliver our project to other website such as AWS EC2.
In general, a simple web app can be launched by just executing index.html. A little more complicated web referring its public folder, for example, can be launched using the simple http server such as npm live-server or node express server. However, Unity WebGL uses http compression (br or gzip) so we need something more. Fortunately, there is a npm library called react-unity-webgl.
Let's create a new react app and see what happens.
import { Unity, useUnityContext } from "react-unity-webgl";
const isGzip = false;
const BASE_URL = `${window.location.protocol}//${window.location.host}/web${isGzip || '_br2'}/Build`
function App() {
const options = isGzip ? {
loaderUrl: `${BASE_URL}/web.loader.js`,
dataUrl: `${BASE_URL}/web.data.unityweb`,
frameworkUrl: `${BASE_URL}/web.framework.js.unityweb`,
codeUrl: `${BASE_URL}/web.wasm.unityweb`,
} : {
loaderUrl: `${BASE_URL}/web.loader.js`,
dataUrl: `${BASE_URL}/web.data.br`,
frameworkUrl: `${BASE_URL}/web.framework.js.br`,
codeUrl: `${BASE_URL}/web.wasm.br`,
}
const { unityProvider } = useUnityContext(options);
return (
<Unity unityProvider={unityProvider} />
);
}
export default App;
Result
It works properly when deployed Gzip (.unityweb), however it causes HTTPS error for Brotli (.br) - it seems to be HTTPS issue so it would be resolved if the server uses HTTPS/TLS.
using custom web server, verify that web server is sending .br files with HTTP Response Header "Content-Encoding: br". Brotli compression may not be supported over HTTP connections. Migrate your server to use HTTPS.
Troubleshoot
Q. Parsing error
A. Check <Project Settings - Build Settings - WebGL - Player Settings... - Publishing Settings - Decompression Fallback> menu
Reference
- 유니티 교과서 그림으로 이해하고 만들면서 익히는 [ 개정5판 ] 기타무라 마나미 저/김은철, 유세라 역 | 길벗 | 2022년 02월 14일 (github: https://github.com/gilbutITbook/080302)
- Streams and Brotli compression in Node.js (https://medium.com/@linoyzaga/streams-and-brotli-compression-in-node-js-fc2507d4d177)
'IT > Unity' 카테고리의 다른 글
[ROS] Unity Robotics Simulation (0) | 2023.01.15 |
---|---|
[Unity] Mixamo Animation (0) | 2023.01.15 |