ingenias.generator.browser.GraphRelationshipFactory Maven / Gradle / Ivy
package ingenias.generator.browser;
/*
Copyright (C) 2005 Jorge Gomez Sanz
This file is part of INGENIAS Development Kit (IDK), a support tool for the INGENIAS
methodology, availabe at http://grasia.fdi.ucm.es/ingenias or
http://ingenias.sourceforge.net
INGENIAS IDE is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
INGENIAS IDE is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with IDK; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
import ingenias.editor.Editor;
import ingenias.editor.IDE;
import ingenias.editor.IDEState;
import ingenias.editor.Log;
import ingenias.editor.Model;
import ingenias.editor.ModelJGraph;
import ingenias.editor.ObjectManager;
import ingenias.editor.TypedVector;
import ingenias.editor.cell.NAryEdge;
import ingenias.editor.cell.RenderComponentManager;
import ingenias.editor.entities.Entity;
import ingenias.editor.entities.NAryEdgeEntity;
import ingenias.editor.entities.RoleEntity;
import ingenias.exception.InvalidAttribute;
import ingenias.exception.InvalidColection;
import ingenias.exception.InvalidEntity;
import ingenias.exception.InvalidGraph;
import ingenias.exception.NotFound;
import ingenias.exception.NotInitialised;
import ingenias.exception.NullEntity;
import ingenias.exception.WrongParameters;
import java.awt.Dimension;
import java.awt.Point;
import java.awt.Rectangle;
import java.awt.geom.Rectangle2D;
import java.lang.reflect.Constructor;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.Collection;
import java.util.Date;
import java.util.Hashtable;
import java.util.List;
import java.util.Map;
import java.util.Vector;
import javax.swing.JOptionPane;
import org.jgraph.JGraph;
import org.jgraph.graph.BasicMarqueeHandler;
import org.jgraph.graph.ConnectionSet;
import org.jgraph.graph.DefaultEdge;
import org.jgraph.graph.DefaultGraphCell;
import org.jgraph.graph.GraphCell;
import org.jgraph.graph.GraphConstants;
import org.jgraph.graph.GraphModel;
import org.jgraph.graph.Port;
public class GraphRelationshipFactory {
private IDEState ids;
private Browser browser;
public static GraphRelationshipFactory createDefaultEmptyGraphFactory(){
return new GraphRelationshipFactory(IDEState.emptyIDEState());
}
public static GraphRelationshipFactory createDefaultGraphFactory(Browser browser) throws NotInitialised{
return new GraphRelationshipFactory(browser.getState());
}
public GraphRelationshipFactory(IDEState ids){
this.ids=ids;
browser=new BrowserImp(ids);
}
/**
* The method converts assignations to an array of String.
* assignations is a Vector of Vectors of Strings where Strings represents roles.
* In a solution assignations.get(j) the role assigned to selected[i] is
*((Vector) assignations.get(j)).get(i).
* @param selected
* @param assignations
* @return
*/
private String[] assignationsToStringArray(GraphCell[] selected,
Vector assignations) {
// The user selects one possible assignation.
String[] displayedAssignations = new String[assignations.size()];
for (int i = 0; i < assignations.size(); i++) {
displayedAssignations[i] = "";
for (int j = 0; j < selected.length; j++) {
if (selected[j] instanceof DefaultGraphCell) {
displayedAssignations[i] +=
( (String) ( (Vector) assignations.get(i)).get(j)) +
" = " +
( (DefaultGraphCell) selected[j]).getUserObject().toString();
}
else {
displayedAssignations[i] +=
( (String) ( (Vector) assignations.get(i)).get(j)) +
" = " + selected[j].getClass().getName();
}
if (j < (selected.length - 1)) {
displayedAssignations[i] += ", ";
}
}
}
return displayedAssignations;
}
private static DefaultGraphCell findEntity(String id, Graph graph){
DefaultGraphCell result=null;
for (int k=0;k graphs = this.ids.gm.getUOModels();
int k=0;
boolean found=false;
DefaultGraphCell result=null;
while (result==null && k> getPossibleRoleAssignment(String relationshipType, String[] connectedEntities) throws NotFound{
Vector entities=new Vector();
for (String entityID:connectedEntities) {
DefaultGraphCell entity = findEntity(entityID);
if (entity==null){
// the entity may have not been created yet as graphical object
// The object manager may know about it.
if (this.ids.om.findUserObject(entityID).size()>0)
entity=new DefaultGraphCell(this.ids.om.findUserObject(entityID).firstElement());
else
throw new ingenias.exception.NotFound("Entity "+entityID+" that you tried to connect did not exist in any graph ");
}
//throw new ingenias.exception.NotFound("Entity "+entityID+" that you tried to connect did not exist in any graph ");
entities.add(entity);
}
GraphCell[] selected=new GraphCell[entities.size()];
selected=entities.toArray(selected);
NAryEdge nEdge=(NAryEdge) RelationshipFactory.getNRelationshipInstance(relationshipType, selected,browser);
Vector> result = convertToVectorHashtable(connectedEntities, selected, nEdge);
return result;
}
public static Vector> getPossibleRoleAssignment(String relationshipType, String[] connectedEntities, Graph graph, Browser browser) throws NotFound{
Vector entities=new Vector();
for (String entityID:connectedEntities) {
DefaultGraphCell entity = findEntity(entityID,graph);
if (entity==null)
throw new ingenias.exception.NotFound("Entity "+entityID+" that you tried to connect did not exist in the graph "+graph.getName());
entities.add(entity);
}
GraphCell[] selected=new GraphCell[entities.size()];
selected=entities.toArray(selected);
NAryEdge nEdge=(NAryEdge) RelationshipFactory.getNRelationshipInstance(relationshipType, selected,browser);
Vector> result = convertToVectorHashtable(connectedEntities, selected, nEdge);
return result;
}
private static Vector> convertToVectorHashtable(String[] connectedEntities, GraphCell[] selected, NAryEdge nEdge) {
Vector> assignationsList = new Vector>(nEdge.assignRoles(selected, true));
Vector> result=new Vector>();
for (List assignation:assignationsList){
Hashtable assignmentTable=new Hashtable();
for (int k=0;k getPossibleRelationships( List connectedEntities, Graph graph) throws NotFound{
return getPossibleRelationships(connectedEntities.toArray(new String[connectedEntities.size()]),graph);
}
public static Vector< String> getPossibleRelationships( String[] connectedEntities, Graph graph) throws NotFound{
Vector entities=new Vector();
for (String entityID:connectedEntities) {
DefaultGraphCell entity = findEntity(entityID,graph);
if (entity==null)
throw new ingenias.exception.NotFound("Entity "+entityID+" that you tried to connect did not exist in the graph "+graph.getName());
entities.add(findEntity(entityID,graph));
}
GraphCell[] selected=new GraphCell[entities.size()];
selected=entities.toArray(selected);
Object[] relObjArray = graph.getGraph().getPossibleRelationships(selected);
Vector result = new Vector();
for (Object rel:relObjArray){
result.add(rel.toString());
}
return result;
}
public static Vector> getPossibleRoleAssignment(String relationshipType, List connectedEntities, Graph graph, Browser browser) throws NotFound{
return getPossibleRoleAssignment(relationshipType,connectedEntities.toArray(new String[connectedEntities.size()]),graph,browser);
}
private void insertRelationshipInManager(NAryEdge nEdge, DefaultEdge[] edges,
GraphCell[] selected,
java.util.List currentAssignation) {
// The NAryEdgeEntity of the relationship is built.
NAryEdgeEntity nae = (NAryEdgeEntity) nEdge.getUserObject();
for (int i = 0; i < currentAssignation.size(); i++) {
if (! ( ( (DefaultGraphCell) selected[i]).getUserObject()instanceof
NAryEdgeEntity)) {
nae.addObject(selected[i].hashCode() + "",
( (Entity) ( (DefaultGraphCell) selected[i]).
getUserObject()),
( (RoleEntity) edges[i].getUserObject()),
(String) currentAssignation.get(i),
( ( (DefaultGraphCell) selected[i]).getUserObject().
getClass().getName()));
}
}
// Insert the Edge in the relationship manager.
// this.rm.addRelationship((Entity) nEdge.getUserObject());
}
private Port[] getPorts(Object[] vertexList, ModelJGraph graph) {
// Ports of argument vertexs.
Port[] ports = new Port[vertexList.length];
// Obtain the model.
GraphModel model = graph.getModel();
// Iterate over all Objects.
for (int i = 0; i < vertexList.length; i++) {
Port objectPort = null;
// Iterate over all Children
for (int j = 0; j < model.getChildCount(vertexList[i]); j++) {
// Fetch the Child of Vertex at Index i
Object child = model.getChild(vertexList[i], j);
// Check if Child is a Port
if (child instanceof Port) {
// Return the Child as a Port
objectPort = (Port) child;
}
}
ports[i] = objectPort;
}
return ports;
}
private Point calculateCenter(GraphCell[] selected){
int x=0;
int y=0;
for (int k=0;k= 0)
// Add a Line Begin Attribute
GraphConstants.setLineBegin(attr, GraphConstants.SIMPLE);*/
// Target
if (roleAssignation[i].toUpperCase().indexOf("TARGET") >= 0 ||
roleAssignation[i].endsWith("T")) {
// Add a Line End Attribute
GraphConstants.setLineEnd(attr, GraphConstants.ARROW_SIMPLE);
// Associate the Edge with its Attributes
}
GraphConstants.setDisconnectable(attr,false);
GraphConstants.setLineWidth(attr, 1);
GraphConstants.setEndSize(attr, 7);
GraphConstants.setBendable(attr,false);
edgesAttributes.put(edges[i], attr);
}
return edgesAttributes;
}
public GraphRelationship createRelationship(String relType,
Graph diagram,
Hashtable assignment) throws InvalidEntity{
ModelJGraph graph = diagram.getGraph();
Collection cells = assignment.values();
Vector selectedV=new Vector();
for (String cellid:cells){
selectedV.add(this.findEntity(cellid, diagram));
}
DefaultGraphCell[] selected=selectedV.toArray(new DefaultGraphCell[selectedV.size()]);
NAryEdge nEdge=(NAryEdge) graph.getInstanciaNRelacion(relType, selected);
if (nEdge != null) {// make sure the relationship type is correct
// All role assignations to classes are obtained.
GraphCell[] newSelected = nEdge.prepareSelected(selected);
// The user selects a role assignation (List of Strings).
java.util.Vector currentAssignation = new Vector(assignment.keySet());
// Connections that will be inserted into the Model.
String[] selectedAssignation = new String[currentAssignation.size()];
for (int i = 0; i < currentAssignation.size(); i++) {
selectedAssignation[i] = (String) currentAssignation.get(i);
}
try {
// Auxiliary edges that will be inserted in the Model.
DefaultEdge[] auxiliaryEdges = nEdge.connectionsEdges(newSelected,
selectedAssignation);
ConnectionSet cs = nEdge.connections(selectedAssignation,
auxiliaryEdges,
getPorts(newSelected, diagram.getGraph()));
// Create a Map that holds the attributes for the NAryEdge Vertex.
// Associate the NAryEdge Vertex with its Attributes.
// Hashtable attributes = nEdgeAttributes(nEdge, pt);
// Atributes for the binary edges of this NAryEdge according to
// targets and sources.
Hashtable attributes = new Hashtable();
Hashtable edgesAttributes = this.edgesAttributes(auxiliaryEdges,
selectedAssignation);
// if (existAlreadyRelationship==null){
// A new relationship. Otherwise, the relationship did exist before
Map m=new Hashtable();
Point centerP=calculateCenter(selected);
Rectangle2D edgeb=GraphConstants.getBounds(nEdge.getAttributes());
GraphConstants.setBounds(m,new Rectangle(centerP,new Dimension(0,0)));
// Associate the Vertex with its Attributes
attributes.put(nEdge, m);
// Insert the Edge and its Attributes. The order matters.
graph.getModel().insert(new Object[] {nEdge},attributes
, null, null, null);
Class.forName("ingenias.editor.cell."+relType+"Renderer"); // to force the static initialization
GraphConstants.setBounds(m,new Rectangle(centerP,
RenderComponentManager.getSize(
((Entity)nEdge.getUserObject()).getType(),
((Entity)nEdge.getUserObject()).getPrefs(graph.getModel().getAttributes(nEdge)).getView())));
graph.getModel().edit(attributes,null,null,null);
// New relationship is inserted also in the relationship manager.
this.insertRelationshipInManager(nEdge, auxiliaryEdges,
newSelected,
currentAssignation);
graph.getModel().insert( (Object[]) auxiliaryEdges,edgesAttributes, cs, null
,null);
Hashtable changes=new Hashtable();
ingenias.editor.events.LocationChange.centerNAryEdge(graph,
(Model) graph.getModel(), changes, nEdge);
if (changes.size()>0)
graph.getModel().edit(changes, null, null, null);
}
catch (WrongParameters wp) {
Log.getInstance().logSYS(
"WARNING: internal error on connecting elements. " +
" Cannot produce edges for this connection");
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
Entity entNEdge=(Entity)nEdge.getUserObject();
RenderComponentManager.setRelationshipView(entNEdge.getPrefs(graph.getModel().getAttributes(nEdge)).getView(),entNEdge,nEdge,graph);
} else {
throw new InvalidEntity("The relationship type "
+relType+" does not exist");
}
return new GraphRelationshipImp((NAryEdgeEntity) nEdge.getUserObject(),graph,ids);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy