X-Git-Url: https://ruin.nu/git/?p=moosique.git;a=blobdiff_plain;f=MooNoteElement.java;h=d5e4d2a433ece1f041b1056403b473425c75d63a;hp=65ed0baf554dd78aab1676e1e7aa41cd6807ecd9;hb=b5028dc9c03585cdf231a37d8996a7e836932c3e;hpb=357944d9255bb7cb1ad5ed4f5c960b22a8c64b8f diff --git a/MooNoteElement.java b/MooNoteElement.java index 65ed0ba..d5e4d2a 100644 --- a/MooNoteElement.java +++ b/MooNoteElement.java @@ -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()); + } + } } }