I had an assignment in school to create curves for a type of graph called Temporal Treemaps. I implemented my solution in a software called Inviwo, this is completely free and open source. I took some shortcuts when it came about to transferring data between so called modules. I did this by storing arrays of values in text files which I saved and loaded.
In short my solution to create graphs worked like the following: I found all points making up lines between sections of data. I used these lines to define one upper and one lower Bezier curve for each set of two triangles. This made it possible to discard unwanted fragments that were on the wrong side of these Bezier curves, in the frament shader. However, if I did this I would end up with white areas. The white areas was filled by drawing everything twice. First I drew everything with scaled triangles to cover up the white areas. Next, I drew normally sized triangles, to cover up for the ruffled cushion effects. My code for this solution is freely available on GitHub here:
https://github.com/marcus1337/InviwoTemporalTreeMapsMOD
data:image/s3,"s3://crabby-images/b7079/b707920a2f6e1a280d16077b1980ed0d1945f00e" alt="" |
Before changes |
data:image/s3,"s3://crabby-images/509ac/509ac3cc9908fda6bc71d9fa88c9b39f81d892ea" alt="" |
Removing unwanted fragments |
data:image/s3,"s3://crabby-images/cdb2f/cdb2f8b8c1e596f1b423f7fe616454bc26dc3428" alt="" |
Scaling up triangles |
data:image/s3,"s3://crabby-images/01c22/01c221cbd79dad8e6c14aeb7012dc4f12741c42e" alt="" |
Drawing twice to cover scaling |
Inga kommentarer:
Skicka en kommentar