RenderSharedTimerDriven
Diese Beispielanwendung verwendet die Core Audio-APIs, um Audiodaten auf einem vom Benutzer angegebenen Ausgabegerät zu rendern. In diesem Beispiel wird die timergesteuerte Pufferung für einen Renderingclient im freigegebenen Modus veranschaulicht. Bei einem Stream im freigegebenen Modus teilt der Client den Endpunktpuffer mit der Audio-Engine.
Dieses Thema enthält folgende Abschnitte:
- Beschreibung
- Anforderungen
- Herunterladen des Beispiels
- Erstellen des Beispiels
- Ausführen des Beispiels
- Zugehörige Themen
BESCHREIBUNG
In diesem Beispiel werden die folgenden Features veranschaulicht.
- MMDevice-API für Die Aufzählung und Auswahl von Multimediageräten.
- WASAPI für Streamverwaltungsvorgänge.
Anforderungen
Produkt | Version |
---|---|
Windows SDK | Windows 7 |
Visual Studio | 2008 |
Herunterladen des Beispiels
Dieses Beispiel ist an den folgenden Speicherorten verfügbar.
Standort | Pfad/URL |
---|---|
Windows SDK | \Programme\Microsoft SDKs\Windows\v7.0\Samples\Multimedia\Audio\RenderSharedTimerDriven\... |
Erstellen des Beispiels
Führen Sie zum Erstellen des RenderSharedTimerDriven-Beispiels die folgenden Schritte aus:
- Öffnen Sie die CMD-Shell für das Windows SDK, und wechseln Sie zum Beispielverzeichnis RenderSharedTimerDriven.
- Führen Sie den Befehl
start WASAPIRenderSharedTimerDriven.sln
im Verzeichnis RenderSharedTimerDriven aus, um das PROJEKT WASAPIRenderSharedTimerDriven im Visual Studio-Fenster zu öffnen. - Wählen Sie im Fenster die Projektmappenkonfiguration Debuggen oder Freigeben aus, wählen Sie in der Menüleiste das Menü Erstellen aus, und wählen Sie die Option Erstellen aus. Wenn Sie Visual Studio nicht über die CMD-Shell für das SDK öffnen, hat Visual Studio keinen Zugriff auf die SDK-Buildumgebung. In diesem Fall wird das Beispiel nur erstellt, wenn Sie die Umgebungsvariable MSSdk explizit festlegen, die in der Projektdatei WASAPIRenderSharedTimerDriven.vcproj verwendet wird.
Ausführen des Beispiels
Wenn Sie die Demoanwendung erfolgreich erstellen, wird eine ausführbare Datei WASAPIRenderSharedTimerDriven.exe generiert. Geben WASAPIRenderSharedTimerDriven
Sie zum Ausführen in ein Befehlsfenster gefolgt von erforderlichen oder optionalen Argumenten ein. Im folgenden Beispiel wird gezeigt, wie das Beispiel ausgeführt wird, indem Sie die Wiedergabedauer auf dem Standard-Multimediagerät angeben.
WASAPIRenderSharedTimerDriven.exe -d 20 -multimedia
Die folgende Tabelle zeigt die Argumente.
Argument | BESCHREIBUNG |
---|---|
-? | Zeigt Hilfe an. |
-H | Zeigt Hilfe an. |
-f | Sinuswellenfrequenz in Hz. |
-l | Audiorenderlatenz in Millisekunden. |
-d | Sinuswellendauer in Sekunden. |
-M | Deaktiviert die Verwendung von MMCSS. |
-Konsole | Verwenden Sie das Standardkonsolengerät. |
-Kommunikation | Verwenden Sie das Standardkommunikationsgerät. |
-Multimedia | Verwenden Sie das Standard-Multimediagerät. |
-Endpunkt | Verwenden Sie den im Switchwert angegebenen Endpunktbezeichner. |
Wenn die Anwendung ohne Argumente ausgeführt wird, listet sie die verfügbaren Geräte auf und fordert den Benutzer auf, ein Gerät für die Renderingsitzung auszuwählen. Nachdem der Benutzer ein Gerät angegeben hat, rendert die Anwendung eine Sinuswelle mit 440 Hz für 10 Sekunden. Diese Werte können geändert werden, indem Sie die Switchwerte -f und -d angeben.
RenderSharedTimerDriven veranschaulicht timergesteuerte Pufferung. In diesem Modus muss der Client für einen bestimmten Zeitraum warten (die Hälfte der Latenz, die durch den Switchwert -d angegeben wird, in Millisekunden). Wenn der Client zur Hälfte des Verarbeitungszeitraums aufwacht, wird der nächste Satz von Beispielen aus der Engine abgerufen. Vor jedem Verarbeitungsdurchlauf in der Pufferschleife muss der Client die Menge der zu rendernden Daten ermitteln, damit die Daten den Puffer nicht überlaufen.
Audiodaten, die auf dem angegebenen Gerät wiedergegeben werden sollen, können verarbeitet werden, indem ereignisgesteuerte Pufferung aktiviert wird. Dieser Modus wird im Beispiel RenderSharedEventDriven veranschaulicht.
Weitere Informationen zum Rendern eines Datenstroms finden Sie unter Rendern eines Streams.
Zugehörige Themen