Skip to content

A WebPage/Site that can graph data collected on the micro:bit.

License

Notifications You must be signed in to change notification settings

fredqian/microbit-usb-grapher

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

83 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Launch our App!

Go!

Micro:bit USB Grapher

A WebPage/Site that can graph, manipulate, and save data collected on the micro:bit.

Project Overview

The micro:bit is a low-cost hardware platform that is used to introduce both computer programming principles and to facilitate maker activities, like making wearables. It's already widely used by K-12 educators for computing activities, but, due to it on-board sensors and its extensibility, it's could also augment classroom science demonstrations. (For example, the existing Makecode editor already can be used to collect and graph streaming data. See here for a simulated micro:bit graphing accelerometer data. Click the Edit button, then clicke the Show console Simulator button. The micro:bit shown as a rectangle with buttons and gold connectors at the bottom. Moving over the image of the micro:bit will simulate tilting and the graphed data)

The Makecode simulator can already collect and graph data, but it's data collection window can only graph a small sample of data and it's limited to just one micro:bit at a time. The goal of this project is to develop a stand-alone web site that will collect information from one or more micro:bits and allow users to graph a wider range of data and interact with the data in ways not supported by Makecode.

Features

  • Required
    • Data will be streamed from one or more micro:bits.
    • Graphs should have titles, axis labels and titles, and legends
    • Data will include numeric values that correspond to time-series. They should be depicted graphically
      • There may be multiple graphs and each graph may have multiple time series shown
      • The number of graphs and series per graph must be updated dynamically. New graphs may need to be added as data is collected.
      • Users should be able to zoom in/out of data
      • Data and ranges should be clearly visible
      • Time scales should be easily identifiable
      • Users should be able to pan through data
      • By default time series should be shown in strip-chart format and most recent data should be shown (autoscrolling)
        • Auto scrolling should be able to be disabled to allow users to view older data as data continues to arrive
      • Text labels (events) may also be included. This should be depicted on the time series as well. Although the text doesn't always need to be visible, there should be clear that there is text available and it should be easy to retrieve the text.
    • Users should be able to download all data as a CSV file
  • Desireable
    • Ability to measure time between different events

Deliverables

  • A web-app for collecting and graphing time-series data and events from micro:bits
    • should allow users to interact with data to find features of interest
  • Instruction manuals & Documentation
    • Use
    • Setup and Application Architecture (how to deploy a new instance and anything future developers may need to know/understand)

Potential Components

USB Interaction

  • Microbit-WebUSB: An simple API designed to retrieve data from a micro:bit via USB. It was designed specifically to support this project.

Graphing

TODO: More and descriptions of good/bad

Example Documentation

Experiment Setup (prior to this application)

About

A WebPage/Site that can graph data collected on the micro:bit.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 93.1%
  • HTML 3.7%
  • CSS 3.2%