Skip to content
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

Many layout algorithms are not centered #276

Open
shadiakiki1986 opened this issue Sep 23, 2021 · 3 comments
Open

Many layout algorithms are not centered #276

shadiakiki1986 opened this issue Sep 23, 2021 · 3 comments

Comments

@shadiakiki1986
Copy link

shadiakiki1986 commented Sep 23, 2021

Bug report

Bug summary

Using several layout algorithms result in a graph that is not centered.
Below code snippet contains list of which ones yield centered graphs and which don't.

Code for reproduction

ex_json = {
    "nodes": [
        {"data": {"id": 0, "name": "A"}},
        {"data": {"id": 1, "name": "B"}},
        {"data": {"id": 2, "name": "C"}}
    ],
    "edges": [
        {"data": {"id": 3, "source": 0, "target": 1}},
        {"data": {"id": 4, "source": 0, "target": 2}},
    ]
}

import ipycytoscape
cyto = ipycytoscape.CytoscapeWidget()
cyto.graph.add_graph_from_json(ex_json)

# https://js.cytoscape.org/#layouts
#layout_name = "cola" # is centered <<<<<<<<<
#layout_name = "asvdf" # not centered
#layout_name = "cise" # not centered
#layout_name = "cose-bilkent" # not centered
#layout_name = "cosep" # not centered
#layout_name = "d3-force" # not centered
layout_name = "dagre" # is centered <<<<<<<<<
#layout_name = "elk" # not centered
#layout_name = "euler" # not centered
#layout_name = "fcose" # not centered
#layout_name = "klay" # is centered <<<<<<<<<
#layout_name = "ngraph.forcelayout" # not centered
#layout_name = "polywas" # not centered
#layout_name = "spread" # not centered
#layout_name = "springy" # not centered


cyto.set_layout(name=layout_name)
cyto

Actual outcome

COLA (centered):
image

ASVDF (not centered):
image

Expected outcome

Centered graph

Update: initially I filed this for ASVDF, but it turns out many algos have this issue

@shadiakiki1986 shadiakiki1986 changed the title AVSDF layout is not centered Many layout algorithms are not centered Sep 23, 2021
@marimeireles
Copy link
Collaborator

marimeireles commented Sep 27, 2021

Wow, great issue!
Thank you for testing with all of these @shadiakiki1986 :)

Ok, I think of two things when I read your issue:

  1. All of the layouts who are centered were included in ipycytoscape deps. They're both on the package.json + imported on the typescript side. So, I'd say a good thing to try would be adding one of these other packages to the packagejson and importing it on the widget.ts file, like we do with ipycytoscape-cola for example.
  2. If this is not it, my next step would look into the repositories of these layouts and see what kind of magical CSS they're setting so we can set on the others too. We either write code with specific selectors for each layout(not sure if this is possible) or a code that will be applied in the whole library. We have a css/widget.css file where these changes can be made. Or maybe we have to create a new file to make it cleaner? If this approach is taken we should check what other bigger more complex widgets (like bqplot for example) are doing and copy them.

For now I can't really tackle this, but I'm always around to answer questions and help any other way I can, both here and on gitter: https://gitter.im/QuantStack/Lobby

@salomonMuriel
Copy link

It is not that they are not centered, but that since they are not part of the package the graph breaks and all nodes are set in the upper-left corner of the canvas. They are all on top of each other.

The real issue here is that we should add more layouts to the Python package.

@norweeg
Copy link

norweeg commented Nov 21, 2024

maybe this is a stupid question, but why aren't all the documented layouts included in the python package? It's a little frustrating to see a layout that you want to use in the cytoscape.js documentation only to find out it doesn't work when you try to use it and end up finding this bug report and that it isn't included for some reason and that nothing in the ipycytoscape documentation actually states which layouts are and are not supported.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants