The fitbitViz R package allows the extraction of data and the visualization of ‘ggplot2’, ‘Leaflet’ and 3-dimensionsal ‘Rayshader’ Maps using the Fitbit Web API. If you own any of the Fitbit activity trackers you can take advantage of this package. A detailed explanation of the functionality can be found both in the Vignette and in the blog post.
The 3-dimensional Rayshader Map requires the installation of the CopernicusDEM R package which includes the 30- and 90-meter elevation data.
To make use of this R package you have first to register an Application in https://dev.fitbit.com/. By registering an application you will receive the Fitbit token which besides your existing user-id is required so that you can take advantage of the fitbitViz functions.
There are many resources on the web on how to setup a Fitbit application. I modified the following guide which explains in detail how to register an application and then receive a token to retrieve the Fitbit data for a specific time period (maximum a year). The next images and comments explain the whole process,
Go to https://dev.fitbit.com/ and click on Manage > Register an App
Login with your Fitbit credentials and follow the prompts. I used as URL in the Registration Page my Fitbit user-id url, https://www.fitbit.com/user/USER_ID
. You have to replace the USER_ID in the url with your specific user-id. Then in the Redirect URL field use https://localhost
. Tick the remaining options as in the next image, read and agree to the terms of service and click Register to register the application.
Once the app is created, click on the ‘OAuth 2.0 tutorial page’ weblink near the bottom of the screen:
Scroll down to the end of 1. Authorize and right click on the provided authorization URL (in blue color) to open this URL on a new web browser tab which will show the Fitbit authorization interface. Change the auth period to 1 year so that you don’t have to go through this too often and tick all options before clicking Allow (you will probably play with the other endpoints at some point in the future)
After clicking Allow, the browser tab redirects to the callback URL. You’ll have to copy and paste the full URL which now includes also the access token to the 2. Parse response header of the previous tab (where we have seen also the 1. Authorize section). The required access token for your application that you can use in this package will appear below the text box (it’s a long string of characters).
You now have your token and can start using the fitbitViz R package to access and visualize your data.
The functions of the fitbitViz R package can be used in an automatic way so that the user can keep track of the Visualizations and data over time.
From the first moment I’ve started implementing the fitbitViz R package this is what I actually had in my mind. You can have a look to my Fitbit Visualizations website. The following steps explain in detail how this can be achieved:
What it remains is to modify the .github/workflows/gh_fitbit_blog.yaml file to adjust the
Regarding the fitbitViz parameters (.github/workflows/gh_fitbit_blog.yaml file) at it’s current state the application takes:
The order to modify, debug or include new code / functions to the files of this Github Repository is the following:
One important thing to keep in mind is that besides the Visualizations the user has access also to the pre-processed Fitbit data by clicking to a CSV button as shown in the next image,
Docker images of the fitbitViz package are available to download from my dockerhub account. The images come with Rstudio and the R-development version (latest) installed. The whole process was tested on Ubuntu 18.04. To pull & run the image do the following,
docker pull mlampros/fitbitviz:rstudiodev
docker run -d --name rstudio_dev -e USER=rstudio -e PASSWORD=give_here_your_password --rm -p 8787:8787 mlampros/fitbitviz:rstudiodev
The user can also bind a home directory / folder to the image to use its files by specifying the -v command,
docker run -d --name rstudio_dev -e USER=rstudio -e PASSWORD=give_here_your_password --rm -p 8787:8787 -v /home/YOUR_DIR:/home/rstudio/YOUR_DIR mlampros/fitbitviz:rstudiodev
In the latter case you might have first give permission privileges for write access to YOUR_DIR directory (not necessarily) using,
The USER defaults to rstudio but you have to give your PASSWORD of preference (see www.rocker-project.org for more information).
Open your web-browser and depending where the docker image was build / run give,
1st. Option on your personal computer,
2nd. Option on a cloud instance,
to access the Rstudio console in order to give your username and password.
To install the package from CRAN use,
and to download the latest version of the package from Github,
If you use the fitbitViz R package in your paper or research please cite https://CRAN.R-project.org/package=fitbitViz
:
@Manual{,
title = {{fitbitViz}: Fitbit Visualizations},
author = {Lampros Mouselimis},
year = {2022},
note = {R package version 1.0.3},
url = {https://CRAN.R-project.org/package=fitbitViz},
}