]> ruin.nu Git - moosique.git/blobdiff - MooView.java
minor changes.
[moosique.git] / MooView.java
index 620478ca09b8857983b2cba25d4618e1612b21c1..8223eca49e62ff4d28e3c5f3398778ba14fa08d8 100644 (file)
@@ -9,57 +9,98 @@ import java.awt.event.*;
  * @author  Einar Pehrson
  */
 
-public class MooView extends JScrollPane {
+public class MooView extends JPanel {
 
-       private Track[] tracks;
-       private MooTrackView[] trackViews;
        private JPanel trackPanel;
+       private JPanel titlePanel;
+       private int numberOfTracks;
+       private JScrollPane trackViews;
+       private JScrollPane trackTitles;
 
        /** 
         * Creates the main view
         */
        public MooView(Track[] tracks) {
-               super(VERTICAL_SCROLLBAR_ALWAYS, HORIZONTAL_SCROLLBAR_AS_NEEDED);
+               trackViews = new JScrollPane(JScrollPane.VERTICAL_SCROLLBAR_ALWAYS, JScrollPane.HORIZONTAL_SCROLLBAR_AS_NEEDED);
+               trackPanel = new JPanel(new GridLayout(1,3), true);
+               trackViews.setViewportView(trackPanel);
 
-               this.tracks = tracks;
+               trackTitles = new JScrollPane(JScrollPane.VERTICAL_SCROLLBAR_NEVER, JScrollPane.HORIZONTAL_SCROLLBAR_NEVER);
+               titlePanel = new JPanel(new GridLayout(1,3),true);
+               trackTitles.setViewportView(titlePanel);
 
-               trackPanel = new JPanel(new GridLayout(1,3), true);
-               createTrackViews();
-               setViewportView(trackPanel);
+               trackViews.setColumnHeaderView(trackTitles);
+               numberOfTracks = tracks.length;
+               setTracks(tracks);
+               setLayout(new BorderLayout());
+               add(trackTitles, BorderLayout.NORTH);
+               add(trackViews, BorderLayout.CENTER);
        }
 
        /** 
         * Fills the track panel with track views for all tracks in the current sequence.
+        * @param tracks        the tracks for which to add views
         */
-       private void createTrackViews() {
-               trackPanel.removeAll();
-               ((GridLayout)trackPanel.getLayout()).setColumns(tracks.length);
-               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 setTracks(Track[] tracks) {
+               if (tracks.length == 1) {
+                       // If MIDI file is of type 0, creates a view for the track.
+                       trackPanel.add(new MooTrackView(tracks[0]));
+                       titlePanel.add(new MooTrackTitle(tracks[0]));
+               } else {
+                       // Creates dialog for progress bar.
+                       JDialog progressDialog = new JDialog(Moosique.getGUI(), "Visualizing...", false);
+                       JProgressBar progressBar = new JProgressBar(0, tracks.length);
+                       progressBar.setValue(0);
+                       progressBar.setStringPainted(true);
+                       progressDialog.getContentPane().add(progressBar);
+                       progressDialog.pack();
+                       progressDialog.setLocation((Toolkit.getDefaultToolkit().getScreenSize().width - progressDialog.getWidth()) / 2, (Toolkit.getDefaultToolkit().getScreenSize().height - progressDialog.getHeight()) / 2);
+                       progressDialog.setVisible(true);
+       
+                       // Starts filling the track panel with track views, while updating the progress bar.
+                       trackPanel.removeAll();
+                       trackPanel.setLayout(new GridLayout(1,tracks.length));
+                       for (int i = 1; i < tracks.length; i++) {
+                               trackPanel.add(new MooTrackView(tracks[i]));
+                               titlePanel.add(new MooTrackTitle(tracks[i]));
+                               progressBar.setValue(i+1);
+                       }
+                       progressDialog.dispose();
                }
                trackPanel.validate();
+               trackViews.setViewportView(trackPanel);
        }
 
-       public void update(Track[] tracks) {
-               this.tracks = tracks;
-               createTrackViews();
+       /** 
+        * Calls on each track view to update itself.
+        */
+       public void update() {
+               Component[] comps = getComponents();
+               for (int i = 0; i < comps.length; i++) {
+                       if(comps[i] instanceof MooTrackView) ((MooTrackView)comps[i]).update();
+               }
        }
 
        /** 
         * Creates a view for the given track and adds it to the main view.
         * @param track         the track for which to add a view
+        * @param index         the index at which to insert the view
         */
-       public void addTrackView(Track track) {
-               
+       public void addTrackView(Track track, int index) {
+               ((GridLayout)trackPanel.getLayout()).setColumns(++numberOfTracks);
+               ((GridLayout)titlePanel.getLayout()).setColumns(++numberOfTracks);
+               trackPanel.add(new MooTrackView(track), index);
+               titlePanel.add(new MooTrackTitle(track), index);
+               validate();
        }
 
        /** 
         * Removes the view for the given track.
-        * @param track         the track for which to remove the view
+        * @param index         the index of the track for which to remove the view
         */
-       public void removeTrackView(Track track) {
-               
+       public void removeTrackView(int index) {
+               remove(index);
+               ((GridLayout)trackPanel.getLayout()).setColumns(--numberOfTracks);
+               validate();
        }
-}
\ No newline at end of file
+}