# ARKit Blendshape Stream Receiver for FaceCap

This folder enables real-time and recorded capture of ARKit blendshape data streamed from the **FaceCap iOS app**. Note that the free version of FaceCap are **time-limited** (10 seconds per stream session).

## Environment Setup

```bash
conda create -n facecap python=3.10
conda activate facecap
pip install -r requirement.txt
```
## Facecap Setup

1. Download Facecap from the [link](https://apps.apple.com/tw/app/face-cap-motion-capture/id1373155478) on your IOS device.
2. Make sure both your iOS device and your computer are connected to the same Wi-Fi network.
3. After launching `bs_receiver.py` as described in [Usage](#usage), tap on `Go Live`, enter your computer's local IP address (e.g., `192.168.1.100`) and set the port to 8080.

> Note: Using an Ethernet-to-Type-C adapter yields the lowest latency.

## Usage

```bash
python bs_receiver.py --type [live|record|record_audio] --ip 0.0.0.0 --port 8080
```

### `live` Mode

- Forwards real-time FaceCap blendshape data.
- You should run `live_renderer.py` simultaneously (which listens on `127.0.0.1:9000`) in another terminal to animate the avatar in real time.

### `record` Mode

- Records blendshape sequences along with timestamps to a local folder.
- You can use `record_audio` mode to record synchronized audio if a microphone is available.
- Each recording session creates a folder named after the timestamp.
- To get the fps aligned result, run `python bs_aligner.py --root PATH_TO_SESSION_FOLDER --fps 30`
- Output format: 
```
PATH_TO_SESSION_FOLDER/
├── arkit_raw.json  # Raw recorded blendshape data
├── audio.wav       # Recorded audio file (if in record_audio mode)
├── log.json        # Metadata: duration, frame count
├── arkit.json      # Fps-aligned output of bs_aligner.py
```

## Hot Key
| Key      | Action                                   | Modes                             |
| -------- | ---------------------------------------- | --------------------------------- |
| `r`      | Toggle recording ON/OFF | record / record\_audio |
| `a`      | Align current face as neutral            | All modes                         |
| `Ctrl+C` | Stop server and save data     | All modes                         |

* To gracefully stop recording, please toggle to recording OFF before pressing `Ctrl+C`

---
## Troubleshooting

If you encounter any trouble or have any questions, please do not hesitate to let us know.
<!-- 

* **No data received**: Ensure FaceCap is streaming to the correct IP/port.
* **"No new data, skipping save"**: Indicates a lag or disconnection in stream.
* **Audio not saved**: Ensure microphone access is allowed and working.
* **Crash on Ctrl+C**: Use keyboard interrupts only as intended; data is saved on exit. -->

<!-- ---

## 📜 License

This project is intended for personal and research use. For commercial applications, please consult the FaceCap app's terms and licensing.

--- -->
