sinahab / BinaryTreeVisualizer

Binary Search Tree visualizer in Javascript.

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

BinaryTreeVisualizer

To run in a browser:

Open the html html/binary_tree.html file in a browser.

What it is:

BinaryTreeVisualizer consists of a Java implementation to create Binary Search Trees and some Javascript code to render these trees in a web page. This API is most useful for applications which have a Javascript capable web-component, with the Java code in the back-end to construct the binary trees, created by user input for instance. I used this API in my final year project (jSCAPE) to provide a visual aid to help students answer exercises on binary search trees.

###Files The Java implementation resides in a single file called BST.java.

In order to visualize the binary trees, you must use the BinaryTreeVisualizer. It is programmed in Javascript using the JIT library. The files for the visualizer are:

-binary_tree.js

-binary_tree.html

-jit.js (Javascript InfoVis Toolkit)

-base.css are modified versions of the original CSS files used for the Spacetree demo.
 Links to the originals: 
 http://philogb.github.io/jit/static/v20/Jit/Examples/css/base.css

###How to use

    BST<Integer> bst = new BST<>();
    
    bst.insert(34);
    bst.insert(22);
    bst.insert(28);
    bst.insert(56);
    
    String bstJSON = bst.toJSON();

The code snippet above shows the creation of a binary tree, how to insert a few elements and how to get the JSON representation of the tree, so that it can be used by the visualizer. Take a look at the rest of the API for other functions which can be called on binary search trees.

The function responsible for rendering the tree is called visualize(binary_tree_json), and can be found in binary_tree.js. The function takes the JSON representation of the binary tree as a parameter. Call this function in the html file, for instance, . This will render the binary tree in the web page at loading time. To customize the BinaryTreeVisualizer, take a look at the References section, which gives links to the Javascript InfoVis Toolkit, where you can find tutorials and more examples of how to customize visualizations, animations, colors, etc...

###Binary Search Tree JSON Representation Using the API's toJSON() function makes it a lot easier to generate the JSON representation used by the BinaryTreeVisualizer to render the trees. However, to allow people to create their own trees manually, without using the Java implementation, the JSON format is shown and explained below:

BST Representation

"null" nodes are necessary so that the visualizer can place single child nodes in the correct location, i.e. to the left or right of its parent. Without these "null" nodes, the child node would be placed directly under the parent node, thus the binary tree wouldn't have the expected layout. At the end of the render function, these "null" nodes are removed from the visualization, and since the other nodes have their location set, then this operation doesn't affect the rest of the tree. However, there is a small bug which very rarely where single child nodes won't be in the correct location. (see Known Bugs).

Try to organize it so that the json code is on the left and the corresponding binary tree is on the right. If this isn't possible using layout, then make an image of the code and the tree side by side.

####Known bugs *For parent nodes which only have one child, sometimes the visualizer won't place the child node in the appropriate location (i.e. to the left or to the right of the parent node). Instead, the child node is placed directly under the parent node. The cause of this bug has to do with the usage of "null" nodes and when they are removed. Recall that "null" nodes are used to establish the location of single child nodes. Sometimes these "null" nodes are removed before the single child nodes have an established location, thus the renderer will default to placing these nodes directly under the parent node.

###References -http://philogb.github.io/jit/static/v20/Jit/Examples/css/base.css

###TODO list

  • Write small tutorial on how to use the visualizer.
  • Explain JSON format for binary tree + example.
  • Clean up javascript code, html code.
  • Add links to library and references used for this project.

About

Binary Search Tree visualizer in Javascript.


Languages

Language:JavaScript 97.8%Language:Java 2.0%Language:HTML 0.2%Language:CSS 0.1%