public class MooNoteElement extends JPanel {
+ private MooTrackView mtv;
private MooNote note;
- private int columns;
private boolean selected;
private Rectangle pitchRect, veloRect;
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);
setBorder(BorderFactory.createLineBorder(Color.black));
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);
+
}
/**
noteVelocity = ""+note.getVelocity();
}
+ public MooNote getNote(){
+ return note;
+ }
+
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);
- }
- 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);
+ 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();
+ e.getComponent().repaint();
+ } else if (e.isPopupTrigger()) {
+ popup.show(e.getComponent(), e.getX(), e.getY());
}
- e.getComponent().repaint();
}
+ }
- public void mousePressed(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) {
+ remove();
+ }
+ }
+ }
- public void mouseReleased(MouseEvent e) {}
+ protected void remove(){
+ mtv.remove(this);
}
+
}