use of org.cytoscape.io.internal.util.session.model.Network in project cytoscape-impl by cytoscape.
the class Cy2SessionReaderImpl method extractSessionState.
private void extractSessionState(InputStream is, String entryName) throws Exception {
CyPropertyReader reader = propertyReaderMgr.getReader(is, entryName);
reader.run(taskMonitor);
cysession = (Cysession) reader.getProperty();
if (cysession != null) {
// Network attributes and visual styles
if (cysession.getNetworkTree() != null) {
for (final Network net : cysession.getNetworkTree().getNetwork()) {
// so let's ignore a network with that name.
if (net.getId().equals(NETWORK_ROOT))
continue;
final String netName = net.getId();
List<Node> selNodes = null;
List<Edge> selEdges = null;
if (net.getSelectedNodes() != null)
selNodes = net.getSelectedNodes().getNode();
if (net.getSelectedEdges() != null)
selEdges = net.getSelectedEdges().getEdge();
nodeSelectionLookup.put(netName, selNodes);
edgeSelectionLookup.put(netName, selEdges);
}
}
// Convert the old cysession to core the required 3.0 core plugin files:
// Actually we just need to extract the "networkFrames" and "cytopanels" data from the Cysession object
// and write an XML file that will be parsed by swing-application.
StringBuilder sb = new StringBuilder("<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\"?>\n");
sb.append("<sessionState documentVersion=\"1.0\">\n");
sb.append(" <networkFrames>\n");
if (cysession.getSessionState() != null && cysession.getSessionState().getDesktop() != null) {
NetworkFrames netFrames = cysession.getSessionState().getDesktop().getNetworkFrames();
if (netFrames != null) {
for (NetworkFrame nf : netFrames.getNetworkFrame()) {
String id = nf.getFrameID();
String x = nf.getX() != null ? nf.getX().toString() : "0";
String y = nf.getY() != null ? nf.getY().toString() : "0";
sb.append(" <networkFrame networkViewID=\"" + id + "\" x=\"" + x + "\" y=\"" + y + "\"/>\n");
}
}
}
sb.append(" </networkFrames>\n");
sb.append(" <cytopanels>\n");
SessionState sessionState = cysession.getSessionState();
if (sessionState != null) {
Cytopanels cytopanels = sessionState.getCytopanels();
if (cytopanels != null) {
List<Cytopanel> cytopanelsList = cytopanels.getCytopanel();
for (Cytopanel cytopanel : cytopanelsList) {
String id = cytopanel.getId();
String state = cytopanel.getPanelState();
String selection = cytopanel.getSelectedPanel();
sb.append(" <cytopanel id=\"" + id + "\">\n");
sb.append(" <panelState>" + state + "</panelState>\n");
sb.append(" <selectedPanel>" + selection + "</selectedPanel>\n");
sb.append(" </cytopanel>\n");
}
}
}
sb.append(" </cytopanels>\n");
sb.append("</sessionState>");
// Extract it as an app file now:
ByteArrayInputStream bais = new ByteArrayInputStream(sb.toString().getBytes("UTF-8"));
extractPluginEntry(bais, cysession.getId() + "/" + PLUGINS_FOLDER + "org.cytoscape.swing-application/session_state.xml");
}
}
use of org.cytoscape.io.internal.util.session.model.Network in project cytoscape-impl by cytoscape.
the class Cy2SessionReaderImpl method extractNetworks.
private void extractNetworks(TaskMonitor tm) throws JAXBException, IOException {
// Extract the XGMML files
Map<String, Network> netMap = new HashMap<>();
for (Network curNet : cysession.getNetworkTree().getNetwork()) {
netMap.put(curNet.getId(), curNet);
}
final CyRootNetworkManager rootNetworkManager = serviceRegistrar.getService(CyRootNetworkManager.class);
walkNetworkTree(netMap.get(NETWORK_ROOT), null, netMap, tm, rootNetworkManager);
}
use of org.cytoscape.io.internal.util.session.model.Network in project cytoscape-impl by cytoscape.
the class Cy2SessionReaderImpl method walkNetworkTree.
private void walkNetworkTree(final Network net, CyNetwork parent, final Map<String, Network> netMap, final TaskMonitor tm, final CyRootNetworkManager rootNetworkManager) {
// Get the list of children under this root
final List<Child> children = net.getChild();
// Traverse using recursive call
final int numChildren = children.size();
Child child = null;
Network childNet = null;
for (int i = 0; i < numChildren; i++) {
if (cancelled)
return;
child = children.get(i);
childNet = netMap.get(child.getId());
String entryName = xgmmlEntries.get(childNet.getFilename());
InputStream is = null;
// This is the original Cytoscape 2 parent.
CyNetwork cy2Parent = null;
try {
is = findEntry(entryName);
if (is != null) {
tm.setStatusMessage("Extracting network: " + entryName);
cy2Parent = extractNetworksAndViews(is, entryName, parent, childNet.isViewAvailable());
// Every 2.x network should be a child of the same root-network.
if (parent == null)
parent = rootNetworkManager.getRootNetwork(cy2Parent);
} else {
logger.error("Cannot find network file \"" + entryName + "\": ");
}
} catch (final Exception e) {
final String message = "Unable to read XGMML file \"" + childNet.getFilename() + "\": " + e.getMessage();
logger.error(message, e);
} finally {
if (is != null) {
try {
is.close();
} catch (final Exception ex) {
logger.error("Unable to close XGMML input stream.", ex);
}
is = null;
}
// Always try to load child networks, even if the parent network is bad
if (!cancelled && childNet.getChild().size() != 0)
walkNetworkTree(childNet, cy2Parent, netMap, tm, rootNetworkManager);
}
}
}
use of org.cytoscape.io.internal.util.session.model.Network in project cytoscape-impl by cytoscape.
the class Cy2SessionReaderImpl method processNetworks.
private void processNetworks() throws Exception {
if (cysession == null)
return;
// Network attributes and visual styles
if (cysession.getNetworkTree() != null) {
for (final Network net : cysession.getNetworkTree().getNetwork()) {
if (cancelled)
return;
// so let's ignore a network with that name.
if (net.getId().equals(NETWORK_ROOT))
continue;
final String netName = net.getId();
final CyNetworkView view = getNetworkView(netName);
if (view != null) {
// Populate the visual style map
String vsName = net.getVisualStyle();
if (vsName != null)
visualStyleMap.put(view, vsName);
// Convert 2.x hidden state (cysession.xml) to 3.x visual properties
if (net.getHiddenEdges() != null) {
for (final Edge edgeObject : net.getHiddenEdges().getEdge()) {
if (cancelled)
return;
final String name = edgeObject.getId();
final CyEdge e = cache.getEdge(name);
if (e != null) {
final View<CyEdge> ev = view.getEdgeView(e);
if (ev != null)
ev.setLockedValue(BasicVisualLexicon.EDGE_VISIBLE, false);
else
logger.error("Cannot restore hidden state of edge \"" + name + "\": Edge view not found.");
} else {
logger.error("Cannot restore hidden state of edge \"" + name + "\": Edge not found.");
}
}
}
if (net.getHiddenNodes() != null) {
for (final Node nodeObject : net.getHiddenNodes().getNode()) {
if (cancelled)
return;
final String name = nodeObject.getId();
final CyNode n = cache.getNodeByName(name);
if (n != null) {
final View<CyNode> nv = view.getNodeView(n);
if (nv != null)
nv.setLockedValue(BasicVisualLexicon.NODE_VISIBLE, false);
else
logger.error("Cannot restore hidden state of node \"" + name + "\": Node view not found.");
} else {
logger.error("Cannot restore hidden state of node \"" + name + "\": Node not found.");
}
}
}
}
}
}
// Network view sizes
if (cysession.getSessionState() != null) {
Desktop desktop = cysession.getSessionState().getDesktop();
if (desktop != null && desktop.getNetworkFrames() != null) {
List<NetworkFrame> frames = desktop.getNetworkFrames().getNetworkFrame();
for (final NetworkFrame nf : frames) {
if (cancelled)
return;
// Set sizes
final CyNetworkView view = getNetworkView(nf.getFrameID());
if (view != null) {
BigInteger w = nf.getWidth();
BigInteger h = nf.getHeight();
if (w != null)
view.setVisualProperty(BasicVisualLexicon.NETWORK_WIDTH, w.doubleValue());
if (h != null)
view.setVisualProperty(BasicVisualLexicon.NETWORK_HEIGHT, h.doubleValue());
}
}
}
}
if (!networks.isEmpty()) {
// Select the last network that has a view, since Cy2 files do not contain the network selection info
final CyNetwork[] array = networks.toArray(new CyNetwork[networks.size()]);
for (int i = array.length - 1; i >= 0; i--) {
final CyNetwork net = array[i];
final CyRow row = net.getRow(net);
final String netName = row.get(CyNetwork.NAME, String.class);
final CyNetworkView view = networkViewLookup.get(netName);
if (view != null) {
row.set(CyNetwork.SELECTED, true);
break;
}
}
}
}
Aggregations