X-Git-Url: http://git.megacz.com/?p=anneal.git;a=blobdiff_plain;f=src%2Fedu%2Fberkeley%2Fqfat%2FInteractiveMeshViewer.java;h=419e20934111101c7f4b699b29df3be913f08620;hp=1a72d7ebb2d6f5bb1a1d3fa3bf190704c79d91ff;hb=e32bd0376c8c859f51920674c84e6599ef7aeb18;hpb=2a2e64829786ee415fd0c0f16957c55e174b793b diff --git a/src/edu/berkeley/qfat/InteractiveMeshViewer.java b/src/edu/berkeley/qfat/InteractiveMeshViewer.java index 1a72d7e..419e209 100644 --- a/src/edu/berkeley/qfat/InteractiveMeshViewer.java +++ b/src/edu/berkeley/qfat/InteractiveMeshViewer.java @@ -11,9 +11,55 @@ import java.util.*; import edu.berkeley.qfat.geom.*; import edu.berkeley.qfat.geom.Point; -public class InteractiveMeshViewer extends MeshViewer { +public class InteractiveMeshViewer extends JPanel implements KeyListener { - public InteractiveMeshViewer(JFrame f) { super(f); } + public Mesh tile; + public Mesh goal; + + private HashSet mvs = new HashSet(); + + public InteractiveMeshViewer(JFrame f) { + MeshViewer mv1 = new MeshViewer(); + MeshViewer mv2 = new MeshViewer(); + MeshViewer mv3 = new MeshViewer(); + MeshViewer mv4 = new MeshViewer(); + mvs.add(mv1); + mvs.add(mv2); + mvs.add(mv3); + mvs.add(mv4); + f.addKeyListener(this); + addKeyListener(this); + mv1.addKeyListener(this); + mv2.addKeyListener(this); + mv3.addKeyListener(this); + mv4.addKeyListener(this); + setLayout(new GridLayout(2,2)); + this.add(mv1); + this.add(mv2); + this.add(mv3); + this.add(mv4); + setTile(new Mesh(false)); + setGoal(new Mesh(false)); + } + public void repaint() { + if (mvs != null) + for(MeshViewer mv : mvs) + mv.repaint(); + } + + + public void setTile(Mesh tile) { + for(MeshViewer mv : mvs) mv.removeMesh(this.tile); + this.tile = tile; + for(MeshViewer mv : mvs) mv.addMesh(this.tile); + } + public void setGoal(Mesh goal) { + for(MeshViewer mv : mvs) mv.removeMesh(this.goal); + this.goal = goal; + goal.option_selectable = false; + goal.option_wireframe = true; + for(MeshViewer mv : mvs) mv.addMesh(this.goal); + } public synchronized void dump() { try { @@ -35,10 +81,38 @@ public class InteractiveMeshViewer extends MeshViewer { } catch (Exception e) { throw new RuntimeException(e); } } + public int whichNeighbor = 1; + public double temp; + public boolean tileon = true; + public boolean tilemeshon = false; + public boolean goalon = true; + public boolean anneal = false; + public boolean hillclimb = false; + public boolean neighbors = false; + public boolean neighborsWire = false; + public boolean neighborsWireOne = false; + public boolean errorNormals = false; + + public boolean force = false; + public Mesh.Vertex[] points; + public int breaks = 0; + + public int temps; + public int accepts; + public int vertss; + + public void keyTyped(KeyEvent e) { } + public void keyReleased(KeyEvent e) { } public void keyPressed(KeyEvent e) { - super.keyPressed(e); + //super.keyPressed(e); switch(e.getKeyCode()) { - case KeyEvent.VK_SPACE: breaks++; force = true; break; + case KeyEvent.VK_SPACE: + System.err.println("hak"); + synchronized(this) { + tile.subdivide(); + break; + } + //case KeyEvent.VK_SPACE: breaks++; force = true; break; case KeyEvent.VK_UP: temp = temp * 2; break; case KeyEvent.VK_ENTER: temp = 10; break; case KeyEvent.VK_LEFT: whichNeighbor--; break;