import javax.swing.*;
import java.awt.*;
import java.awt.event.*;
+import java.beans.*;
/**
* The main view, the container of the track views.
public class MooView extends JScrollPane {
- private Track[] tracks;
- private MooTrackView[] trackViews;
private JPanel trackPanel;
+ private JPanel titlePanel;
+ private int numberOfTracks;
/**
* Creates the main view
*/
public MooView(Track[] tracks) {
- super(VERTICAL_SCROLLBAR_ALWAYS, HORIZONTAL_SCROLLBAR_AS_NEEDED);
-
- this.tracks = tracks;
-
+ super(JScrollPane.VERTICAL_SCROLLBAR_ALWAYS, JScrollPane.HORIZONTAL_SCROLLBAR_AS_NEEDED);
trackPanel = new JPanel(new GridLayout(1,3), true);
- createTrackViews();
setViewportView(trackPanel);
+
+ titlePanel = new JPanel(new GridLayout(1,3),true);
+
+ JViewport columnHeader = new JViewport();
+ columnHeader.setView(titlePanel);
+ setColumnHeaderView(columnHeader);
+ setTracks(tracks);
}
/**
* 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) {
+ numberOfTracks = tracks.length;
+ if (numberOfTracks == 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,numberOfTracks));
+ 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();
+ }
+/* JPanel filler = new JPanel();
+ int totalViewLength = trackPanel.getComponents().length * MooTrackView.VIEW_WIDTH;
+ if (totalViewLength < getWidth()) {
+ System.out.println("Adding filler since width = " + getWidth() + " and tracks = " + totalViewLength);
+ ((GridLayout)trackPanel.getLayout()).setColumns(numberOfTracks + 1);
+ filler.setPreferredSize(new Dimension(getWidth() - totalViewLength, 140 * MooTrackView.NOTE_HEIGHT));
+ trackPanel.add(filler);
+ setPreferredSize(new Dimension(getWidth(), getHeight()));
}
+*/
trackPanel.validate();
+ setViewportView(trackPanel);
}
- public void update(Track[] tracks) {
- this.tracks = tracks;
- createTrackViews();
+ /**
+ * Calls on each track view to update itself.
+ */
+ public void update(long tickPosition) {
+ Component[] comps = getComponents();
+ for (int i = 0; i < comps.length; i++) {
+ if(comps[i] instanceof MooTrackView) ((MooTrackView)comps[i]).update(tickPosition);
+ }
}
/**
* 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
+}