X-Git-Url: https://ruin.nu/git/?p=moosique.git;a=blobdiff_plain;f=MooNoteElement.java;h=8b15596e9df44a24e13cac96859861a11689eebd;hp=67555fcf5ccc80c45c85c7512b7ae69f1928ccd3;hb=HEAD;hpb=a8b0b5e27d120df964c5b6d8554a6207951b00d0 diff --git a/MooNoteElement.java b/MooNoteElement.java index 67555fc..8b15596 100644 --- a/MooNoteElement.java +++ b/MooNoteElement.java @@ -9,15 +9,13 @@ import java.awt.event.*; * @version 1 */ -public class MooNoteElement extends JPanel { +public class MooNoteElement extends JPanel implements Comparable { private MooTrackView mtv; private MooNote note; - private JPopupMenu popup; - private JMenuItem popupRemove, popupProp, popupTranspOctUp, popupTranspOctDown; private Rectangle pitchRect, veloRect; private String notePitch, noteVelocity; - private boolean selected = false; + private boolean selected = false, leftMouseButtonPressed = false, mouseIn = false; public Color textColor; public static final Color bgColor = new Color(160, 218, 255); public static final Color invBgColor = new Color(96, 38, 0); @@ -39,22 +37,6 @@ public class MooNoteElement extends JPanel { // 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); - popupTranspOctUp = new JMenuItem("Transpose one octave up"); - popupTranspOctUp.addActionListener(pList); - popup.add(popupTranspOctUp); - popupTranspOctDown = new JMenuItem("Transpose one octave down"); - popupTranspOctDown.addActionListener(pList); - popup.add(popupTranspOctDown); } /** @@ -65,12 +47,20 @@ public class MooNoteElement extends JPanel { return note; } + /** + * Compares the note of this element to that of another element. + * @return a negative integer, zero, or a positive integer as this object is less than, equal to, or greater than the specified object + */ + public int compareTo(Object o) { + return note.compareTo(((MooNoteElement)o).getNote()); + } + /** * Selects the current NoteElement. */ public void select() { selected = true; - mtv.selectNote(this); + Moosique.selectNote(this); setBackground(invBgColor); textColor = Color.white; repaint(); @@ -87,6 +77,15 @@ public class MooNoteElement extends JPanel { repaint(); } + /** + * Transposes the current note element the given number of halftones. + * @param halftones the number of halftones to transpose - positive for up, negative for down + */ + public void transpose(int halftones) { + note.transpose(halftones); + update(); + } + /** * Draws the string that shows the note's properties. * @param g The Graphics object used to draw the strings. @@ -155,26 +154,43 @@ public class MooNoteElement extends JPanel { } /** - * layout this changed elemnt + * Layout this changed elemnt. */ protected void newLayout(){ mtv.layoutElement(this,true); } + /** * Listener that checks the mouse actions on this element. */ class MAdapter extends MouseAdapter { /** - * If left mouse button is clicked, selects the note and plays it. + * Plays the note on double-click. */ public void mouseClicked(MouseEvent e) { - if (SwingUtilities.isLeftMouseButton(e) && !e.isControlDown()) { + if (SwingUtilities.isLeftMouseButton(e) && e.getClickCount() == 2) + Moosique.getReceiver().send(note.getMessage(), -1); + } + + /** + * Selects the note if mouse entered with the left mouse button pressed. + */ + public void mouseEntered(MouseEvent e) { + mouseIn = true; + if (mtv.isLeftMouseButtonPressed()) { select(); - // Play the note } } + /** + * Registers mouse exited. + */ + public void mouseExited(MouseEvent e) { + mouseIn = false; + Moosique.getReceiver().send(note.getNoteOffEvent().getMessage(), -1); + } + /** * Checks if the mouse is pressed. * Increases the pitch or velocity if the right mouse button is pressed while holding CTRL. @@ -202,42 +218,27 @@ public class MooNoteElement extends JPanel { calculateString(); repaint(); } - } else maybeShowPopup(e); + } else { + select(); + maybeShowPopup(e); + } } public void mouseReleased(MouseEvent e) { - maybeShowPopup(e); + if (!maybeShowPopup(e) && !mouseIn) { + int y = e.getY(); + if (y < 0) mtv.moveSelectedNotes((Moosique.getSequence().getResolution() / 4)* (int)Math.floor((double)y / MooTrackView.NOTE_HEIGHT)); + if (y > getHeight()) mtv.moveSelectedNotes((Moosique.getSequence().getResolution() / 4) * (int)Math.ceil(((double)y - getHeight()) / MooTrackView.NOTE_HEIGHT)); + } } /** * Shows the menu if an OS-specific popup-trigger was activated. */ - private void maybeShowPopup(MouseEvent e) { - if (e.isPopupTrigger() && !e.isControlDown()) { - if (!selected || mtv.isTheOnlySelected((MooNoteElement)e.getComponent())) popup.show(e.getComponent(), e.getX(), e.getY()); - else mtv.showSelectionPopup(e.getComponent(), e.getX(), e.getY()); - } - } - } - - /** - * Listens on the actions made to the popupmenu. - */ - class PopupListener implements ActionListener { - public void actionPerformed(ActionEvent e) { - Object source = e.getSource(); - if (source == popupProp) { - new MooDialog(note); - newLayout(); - } else if (source == popupRemove) { - remove(); - } else if (source == popupTranspOctUp) { - note.transpose(12); - update(); - } else if (source == popupTranspOctDown) { - note.transpose(-12); - update(); - } + private boolean maybeShowPopup(MouseEvent e) { + if (!e.isPopupTrigger()) return false; + if (!e.isControlDown()) mtv.showSelectionPopup(e.getComponent(), e.getX(), e.getY()); + return true; } } }