Skip to content

Commit

Permalink
Merge pull request upsidedownlabs#49 from Ritika8081/main
Browse files Browse the repository at this point in the history
updated indexed db logic
  • Loading branch information
lorforlinux authored Oct 3, 2024
2 parents c359aa4 + a568547 commit 57d3f3f
Show file tree
Hide file tree
Showing 3 changed files with 157 additions and 156 deletions.
1 change: 0 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
![Chords Default](public/assets/dark/HeroSignalsClean.png)

</p>

Chords is an application based on Web Serial connection, you can connect boards like Arduino Uno, Arduino Nano after uploading the ArduinoFirmware.ino code to it, you'll recieve data signals from the board which can be visualized on web using Chords. Users can visualize ECG and EMG signals.

Expand Down
62 changes: 33 additions & 29 deletions src/components/Canvas.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -170,30 +170,29 @@ const Canvas: React.FC<CanvasProps> = ({
getChannelColor, // Dependency: function to get the color for a specific channel
]);

// Callback function to process a batch of data and append it to the corresponding time series
const processBatch = useCallback(() => {
// Exit early if the batch buffer is empty or the global state is paused
if (batchBuffer.length === 0 || isGlobalPaused) return;

// Iterate over each batch in the batch buffer
batchBuffer.forEach((batch: Batch) => {
// Iterate over each channel to update the corresponding time series
channels.forEach((_, index) => {
const series = seriesRef.current[index]; // Get the time series for the current channel
if (
series && // Check if the series exists
batch.values[index] !== undefined && // Ensure the batch has a value for the current channel
!isNaN(batch.values[index]) // Check that the value is a valid number
) {
series.append(batch.time, batch.values[index]); // Append the time and value to the series
}
// Callback function to process a batch of data and append it to the corresponding time series
const processBatch = useCallback(() => {
// Exit early if the batch buffer is empty or the global state is paused
if (batchBuffer.length === 0 || isGlobalPaused) return;

// Iterate over each batch in the batch buffer
batchBuffer.forEach((batch: Batch) => {
// Iterate over each channel to update the corresponding time series
channels.forEach((_, index) => {
const series = seriesRef.current[index]; // Get the time series for the current channel
if (
series && // Check if the series exists
batch.values[index] !== undefined && // Ensure the batch has a value for the current channel
!isNaN(batch.values[index]) // Check that the value is a valid number
) {
series.append(batch.time, batch.values[index]); // Append the time and value to the series
}
});
});
});

// Clear the batch buffer after processing
batchBuffer.length = 0;
}, [channels, batchBuffer, isGlobalPaused]); // Dependencies for the useCallback

// Clear the batch buffer after processing
batchBuffer.length = 0;
}, [channels, batchBuffer, isGlobalPaused]); // Dependencies for the useCallback

// Improve the data update to handle data flow more consistently
const handleDataUpdate = useCallback(
Expand Down Expand Up @@ -222,7 +221,7 @@ const processBatch = useCallback(() => {
// Initialize charts only when the number of channels (canvasCount) changes
const initializeCharts = () => {
const colors = getThemeColors(); // Get the current theme colors

// Clean up existing charts before initializing new ones
chartRef.current.forEach((chart, index) => {
if (chart) {
Expand All @@ -233,7 +232,7 @@ const processBatch = useCallback(() => {
}
}
});

// Re-initialize all channels
channels.forEach((_, index) => {
// Loop through each channel to create a new chart
Expand Down Expand Up @@ -265,26 +264,26 @@ const processBatch = useCallback(() => {
? undefined
: getMaxValue(selectedBits), // Set maximum value based on auto-scaling
});

const series = new TimeSeries(); // Create a new TimeSeries instance
chartRef.current[index] = chart; // Store the chart in the ref array
seriesRef.current[index] = series; // Store the series in the ref array

chart.addTimeSeries(series, {
// Add the time series to the chart with specified styling
strokeStyle: getChannelColor(index), // Set the stroke color based on the channel index
lineWidth: 1, // Set the line width
});

chart.streamTo(canvas, 100); // Stream data to the canvas at 100 ms intervals
}
});
setIsChartInitialized(true); // Update state to indicate charts have been initialized
};

initializeCharts(); // Call the initialize function when canvasCount changes
}, [canvasCount]); // Dependency array: re-run the effect only when canvasCount changes

// Update chart properties (theme, selectedBits) without reinitializing the charts
useEffect(() => {
if (isChartInitialized) {
Expand Down Expand Up @@ -386,6 +385,11 @@ const processBatch = useCallback(() => {
channels.length
)} relative bg-white dark:bg-gray-900`}
>
{/* Badge for Channel Number */}
<span className="absolute top-1 left-1 transform -translate-y-1/20 translate-x-1/6 text-gray-500 text-sm rounded-full">
{`CH${index + 1}`}
</span>

<canvas
id={`smoothie-chart-${index + 1}`}
className="w-full h-full m-0 p-0"
Expand Down
Loading

0 comments on commit 57d3f3f

Please sign in to comment.