-
- MouseMotionListener doScrollRectToVisible = new MouseMotionAdapter() {
- public void mouseDragged(MouseEvent e) {
- Rectangle r = new Rectangle(e.getX(), e.getY(), 1, 1);
- ((JPanel)e.getSource()).scrollRectToVisible(r);
- }
- };
-
- private JPanel trackTitle () {
- title = new MooTrackTitle();
- title.setPreferredSize(new Dimension(PANEL_WIDTH, TITLE_HEIGHT));
- title.setBorder(BorderFactory.createLineBorder(Color.black));
- return title;
+
+ public void layoutElement(MooNoteElement elem){
+ int extraHeight = Toolkit.getDefaultToolkit().getScreenSize().height - 150;
+ int beatsPerSixteenth = Moosique.getSequence().getResolution() / 4;
+ MooNote mn = elem.getNote();
+ Insets insets = getInsets();
+ int x, y, height;
+ x = insets.left;
+ y = insets.top + (int)(mn.getTick() / beatsPerSixteenth) * NOTE_HEIGHT;
+ height = (mn.getDuration() / beatsPerSixteenth) * NOTE_HEIGHT;
+ if (height == 0) height = NOTE_HEIGHT;
+ Rectangle r = new Rectangle(x, y, NOTE_WIDTH, height);
+ while(isOccupied(r)) r.translate(NOTE_WIDTH, 0);
+ elem.setBounds(r);
+ rects.add(r);
+ if (viewLength < (y + height)){
+ viewLength = y + height;
+ setPreferredSize(new Dimension(VIEW_WIDTH, viewLength + extraHeight));
+ }
+
+ }
+
+ public Track getTrack() {
+ return track;
+ }
+
+
+ /**
+ * Updates the track view.
+ */
+ public void update(long tickPosition) {
+ repaint();