]> ruin.nu Git - moosique.git/blobdiff - MooGUI.java
vad sägs om bordern?
[moosique.git] / MooGUI.java
index b7031d8b1f78fdd1660fb5430ae1943f42dba897..f0c108ae7a800831ecc371584081433c34fc29d6 100644 (file)
@@ -11,25 +11,50 @@ import java.awt.event.*;
  
 public class MooGUI extends JFrame implements WindowListener {
 
-       Sequence seq;
+       private Sequence seq;
+
+       private JPanel trackPanel;
+       private MooTrackView[] trackViews;
+       private JLabel statusBar;
+
+       public static Font standardFont = new Font("Helvetica", Font.PLAIN, 10);
        
        /** 
         * Creates the GUI.
         */
        public MooGUI(Sequence seq) {
                super("Moosique");
+
+               this.seq = seq;
+               
+               Container pane = getContentPane();
+               pane.setLayout(new BorderLayout());
+               
+               // Adds menu bar.
+               setJMenuBar(new MooMenu());
+
+               // Adds toolbar.
+               pane.add(new MooToolbar(), BorderLayout.NORTH);
+               addWindowListener(this);
+
+               // Adds tracks.
+               trackPanel = new JPanel(true);
+               createTrackViews();
+               pane.add(trackPanel, BorderLayout.CENTER);
+
+               // Adds status bar.
+               statusBar = new JLabel("Welcome to Moosique!", JLabel.CENTER);
+               pane.add(statusBar, BorderLayout.SOUTH);
+
                addWindowListener(this);
-               MooInstrumentList m = new MooInstrumentList();
-               getContentPane().add(m);
-               m.addKeyListener(new MooKeyboard());
                pack();
-               Dimension bounds = new Dimension(300,70);
-               setJMenuBar(new MooMenu());
-//             setSize(bounds.width,bounds.height);
+               Dimension bounds = new Dimension(400,300);
+               setSize(bounds.width,bounds.height);
                setLocation((Toolkit.getDefaultToolkit().getScreenSize().width / 2) - (bounds.width / 2), (Toolkit.getDefaultToolkit().getScreenSize().height / 2) - (bounds.height / 2));
-//             setResizable(false);
-               setBackground(Color.white);
+               // setResizable(false);
+               // setBackground(Color.white);
                setVisible(true);
+               show();
        }
        
        /** 
@@ -38,6 +63,25 @@ public class MooGUI extends JFrame implements WindowListener {
         */
        public void setSequence(Sequence sequence) {
                seq = sequence;
+               createTrackViews();
+       }
+
+       /** 
+        * Shows the given message in the status bar.
+        * @param text  the message to show
+        */
+       public void setStatus(String text) {
+               statusBar.setText(text);
+       }
+       
+       private void createTrackViews() {
+               trackPanel.removeAll();
+               Track[] tracks = seq.getTracks();
+               trackViews = new MooTrackView[tracks.length];
+               for (int i = 0; i < tracks.length; i++) {
+                       trackViews[i] = new MooTrackView(tracks[i]);
+                       trackPanel.add(new MooTrackView(tracks[i]));
+               }
        }
 
        public void windowOpened(WindowEvent e) {}