Skip to content

Commit

Permalink
feat(ProTubeVR): add proof-of-concept sketch
Browse files Browse the repository at this point in the history
  • Loading branch information
leon0399 committed Aug 7, 2023
1 parent fbbf901 commit 3619dda
Showing 1 changed file with 108 additions and 0 deletions.
108 changes: 108 additions & 0 deletions examples/poc-protubevr-compat/poc-protubevr-compat.ino
Original file line number Diff line number Diff line change
@@ -0,0 +1,108 @@
#include "BluetoothSerial.h"

#define PIN_RUMBLE 32
#define CHA_RUMBLE 1

#define PIN_KICK 33
#define CHA_KICK 2

const int freq = 60;
const int resolution = 8;

constexpr inline const bool checkSN(const uint32_t sn) {
return (sn % 48991) % 521 == 0;
}

const uint32_t generateSN(const uint32_t i) {
// TODO: I'm to lazy to write it normally, and since it is invoked only once on boot it is OK
uint32_t sn = i;
while (!checkSN(sn)) sn++;
return sn;
}

#if !defined(CONFIG_BT_ENABLED) || !defined(CONFIG_BLUEDROID_ENABLED)
#error Bluetooth is not enabled! Please run `make menuconfig` to and enable it
#endif

BluetoothSerial SerialBT;

template<typename _Tp>
constexpr inline _Tp simpleMap(_Tp x, _Tp in_max, _Tp out_max) {
return x * out_max / in_max;
}

void btCallback(esp_spp_cb_event_t event, esp_spp_cb_param_t *param) {
Serial.printf("BT Callback: %d\n", event);
}

void setup() {
Serial.begin(115200);

uint64_t chipId = ESP.getEfuseMac();
const uint32_t sn = generateSN(chipId);

Serial.printf("ESP32 Chip model = %s Rev %d\n", ESP.getChipModel(), ESP.getChipRevision());
Serial.printf("Chip ID: %u\n", chipId);
Serial.printf("SN: %u\n", sn);

char deviceName[64];
sprintf(deviceName, "ForceTubeVR %u", sn);
// TODO: fix not working name
// SerialBT.begin(deviceName); // Bluetooth device name
SerialBT.begin("ForceTubeVR 1035102167");
Serial.println("The device started, now you can pair it with bluetooth!");

pinMode(PIN_RUMBLE, OUTPUT);
pinMode(PIN_KICK, OUTPUT);

ledcSetup(CHA_RUMBLE, freq, resolution);
ledcAttachPin(PIN_RUMBLE, CHA_RUMBLE);

ledcSetup(CHA_KICK, freq, resolution);
ledcAttachPin(PIN_KICK, CHA_KICK);

SerialBT.register_callback(btCallback);
}

#define COMMAND_START 0x2a
#define MAGIC 0xb0
#define CHANNEL_KICK 0x00
#define CHANNEL_RUMBLE 0x01

uint8_t payload[4];

void loop() {
if (!SerialBT.available()) {
return;
}

size_t s = SerialBT.readBytes(payload, 4);
if (s == 0) return;

Serial.printf("%03u %03u %03u %03u", payload[0], payload[1], payload[2], payload[3]);

if (payload[0] != COMMAND_START) {
Serial.println(" !!! not starting with COMMAND_START");
return;
}
switch (payload[1]) {
case MAGIC:
if (payload[2] == CHANNEL_KICK) {
uint16_t val = simpleMap<uint16_t>(payload[3], 255, 1 << resolution);
Serial.printf(" - kick %03u", val);
if (val == 0) {
delay(100);
}
ledcWrite(CHA_KICK, val);
} else if (payload[2] == CHANNEL_RUMBLE) {
uint16_t val = simpleMap<uint16_t>(payload[3], 255, 1 << resolution);
ledcWrite(CHA_RUMBLE, val);
Serial.printf(" - rumble %03u", val);
} else Serial.print(" - unknown effect");
break;
default:
Serial.println(" !!! Unknown 2nd value, not MAGIC");
break;
}
Serial.println();
}

0 comments on commit 3619dda

Please sign in to comment.