]> ruin.nu Git - moosique.git/blobdiff - MooNoteElement.java
*** empty log message ***
[moosique.git] / MooNoteElement.java
index 65ed0baf554dd78aab1676e1e7aa41cd6807ecd9..d5e4d2a433ece1f041b1056403b473425c75d63a 100644 (file)
@@ -11,6 +11,7 @@ import java.awt.event.*;
  
 public class MooNoteElement extends JPanel {
 
+       private MooTrackView mtv;
        private MooNote note;
        private int columns;
        private boolean selected;
@@ -18,13 +19,16 @@ public class MooNoteElement extends JPanel {
        public static final Color bgColor = new Color(160, 218, 255);
        private String notePitch;
        private String noteVelocity;
+       private JPopupMenu popup;
+       private JMenuItem popupRemove, popupProp;
 
        /** 
         * Creates a new note element.
         * @param mn    the note that will be graphically represented
         * @param rows  the number of rows that the note will occupy
         */
-       public MooNoteElement (MooNote mn) {
+       public MooNoteElement (MooTrackView parent, MooNote mn) {
+               mtv = parent;
                note = mn;
                calculateString();
                columns = mn.getDuration() / (Moosique.getSequence().getResolution() / 4);
@@ -32,8 +36,21 @@ public class MooNoteElement extends JPanel {
                setBackground(bgColor);
                addMouseListener(new MAdapter());
 
+               // Defines coordinates.
                pitchRect = new Rectangle(0, 0, 15, 10);
                veloRect = new Rectangle(20, 0, 40, 10);
+
+               // Creates pop-up menu.
+               popup = new JPopupMenu();
+               PopupListener pList = new PopupListener();
+               popupProp = new JMenuItem("Preferences...");
+               popupProp.addActionListener(pList);
+               popup.add(popupProp);
+
+               popupRemove = new JMenuItem("Remove");
+               popupRemove.addActionListener(pList);
+               popup.add(popupRemove);
+
        }
 
        /** 
@@ -99,27 +116,39 @@ public class MooNoteElement extends JPanel {
        }
 
        class MAdapter extends MouseAdapter {
-               public void mouseClicked(MouseEvent e) {
-                       if (pitchRect.contains(e.getPoint())) {
-                               if (SwingUtilities.isRightMouseButton(e)) {
-                                       note.setPitch(note.getPitch() + 1);
-                               } else if (SwingUtilities.isLeftMouseButton(e)) {
-                                       note.setPitch(note.getPitch() - 1);
+               public void mousePressed(MouseEvent e) {
+                       if (e.isControlDown()) {
+                               if (pitchRect.contains(e.getPoint())) {
+                                       if (SwingUtilities.isRightMouseButton(e)) {
+                                               note.setPitch(note.getPitch() + 1);
+                                       } else if (SwingUtilities.isLeftMouseButton(e)) {
+                                               note.setPitch(note.getPitch() - 1);
+                                       }
+                                       calculateString();
+                               } else if (veloRect.contains(e.getPoint())) {
+                                       if (SwingUtilities.isRightMouseButton(e)) {
+                                               note.setVelocity(note.getVelocity() + 1);
+                                       } else if (SwingUtilities.isLeftMouseButton(e)) {
+                                               note.setVelocity(note.getVelocity() - 1);
+                                       }
+                                       calculateString();
                                }
-                               calculateString();
-                       } else if (veloRect.contains(e.getPoint())) {
-                               if (SwingUtilities.isRightMouseButton(e)) {
-                                       note.setVelocity(note.getVelocity() + 1);
-                               } else if (SwingUtilities.isLeftMouseButton(e)) {
-                                       note.setVelocity(note.getVelocity() - 1);
-                               }
-                               calculateString();
+                               e.getComponent().repaint();
+                       }
+                       if (e.isPopupTrigger()) {
+                               popup.show(e.getComponent(), e.getX(), e.getY());
                        }
-                       e.getComponent().repaint();
                }
+       }
 
-               public void mousePressed(MouseEvent e) {}
-
-               public void mouseReleased(MouseEvent e) {}
+       class PopupListener implements ActionListener {
+               public void actionPerformed(ActionEvent e) {
+                       Object source = e.getSource();
+                       if  (source == popupProp) {
+                               new MooDialog(note);
+                       } else if  (source == popupRemove) {
+                               mtv.remove((MooNoteElement)((JComponent)e.getSource()).getParent().getParent());
+                       }
+               }
        }
 }