*/
public MooNoteElement (MooNote mn) {
note = mn;
- setPreferredSize(new Dimension(20,20));
- setFont(new Font("Helvetica", Font.PLAIN, 10));
-
- class MouseList implements MouseListener{
- public void mouseClicked(MouseEvent event){
- //Bring upp dialog to edit note.
- }
-
- public void mouseEntered(MouseEvent event){
- //Show note props in statusbar?
- }
-
- public void mouseExited(MouseEvent event){
- //Reset statusbar?
- }
-
- public void mousePressed(MouseEvent event){ }
-
- public void mouseReleased(MouseEvent event){}
- };
- MouseListener listener = new MouseList();
- addMouseListener(listener);
}
/**
case 10: n = "A#"; break;
case 11: n = "B"; break;
}
-
- g2.drawString(n +" "+(pitch/12), 2, 2);
+ g2.setFont(new Font("Helvetica", Font.PLAIN, 10));
+ n = n +(pitch/12);
+ g2.drawString(n, 1, 11);
+ g2.drawString(""+note.getVelocity(),1,23);
}
private Rectangle box;
private JPopupMenu popup;
private JMenuItem menuItem;
+
public MooTrackView (Track track) {
this.track = track;
}
class NoteArea extends JPanel {
-
- public static final int NOTE_SIZE = 20;
+ public static final int NOTE_SIZE = 25;
+ private int trackLength;
public NoteArea(Track track) {
setLayout(null);
+ trackLength = 60;
MidiEvent note;
MooNoteElement elem;
boolean isOccupied;
// Places the note element in the appropriate place.
x = insets.left;
y = insets.top + (int)(mn.getTick() / 24) * NOTE_SIZE;
- height = (mn.getDuration() / 24) * NOTE_SIZE;
- //System.out.println(findComponentAt(x, y) != this);
- elem.setBounds(x, y, NOTE_SIZE, 20);
+ height = NOTE_SIZE;
+ // height = (mn.getDuration() / 24) * NOTE_SIZE;
+ System.out.println("Comp at: " + x + ", " + y + " is: " + findComponentAt(x + 10, y + 10));
+ while(findComponentAt(x, y) instanceof MooNoteElement ||
+ findComponentAt(x, y + height - 1) instanceof MooNoteElement) x += NOTE_SIZE;
+ elem.setBounds(x, y, NOTE_SIZE, height);
}
}
}
public void paintComponent(Graphics g) {
super.paintComponent(g);
Graphics2D g2 = (Graphics2D)g;
- for (int c = 0; c < 1000; c += 20) {
- for (int r = 0; r < 200; r += 20) {
- box = new Rectangle(r, c, 20, 20);
+ for (int c = 0; c < (trackLength*NOTE_SIZE); c += NOTE_SIZE) {
+ for (int r = 0; r < (10*NOTE_SIZE); r += NOTE_SIZE) {
+ box = new Rectangle(r, c, NOTE_SIZE, NOTE_SIZE);
g2.setColor(Color.gray);
g2.draw(box);
}