Skip to content

Commit

Permalink
Merge remote-tracking branch 'origin/gui_graphs' into better_settings…
Browse files Browse the repository at this point in the history
…_layout
  • Loading branch information
toni-neurosc committed Dec 4, 2024
2 parents 35f3a89 + b2e1404 commit 96c7770
Show file tree
Hide file tree
Showing 8 changed files with 228 additions and 186 deletions.
1 change: 0 additions & 1 deletion gui_dev/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,6 @@
"@mui/material": "latest",
"cbor-js": "^0.1.0",
"immer": "^10.1.1",
"plotly.js": "^2.35.2",
"plotly.js-basic-dist-min": "^2.35.2",
"react": "next",
"react-dom": "next",
Expand Down
2 changes: 2 additions & 0 deletions gui_dev/src/components/BandPowerGraph.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -121,6 +121,7 @@ export const BandPowerGraph = () => {
height: 350,
paper_bgcolor: "#333",
plot_bgcolor: "#333",
hovermode: false, // Add this line to disable hovermode
xaxis: {
title: { text: "Frequency Band", font: { color: "#f4f4f4" } },
color: "#cccccc",
Expand All @@ -141,6 +142,7 @@ export const BandPowerGraph = () => {
x: data.features,
y: data.values,
type: "bar",
hoverinfo: 'skip',
name: data.channelName,
marker: { color: barColors },
};
Expand Down
28 changes: 17 additions & 11 deletions gui_dev/src/components/DecodingGraph.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@ export const DecodingGraph = ({
}) => {
//const graphData = useSocketStore((state) => state.graphData);
const graphDecodingData = useSocketStore((state) => state.graphDecodingData);

const samplingRate = useSessionStore((state) => state.streamParameters.samplingRateFeatures);
//const channels = useSessionStore((state) => state.channels, shallow);

//const usedChannels = useMemo(
Expand Down Expand Up @@ -68,6 +68,7 @@ export const DecodingGraph = ({
height: 400,
paper_bgcolor: "#333",
plot_bgcolor: "#333",
hovermode: false, // Add this line to disable hovermode
margin: {
l: 50,
r: 50,
Expand Down Expand Up @@ -110,7 +111,7 @@ export const DecodingGraph = ({
};

const handleMaxDataPointsChangeDecoding = (event, newValue) => {
setMaxDataPointsDecoding(newValue);
setMaxDataPointsDecoding(newValue * samplingRate); // Convert seconds to number of samples
};

//useEffect(() => {
Expand Down Expand Up @@ -218,13 +219,14 @@ export const DecodingGraph = ({
const traces = selectedDecodingOutputs.map((decodingOutput, idx) => {
const yData = decodingData[decodingOutput] || [];
const y = yData.slice().reverse();
const x = Array.from({ length: y.length }, (_, i) => i);
const x = Array.from({ length: y.length }, (_, i) => i / samplingRate); // Convert to time in seconds

return {
x,
y,
type: "scatter",
type: "scattergl",
mode: "lines",
hoverinfo: 'skip',
name: decodingOutput,
line: { simplify: false, color: colors[idx] },
yaxis: idx === 0 ? "y" : `y${idx + 1}`,
Expand All @@ -236,9 +238,13 @@ export const DecodingGraph = ({
xaxis: {
...layoutRef.current.xaxis,
autorange: "reversed",
range: [0, maxDataPointsDecoding],
range: [0, maxDataPointsDecoding / samplingRate], // Adjust range to time in seconds
domain: [0, 1],
anchor: totalDecodingOutputs === 1 ? "y" : `y${totalDecodingOutputs}`,
title: {
text: "Time [s]", // Update x-axis title
font: { color: "#f4f4f4" },
},
},
...yAxes,
height: 350, // TODO height autoadjust to screen
Expand All @@ -254,7 +260,7 @@ export const DecodingGraph = ({
.catch((error) => {
console.error("Plotly error:", error);
});
}, [decodingData, selectedDecodingOutputs, yAxisMaxValue, maxDataPointsDecoding]);
}, [decodingData, selectedDecodingOutputs, yAxisMaxValue, maxDataPointsDecoding, samplingRate]);

return (
<Box>
Expand Down Expand Up @@ -310,20 +316,20 @@ export const DecodingGraph = ({
</Box>
<Box sx={{ minWidth: 200 }}>
<CollapsibleBox
title="Window Size" defaultExpanded={true} id="BoxDecoding">
title="Window Size (s)" defaultExpanded={true} id="BoxDecoding">
<Typography gutterBottom>
Current Value: {maxDataPointsDecoding}
Current Value: {(maxDataPointsDecoding / samplingRate).toFixed(1)} s
</Typography>
<Slider
id="max-data-points-slider-decoding"
value={maxDataPointsDecoding}
value={maxDataPointsDecoding / samplingRate} // Convert number of samples to seconds
onChange={handleMaxDataPointsChangeDecoding}
aria-labelledby="max-data-points-slider"
valueLabelDisplay="auto"
step={10}
step={0.1}
marks
min={0}
max={1000}
max={10}
/>
</CollapsibleBox>
</Box>
Expand Down
Loading

0 comments on commit 96c7770

Please sign in to comment.