mirror of
				https://github.com/saitohirga/WSJT-X.git
				synced 2025-10-26 02:20:20 -04:00 
			
		
		
		
	
		
			
	
	
		
			93 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
		
		
			
		
	
	
			93 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
|  | <!doctype html public "-//w3c//dtd html 4.0 transitional//en"> | ||
|  | <html> | ||
|  | <head> | ||
|  |    <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1"> | ||
|  |    <meta name="GENERATOR" content="Mozilla/4.79 [en] (Windows NT 5.0; U) [Netscape]"> | ||
|  |    <meta name="Author" content="Phil Burk"> | ||
|  |    <meta name="Description" content="Tutorial for PortAudio, a cross platform, open-source, audio I/O library.It provides a very simple API for recording and/or playing sound using a simple callback function."> | ||
|  |    <meta name="KeyWords" content="audio, tutorial, library, portable, open-source, DirectSound,sound, music, JSyn, synthesis,"> | ||
|  |    <title>PortAudio Tutorial</title> | ||
|  | </head> | ||
|  | <body> | ||
|  |   | ||
|  | <center><table COLS=1 WIDTH="100%" BGCOLOR="#FADA7A" > | ||
|  | <tr> | ||
|  | <td> | ||
|  | <center> | ||
|  | <h1> | ||
|  | PortAudio Tutorial</h1></center> | ||
|  | </td> | ||
|  | </tr> | ||
|  | </table></center> | ||
|  | 
 | ||
|  | <h2> | ||
|  | Overview of PortAudio</h2> | ||
|  | 
 | ||
|  | <blockquote>PortAudio is a library that provides streaming audio input | ||
|  | and output. It is a cross-platform API (Application Programming Interface) | ||
|  | that works on Windows, Macintosh, Unix running OSS, SGI, BeOS, and perhaps | ||
|  | other platforms by the time you read this. This means that you can write | ||
|  | a simple 'C' program to process or generate an audio signal, and that program | ||
|  | can run on several different types of computer just by recompiling the | ||
|  | source code. | ||
|  | <p>Here are the steps to writing a PortAudio application: | ||
|  | <ol> | ||
|  | <li> | ||
|  | Write a callback function that will be called by PortAudio when audio processing | ||
|  | is needed.</li> | ||
|  | 
 | ||
|  | <li> | ||
|  | Initialize the PA library and open a stream for audio I/O.</li> | ||
|  | 
 | ||
|  | <li> | ||
|  | Start the stream. Your callback function will be now be called repeatedly | ||
|  | by PA in the background.</li> | ||
|  | 
 | ||
|  | <li> | ||
|  | In your callback you can read audio data from the inputBuffer and/or write | ||
|  | data to the outputBuffer.</li> | ||
|  | 
 | ||
|  | <li> | ||
|  | Stop the stream by returning 1 from your callback, or by calling a stop | ||
|  | function.</li> | ||
|  | 
 | ||
|  | <li> | ||
|  | Close the stream and terminate the library.</li> | ||
|  | </ol> | ||
|  | </blockquote> | ||
|  | 
 | ||
|  | <blockquote>There is also <a href="pa_tut_rw.html">another interface</a> | ||
|  | provided that allows you to generate audio in the foreground. You then | ||
|  | simply write data to the stream and the tool will not return until it is | ||
|  | ready to accept more data. This interface is simpler to use but is usually | ||
|  | not preferred for large applications because it requires that you launch | ||
|  | a thread to perform the synthesis. Launching a thread may be difficult | ||
|  | on non-multi-tasking systems such as the Macintosh prior to MacOS X. | ||
|  | <p>Let's continue by building a simple application that will play a sawtooth | ||
|  | wave. | ||
|  | <p>Please select the page for the specific implementation you would like | ||
|  | to use: | ||
|  | <ul> | ||
|  | <li> | ||
|  | <a href="pa_tut_pc.html">Windows (WMME or DirectSound)</a></li> | ||
|  | 
 | ||
|  | <li> | ||
|  | <a href="pa_tut_mac.html">Macintosh SoundManager for OS 7,8,9</a></li> | ||
|  | 
 | ||
|  | <li> | ||
|  | <a href="pa_tut_mac_osx.html">Macintosh CoreAudio for OS X</a></li> | ||
|  | 
 | ||
|  | <li> | ||
|  | <a href="pa_tut_asio.html">ASIO on Windows or Macintosh</a></li> | ||
|  | 
 | ||
|  | <li> | ||
|  | <a href="pa_tut_oss.html">Unix OSS</a></li> | ||
|  | </ul> | ||
|  | or continue with the <a href="pa_tut_callback.html">next page of the programming | ||
|  | tutorial</a>.</blockquote> | ||
|  | <font size=+2><a href="http://www.portaudio.com/">home</a> | | ||
|  | <a href="pa_tutorial.html">contents</a> | ||
|  | | <a href="pa_tutorial.html">previous</a></font> | ||
|  | </body> | ||
|  | </html> |