Skip to content

erigobeli/Candlestick.js

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

20 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Candlestick.js

candlestick chart on canvas

This is a simple function to draw a candlestick chart using canvas. The only file you need from this project is Candlestick.js

Not compatible with old browsers! Tested on Chrome only!

alt tag

Live demo:

Assumptions

Data is in the same format as in finance.yahoo.com historical prices, see for example: http://finance.yahoo.com/q/hp?s=AAPL+Historical+Prices On this page in finance.yahoo.com you can inspect the link below the table titled: "Download to Spreadsheet"

Roadmap:

  • x coordinate labels for different ranges - daily charts
  • add more indicators to top of the screen - bollinger bands, keltner bands, EMA, ...
  • add bottom indicators - MACD, Volume, ...
  • cache data using indexedDB
  • add labels for each top indicator, SMA(C,20) + line color
  • interactivity - allow scrolling by dragging sideways
  • allow drawing of trendlines by clicking and dragging
  • add mini language to define indicators and how to draw them

Demo explanation

The minimal index.html file is really short, it contains in the HEAD section 3 javascript files,

  1. jQuery from a CDN
  2. the Candlestick.js file which is the main file for this project
  3. the demo index.js file

In the BODY section there is one canvas element with an id and dimensions.

The index.js file has one jQuery function which onLoad sets the indicators object and uses AJAX to get the data from a file on the same server as the rest of the project. when the get returns with data it calls the main function:

Candlestick(canvasID, data, options);

the parameters:

Data for the testing is for AAPL, MA and PRAA symbols. A live demo is at smallestbusiness.com/Candlestick.js.demo_page/

Questions? Comments? @amiheines

About

candlestick chart on canvas

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 100.0%