У меня есть несколько устройств, которые я пытаюсь построить в реальном времени на основе данных, которые они собирают. В настоящее время я пытаюсь прочитать и отобразить их уровень сигнала Wi-Fi, но у меня возникают проблемы, связывая вещи вместе. Как бы я построил Xaxis из опубликованных данных и составил график сигнала Wi-Fi?
Пример переменной parsedData
{coreid: "1f0039000547363339343638", data: "-21", published_at: "2018-11-02T17:36:15.794Z", ttl: 60}
home.vue
<template>
<div>
<line-chart :chart-data="chartData" />
</div>
</template>
<script>
import LineChart from '@/components/lineChart'
let wifiSignal = []
export default {
components: {
LineChart
},
data() {
return {
wifiSignal: null,
datacollection: null,
probes: [],
probe: [],
chartData: {
labels: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October',
'November', 'December'
],
datasets: [{
label: 'Wifi Signal',
backgroundColor: '#f87979',
data: this.wifiSignal
}]
}
}
},
created() {
this.streamData()
},
mounted() {
// grab probe data
axios.get('http://10.10.10.1:8080/v1/devices')
.then((res) => {
(this.probes = res.data)
// console.log(res.data)
}).catch((error) => {
console.log(error.res);
});
},
methods: {
streamData() {
// LIVE PUSH EVENTS
if (typeof (EventSource) !== "undefined") {
var eventSource = new EventSource(
"http://10.10.10.1:8080/v1/Events");
eventSource.addEventListener('open', function (e) {
console.log("Opened connection to event stream!");
}, false);
eventSource.addEventListener('error', function (e) {
console.log("Errored!");
}, false);
eventSource.addEventListener('WiFi Signal', function (e) {
var parsedData = JSON.parse(e.data);
let cat = parseInt(parsedData.data)
console.log(cat)
wifiSignal.push(cat);
}, false);
}
}
},
};
</script>
linechart.js
import { Line, mixins } from 'vue-chartjs'
const { reactiveProp } = mixins
export default {
extends: Line,
mixins: [reactiveProp],
props: ['options'],
mounted () {
// this.chartData is created in the mixin.
// If you want to pass options please create a local options object
this.renderChart(this.chartData, this.options)
}
}