🎮 Makes controller sub for imu updates
This commit is contained in:
@@ -8,15 +8,15 @@ export const imu = (() => {
|
|||||||
x: [] as number[],
|
x: [] as number[],
|
||||||
y: [] as number[],
|
y: [] as number[],
|
||||||
z: [] as number[],
|
z: [] as number[],
|
||||||
imu_temp: [] as number[],
|
heading: [] as number[],
|
||||||
altitude: [] as number[],
|
altitude: [] as number[],
|
||||||
pressure: [] as number[],
|
pressure: [] as number[],
|
||||||
bmp_temp: [] as number[]
|
bmp_temp: [] as number[]
|
||||||
});
|
});
|
||||||
|
|
||||||
const addData = (content: IMU) => {
|
const addData = (content: IMU) => {
|
||||||
update((data) => {
|
update(data => {
|
||||||
(Object.keys(content) as (keyof IMU)[]).forEach((key) => {
|
(Object.keys(content) as (keyof IMU)[]).forEach(key => {
|
||||||
data[key] = [...data[key], content[key]].slice(-maxIMUData);
|
data[key] = [...data[key], content[key]].slice(-maxIMUData);
|
||||||
});
|
});
|
||||||
return data;
|
return data;
|
||||||
|
|||||||
@@ -150,7 +150,7 @@ export type IMU = {
|
|||||||
x: number;
|
x: number;
|
||||||
y: number;
|
y: number;
|
||||||
z: number;
|
z: number;
|
||||||
imu_temp: number;
|
heading: number;
|
||||||
altitude: number;
|
altitude: number;
|
||||||
bmp_temp: number;
|
bmp_temp: number;
|
||||||
pressure: number;
|
pressure: number;
|
||||||
|
|||||||
@@ -2,8 +2,25 @@
|
|||||||
import Controls from './Controls.svelte';
|
import Controls from './Controls.svelte';
|
||||||
import WidgetContainer from '$lib/components/layout/WidgetContainer.svelte';
|
import WidgetContainer from '$lib/components/layout/WidgetContainer.svelte';
|
||||||
import { selectedView, views } from '$lib/stores/application';
|
import { selectedView, views } from '$lib/stores/application';
|
||||||
|
import { onMount } from 'svelte';
|
||||||
|
import { mpu, socket } from '$lib/stores';
|
||||||
|
import { imu } from '$lib/stores/imu';
|
||||||
|
import type { IMU } from '$lib/types/models';
|
||||||
|
|
||||||
$: layout = $views.find(v => v.name === $selectedView)!
|
$: layout = $views.find(v => v.name === $selectedView)!;
|
||||||
|
|
||||||
|
onMount(() => {
|
||||||
|
socket.on('imu', (data: IMU) => {
|
||||||
|
imu.addData(data);
|
||||||
|
if (data.heading)
|
||||||
|
mpu.update(mpuData => {
|
||||||
|
mpuData.heading = data.heading;
|
||||||
|
console.log(data.heading);
|
||||||
|
|
||||||
|
return mpuData;
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<div class="absolute top-0 select-none w-screen h-screen">
|
<div class="absolute top-0 select-none w-screen h-screen">
|
||||||
|
|||||||
Reference in New Issue
Block a user