D3 Parade
To celebrate 10 years of D3.js the D3.js Community organized a competition where you had to visualize some aspect of D3.js using D3.js! I played around with some ideas and decided that visualising the Git repositories would make an interesting visualisation especially the branching. I started by downloading all the commits of the D3 repositories via the Github API. Then I tried to see if I could use a force directed graph but I just ended up with a long line. Next I tried a long horizontal chart but there was too much scrolling. I was inspired by the way the force directed graph started curled up and then expanded into a long line. So I decided to go with a spiral - all the commits could be presented in a small space.
data:image/s3,"s3://crabby-images/acc75/acc75b4401551b55fbcb200b12fad7b211b569c1" alt=""
How was it made?
Git consists of a linked lists of commits. Named branches point to the end of one of those link lists. To start off the commits were ordered by time.
data:image/s3,"s3://crabby-images/23d3d/23d3df355ee6ac6b8f1d8a66af8bafdaf372951d" alt="d3_parade_diagram_1.png"
Commits can have 1 or more parents. If a commit has 2 parents it's a new branch. If a commit's parent points to an existing branch it's a merge.
data:image/s3,"s3://crabby-images/f32cf/f32cf53a3adecbacca5d82c1c53b6a0aee1122aa" alt="d3_parade_diagram_2.png"
Next the location of the start and end branches is found.
data:image/s3,"s3://crabby-images/b03a2/b03a22c5d945131699d4175a176711cd0468ea28" alt="d3_parade_diagram_3.png"
Some branches will occupy the same space horizontally so they have to be moved up until they find some free space.
data:image/s3,"s3://crabby-images/7e279/7e279c5ad3e58f989f3704c8a97e5c5ad27b88b1" alt="d3_parade_diagram_4.png"
Next it works out whether there is enough room to display the branch names.
data:image/s3,"s3://crabby-images/300c3/300c3e57f969283ffcc2f960d2ce44db42064094" alt="d3_parade_diagram_5.png"
The commit nodes are then mapped onto a spiral with the help of SVG's path.getPointAtLength().
data:image/s3,"s3://crabby-images/a1a15/a1a159d2a175e5b854681f9925930ad5c369f18e" alt="d3_parade_diagram_6.png"