UMD Javascript Plotting Utility, Version 3.7

Table of Contents

(End of Page)

Introduction

Back to top
There are many ways to make scatter plots, graphs, bar charts, pie charts, etc in javascript. Google developers have a wonderful set of free javascript sources that you can use called
Google Charts that are quite powerful, and SitePoint has a whole page of javascript libraries for this purpose.

So why develop yet another? There are lots of reasons:

This library was written so as to be pretty easy to use, sort of modeled on the Google Charts, lightweight, and downloadable so you don't need to access it over the internet.

What is usually the case in science is that we need histograms, scatterplots, and functions, and this is what this package provides (so far just scatterplots and histograms but functions are on the way). No bar charts, pie charts, etc, just basic histograms and scatter plots.


Access

Back to top
The code is available for download
here. There are 3 parts to using this code:
  1. In your html, preferably inside the <head> tag, include the following javascript source:
    	<script src="/location/plots3.7.js"></script>
    
    where "location" is of course dependent on where you put the code.

  2. The only thing you have to put in your HTML is a div, with an ID:
    	<div id="mydiv"></div>
    
    Note that if you leave off the </div>, then HTML won't complain but the entire hierarchy of what's in that div will be messed up. So don't forget to close the div!!

  3. In your javascript, you create a new plot using:
    	let plot = new UMD_plot("mydiv");
    
    where "mydiv" is the id of the <div> that you put in step 2.

    All plots, whether histograms,scatter plots, or functions (or whatever is implemented) are drawn in an HTML5 canvas (<canvas>) and that is created in the constructor ("new..."). See below for details.


Version

Back to top
You can get the version from the object variable "version. So for instance, to type it out on the console, do something like this in your javascript code:
	let plot = new UMD_plot("mydiv");
	.
	.
	.
	console.log(plot.version);

Usage

Back to top
As of version 3.1, functions are not yet available, but scatterplots are, and the others will follow quickly.

To make a scatterplot, let's say you have some data you want to plot, here we will make an array called y and fill it with 100 random numbers.

	let y = [];
	for (var i=0; i<100; i++) x.push(Math.random());
If the <div> id is "divid", then we invoke a new UMD_plot object via:
	let plot = new UMD_plot("divid");
This will set up all the values and methods for plotting the function onto a canvas that will live inside the "divid" div. To plot, you do this:
	plot.plotit(options)
The variable options is a javascript object that you fill in, and it will contain things like the size of the plot in pixels, the data to plot, colors, fonts, etc. The table below will show you the available options, and the defaults.

The following lists the different ways available to show the plot

For each of these, you can specify the color, the "size" (width of line, radius of circle, or side of the box). How you do this is explained next: For example, let's say you have arrays x and y and you wanted to make a plot that connects the points with a blue line and puts open red circles of radius 3 pixels on the points, with a particular title, x-axis title, y-axis title, and make the canvas height 500 and width 600 pixels, you would have options like this:
let plot = UMD_plot("mydiv");
let yobj1 = {
    data: y,
    type: "line",
    color: "blue",
    size:  0.5,
};
let yobj2 = {
    data: y,
    type: "circle",
    color: "red",
    size:  3,
    fill: false
};
options = {
    ydata: [yobj1,yobj2],
    title: "this is the overall plot title",
    xtitle: "this goes along the bottom horizontal",
    ytitle: "this goes along the vertical to the left"
    width: 500,
    height: 600,
 };
  .
  .
  .
plot.plotit(options);
There is an additional way to plot individual x,y points. Create an item in options called "points", which will hold an array of objects, with the objects being pairs of points to plot. The object needs the following items defined: x,y,type,color,fill,size (type, color, fill, size are defined the same for ydata objects, defaults are "circle", "blue", true, and 3 respectively...see above) For instance, if you want to plot the point x,y=2,5 as a blue closed circle and x,y=1,4 as a red open circle both of radius 5 then add the option:
options = {
	.
	.
	.
	points: [
		{x:2,y:5,type:"circle",size:"5",color:"blue",fill:true},
		{x:1,y:4,type:"circle",size:"5",color:"red",fill:false}
	],
	.
	.
	.
}

Options

Back to top
Option Description Example Default
xdatahorizontal data pointsarray [] or "sequential"see above
ydatavertical data pointarray of objectssee above
pointsobject with individual sets of points[{x:2,y:3},{x:1,y:3.4}] see above
backgroundbackground color"grey" or "#A5A5A5" "white"
use_xlabelsboolean to control using x-labels (see below)truefalse
xlabelsarray of labels along x axis[0,2,4,6]n/a
titletitle string"My Title" blank (see below)
fontthis is the font used for everything"14px arial" "Courier"
font_sizesize of the font1412
font_colorcolor of all fonts"white" "black"
gridboolean to control displaying gridfalsetrue
grid_colorcolor of horizontal and vertical grid lines"black" "#d0d0d0"
xgridnumber of grid lines and labels along x-axis45
showxgridboolean for showing the vertical grid linesfalsetrue
ygridnumber of grid lines and labels along y-axis56
showygridboolean for showing the horizontal grid linesfalsetrue
widthcanvas width in pixels500400
heightcanvas height in pixels500400
xtitlehorizontal axis title string"Age"blank
ytitlevertical axis title string"Number"blank
xminhorizontal min value for displaying1 minimum x value from array
xmaxhorizontal max value for displaying1 maximum x value from array
yminvertical axis min for displaying0 maximum y value from array
ymaxvertical axis max for displaying20 minimum y value from array

The title string allows you to have different colors for different parts of the title. For instance, if you want to have a title that looks like this:

The blue part of the title followed by the red part of the title

you can do this by adding this to the title string that you pass:

/"blue"/The blue part of the title /"black"/folowed by /"red"/the red part of the title
What is bewteen the "/" characters will be the color for the words coming after.

Histograms

Back to top
To make a plot of a histogram, you first generate the data you want binned. You do the same constructor as before:
	let hist = UMD_plot("divid");
To make the histogram, you call the method histogram with options:
	hist.histogram(options);
The options argument is the same object that you use for scatterplot, with an additional argument that is used for histograms:
	options = {
		title : "your title",
		.
		.
		.
		hist : {
			bins: "number of bins",
			data: "1-d array of points to bin",
			xlow: "low edge of low bin",
			xhigh: "high edge of high bin",
			color: "color of the histogram",   // default is "blue"
			fill: "boolean for fill (true) or stroke (false)",  // default is true
			stats: "boolean, true for display, false to not display", // default is false
			errors: "boolean true for sqrt(n)", // default is false
			ecolor: "color of error bars" // default is "yellow"
		}
	}
Calling hist.histogram(options) will bin the histogram and pipe the arguments off to the scatterplot method for drawing.

Interactions

Back to top
The plotting package allows you to drag along the x-axis to change the horizontal scale, and drag along the y-axis to change the vertical: Here is an example of a plot, notice the yellow dot:
If you mouse over any of the data points, the value of the nearest point will be displayed.


Testing

Back to top
If you want to see how to use plots3.7.js, just click on this
test3.7.html file, it will draw a gaussian with "lines", "circle", and "hist" and show you the code. Back to top
Last updated Dec 10, 2021 Drew Baden

All rights reserved. No part of this publication may be reproduced, distributed, or transmitted in any form or by any means, including photocopying, recording, or other electronic or mechanical methods, without the prior written permission of the publisher, except in the case of brief quotations embodied in critical reviews and certain other noncommercial uses permitted by copyright law.