-
Notifications
You must be signed in to change notification settings - Fork 31
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Export svg #218
Export svg #218
Conversation
Very cool @sjanssen2! |
@sjanssen2 thanks! Regarding the second issue: We can should be able to normalize the coordinate so that they fit in a standard letter document. Regarding the third issue: Unfortunately WebGl can only draw lines/triangles and no longer supports the ability to natively draw arcs (hence the approximation with line segments). I'm not familiar with SVG, but Empress stores the information needed to draw arcs so it would be possible to create a custom "getCoords" function for SVG's that would represent the circular layout using arcs instead of line segements. What information would you need to represent arcs in SVG's? |
@biocore/empress-dev I'd like to also draw the color legend within the SVG. Does the empress object hold this information or is that only available in the |
@ElDeveloper @kwcantrell I think this PR is not yet ready to get merged, but a first round of code review would be very helpful. In addition, some opinions regarding the open questions are welcome, too! |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@sjanssen2 This looks good so far! I have a couple minor suggestions but nothing to major.
@ElDeveloper I would be interested in what you think about the location of this method. But, I think it might be better to move this to SidePanel. Mainly because the empress class does not have access to the legend, as that is something SidePanel is responsible for. But I also feel like the empress class shouldn't be responsible for creating the svg object as empress's main functionality is manipulating the tree using metadata.
// 5 array elements encode one coordinate: | ||
// i=x, i+1=y, i+2=red, i+3=green, i+4=blue | ||
svg += "<!-- tree branches -->\n"; | ||
coords = this.getCoords(); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Just a heads up, after #190 is merged, this method will no longer return the proper coordinates since they will be calculated in WebGl. Maybe we can keep this method but rename it to getSvgCoords. @ElDeveloper any thoughts?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That sounds like a good way to go 👍 . And once we do that, it might be best to draw the arcs with single splines (which are supported in SVG) instead of line segments.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Currently, we can simply draw a line for every two successive coordinates. For circular layout, if #190 is merged, we will than track if we have to draw a "normal" line or an arc. How would this method know? But I figure we should leave this issue for future development.
@sjanssen2 thanks again for contributing this much needed functionality. This is great!! 🎆
I agree that having this method in |
I would prefer to move the export function from empress.js to side-panel-handler.js, however I am quite of stuck with unit-tests. Can someone show me how to properly initialize a SidePanel object? Especially, how do I best emulate |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@sjanssen2 I would be more than happy to set up a call to help you to help out with the unit tests! Alternatively, I will be submitting a PR for #142 within the next couple of days that will include tests for side-panel-handler.js you can look at.
Hi @kwcantrell, could you give me a code example on how to accomplish that? |
I am not 100% sure if I understand data flow within Empress correctly, but I was not able to move the export function to side-panel since I could not instantiate a side-panel object for unit testing. Furthermore, I had to create a separate function to export the legend(s), since they are not part of the tree object. I am also no particular fan of this block of code, as I have to count rows and increase indices and so on. Hard to read. @ElDeveloper did you came up with a better solution in Emperor, or is that simply an ugly business, due to explicit computation of x,y coordinates? I suggest we merge the code now and raise new issues for the missing aspects / refactoring to give other developers the chance to use the existing export capabilities and suggest further improvements. |
@kwcantrell has been working on improving the "testability" of the classes in the project. @kwcantrell is there a branch that you are working on that would make this easier? If so can we get that merged in sometime soon so that @sjanssen2 can add the needed tests here? I think it's important to have some tests now, specially if we want to improve/optimize this.
In Emperor we re-use a class that's bundled with the GL framework (THREE.js). Is there any chance we could limit the SVG render to what's currently visible on screen or would that be hard to compute. @kwcantrell might have some insight into this. |
@sjanssen2 I think this PR looks like is in good shape to get merged soon, is there any chance you can solve conflicts, and look into limiting the the SVG export to only the edges that are currently visible on screen? Let me know if I can help with any of this! It would be wonderful if we can include this in the upcoming release that's currently scheduled for August 3rd. 🖨️ 🌲 |
Still on vacation until Tuesday. Will look into this afterwards! |
only draw visible edges: this is a pretty big request and I would thus recommend to add it via another PR to keep this one slim and ease future reviewing. I see two problems:
|
@ElDeveloper @fedarko @kwcantrell |
@sjanssen2 Thanks, that makes sense. I agree that we should merge this.
@kwcantrell would you mind commenting on whether something like this could be easily doable right now? It's OK if it isn't, and we can postpone until later (in favor of getting this PR merged).
We actually did something like this for the qemistree paper (see figure 3 panels b-g) where we wanted to highlight some internal details. As for clade collapsing, @kwcantrell put together a PR here #277. If you have any input and time to provide feedback that would be great. 👍 |
@ElDeveloper I'm not sure if its possible to retrieve the elements drawn from WebGl. I know in OpenGl you can write back to buffers but I don't believe you can do this in WebGl. I'll look into it through. However, it would be possible to create a special function in drawer.js that "mimics" the vertex shader and we could use that to returns the a list of edges that are drawn withing the bounds of the viewing window. But I think it would probably be better to leave this feature to another PR. |
Thanks so much @kwcantrell. @sjanssen2, this looks great and is all good to merge. I submitted a small PR to your fork, let me know if you have any thoughts. After we get that merged this should be good to go. |
Exportsvg changes
many thanks for your good catches in your PR @ElDeveloper. I consider this PR as good to go! |
Thanks so much @sjanssen2! |
Thanks @sjanssen2! |
Addressing #202, this is the very first rudimentary block of code that creates SVGs.
Open issues: