|
@@ -5,12 +5,15 @@ import java.awt.Dimension;
|
|
|
import java.awt.Graphics;
|
|
|
import java.awt.Graphics2D;
|
|
|
import java.awt.RenderingHints;
|
|
|
+import java.awt.ScrollPane;
|
|
|
import java.util.ArrayList;
|
|
|
|
|
|
import javax.swing.JPanel;
|
|
|
+import javax.swing.JScrollPane;
|
|
|
|
|
|
import classes.Constants;
|
|
|
import classes.HolonBody;
|
|
|
+import classes.HolonObject;
|
|
|
import classes.SubNet;
|
|
|
import ui.controller.Control;
|
|
|
import ui.model.Model;
|
|
@@ -59,12 +62,21 @@ public class HolonCanvas extends JPanel {
|
|
|
|
|
|
public void paintComponent(Graphics g) {
|
|
|
super.paintComponent(g);
|
|
|
+
|
|
|
+
|
|
|
+ for (int i = 0; i < controller.getSimManager().getSubNets().size(); i++) {
|
|
|
+ if (model.getSubNetColors().size() - 1 < i) {
|
|
|
+ controller.addSubNetColor(new Color((int) (Math.random() * 255), (int) (Math.random() * 255),
|
|
|
+ (int) (Math.random() * 255)));
|
|
|
+ }
|
|
|
+ }
|
|
|
|
|
|
+ JScrollPane focus = (JScrollPane) this.getParent().getComponent(0);
|
|
|
+ focus.getViewport().getComponent(0).requestFocus();
|
|
|
+ this.requestFocus();
|
|
|
if (!controller.getSimManager().getSubNets().equals(subnets)) {
|
|
|
subnets = controller.getSimManager().getSubNets();
|
|
|
subCount = subnets.size();
|
|
|
-
|
|
|
-
|
|
|
calcCenter();
|
|
|
if (bodies.isEmpty()) {
|
|
|
createBodies(subCount);
|
|
@@ -102,12 +114,13 @@ public class HolonCanvas extends JPanel {
|
|
|
private void addNewBodies(int subCount) {
|
|
|
|
|
|
ArrayList<HolonBody> newBodies = new ArrayList<>();
|
|
|
- for (int i = 0; i < bodies.size(); i++) {
|
|
|
- for (int j = 0; j < subCount; j++) {
|
|
|
- if (model.getSubNetColors().get(j) == bodies.get(i).getColor()) {
|
|
|
- bodies.get(i).setRadius(subnets.get(j).getObjects().size() * 5 + 10);
|
|
|
- bodies.get(i).setMass(subnets.get(j).getObjects().size() * 5 + 10);
|
|
|
- newBodies.add(bodies.get(i));
|
|
|
+ for (int i = 0; i < subCount; i++) {
|
|
|
+ for (int j = 0; j < bodies.size(); j++) {
|
|
|
+ if (model.getSubNetColors().get(i) == bodies.get(j).getColor()) {
|
|
|
+ bodies.get(j).setRadius(subnets.get(i).getObjects().size() * 5 + 10);
|
|
|
+ bodies.get(j).setMass(subnets.get(i).getObjects().size() * 5 + 10);
|
|
|
+ newBodies.add(bodies.get(j));
|
|
|
+ newBodies.get(newBodies.size()-1).setId(newBodies.size()-1);
|
|
|
break;
|
|
|
}
|
|
|
}
|
|
@@ -118,6 +131,7 @@ public class HolonCanvas extends JPanel {
|
|
|
HolonBody temp = new HolonBody((center.width + 1) + (-1 * i), (center.height + 1) + (-1 * i),
|
|
|
subnets.get(i).getObjects().size() * 5 + 10, subnets.get(i).getObjects().size() * 5 + 10,
|
|
|
model.getSubNetColors().get(i));
|
|
|
+ temp.setId(i);
|
|
|
bodies.add(temp);
|
|
|
}
|
|
|
|
|
@@ -129,6 +143,7 @@ public class HolonCanvas extends JPanel {
|
|
|
HolonBody temp = new HolonBody((center.width + 1) + (-1 * i), (center.height + 1) + (-1 * i),
|
|
|
subnets.get(i).getObjects().size() * 5 + 10, subnets.get(i).getObjects().size() * 5 + 10,
|
|
|
model.getSubNetColors().get(i));
|
|
|
+ temp.setId(i);
|
|
|
bodies.add(temp);
|
|
|
}
|
|
|
}
|
|
@@ -149,7 +164,7 @@ public class HolonCanvas extends JPanel {
|
|
|
|
|
|
for (int i = 0; i < subCount; i++) {
|
|
|
bodies.get(i).setRadius((subnets.get(i).getObjects().size() * 5 + 10)*controller.getHolonBodyScale()/100);
|
|
|
- bodies.get(i).draw(this.g2, controller.getHolonBodyScale());
|
|
|
+ bodies.get(i).draw(this.g2);
|
|
|
}
|
|
|
}
|
|
|
|