WASAPIとは? わかりやすく解説

Weblio 辞書 > 辞書・百科事典 > 百科事典 > WASAPIの意味・解説 

WASAPI

出典: フリー百科事典『ウィキペディア(Wikipedia)』 (2022/07/15 10:16 UTC 版)

Windows Audio Session API、通称 WASAPI(ワサピ)はアプリ-オーディオデバイス間のストリームを管理する低レベルWin32 APIである[1]Core Audio APIsの1つ。

概要

オーディオを扱うアプリケーションはマイク・スピーカー等の"オーディオエンドポイントデバイス"と連携して機能する。デバイスはOSによって管理されており、これらデバイスとアプリケーションを繋ぐオーディオストリームの管理がWASAPIの役割である。

例えばスピーカー出力を行うためにはWASAPIを用いて"エンドポイントバッファ"へ音声データを書きこめばよい[2]。APIコールを受けたOSはAudioEngineによるミキシング、デバイスドライバを介したスピーカー制御をおこない、実際にスピーカーから音声が出力される。

WASAPIは基本的にどのようなサウンドデバイスでも利用することができるが、使用するアプリケーションがWASAPIに対応している必要がある。

動作モード

排他モード(exclusive)

OS標準のミキサーや各種エフェクト(APO)処理を一切介さずにエンドポイントバッファ上のオーディオサンプルをアプリケーションが直接読み書きできる構造となっている。

共有モード

他のアプリケーションの出力と共にOS標準のミキサーや各種エフェクト(APO)を介して再生されるため、複数の音声再生・録音アプリケーションを同時に使用する場合に適している。

利用

WASAPIはWin32 APIすなわちOSに対するシステムコールである。Windows OSはAudioclient.hAudiopolicy.h で定義されるWASAPIインターフェースを介してOSのオーディオストリーム管理を公開することで[3]、アプリケーションによる低レイテンシの音声入出力を可能にしている。アプリケーションはWASAPIを呼び出すことでI/Oストリームを利用できる。

WASAPIの利用ではまずストリームの準備を次のようにおこなう。

オーディオI/Oの場合、開始に引き続いて、必要に応じてパケット単位のread/writeを次のようにおこなう。

このように、WASAPIはクライアントとエンドポイントバッファ間のデータ転送を簡潔に記述できる。高レベルAPIと異なりバッファ取得を明示的に都度おこなうため、read/writeされるデータ量や転送頻度の調整を柔軟にプログラムできる。また初期化時の設定により排他モード/共有モード、バッファ全長、デバイス動作周期など、Windows OSが提供するストリーム管理の様々な側面を調整できる。

対応ソフトウェア

以下はWASAPI対応ソフトウェアの一例である。

DTMソフトウェア

波形編集ソフトウェア

メディアプレーヤー

歴史

Core Audio APIの一部としてMicrosoft Windows Vistaにて導入された。それ以降も機能が追加されている(例: IAudioClient3)。

脚注

  1. ^ "The Windows Audio Session API (WASAPI) enables client applications to manage the flow of audio data between the application and an audio endpoint device." Windows Developer. About WASAPI.
  2. ^ "To play an audio stream through a rendering endpoint device, an application periodically writes audio data to a rendering endpoint buffer. The audio engine mixes the streams from the various applications." Windows Developer. About WASAPI.
  3. ^ "Header files Audioclient.h and Audiopolicy.h define the WASAPI interfaces." About WASAPI. Windows App Development.
  4. ^ "the client can call the IAudioClient::GetCurrentPadding method to get the total amount of captured data that is available in the buffer." Capturing a Stream. Windows App Development.
  5. ^ "For a rendering buffer, the padding value that is reported by the IAudioClient::GetCurrentPadding method represents the amount of rendering data that is queued up to play in the buffer." Rendering a Stream. Windows App Development.
  6. ^ foobar2000: Change Log”. 2022年7月15日閲覧。

関連項目

外部リンク




英和和英テキスト翻訳>> Weblio翻訳
英語⇒日本語日本語⇒英語
  

辞書ショートカット

すべての辞書の索引

「WASAPI」の関連用語

WASAPIのお隣キーワード
検索ランキング

   

英語⇒日本語
日本語⇒英語
   



WASAPIのページの著作権
Weblio 辞書 情報提供元は 参加元一覧 にて確認できます。

   
ウィキペディアウィキペディア
All text is available under the terms of the GNU Free Documentation License.
この記事は、ウィキペディアのWASAPI (改訂履歴)の記事を複製、再配布したものにあたり、GNU Free Documentation Licenseというライセンスの下で提供されています。 Weblio辞書に掲載されているウィキペディアの記事も、全てGNU Free Documentation Licenseの元に提供されております。

©2025 GRAS Group, Inc.RSS