From 7e24ce0f171387197979b78209fb15f57f70d4bd Mon Sep 17 00:00:00 2001 From: goasChris Date: Fri, 16 Feb 2024 20:39:33 +0000 Subject: [PATCH] Add support for non-default vehicle ID Add detection, storage, and handling of system_id --- src/libs/vehicle/ardupilot/arducopter.ts | 9 ++++--- src/libs/vehicle/ardupilot/ardupilot.ts | 34 +++++++++++++++++------- src/libs/vehicle/ardupilot/arduplane.ts | 9 ++++--- src/libs/vehicle/ardupilot/ardurover.ts | 9 ++++--- src/libs/vehicle/ardupilot/ardusub.ts | 9 ++++--- src/libs/vehicle/ardupilot/types.ts | 7 +++-- src/libs/vehicle/vehicle-factory.ts | 28 +++++++++++-------- src/stores/mainVehicle.ts | 2 +- 8 files changed, 71 insertions(+), 36 deletions(-) diff --git a/src/libs/vehicle/ardupilot/arducopter.ts b/src/libs/vehicle/ardupilot/arducopter.ts index 9e97d9327..1009d1db3 100644 --- a/src/libs/vehicle/ardupilot/arducopter.ts +++ b/src/libs/vehicle/ardupilot/arducopter.ts @@ -76,9 +76,10 @@ export class ArduCopter extends ArduPilotVehicle { /** * Create ArduCopter vehicle + * @param {number} system_id */ - constructor() { - super(Vehicle.Type.Copter) + constructor(system_id: number) { + super(Vehicle.Type.Copter, system_id) } /** @@ -109,7 +110,9 @@ export class ArduCopter extends ArduPilotVehicle { */ onMAVLinkPackage(mavlink: Package): void { const { system_id, component_id } = mavlink.header - if (system_id != 1 || component_id !== 1) { + this.currentSystemId = system_id + + if (component_id !== 1) { return } diff --git a/src/libs/vehicle/ardupilot/ardupilot.ts b/src/libs/vehicle/ardupilot/ardupilot.ts index fb2b340c2..6aef6bde3 100644 --- a/src/libs/vehicle/ardupilot/ardupilot.ts +++ b/src/libs/vehicle/ardupilot/ardupilot.ts @@ -82,6 +82,8 @@ export abstract class ArduPilotVehicle extends Vehicle.AbstractVehicle extends Vehicle.AbstractVehicle extends Vehicle.AbstractVehicle extends Vehicle.AbstractVehicle extends Vehicle.AbstractVehicle extends Vehicle.AbstractVehicle extends Vehicle.AbstractVehicle extends Vehicle.AbstractVehicle extends Vehicle.AbstractVehicle extends Vehicle.AbstractVehicle extends Vehicle.AbstractVehicle { + const systemIdToUse = this.currentSystemId ?? 1 // Convert from Cockpit waypoints to MAVLink waypoints this._currentCockpitMissionItemsOnPlanning = items - const mavlinkWaypoints = convertCockpitWaypointsToMavlink(items) + const mavlinkWaypoints = convertCockpitWaypointsToMavlink(items, systemIdToUse) // Only deal with regular mission items for now const missionType = MavMissionType.MAV_MISSION_TYPE_MISSION diff --git a/src/libs/vehicle/ardupilot/arduplane.ts b/src/libs/vehicle/ardupilot/arduplane.ts index a74563e7c..c6300c435 100644 --- a/src/libs/vehicle/ardupilot/arduplane.ts +++ b/src/libs/vehicle/ardupilot/arduplane.ts @@ -49,9 +49,10 @@ export class ArduPlane extends ArduPilotVehicle { /** * Create ArduPlane vehicle + * @param {number} system_id */ - constructor() { - super(Vehicle.Type.Plane) + constructor(system_id: number) { + super(Vehicle.Type.Plane, system_id) } /** @@ -82,7 +83,9 @@ export class ArduPlane extends ArduPilotVehicle { */ onMAVLinkPackage(mavlink: Package): void { const { system_id, component_id } = mavlink.header - if (system_id != 1 || component_id !== 1) { + this.currentSystemId = system_id + + if (component_id !== 1) { return } diff --git a/src/libs/vehicle/ardupilot/ardurover.ts b/src/libs/vehicle/ardupilot/ardurover.ts index 69d4fc787..82fd25275 100644 --- a/src/libs/vehicle/ardupilot/ardurover.ts +++ b/src/libs/vehicle/ardupilot/ardurover.ts @@ -37,9 +37,10 @@ export class ArduRover extends ArduPilotVehicle { /** * Create ArduRover vehicle + * @param {number} system_id */ - constructor() { - super(Vehicle.Type.Rover) + constructor(system_id: number) { + super(Vehicle.Type.Rover, system_id) } /** @@ -70,7 +71,9 @@ export class ArduRover extends ArduPilotVehicle { */ onMAVLinkPackage(mavlink: Package): void { const { system_id, component_id } = mavlink.header - if (system_id != 1 || component_id !== 1) { + this.currentSystemId = system_id + + if (component_id !== 1) { return } diff --git a/src/libs/vehicle/ardupilot/ardusub.ts b/src/libs/vehicle/ardupilot/ardusub.ts index 88e48cafd..b6f4d160d 100644 --- a/src/libs/vehicle/ardupilot/ardusub.ts +++ b/src/libs/vehicle/ardupilot/ardusub.ts @@ -43,9 +43,10 @@ export class ArduSub extends ArduPilotVehicle { /** * Create ArduSub vehicle + * @param {number} system_id */ - constructor() { - super(Vehicle.Type.Sub) + constructor(system_id: number) { + super(Vehicle.Type.Sub, system_id) } /** @@ -76,7 +77,9 @@ export class ArduSub extends ArduPilotVehicle { */ onMAVLinkPackage(mavlink: Package): void { const { system_id, component_id } = mavlink.header - if (system_id != 1 || component_id !== 1) { + this.currentSystemId = system_id + + if (component_id !== 1) { return } diff --git a/src/libs/vehicle/ardupilot/types.ts b/src/libs/vehicle/ardupilot/types.ts index aba764fd4..33a55874d 100644 --- a/src/libs/vehicle/ardupilot/types.ts +++ b/src/libs/vehicle/ardupilot/types.ts @@ -31,10 +31,13 @@ const cockpitAltRefFromMavlinkFrame = (mavframe: MavFrame): AltitudeReferenceTyp return correspondency === undefined ? undefined : correspondency[1] } -export const convertCockpitWaypointsToMavlink = (cockpitWaypoints: Waypoint[]): Message.MissionItemInt[] => { +export const convertCockpitWaypointsToMavlink = ( + cockpitWaypoints: Waypoint[], + system_id: number +): Message.MissionItemInt[] => { return cockpitWaypoints.map((cockpitWaypoint, i) => { return { - target_system: 1, + target_system: system_id, target_component: 1, type: MAVLinkType.MISSION_ITEM_INT, seq: i, diff --git a/src/libs/vehicle/vehicle-factory.ts b/src/libs/vehicle/vehicle-factory.ts index 264f38bff..37b3427f4 100644 --- a/src/libs/vehicle/vehicle-factory.ts +++ b/src/libs/vehicle/vehicle-factory.ts @@ -23,14 +23,19 @@ export class VehicleFactory { * Create vehicle based on the firmware and vehicle type * @param {Vehicle.Firmware} firmware * @param {Vehicle.Type} type + * @param {number} system_id - The system ID for the vehicle * @returns {Vehicle.Abstract | undefined} */ - static createVehicle(firmware: Vehicle.Firmware, type: Vehicle.Type): Vehicle.Abstract | undefined { + static createVehicle( + firmware: Vehicle.Firmware, + type: Vehicle.Type, + system_id: number + ): Vehicle.Abstract | undefined { let vehicle: undefined | Vehicle.Abstract = undefined switch (firmware) { case Vehicle.Firmware.ArduPilot: - vehicle = VehicleFactory.createArduPilotVehicle(type) + vehicle = VehicleFactory.createArduPilotVehicle(type, system_id) break } @@ -50,18 +55,19 @@ export class VehicleFactory { /** * Create ArduPilot vehicle based on the category * @param {Vehicle.Type} type + * @param {number} system_id * @returns {Vehicle.Abstract | undefined} */ - static createArduPilotVehicle(type: Vehicle.Type): Vehicle.Abstract | undefined { + static createArduPilotVehicle(type: Vehicle.Type, system_id: number): Vehicle.Abstract | undefined { switch (type) { case Vehicle.Type.Copter: - return new ArduCopter() + return new ArduCopter(system_id) case Vehicle.Type.Plane: - return new ArduPlane() + return new ArduPlane(system_id) case Vehicle.Type.Rover: - return new ArduRover() + return new ArduRover(system_id) case Vehicle.Type.Sub: - return new ArduSub() + return new ArduSub(system_id) default: unimplemented('Firmware not supported') } @@ -105,18 +111,18 @@ function createVehicleFromMessage(message: Uint8Array): void { switch (heartbeat.mavtype.type) { case MavType.MAV_TYPE_SUBMARINE: - VehicleFactory.createVehicle(Vehicle.Firmware.ArduPilot, Vehicle.Type.Sub) + VehicleFactory.createVehicle(Vehicle.Firmware.ArduPilot, Vehicle.Type.Sub, system_id) break case MavType.MAV_TYPE_GROUND_ROVER: case MavType.MAV_TYPE_SURFACE_BOAT: - VehicleFactory.createVehicle(Vehicle.Firmware.ArduPilot, Vehicle.Type.Rover) + VehicleFactory.createVehicle(Vehicle.Firmware.ArduPilot, Vehicle.Type.Rover, system_id) break case MavType.MAV_TYPE_FLAPPING_WING: case MavType.MAV_TYPE_VTOL_TILTROTOR: case MavType.MAV_TYPE_VTOL_QUADROTOR: case MavType.MAV_TYPE_VTOL_DUOROTOR: case MavType.MAV_TYPE_FIXED_WING: - VehicleFactory.createVehicle(Vehicle.Firmware.ArduPilot, Vehicle.Type.Plane) + VehicleFactory.createVehicle(Vehicle.Firmware.ArduPilot, Vehicle.Type.Plane, system_id) break case MavType.MAV_TYPE_TRICOPTER: case MavType.MAV_TYPE_COAXIAL: @@ -125,7 +131,7 @@ function createVehicleFromMessage(message: Uint8Array): void { case MavType.MAV_TYPE_OCTOROTOR: case MavType.MAV_TYPE_DODECAROTOR: case MavType.MAV_TYPE_QUADROTOR: - VehicleFactory.createVehicle(Vehicle.Firmware.ArduPilot, Vehicle.Type.Copter) + VehicleFactory.createVehicle(Vehicle.Firmware.ArduPilot, Vehicle.Type.Copter, system_id) break default: console.warn(`Vehicle type not supported: ${system_id}/${component_id}: ${heartbeat.mavtype.type}`) diff --git a/src/stores/mainVehicle.ts b/src/stores/mainVehicle.ts index 71065d295..f21d59201 100644 --- a/src/stores/mainVehicle.ts +++ b/src/stores/mainVehicle.ts @@ -363,7 +363,7 @@ export const useMainVehicleStore = defineStore('main-vehicle', () => { Object.assign(genericVariables, newGenericVariablesState) }) mainVehicle.value.onMAVLinkMessage.add(MAVLinkType.HEARTBEAT, (pack: Package) => { - if (pack.header.system_id != 1 || pack.header.component_id != 1) { + if (pack.header.component_id != 1) { return }