git clone https://github.com/luffy-yu/HoloAAC.git
cd HoloAAC
git submodule update --init --recursive
- Windows 11
- Unity 2020.3.20
- Microsoft Visual Studio Community 2019
There are three branches: master, pc, and hl2.
The source code is under Unity/ folder in pc and hl2 branches.
Unity folder is empty in master branch.
PC client and HoloLens 2 client share the almost entire same code, but there are four source files that are different to resolve the compilation issues using comments, etc.
1Photon Fusion only exists in pc branch under Assets/Photon/.
2Photon Voice for HoloLens 2 plugin is not free, so it's not included in the source code.
3You should change the
AppIdFusion
to yours even though it can work even without changing.
Four different files.
.../CamStream/Scripts/CameraStreamHelper.cs | 16 ++++++-------
Assets/Scripts/HoloLens2/CoachMenuEvents.cs | 16 ++++++-------
Assets/Scripts/Sync/ImageFromVideoStream.cs | 24 +++++++++----------
Assets/Scripts/Sync/ImageSender.cs | 28 +++++++++++-----------
Here is an example of the difference of `CoachMenuEvents.cs` file
diff --git a/Assets/Scripts/HoloLens2/CoachMenuEvents.cs b/Assets/Scripts/HoloLens2/CoachMenuEvents.cs
--- a/Assets/Scripts/HoloLens2/CoachMenuEvents.cs
+++ b/Assets/Scripts/HoloLens2/CoachMenuEvents.cs
@@ -3,13 +3,13 @@
// Licensed under the MIT License. See LICENSE file in the project root for full license information.
//
-#if !UNITY_WSA // not windows uwp
-using UnityEngine;
-public class CoachMenuEvents : MonoBehaviour
-{
-
-}
-#else
+// #if !UNITY_WSA // not windows uwp
+// using UnityEngine;
+// public class CoachMenuEvents : MonoBehaviour
+// {
+//
+// }
+// #else
using System;
using System.Collections.Concurrent;
using System.Collections.Generic;
@@ -544,4 +544,4 @@ namespace HoloCook.HoloLens2
#endregion
}
}
-#endif
\ No newline at end of file
+// #endif
\ No newline at end of file
PC
- Checkout pc branch via
git checkout pc
- Open this project source under Unity/ with Unity
- Open the PC scene
- Run in the editor
- Change the HoloLens 2 ip in
Server -- Netly Target Host -- IP Address
- Change the HoloLens 2 ip in
- Build and run
- Create a
hololens2.ip
within the same folder as the built executableHoloCook.exe
.- The content is like
192.168.0.163:8888
, where192.168.0.163
is the ip of the HoloLens 2, and8888
is the port of the PC. - If this file doesn't exist, it will use the default setting.
- Sample file is here.
- The content is like
- Create a
Note that HoloLens 2 always uses the
8888
port for TCP communication.
- The built application can be deployed in another PC or the same PC as long as they are networked reachable.
- If they are running in the same pc, make sure that they are in different folders (just make a copy of the build folder) and use different ports (e.g., 8888 and 9999).
Ensure Windows firewall is properly configured.
HoloLens 2
- Checkout hl2 branch via
git checkout hl2
- Open this project source under Unity/ with Unity
- Open this HoloLens2 scene
- Build and run
- It can be simply built without changing anything.
- Open with VS 2019, and build it with
Release
,ARM64
. - Deploy it.
- Allow the permission request at the 1st running.
- It will load the configuration file
host.ip
under\User Folders\LocalAppData\HoloCook_1.0.0.0_arm64__xxxxxxxxxxxx\LocalState\
.- The content is like
192.168.0.221:8888
, where192.168.0.221
is the ip of the PC, and8888
is the port of the PC. - If this file doesn't exist, it will use the default setting.
- Sample file is here.
- The content is like
- Prepare two kitchens
- Kitchen wares and tools
- Ingredients
- Refer to the video
More than the HoloCook system itself that is mentioned in this paper, some functionalities that I have preliminarily explored are also open sourced in this repository, such as:
-
Video Stream / Image Capture with Locatable Camera Parameters [CamStream/, ImageFromVideoStream.cs, ImageSender.cs]
- Thanks to this project [included].
-
Trajectory Mapping [TrajectoryFitting.cs] video demostration
-
Action Recording and Replay [ActionRecordSyncer.cs] video demostration
-
Registration on a Known Plane [RegistrationNetwork.cs] video demostration
- Pipeline: Picture --> Python (segmentation by (SAM)[https://segment-anything.com/], not included) --> Unity --> HoloLens 2
-
Opencv Module Adaptation from OpenCvSharp [included, used in RegistrationNetwork.cs]
If you are interested in these functionalities, feel free to reach out to me at lyu20@gmu.edu. I am glad to help or even collaborate.
If you find this work useful, please cite it using the following format.
@inproceedings{yu2025holocook,
title={HoloCook: A Real-Time Remote Mixed Reality Cooking Tutoring System},
author={Yu, Liuchuan and Han, Bo and Chen, Songqing and Yu, Lap-Fai},
booktitle={International Conference on Human-Computer Interaction},
pages={244--264},
year={2025},
organization={Springer}
}