Files
velopack/samples/CSharpUnityMono/README.md
2024-11-07 08:23:29 +00:00

92 lines
3.6 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

# UnitySample(Mono)
This project integrates Velopack into unity by way of a [nuget for Unity](https://github.com/GlitchEnzo/NuGetForUnity) package.
## How to use
1. Clone this repository
2. Open the project in Unity (2022.3.51f1)
**Opening the project for the first time may result in errors. Please ignore them.**
3. Build the Unity project to \Build folder
4. (With Visual Studio) Open BuildVisualStudioSolution\UnityMonoSample.sln and build solution
4. (With msbuild) `msbuild .\BuildVisualStudioSolution\BuildVisualStudioSolution.sln /p:Configuration=Master /p:Platform=x64`
5. Copy BuildVisualStudioSolution\build\bin\x64\Master\UnityMonoSample.exe to \Build folder
6. Use vpk cli tool to pack your project `vpk pack -u UnityMonoSample -v 0.0.1 -p .\Build -e UnityMonoSample.exe`
## Requirements for your project
Currently, Velopack is only support for Unity mono runtime, it does not support for IL2CPP, due to the following reasons:
https://docs.unity3d.com/2022.3/Documentation/Manual/ScriptingRestrictions.html
### System.Diagnostics.Process API
IL2CPP doesnt support the `System.Diagnostics.Process` API methods. For cases where this is required on desktop platforms, use the Mono scripting backend.
----
If you still want to use Velopack in IL2CPP, you can use the following workaround
(remember that this is not recommended and may change in the future):
1. Clone the Velopack repository
2. Edit the VelopackRuntimeInfo.cs file like this:
```csharp
static VelopackRuntimeInfo()
{
//delete the following line
//EntryExePath = System.Diagnostics.Process.GetCurrentProcess().MainModule.FileName;
EntryExePath = Application.dataPath;
if (!Application.isEditor)
{
EntryExePath = Path.Combine(EntryExePath, "..", Application.productName + ".exe");
}
}
```
3. Build the Velopack project
4. Replace the Velopack.dll in your project with the new Velopack.dll
## FAQ
### Why do I need to build the project twice?
The first build is to generate the normal Unity project.
The second build is to generate the .exe file that Velopack needs to pack. Since the Unity executable on Windows is packaged in C++, its process needs some modification to integrate Velopack's [App Hooks](https://docs.velopack.io/integrating/hooks).
you can see the following code in the Main.cpp file
```c++
#include "PrecompiledHeader.h"
#include "..\UnityPlayerStub\Exports.h"
//for Velopack
#include "..\Velopack.hpp"
#include "Windows.h"
#include <shellapi.h>
//for Velopack
// Hint that the discrete gpu should be enabled on optimus/enduro systems
// NVIDIA docs: http://developer.download.nvidia.com/devzone/devcenter/gamegraphics/files/OptimusRenderingPolicies.pdf
// AMD forum post: http://devgurus.amd.com/thread/169965
extern "C"
{
__declspec(dllexport) DWORD NvOptimusEnablement = 0x00000001;
__declspec(dllexport) int AmdPowerXpressRequestHighPerformance = 1;
}
int WINAPI wWinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPWSTR lpCmdLine, int nShowCmd)
{
//for Velopack
int pNumArgs = 0;
wchar_t** args = CommandLineToArgvW(lpCmdLine, &pNumArgs);
Velopack::startup(args, pNumArgs);
//for Velopack
return UnityMain(hInstance, hPrevInstance, lpCmdLine, nShowCmd);
}
```
## Note
Do not use `ApplyUpdatesAndExit` because Environment.Exit is not supported. Instead, use the following to apply update:
```csharp
updateManager.WaitExitThenApplyUpdates(...);
UnityEngine.Application.Quit();
```
This will work because `WaitExitThenApplyUpdates` will not call `Environment.Exit`, but it will prepare up the Velopack updater to install the update when unity closes.