Formato
Plain text
Post date
2014-06-26 14:52
Publication Period
Unlimited
  1. // http://www.hakkaku.net/articles/20071019-56 ----------------
  2. // Receiverを使う **
  3. import javax.sound.midi.*;
  4. public class TestReceiver {
  5. // メイン
  6. public static void main(String[] args) throws Exception {
  7. Receiver receiver = MidiSystem.getReceiver();
  8. // send
  9. receiver.send(NoteOn(60, 120), 1000); // c
  10. receiver.send(NoteOn(64, 120), 1000); // e
  11. receiver.send(NoteOn(67, 120), 1000); // g
  12. // sleep
  13. Thread.sleep(1500);
  14. receiver.close();
  15. }
  16. // 発音用のメッセージを生成する
  17. public static ShortMessage NoteOn(int noteno, int velocity)
  18. throws Exception {
  19. ShortMessage sm = new ShortMessage();
  20. sm.setMessage(ShortMessage.NOTE_ON, noteno, velocity);
  21. return sm;
  22. }
  23. }
  24. // http://www.ruimo.com/howto/java/midi/ ----------------
  25. // Receiverを使う
  26. public class ReceiverSample {
  27. // メイン
  28. public static void main(String[] args) throws Exception {
  29. Receiver receiver = null;
  30. try {
  31. receiver = MidiSystem.getReceiver();
  32. ShortMessage noteOn1 = new ShortMessage();
  33. noteOn1.setMessage(ShortMessage.NOTE_ON, 60, 90);
  34. receiver.send(noteOn1, 1);
  35. ShortMessage noteOn2 = new ShortMessage();
  36. noteOn2.setMessage(ShortMessage.NOTE_ON, 62, 90);
  37. receiver.send(noteOn2, 1000L * 1000);
  38. Thread.sleep(1100);
  39. }
  40. finally {
  41. if (receiver != null) receiver.close();
  42. }
  43. }
  44. }
  45. // ********************************************************************************
  46. // http://www.hakkaku.net/articles/20071019-56 ----------------
  47. // Sequencerを使う **
  48. import javax.sound.midi.*;
  49. public class TestSequencer {
  50. public static void main(String[] args) throws Exception {
  51. // 演奏データの作成
  52. Sequence sequence = new Sequence(Sequence.PPQ, 96);
  53. Track track = sequence.createTrack();
  54. track.add(NoteOn ( 0, 60, 120));
  55. track.add(NoteOff( 90, 60, 0));
  56. track.add(NoteOn ( 96, 62, 120));
  57. track.add(NoteOff(188, 62, 0));
  58. track.add(NoteOn (192, 64, 120));
  59. track.add(NoteOff(282, 64, 0));
  60. // 演奏
  61. Sequencer sequencer = MidiSystem.getSequencer();
  62. sequencer.open();
  63. sequencer.setSequence(sequence);
  64. sequencer.start();
  65. while (sequencer.isRunning()) Thread.sleep(100);
  66. sequencer.close();
  67. }
  68. // イベントの作成
  69. public static MidiEvent NoteOn(int time, int noteno, int velocity)
  70. throws Exception {
  71. ShortMessage sm = new ShortMessage();
  72. sm.setMessage(ShortMessage.NOTE_ON, noteno, velocity);
  73. return new MidiEvent(sm, time);
  74. }
  75. public static MidiEvent NoteOff(int time, int noteno, int velocity)
  76. throws Exception {
  77. ShortMessage sm = new ShortMessage();
  78. sm.setMessage(ShortMessage.NOTE_OFF, noteno, velocity);
  79. return new MidiEvent(sm, time);
  80. }
  81. }
  82. // http://www.ruimo.com/howto/java/midi/ ----------------
  83. // Sequencerを使う
  84. public class Test {
  85. public static void main(String[] args) throws Exception {
  86. Sequencer sequencer = null;
  87. try {
  88. sequencer = MidiSystem.getSequencer();
  89. sequencer.open();
  90. Sequence seq = new Sequence(Sequence.PPQ, 240);
  91. Track track = seq.createTrack();
  92. MetaMessage tempo = new MetaMessage();
  93. tempo.setMessage(0x51, new byte[] {0x07, (byte)0xa1, 0x20}, 3);
  94. track.add(new MidiEvent(tempo, 0));
  95. ShortMessage noteOn1 = new ShortMessage();
  96. noteOn1.setMessage(ShortMessage.NOTE_ON, 60, 64);
  97. track.add(new MidiEvent(noteOn1, 0));
  98. ShortMessage noteOn2 = new ShortMessage();
  99. noteOn2.setMessage(ShortMessage.NOTE_OFF, 60, 0);
  100. track.add(new MidiEvent(noteOn2, 480));
  101. sequencer.setSequence(seq);
  102. sequencer.start();
  103. while (sequencer.isRunning()) Thread.sleep(100);
  104. }
  105. finally {
  106. if (sequencer != null && sequencer.isOpen()) sequencer.close();
  107. }
  108. }
  109. }
  110. // ********************************************************************************
  111. // http://dlc.sun.com.edgesuite.net/jdk/jdk-api-localizations/jdk-api-ja/builds/latest/html/ja/technotes/guides/sound/programmer_guide/chapter9.html ----------------
  112. // デバイスの取得
  113. /* 別の例として、ユーザーを介在させずに、プログラムによってデバイスを選択する方法について考えましょう。ほとんどの音色を同時に再生できるシンセサイザを取得するとします。 上記のように、すべての MidiDevice.Info オブジェクトを繰り返し処理して、デバイスがシンセサイザであることを確認できた時点で、Synthesizer の getMaxPolyphony メソッドを呼び出して機能を問い合わせます。次の節で示すように、最大のポリフォニー (同時に演奏できる音) を保持するシンセサイザを予約します。ユーザーにシンセサイザの選択を求めない場合でも、ユーザーへの参考情報として、選択した MidiDevice.Info オブジェクトから返る文字列を表示することもできます。*/
  114. // Obtain information about all the installed synthesizers.
  115. Vector synthInfos;
  116. MidiDevice device;
  117. MidiDevice.Info[] infos = MidiSystem.getMidiDeviceInfo();
  118. for (int i = 0; i < infos.length; i++) {
  119. try {
  120. device = MidiSystem.getMidiDevice(infos[i]);
  121. } catch (MidiUnavailableException e) {
  122. // Handle or throw exception...
  123. }
  124. if (device instanceof Synthesizer) {
  125. synthInfos.add(infos[i]);
  126. }
  127. }
  128. // Now, display strings from synthInfos list in GUI.
  129. // デバイスのオープン
  130. /* 前の節では、インストールされているデバイスを取得する方法を示しました。ただし、デバイスはインストールされていても、利用できない場合があります。たとえば、別のアプリケーションプログラムが、排他的に使用している場合があります。 使用するプログラム用にデバイスを確実に予約するには、次のように MidiDevice の open メソッドを使用する必要があります。*/
  131. if (!(device.isOpen())) {
  132. try {
  133. device.open();
  134. } catch (MidiUnavailableException e) {
  135. // Handle or throw exception...
  136. }
  137. }
  138. // http://www.ruimo.com/howto/java/midi/ ----------------
  139. // デバイスの取得 **
  140. public class DeviceList {
  141. public static void main(String[] args) throws Exception {
  142. MidiDevice.Info[] info = MidiSystem.getMidiDeviceInfo();
  143. System.err.println("There are " + info.length + " devices.");
  144. for (int i = 0; i < info.length; i++) {
  145. System.err.println("*** " + i + " ***");
  146. System.err.println(" Description:" + info[i].getDescription());
  147. System.err.println(" Name:" + info[i].getName());
  148. System.err.println(" Vendor:" + info[i].getVendor());
  149. MidiDevice device = MidiSystem.getMidiDevice(info[i]);
  150. if (device instanceof Sequencer) {
  151. System.err.println(" *** This is Sequencer.");
  152. }
  153. if (device instanceof Synthesizer) {
  154. System.err.println(" *** This is Synthesizer.");
  155. }
  156. System.err.println();
  157. }
  158. }
  159. }
  160. // ********************************************************************************
  161. // JFrameTest.java
  162. import java.awt.*;
  163. import java.awt.event.*;
  164. import javax.swing.*;
  165. class JFrameTest extends JFrame implements ActionListener {
  166. JFrameTest() {
  167. getContentPane().setLayout(new FlowLayout());
  168. // Button
  169. JButton b1 = new JButton("OK");
  170. b1.addActionListener(this);
  171. getContentPane().add(b1);
  172. // ComboBox
  173. JComboBox cb = new JComboBox();
  174. cb.addItem("ComboA");
  175. cb.addItem("ComboB");
  176. cb.addItem("ComboC");
  177. cb.addActionListener(this);
  178. getContentPane().add(cb);
  179. // ScrollBar
  180. JScrollBar sb = new JScrollBar(JScrollBar.HORIZONTAL, 30, 5, 0, 105);
  181. sb.setPreferredSize(new Dimension(150, 17));
  182. sb.addAdjustmentListener(this);
  183. getContentPane().add(sb);
  184. setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
  185. setTitle("JFrameTest");
  186. setSize(200, 120);
  187. setVisible(true);
  188. }
  189. public static void main(String[] args) {
  190. new JFrameTest();
  191. }
  192. public void actionPerformed(ActionEvent e) {
  193. JComboBox cb = (JComboBox)e.getSource();
  194. System.out.println(cb.getSelectedItem());
  195. }
  196. public void adjustmentValueChanged(AdjustmentEvent e) {
  197. JScrollBar sb = (JScrollBar)e.getSource();
  198. System.out.println(sb.getValue());
  199. }
  200. }
  201. // ********************************************************************************
  202. // MenuTest.java
  203. import java.awt.*;
  204. import java.awt.event.*;
  205. class MenuTest extends Frame implements ActionListener, ItemListener {
  206. public static void main(String[] args) {
  207. new MenuTest();
  208. }
  209. MenuTest() {
  210. setTitle("MenuTest");
  211. setSize(200, 120);
  212. setLayout(new FlowLayout());
  213. MenuBar menuBar = new MenuBar();
  214. setMenuBar(menuBar);
  215. // [File]
  216. Menu menuFile = new Menu("File");
  217. menuFile.addActionListener(this);
  218. menuBar.add(menuFile);
  219. // [File]-[Open]
  220. MenuItem menuOpen = new MenuItem("Open...", new MenuShortcut('O'));
  221. menuFile.add(menuOpen);
  222. // [File]-[----]
  223. menuFile.addSeparator();
  224. // [File]-[Exit]
  225. MenuItem menuExit = new MenuItem("Exit");
  226. menuFile.add(menuExit);
  227. // [View]
  228. Menu menuView = new Menu("View");
  229. menuView.addActionListener(this);
  230. menuBar.add(menuView);
  231. // [View]-[Status Bar]
  232. CheckboxMenuItem menuStatusBar = new CheckboxMenuItem("Status Bar");
  233. menuStatusBar.addItemListener(this);
  234. menuView.add(menuStatusBar);
  235. // [View]-[Size]
  236. Menu menuSize = new Menu("Size");
  237. menuSize.addActionListener(this);
  238. menuView.add(menuSize);
  239. // [View]-[Size]-[Large]
  240. MenuItem menuSizeLarge = new MenuItem("Large");
  241. menuSize.add(menuSizeLarge);
  242. // [View]-[Size]-[Small]
  243. MenuItem menuSizeSmall = new MenuItem("Small");
  244. menuSize.add(menuSizeSmall);
  245. show();
  246. }
  247. public void actionPerformed(ActionEvent e) {
  248. System.out.println(e.getActionCommand());
  249. }
  250. public void itemStateChanged(ItemEvent e) {
  251. CheckboxMenuItem menu = (CheckboxMenuItem)e.getSource();
  252. if (menu.getState()) {
  253. System.out.println(menu.getLabel() + " SELECTED");
  254. } else {
  255. System.out.println(menu.getLabel() + " DESELECTED");
  256. }
  257. }
  258. }
Descargar Printable view

URL of this paste

Embed with JavaScript

Embed with iframe

Raw text