mirror of
https://github.com/thestk/stk
synced 2026-01-11 20:11:52 +00:00
184 lines
18 KiB
HTML
184 lines
18 KiB
HTML
<HTML>
|
|
<HEAD>
|
|
<TITLE>The Synthesis ToolKit in C++ (STK)</TITLE>
|
|
<LINK HREF="doxygen.css" REL="stylesheet" TYPE="text/css">
|
|
</HEAD>
|
|
<BODY BGCOLOR="#FFFFFF">
|
|
<CENTER>
|
|
<img src="princeton.gif"> <img src="ccrma.gif"> <img src="mcgill.gif"><P>
|
|
<a class="qindex" href="index.html">Home</a> <a class="qindex" href="information.html">Information</a> <a class="qindex" href="classes.html">Classes</a> <a class="qindex" href="download.html">Download</a> <a class="qindex" href="usage.html">Usage</a> <a class="qindex" href="maillist.html">Mail List</a> <a class="qindex" href="system.html">Requirements</a> <a class="qindex" href="links.html">Links</a> <a class="qindex" href="faq.html">FAQ</a> <a class="qindex" href="tutorial.html">Tutorial</a></CENTER>
|
|
<HR>
|
|
<!-- Generated by Doxygen 1.5.8 -->
|
|
<div class="navpath"><a class="el" href="dir_d499f4756a454d8a02faa5ebe57d576f.html">include</a>
|
|
</div>
|
|
<div class="contents">
|
|
<h1>RtMidi.h</h1><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001 <span class="comment">/**********************************************************************/</span>
|
|
<a name="l00036"></a>00036 <span class="comment">/**********************************************************************/</span>
|
|
<a name="l00037"></a>00037
|
|
<a name="l00038"></a>00038 <span class="comment">// RtMidi: Version 1.0.9</span>
|
|
<a name="l00039"></a>00039
|
|
<a name="l00040"></a>00040 <span class="preprocessor">#ifndef RTMIDI_H</span>
|
|
<a name="l00041"></a>00041 <span class="preprocessor"></span><span class="preprocessor">#define RTMIDI_H</span>
|
|
<a name="l00042"></a>00042 <span class="preprocessor"></span>
|
|
<a name="l00043"></a>00043 <span class="preprocessor">#include "RtError.h"</span>
|
|
<a name="l00044"></a>00044 <span class="preprocessor">#include <string></span>
|
|
<a name="l00045"></a>00045
|
|
<a name="l00046"></a><a class="code" href="classRtMidi.html">00046</a> <span class="keyword">class </span><a class="code" href="classRtMidi.html" title="An abstract base class for realtime MIDI input/output.">RtMidi</a>
|
|
<a name="l00047"></a>00047 {
|
|
<a name="l00048"></a>00048 <span class="keyword">public</span>:
|
|
<a name="l00049"></a>00049
|
|
<a name="l00051"></a>00051 <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="code" href="classRtMidi.html#d9e30a89638f93193cb40edebaa536f5" title="Pure virtual openPort() function.">openPort</a>( <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> portNumber = 0, <span class="keyword">const</span> std::string portName = std::string( <span class="stringliteral">"RtMidi"</span> ) ) = 0;
|
|
<a name="l00052"></a>00052
|
|
<a name="l00054"></a>00054 <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="code" href="classRtMidi.html#9200cde4f5337c0bc421d20bd4fcf654" title="Pure virtual openVirtualPort() function.">openVirtualPort</a>( <span class="keyword">const</span> std::string portName = std::string( <span class="stringliteral">"RtMidi"</span> ) ) = 0;
|
|
<a name="l00055"></a>00055
|
|
<a name="l00057"></a>00057 <span class="keyword">virtual</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> <a class="code" href="classRtMidi.html#9a49ef73a1e6007444019a7ae095e195" title="Pure virtual getPortCount() function.">getPortCount</a>() = 0;
|
|
<a name="l00058"></a>00058
|
|
<a name="l00060"></a>00060 <span class="keyword">virtual</span> std::string <a class="code" href="classRtMidi.html#799e2b9f4df39b298518f2b394db3391" title="Pure virtual getPortName() function.">getPortName</a>( <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> portNumber = 0 ) = 0;
|
|
<a name="l00061"></a>00061
|
|
<a name="l00063"></a>00063 <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="code" href="classRtMidi.html#36125c4fa16550345b57f4a4927f5b4a" title="Pure virtual closePort() function.">closePort</a>( <span class="keywordtype">void</span> ) = 0;
|
|
<a name="l00064"></a>00064
|
|
<a name="l00065"></a>00065 <span class="keyword">protected</span>:
|
|
<a name="l00066"></a>00066
|
|
<a name="l00067"></a>00067 <a class="code" href="classRtMidi.html" title="An abstract base class for realtime MIDI input/output.">RtMidi</a>();
|
|
<a name="l00068"></a>00068 <span class="keyword">virtual</span> ~<a class="code" href="classRtMidi.html" title="An abstract base class for realtime MIDI input/output.">RtMidi</a>() {};
|
|
<a name="l00069"></a>00069
|
|
<a name="l00070"></a>00070 <span class="comment">// A basic error reporting function for internal use in the RtMidi</span>
|
|
<a name="l00071"></a>00071 <span class="comment">// subclasses. The behavior of this function can be modified to</span>
|
|
<a name="l00072"></a>00072 <span class="comment">// suit specific needs.</span>
|
|
<a name="l00073"></a>00073 <span class="keywordtype">void</span> error( <a class="code" href="classRtError.html#b04667aae01bffc354a9ac6bda6903ac" title="Defined RtError types.">RtError::Type</a> type );
|
|
<a name="l00074"></a>00074
|
|
<a name="l00075"></a>00075 <span class="keywordtype">void</span> *apiData_;
|
|
<a name="l00076"></a>00076 <span class="keywordtype">bool</span> connected_;
|
|
<a name="l00077"></a>00077 std::string errorString_;
|
|
<a name="l00078"></a>00078 };
|
|
<a name="l00079"></a>00079
|
|
<a name="l00080"></a>00080 <span class="comment">/**********************************************************************/</span>
|
|
<a name="l00096"></a>00096 <span class="comment">/**********************************************************************/</span>
|
|
<a name="l00097"></a>00097
|
|
<a name="l00098"></a>00098 <span class="preprocessor">#include <vector></span>
|
|
<a name="l00099"></a>00099 <span class="preprocessor">#include <queue></span>
|
|
<a name="l00100"></a>00100
|
|
<a name="l00101"></a><a class="code" href="classRtMidiIn.html">00101</a> <span class="keyword">class </span><a class="code" href="classRtMidiIn.html" title="A realtime MIDI input class.">RtMidiIn</a> : <span class="keyword">public</span> <a class="code" href="classRtMidi.html" title="An abstract base class for realtime MIDI input/output.">RtMidi</a>
|
|
<a name="l00102"></a>00102 {
|
|
<a name="l00103"></a>00103 <span class="keyword">public</span>:
|
|
<a name="l00104"></a>00104
|
|
<a name="l00106"></a>00106 <span class="keyword">typedef</span> void (*<a class="code" href="classRtMidiIn.html#297d2eb3c3420b437970a6fc59d89cbf" title="User callback function type definition.">RtMidiCallback</a>)( <span class="keywordtype">double</span> timeStamp, std::vector<unsigned char> *message, <span class="keywordtype">void</span> *userData);
|
|
<a name="l00107"></a>00107
|
|
<a name="l00109"></a>00109
|
|
<a name="l00112"></a>00112 <a class="code" href="classRtMidiIn.html#31abb996e5fdc4a8f9dc5a50848e2ee5" title="Default constructor that allows an optional client name.">RtMidiIn</a>( <span class="keyword">const</span> std::string clientName = std::string( <span class="stringliteral">"RtMidi Input Client"</span>) );
|
|
<a name="l00113"></a>00113
|
|
<a name="l00115"></a>00115 <a class="code" href="classRtMidiIn.html#f865d88c154b6fdadc640da5dc278d40" title="If a MIDI connection is still open, it will be closed by the destructor.">~RtMidiIn</a>();
|
|
<a name="l00116"></a>00116
|
|
<a name="l00118"></a>00118
|
|
<a name="l00122"></a>00122 <span class="keywordtype">void</span> <a class="code" href="classRtMidiIn.html#7e853661b1056083e07318d67c51f6fd" title="Open a MIDI input connection.">openPort</a>( <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> portNumber = 0, <span class="keyword">const</span> std::string Portname = std::string( <span class="stringliteral">"RtMidi Input"</span> ) );
|
|
<a name="l00123"></a>00123
|
|
<a name="l00125"></a>00125
|
|
<a name="l00131"></a>00131 <span class="keywordtype">void</span> <a class="code" href="classRtMidiIn.html#245261b3f12ce727faed18fcfeef18c2" title="Create a virtual input port, with optional name, to allow software connections (OS...">openVirtualPort</a>( <span class="keyword">const</span> std::string portName = std::string( <span class="stringliteral">"RtMidi Input"</span> ) );
|
|
<a name="l00132"></a>00132
|
|
<a name="l00134"></a>00134
|
|
<a name="l00140"></a>00140 <span class="keywordtype">void</span> <a class="code" href="classRtMidiIn.html#7590563461c7467608a4b3806406b32d" title="Set a callback function to be invoked for incoming MIDI messages.">setCallback</a>( <a class="code" href="classRtMidiIn.html#297d2eb3c3420b437970a6fc59d89cbf" title="User callback function type definition.">RtMidiCallback</a> callback, <span class="keywordtype">void</span> *userData = 0 );
|
|
<a name="l00141"></a>00141
|
|
<a name="l00143"></a>00143
|
|
<a name="l00147"></a>00147 <span class="keywordtype">void</span> <a class="code" href="classRtMidiIn.html#de23832a66c1ed56965c26325602543e" title="Cancel use of the current callback function (if one exists).">cancelCallback</a>();
|
|
<a name="l00148"></a>00148
|
|
<a name="l00150"></a>00150 <span class="keywordtype">void</span> <a class="code" href="classRtMidiIn.html#55bacf0d228fd8e3be6a79d12fd1dc39" title="Close an open MIDI connection (if one exists).">closePort</a>( <span class="keywordtype">void</span> );
|
|
<a name="l00151"></a>00151
|
|
<a name="l00153"></a>00153 <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> <a class="code" href="classRtMidiIn.html#62b1b38aa8e5f11cd66f03d59228f4e4" title="Return the number of available MIDI input ports.">getPortCount</a>();
|
|
<a name="l00154"></a>00154
|
|
<a name="l00156"></a>00156
|
|
<a name="l00159"></a>00159 std::string <a class="code" href="classRtMidiIn.html#f2961fff09fa01a3d5bc0f0c5a042aaf" title="Return a string identifier for the specified MIDI input port number.">getPortName</a>( <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> portNumber = 0 );
|
|
<a name="l00160"></a>00160
|
|
<a name="l00162"></a>00162
|
|
<a name="l00166"></a>00166 <span class="keywordtype">void</span> <a class="code" href="classRtMidiIn.html#2e15868916737039e0a34d47bffdf188" title="Set the maximum number of MIDI messages to be saved in the queue.">setQueueSizeLimit</a>( <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> queueSize );
|
|
<a name="l00167"></a>00167
|
|
<a name="l00169"></a>00169
|
|
<a name="l00176"></a>00176 <span class="keywordtype">void</span> <a class="code" href="classRtMidiIn.html#f9507125aaa42276ccc01df576fc3533" title="Specify whether certain MIDI message types should be queued or ignored during input...">ignoreTypes</a>( <span class="keywordtype">bool</span> midiSysex = <span class="keyword">true</span>, <span class="keywordtype">bool</span> midiTime = <span class="keyword">true</span>, <span class="keywordtype">bool</span> midiSense = <span class="keyword">true</span> );
|
|
<a name="l00177"></a>00177
|
|
<a name="l00179"></a>00179
|
|
<a name="l00186"></a>00186 <span class="keywordtype">double</span> <a class="code" href="classRtMidiIn.html#1ba10ecd276b30a8579c7d60a9c890eb" title="Fill the user-provided vector with the data bytes for the next available MIDI message...">getMessage</a>( std::vector<unsigned char> *message );
|
|
<a name="l00187"></a>00187
|
|
<a name="l00188"></a>00188 <span class="comment">// A MIDI structure used internally by the class to store incoming</span>
|
|
<a name="l00189"></a>00189 <span class="comment">// messages. Each message represents one and only one MIDI message.</span>
|
|
<a name="l00190"></a>00190 <span class="keyword">struct </span>MidiMessage {
|
|
<a name="l00191"></a>00191 std::vector<unsigned char> bytes;
|
|
<a name="l00192"></a>00192 <span class="keywordtype">double</span> timeStamp;
|
|
<a name="l00193"></a>00193
|
|
<a name="l00194"></a>00194 <span class="comment">// Default constructor.</span>
|
|
<a name="l00195"></a>00195 MidiMessage()
|
|
<a name="l00196"></a>00196 :bytes(3), timeStamp(0.0) {}
|
|
<a name="l00197"></a>00197 };
|
|
<a name="l00198"></a>00198
|
|
<a name="l00199"></a>00199 <span class="comment">// The RtMidiInData structure is used to pass private class data to</span>
|
|
<a name="l00200"></a>00200 <span class="comment">// the MIDI input handling function or thread.</span>
|
|
<a name="l00201"></a>00201 <span class="keyword">struct </span>RtMidiInData {
|
|
<a name="l00202"></a>00202 std::queue<MidiMessage> queue;
|
|
<a name="l00203"></a>00203 MidiMessage message;
|
|
<a name="l00204"></a>00204 <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> queueLimit;
|
|
<a name="l00205"></a>00205 <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> ignoreFlags;
|
|
<a name="l00206"></a>00206 <span class="keywordtype">bool</span> doInput;
|
|
<a name="l00207"></a>00207 <span class="keywordtype">bool</span> firstMessage;
|
|
<a name="l00208"></a>00208 <span class="keywordtype">void</span> *apiData;
|
|
<a name="l00209"></a>00209 <span class="keywordtype">bool</span> usingCallback;
|
|
<a name="l00210"></a>00210 <span class="keywordtype">void</span> *userCallback;
|
|
<a name="l00211"></a>00211 <span class="keywordtype">void</span> *userData;
|
|
<a name="l00212"></a>00212 <span class="keywordtype">bool</span> continueSysex;
|
|
<a name="l00213"></a>00213
|
|
<a name="l00214"></a>00214 <span class="comment">// Default constructor.</span>
|
|
<a name="l00215"></a>00215 RtMidiInData()
|
|
<a name="l00216"></a>00216 : queueLimit(1024), ignoreFlags(7), doInput(<span class="keyword">false</span>), firstMessage(<span class="keyword">true</span>),
|
|
<a name="l00217"></a>00217 apiData(0), usingCallback(<span class="keyword">false</span>), userCallback(0), userData(0),
|
|
<a name="l00218"></a>00218 continueSysex(<span class="keyword">false</span>) {}
|
|
<a name="l00219"></a>00219 };
|
|
<a name="l00220"></a>00220
|
|
<a name="l00221"></a>00221 <span class="keyword">private</span>:
|
|
<a name="l00222"></a>00222
|
|
<a name="l00223"></a>00223 <span class="keywordtype">void</span> initialize( <span class="keyword">const</span> std::string& clientName );
|
|
<a name="l00224"></a>00224 RtMidiInData inputData_;
|
|
<a name="l00225"></a>00225
|
|
<a name="l00226"></a>00226 };
|
|
<a name="l00227"></a>00227
|
|
<a name="l00228"></a>00228 <span class="comment">/**********************************************************************/</span>
|
|
<a name="l00240"></a>00240 <span class="comment">/**********************************************************************/</span>
|
|
<a name="l00241"></a>00241
|
|
<a name="l00242"></a><a class="code" href="classRtMidiOut.html">00242</a> <span class="keyword">class </span><a class="code" href="classRtMidiOut.html" title="A realtime MIDI output class.">RtMidiOut</a> : <span class="keyword">public</span> <a class="code" href="classRtMidi.html" title="An abstract base class for realtime MIDI input/output.">RtMidi</a>
|
|
<a name="l00243"></a>00243 {
|
|
<a name="l00244"></a>00244 <span class="keyword">public</span>:
|
|
<a name="l00245"></a>00245
|
|
<a name="l00247"></a>00247
|
|
<a name="l00250"></a>00250 <a class="code" href="classRtMidiOut.html#8ed1b492900f3410bf91ad53203b9db3" title="Default constructor that allows an optional client name.">RtMidiOut</a>( <span class="keyword">const</span> std::string clientName = std::string( <span class="stringliteral">"RtMidi Output Client"</span> ) );
|
|
<a name="l00251"></a>00251
|
|
<a name="l00253"></a>00253 <a class="code" href="classRtMidiOut.html#b776c431bd84193febb2f78fb8c7e792" title="The destructor closes any open MIDI connections.">~RtMidiOut</a>();
|
|
<a name="l00254"></a>00254
|
|
<a name="l00256"></a>00256
|
|
<a name="l00262"></a>00262 <span class="keywordtype">void</span> <a class="code" href="classRtMidiOut.html#1b280d67317cd473a8816aeb2fe6c186" title="Open a MIDI output connection.">openPort</a>( <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> portNumber = 0, <span class="keyword">const</span> std::string portName = std::string( <span class="stringliteral">"RtMidi Output"</span> ) );
|
|
<a name="l00263"></a>00263
|
|
<a name="l00265"></a>00265 <span class="keywordtype">void</span> <a class="code" href="classRtMidiOut.html#3092e53a8aed2d3b163fcaa05fafd041" title="Close an open MIDI connection (if one exists).">closePort</a>();
|
|
<a name="l00266"></a>00266
|
|
<a name="l00268"></a>00268
|
|
<a name="l00276"></a>00276 <span class="keywordtype">void</span> <a class="code" href="classRtMidiOut.html#47068e1c076d91fd89587c0ccdeddc7a" title="Create a virtual output port, with optional name, to allow software connections (OS...">openVirtualPort</a>( <span class="keyword">const</span> std::string portName = std::string( <span class="stringliteral">"RtMidi Output"</span> ) );
|
|
<a name="l00277"></a>00277
|
|
<a name="l00279"></a>00279 <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> <a class="code" href="classRtMidiOut.html#d6cddbcc7faa20a7be229f765ade0877" title="Return the number of available MIDI output ports.">getPortCount</a>();
|
|
<a name="l00280"></a>00280
|
|
<a name="l00282"></a>00282
|
|
<a name="l00285"></a>00285 std::string <a class="code" href="classRtMidiOut.html#cc4ae0ab71a49ae7629075d5a9cd837c" title="Return a string identifier for the specified MIDI port type and number.">getPortName</a>( <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> portNumber = 0 );
|
|
<a name="l00286"></a>00286
|
|
<a name="l00288"></a>00288
|
|
<a name="l00292"></a>00292 <span class="keywordtype">void</span> <a class="code" href="classRtMidiOut.html#0bd8972ef8ac4e8d37ccc4b5d51c2eb3" title="Immediately send a single message out an open MIDI output port.">sendMessage</a>( std::vector<unsigned char> *message );
|
|
<a name="l00293"></a>00293
|
|
<a name="l00294"></a>00294 <span class="keyword">private</span>:
|
|
<a name="l00295"></a>00295
|
|
<a name="l00296"></a>00296 <span class="keywordtype">void</span> initialize( <span class="keyword">const</span> std::string& clientName );
|
|
<a name="l00297"></a>00297 };
|
|
<a name="l00298"></a>00298
|
|
<a name="l00299"></a>00299 <span class="preprocessor">#endif</span>
|
|
</pre></div></div>
|
|
<HR>
|
|
|
|
<table>
|
|
<tr><td><A HREF="http://ccrma.stanford.edu/software/stk/"><I>The Synthesis ToolKit in C++ (STK)</I></A></td></tr>
|
|
<tr><td>©1995-2009 Perry R. Cook and Gary P. Scavone. All Rights Reserved.</td></tr>
|
|
</table>
|
|
|
|
</BODY>
|
|
</HTML>
|