aboutsummaryrefslogtreecommitdiff
path: root/lib/BleMouse/BleMouse.cpp
diff options
context:
space:
mode:
authorkrolyxon <me@krolyxon.com>2026-06-20 00:24:34 +0530
committerkrolyxon <me@krolyxon.com>2026-06-20 00:24:34 +0530
commit7e4cfad53699fabbecb6696508e5addcffc1b095 (patch)
treeebff581b0989df578c312247e1dad514c956572b /lib/BleMouse/BleMouse.cpp
parent1f800b74329d4f8b1511b4cf2a0d031439e1038d (diff)
restructure to use rust source tree primarily
Diffstat (limited to 'lib/BleMouse/BleMouse.cpp')
-rw-r--r--lib/BleMouse/BleMouse.cpp165
1 files changed, 0 insertions, 165 deletions
diff --git a/lib/BleMouse/BleMouse.cpp b/lib/BleMouse/BleMouse.cpp
deleted file mode 100644
index 8f5c16e..0000000
--- a/lib/BleMouse/BleMouse.cpp
+++ /dev/null
@@ -1,165 +0,0 @@
-#include "BLE2902.h"
-#include "BLEHIDDevice.h"
-#include "HIDKeyboardTypes.h"
-#include "HIDTypes.h"
-#include "sdkconfig.h"
-#include <BLEDevice.h>
-#include <BLEServer.h>
-#include <BLEUtils.h>
-#include <driver/adc.h>
-
-#include "BleConnectionStatus.h"
-#include "BleMouse.h"
-
-#if defined(CONFIG_ARDUHAL_ESP_LOG)
-#include "esp32-hal-log.h"
-#define LOG_TAG ""
-#else
-#include "esp_log.h"
-static const char *LOG_TAG = "BLEDevice";
-#endif
-
-static const uint8_t _hidReportDescriptor[] = {
- USAGE_PAGE(1), 0x01, // USAGE_PAGE (Generic Desktop)
- USAGE(1), 0x02, // USAGE (Mouse)
- COLLECTION(1), 0x01, // COLLECTION (Application)
- USAGE(1), 0x01, // USAGE (Pointer)
- COLLECTION(1), 0x00, // COLLECTION (Physical)
- // ------------------------------------------------- Buttons (Left, Right,
- // Middle, Back, Forward)
- USAGE_PAGE(1), 0x09, // USAGE_PAGE (Button)
- USAGE_MINIMUM(1), 0x01, // USAGE_MINIMUM (Button 1)
- USAGE_MAXIMUM(1), 0x05, // USAGE_MAXIMUM (Button 5)
- LOGICAL_MINIMUM(1), 0x00, // LOGICAL_MINIMUM (0)
- LOGICAL_MAXIMUM(1), 0x01, // LOGICAL_MAXIMUM (1)
- REPORT_SIZE(1), 0x01, // REPORT_SIZE (1)
- REPORT_COUNT(1), 0x05, // REPORT_COUNT (5)
- HIDINPUT(1), 0x02, // INPUT (Data, Variable, Absolute) ;5 button bits
- // ------------------------------------------------- Padding
- REPORT_SIZE(1), 0x03, // REPORT_SIZE (3)
- REPORT_COUNT(1), 0x01, // REPORT_COUNT (1)
- HIDINPUT(1),
- 0x03, // INPUT (Constant, Variable, Absolute) ;3 bit padding
- // ------------------------------------------------- X/Y position, Wheel
- USAGE_PAGE(1), 0x01, // USAGE_PAGE (Generic Desktop)
- USAGE(1), 0x30, // USAGE (X)
- USAGE(1), 0x31, // USAGE (Y)
- USAGE(1), 0x38, // USAGE (Wheel)
- LOGICAL_MINIMUM(1), 0x81, // LOGICAL_MINIMUM (-127)
- LOGICAL_MAXIMUM(1), 0x7f, // LOGICAL_MAXIMUM (127)
- REPORT_SIZE(1), 0x08, // REPORT_SIZE (8)
- REPORT_COUNT(1), 0x03, // REPORT_COUNT (3)
- HIDINPUT(1),
- 0x06, // INPUT (Data, Variable, Relative) ;3 bytes (X,Y,Wheel)
- // ------------------------------------------------- Horizontal wheel
- USAGE_PAGE(1), 0x0c, // USAGE PAGE (Consumer Devices)
- USAGE(2), 0x38, 0x02, // USAGE (AC Pan)
- LOGICAL_MINIMUM(1), 0x81, // LOGICAL_MINIMUM (-127)
- LOGICAL_MAXIMUM(1), 0x7f, // LOGICAL_MAXIMUM (127)
- REPORT_SIZE(1), 0x08, // REPORT_SIZE (8)
- REPORT_COUNT(1), 0x01, // REPORT_COUNT (1)
- HIDINPUT(1), 0x06, // INPUT (Data, Var, Rel)
- END_COLLECTION(0), // END_COLLECTION
- END_COLLECTION(0) // END_COLLECTION
-};
-
-BleMouse::BleMouse(std::string deviceName, std::string deviceManufacturer,
- uint8_t batteryLevel)
- : _buttons(0), hid(0) {
- this->deviceName = deviceName;
- this->deviceManufacturer = deviceManufacturer;
- this->batteryLevel = batteryLevel;
- this->connectionStatus = new BleConnectionStatus();
-}
-
-void BleMouse::begin(void) {
- xTaskCreate(this->taskServer, "server", 20000, (void *)this, 5, NULL);
-}
-
-void BleMouse::end(void) {}
-
-void BleMouse::click(uint8_t b) {
- _buttons = b;
- move(0, 0, 0, 0);
- _buttons = 0;
- move(0, 0, 0, 0);
-}
-
-void BleMouse::move(signed char x, signed char y, signed char wheel,
- signed char hWheel) {
- if (this->isConnected()) {
- uint8_t m[5];
- m[0] = _buttons;
- m[1] = x;
- m[2] = y;
- m[3] = wheel;
- m[4] = hWheel;
- this->inputMouse->setValue(m, 5);
- this->inputMouse->notify();
- }
-}
-
-void BleMouse::buttons(uint8_t b) {
- if (b != _buttons) {
- _buttons = b;
- move(0, 0, 0, 0);
- }
-}
-
-void BleMouse::press(uint8_t b) { buttons(_buttons | b); }
-
-void BleMouse::release(uint8_t b) { buttons(_buttons & ~b); }
-
-bool BleMouse::isPressed(uint8_t b) {
- if ((b & _buttons) > 0)
- return true;
- return false;
-}
-
-bool BleMouse::isConnected(void) { return this->connectionStatus->connected; }
-
-void BleMouse::setBatteryLevel(uint8_t level) {
- this->batteryLevel = level;
- if (hid != 0)
- this->hid->setBatteryLevel(this->batteryLevel);
-}
-
-void BleMouse::taskServer(void *pvParameter) {
- BleMouse *bleMouseInstance =
- (BleMouse *)pvParameter; // static_cast<BleMouse *>(pvParameter);
- BLEDevice::init(std::string(bleMouseInstance->deviceName.c_str()));
- BLEServer *pServer = BLEDevice::createServer();
- pServer->setCallbacks(bleMouseInstance->connectionStatus);
-
- bleMouseInstance->hid = new BLEHIDDevice(pServer);
- bleMouseInstance->inputMouse = bleMouseInstance->hid->inputReport(
- 0); // <-- input REPORTID from report map
- bleMouseInstance->connectionStatus->inputMouse =
- bleMouseInstance->inputMouse;
-
- bleMouseInstance->hid->manufacturer()->setValue(
- std::string(bleMouseInstance->deviceManufacturer.c_str()));
-
- bleMouseInstance->hid->pnp(0x02, 0xe502, 0xa111, 0x0210);
- bleMouseInstance->hid->hidInfo(0x00, 0x02);
-
- BLESecurity *pSecurity = new BLESecurity();
-
- pSecurity->setAuthenticationMode(ESP_LE_AUTH_BOND);
-
- bleMouseInstance->hid->reportMap((uint8_t *)_hidReportDescriptor,
- sizeof(_hidReportDescriptor));
- bleMouseInstance->hid->startServices();
-
- bleMouseInstance->onStarted(pServer);
-
- BLEAdvertising *pAdvertising = pServer->getAdvertising();
- pAdvertising->setAppearance(HID_MOUSE);
- pAdvertising->addServiceUUID(
- bleMouseInstance->hid->hidService()->getUUID());
- pAdvertising->start();
- bleMouseInstance->hid->setBatteryLevel(bleMouseInstance->batteryLevel);
-
- ESP_LOGD(LOG_TAG, "Advertising started!");
- vTaskDelay(portMAX_DELAY); // delay(portMAX_DELAY);
-}