X-Git-Url: https://ruin.nu/git/?a=blobdiff_plain;f=MooTrackView.java;h=1a612e47eb01f7f748ed05e70d01cc88351b7be0;hb=65ea2a43eb97459592d222ea00082e46343c9d8b;hp=854cfec806308b0680360ea5a0f41c1999b4301a;hpb=e49990e17bff158ad638a16ba4aa616673b94627;p=moosique.git diff --git a/MooTrackView.java b/MooTrackView.java index 854cfec..1a612e4 100644 --- a/MooTrackView.java +++ b/MooTrackView.java @@ -17,7 +17,7 @@ public class MooTrackView extends JPanel { private Rectangle box; private JPopupMenu popup; - private JMenuItem menuItem; + private JMenuItem popupAdd; private ArrayList rects; protected static int viewLength = 0; protected static int extraHeight = 0; @@ -56,9 +56,10 @@ public class MooTrackView extends JPanel { // Creates pop-up menu. popup = new JPopupMenu(); - menuItem = new JMenuItem("Add note..."); - // menuItem.addActionListener(); - popup.add(menuItem); + PopupListener pList = new PopupListener(); + popupAdd = new JMenuItem("Add note..."); + popupAdd.addActionListener(pList); + popup.add(popupAdd); // Adds listeners for popup menu and keyboard synthesizer. addMouseListener(new MAdapter()); @@ -100,7 +101,6 @@ public class MooTrackView extends JPanel { viewLength = y + height; if(old)setPreferredSize(new Dimension(VIEW_WIDTH, viewLength + extraHeight)); } - } public Track getTrack() { @@ -123,8 +123,17 @@ public class MooTrackView extends JPanel { return false; } - public void remove(MooNoteElement elem) { - remove((Component)elem); + public void addNote(MooNote mn) { + mn.addTo(track); + MooNoteElement elem = new MooNoteElement(this, mn); + add(elem); + layoutElement(elem, false); + setPreferredSize(new Dimension(VIEW_WIDTH, viewLength + extraHeight)); + } + + public void removeNote(MooNoteElement elem, MooNote mn) { + mn.removeFrom(track); + remove(elem); elem.getNote().removeFrom(track); validate(); repaint(); @@ -151,6 +160,17 @@ public class MooTrackView extends JPanel { public void mouseEntered(MouseEvent e) { // Moosique.setActiveChannel(track.getChannel()); + grabFocus(); + } + } + + class PopupListener implements ActionListener { + public void actionPerformed(ActionEvent e) { + Object source = e.getSource(); + if (source == popupAdd) { + //addNote(new MooNote()); + // int channel, int pitch, int velocity, long timestamp, int duration + } } } -} +} \ No newline at end of file