]> ruin.nu Git - moosique.git/blobdiff - MooView.java
YES!
[moosique.git] / MooView.java
index 9ee52b3636abd882686e27658e3f4193c12fd10f..0e103b89774c815b7ef512afec2c445afc45d83e 100644 (file)
@@ -2,6 +2,7 @@ import javax.sound.midi.*;
 import javax.swing.*;
 import java.awt.*;
 import java.awt.event.*;
+import java.beans.*;
 
 /**
  * The main view, the container of the track views.
@@ -15,7 +16,6 @@ public class MooView extends JPanel {
        private JPanel titlePanel;
        private int numberOfTracks;
        private JScrollPane trackViews;
-       private JScrollPane trackTitles;
 
        /** 
         * Creates the main view
@@ -25,15 +25,20 @@ public class MooView extends JPanel {
                trackPanel = new JPanel(new GridLayout(1,3), true);
                trackViews.setViewportView(trackPanel);
 
-               trackTitles = new JScrollPane(JScrollPane.VERTICAL_SCROLLBAR_NEVER, JScrollPane.HORIZONTAL_SCROLLBAR_NEVER);
                titlePanel = new JPanel(new GridLayout(1,3),true);
-               trackTitles.setViewportView(titlePanel);
 
+               JViewport columnHeader = new JViewport();
+               columnHeader.setView(titlePanel);
+               trackViews.setColumnHeaderView(columnHeader);
                numberOfTracks = tracks.length;
                setTracks(tracks);
                setLayout(new BorderLayout());
-               add(trackTitles, BorderLayout.NORTH);
                add(trackViews, BorderLayout.CENTER);
+
+               trackViews.addPropertyChangeListener(new PropertyChangeListener(){
+                               public void propertyChange(PropertyChangeEvent e){
+                                       System.out.println(e.getSource());
+                               }});
        }
 
        /** 
@@ -73,10 +78,10 @@ public class MooView extends JPanel {
        /** 
         * Calls on each track view to update itself.
         */
-       public void update() {
+       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();
+                       if(comps[i] instanceof MooTrackView) ((MooTrackView)comps[i]).update(tickPosition);
                }
        }