import javax.swing.*;
-import java.awt.event.MouseListener;
-import java.awt.event.MouseEvent;
-import java.awt.event.MouseMotionAdapter;
-import java.awt.event.MouseMotionListener;
-import java.awt.Dimension;
import java.awt.*;
-//import java.awt.Graphics;
-//import java.awt.Graphics2D;
-//import java.awt.Rectangle;
+import java.awt.event.*;
+import javax.sound.midi.*;
/**
+ * Graphical representation of a MIDI track.
*
- *
- * @author Andersson, Andreen, Lanneskog, Pehrson
+ * @author Andersson , Andreen, Lanneskog, Pehrson
* @version 1
*/
-public class MooTrackView extends JPanel{
+public class MooTrackView extends JPanel implements ActionListener {
+ private Track track;
private MooTrackTitle title;
- private JScrollPane table;
+ private NoteArea notes;
+ private Rectangle box;
+ private JPopupMenu popup;
+ private JMenuItem menuItem;
- /**
- * Creates
- */
- public MooTrackView () {
- this.addMouseMotionListener(doScrollRectToVisible);
- setLayout(new BorderLayout());
- this.setBorder(BorderFactory.createLineBorder(Color.black));
- add(trackTitle(), BorderLayout.NORTH);
- add(noteView(), BorderLayout.SOUTH);
+ public MooTrackView (Track track) {
+ this.track = track;
+ setPreferredSize(new Dimension(200, 200));
+ setLayout(new BorderLayout());
+ this.setBorder(BorderFactory.createLineBorder(Color.black));
+
+ title = new MooTrackTitle(track);
+ title.setBorder(BorderFactory.createLineBorder(Color.black));
+ add(title, BorderLayout.NORTH);
+
+ notes = new NoteArea();
+ notes.setBackground(Color.white);
+ notes.setBorder(BorderFactory.createLineBorder(Color.black));
+
+ popup = new JPopupMenu();
+ menuItem = new JMenuItem("Add...");
+ menuItem.addActionListener(this);
+ popup.add(menuItem);
+ menuItem = new JMenuItem("Preferences...");
+ menuItem.addActionListener(this);
+ popup.add(menuItem);
+
+ notes.addMouseListener(new PopupListener());
+ add(notes, BorderLayout.CENTER);
}
- MouseMotionListener doScrollRectToVisible = new MouseMotionAdapter() {
- public void mouseDragged(MouseEvent e) {
- Rectangle r = new Rectangle(e.getX(), e.getY(), 1, 1);
- ((JPanel)e.getSource()).scrollRectToVisible(r);
- }
- };
-
- private JPanel trackTitle () {
- title = new MooTrackTitle();
- title.setPreferredSize(new Dimension(PANEL_WIDTH, TITLE_HEIGHT));
- title.setBorder(BorderFactory.createLineBorder(Color.black));
- return title;
+ public void actionPerformed(ActionEvent e) {}
+
+ public Track getTrack() {
+ return track;
}
- private JScrollPane noteView() {
- JScrollPane scrollPane = new JScrollPane(table);
- table.setPreferredScrollableViewportSize(new Dimension(500, 70));
- return scrollPane;
+ class NoteArea extends JPanel {
+ public void RectanglePanel() {
+ setPreferredSize(new Dimension(20, 20));
}
- }
-
- private static final int PANEL_WIDTH = 65;
- private static final int TITLE_HEIGHT = 20;
- private static final int NOTEVIEW_HEIGHT = 200;
- private static final int BOX_WIDTH = 20;
- private static final int BOX_HEIGHT = 20;
-}
+ public void paintComponent(Graphics g) {
+ super.paintComponent(g);
+ Graphics2D g2 = (Graphics2D)g;
+ for (int c = 0; c < 1000; c += 20) {
+ int r=0;
+ for (r = 0; r < 200; r += 20) {
+ box = new Rectangle(r, c, 20, 20);
+ g2.setColor(Color.gray);
+ g2.draw(box);
+ }
+ }
+ }
+ }
+
+ class PopupListener extends MouseAdapter {
+ public void mousePressed(MouseEvent e) {
+ maybeShowPopup(e);
+ }
+
+ public void mouseReleased(MouseEvent e) {
+ maybeShowPopup(e);
+ }
+
+ private void maybeShowPopup(MouseEvent e) {
+ if (e.isPopupTrigger()) {
+ popup.show(e.getComponent(), e.getX(), e.getY());
+ }
+ }
+ }
+}
\ No newline at end of file