Skip to main content

Adding Support for New Smart Glasses

This guide explains how to add support for new smart glasses to the MentraOS ecosystem. The process involves creating platform-specific communicators and updating the UI to recognize your glasses model.

Overview

MentraOS supports different types of smart glasses through a modular architecture:

  • Android-based glasses (like Mentra Live, TCL Rayneo, INMO Air) - Run Android OS directly
  • RTOS/Firmware-based glasses (like Even Realities G1, Vuzix Z100) - Run custom firmware
  • Future glasses - Any glasses that can communicate via Bluetooth/WiFi

What is a SmartGlassesCommunicator (SGC)?

A SmartGlassesCommunicator (SGC) is the bridge between MentraOS and your specific smart glasses hardware. It handles:

  • Bluetooth/USB connection to the glasses
  • Translating MentraOS commands to your glasses' protocol
  • Sending display data, audio, and control commands
  • Receiving sensor data, button presses, and status updates

The data flow is: Cloud → Phone App → SGC → Your Glasses

Implementation Paths

For Android-Based Glasses

If your glasses run Android OS:

  1. Use the MentraOS ASG Client - An Android app that runs on the glasses

    • See MentraOS ASG Client Guidelines
    • Modify device detection in the NetworkManager and BluetoothManager factories
    • The existing StandardBluetoothManager can work with most Android glasses
  2. Create an SGC in the phone app to communicate with your glasses

    • Location: android_core/ folder (Android) or mobile/ios/ (iOS)
    • Your SGC will act as a BLE client connecting to the glasses' BLE server

For RTOS/Firmware-Based Glasses

If your glasses run custom firmware:

  1. Review the firmware specification

    • See firmware_spec.md
    • Implement the required BLE services and characteristics
    • Handle display commands, sensor data, etc.
  2. Create an SGC to communicate with your firmware

    • Implement the BLE client protocol matching your firmware

Creating a SmartGlassesCommunicator (Android)

1. Create Your SGC Class

Location: android_core/app/src/main/java/com/augmentos/android_core/smarterglassesmanager/smartglassescommunicators/

Create a new Java file extending SmartGlassesCommunicator:

package com.augmentos.augmentos_core.smarterglassesmanager.smartglassescommunicators;

public class YourGlassesSGC extends SmartGlassesCommunicator {
private static final String TAG = "YourGlassesSGC";

// BLE Service and Characteristic UUIDs
private static final String SERVICE_UUID = "your-service-uuid";
private static final String RX_CHAR_UUID = "your-rx-characteristic-uuid";
private static final String TX_CHAR_UUID = "your-tx-characteristic-uuid";

// Constructor
public YourGlassesSGC(Context context, String glassesId) {
super(context, glassesId);
deviceModelName = "Your Glasses Model Name"; // Must match UI
}
}

2. Implement Required Methods

Device Discovery

@Override
public void findCompatibleDeviceNames() {
BluetoothAdapter adapter = BluetoothAdapter.getDefaultAdapter();

if (adapter != null && adapter.isEnabled()) {
Set<BluetoothDevice> pairedDevices = adapter.getBondedDevices();

for (BluetoothDevice device : pairedDevices) {
String deviceName = device.getName();
if (deviceName != null && isYourGlassesDevice(deviceName)) {
// Notify UI about found device
EventBus.getDefault().post(
new GlassesBluetoothSearchDiscoverEvent(
deviceModelName,
deviceName
)
);
}
}
}

// Signal search complete
EventBus.getDefault().post(
new GlassesBluetoothSearchStopEvent(deviceModelName)
);
}

Connection Management

@Override
public void connectToSmartGlasses() {
connectionEvent(SmartGlassesConnectionState.CONNECTING);

BluetoothDevice device = bluetoothAdapter.getRemoteDevice(deviceMacAddress);
bluetoothGatt = device.connectGatt(context, false, gattCallback);
}

3. Handle Display Commands

Implement based on your glasses' capabilities:

@Override
public void displayReferenceCardSimple(String title, String body) {
// Convert text to your glasses' format
// Send via BLE
}

@Override
public void displayBitmap(Bitmap bmp) {
// Convert bitmap to your display format
// Handle compression/chunking if needed
}

4. Register Your Glasses in the System

To make your glasses available in the system, you need to:

a. Create a SmartGlassesDevice class

In android_core/app/src/main/java/com/augmentos/augmentos_core/smarterglassesmanager/supportedglasses/:

public class YourGlasses extends SmartGlassesDevice {
public YourGlasses() {
deviceModelName = "Your Glasses Model Name";
deviceIconName = "your_glasses"; // Icon resource name
manufacturer = "Your Company";
glassesOs = SmartGlassesOperatingSystem.YOUR_GLASSES_OS; // Add this to enum
}
}

b. Add your Operating System type

In SmartGlassesOperatingSystem.java, add your OS type:

public enum SmartGlassesOperatingSystem {
ANDROID_OS_GLASSES,
SELF_OS_GLASSES,
EVEN_REALITIES_G1_MCU_OS_GLASSES,
MENTRA_LIVE_OS,
YOUR_GLASSES_OS, // Add your OS type
// ... other OS types
}

c. Update SmartGlassesManager

In SmartGlassesManager.java, add your device to the supported list:

public static SmartGlassesDevice getSmartGlassesDeviceFromModelName(String modelName) {
ArrayList<SmartGlassesDevice> allDevices = new ArrayList<>(
Arrays.asList(
new VuzixUltralite(),
new MentraLive(),
new YourGlasses(), // Add your glasses here
// ... other devices
)
);

for (SmartGlassesDevice device : allDevices) {
if (device.deviceModelName.equals(modelName)) {
return device;
}
}
return null;
}

d. Map OS to SGC in SmartGlassesRepresentative

In SmartGlassesRepresentative.java, update the createCommunicator() method:

private SmartGlassesCommunicator createCommunicator() {
SmartGlassesCommunicator communicator;

switch (smartGlassesDevice.getGlassesOs()) {
// ... existing cases

case YOUR_GLASSES_OS:
communicator = new YourGlassesSGC(context, smartGlassesDevice);
break;

default:
return null;
}

// Register audio callback if needed
if (communicator != null && audioProcessingCallback != null) {
communicator.registerAudioProcessingCallback(audioProcessingCallback);
}

return communicator;
}


## UI Integration

After creating your SGC, update the MentraOS Mobile App UI:

### 1. Add to Glasses Model List

In `mobile/src/app/pairing/select-glasses-model.tsx`:

```javascript
const glassesOptions = Platform.select({
android: [
// ... existing models
"Your Glasses Model Name", // Must match SGC deviceModelName
],
ios: [
// Add here if iOS is supported
],
})

2. Define Glasses Features

In mobile/src/config/glassesFeatures.ts:

"Your Glasses Model Name": {
camera: false, // if it has a camera
speakers: false, // if it has speakers
display: true, // if it has a display
binocular: false, // if it has binocular displays
wifi: false, // if it has WiFi
imu: false, // if it has IMU/motion sensors
micTypes: ["sco"], // microphone types: ["none"], ["sco"], ["custom"], or ["sco", "custom"]
},

3. Add Glasses Image

  1. Add your image to mobile/assets/glasses/your-glasses-image.png
  2. Update mobile/src/utils/getGlassesImage.tsx:
case "Your Glasses Model Name":
return require("@/assets/glasses/your-glasses-image.png");

4. Create Pairing Guide

In mobile/src/components/misc/GlassesPairingGuides.tsx:

const YourGlassesPairingGuide = () => (
<View>
<Text style={styles.subtitle}>How to pair Your Glasses:</Text>
<Text style={styles.instructions}>
1. Turn on your glasses{"\n"}
2. Enable Bluetooth pairing mode{"\n"}
3. Select your glasses from the list
</Text>
</View>
)

Update mobile/src/utils/getPairingGuide.tsx:

case "Your Glasses Model Name":
return <YourGlassesPairingGuide />;

Testing Your Implementation

  1. Device Discovery: Verify your glasses appear in the pairing list
  2. Connection: Test connection/disconnection cycles
  3. Display: Send test cards and bitmaps
  4. Events: Verify battery, tap, and other events work
  5. Cleanup: Ensure proper disconnect and resource cleanup

Example Implementations

Study these existing SGCs for reference:

  • EvenRealitiesG1SGC.java - Display-focused glasses with dual device support
  • MentraLiveSGC.java - Audio-focused glasses with streaming capabilities
  • VuzixZ100SGC.java - Simple display implementation

Getting Help

  • Join the Discord community
  • Review existing SGC implementations
  • Post questions on GitHub issues
  • Schedule a demo call to show your glasses and get guidance

Important Notes

  • Naming consistency: The device model name must match exactly across all files
  • Platform support: Only add to iOS if you've implemented iOS support
  • Testing: Test the complete flow from pairing to data exchange
  • Documentation: Document any special pairing procedures or requirements