Inhaltsverzeichnis
Verwenden Sie JavaScript, um den aufgezeichneten Blob-Stream zu teilen und eine 5-Sekunden-WAV-Datei zu generieren
Heim Web-Frontend js-Tutorial Wie teilen Sie einen aufgezeichneten Blob -Stream mit JavaScript in mehrere 5 -Sekunden -WAV -Dateien auf und stellen Sie sicher, dass er normal abgespielt wird?

Wie teilen Sie einen aufgezeichneten Blob -Stream mit JavaScript in mehrere 5 -Sekunden -WAV -Dateien auf und stellen Sie sicher, dass er normal abgespielt wird?

Apr 04, 2025 pm 02:39 PM
nodejs 浏览器 ai

Verwenden Sie JavaScript, um den aufgezeichneten Blob-Stream zu teilen und eine 5-Sekunden-WAV-Datei zu generieren

Bei der Aufzeichnung mit React-MIC habe ich auf eine Anforderung gestoßen: Ich muss den aufgezeichneten Blob-Stream in mehrere 5-Sekunden-WAV-Dateien aufteilen. Nach dem Versuch stellte ich jedoch fest, dass nur die erste geteilte WAV -Datei normal abgespielt werden kann und der Rest der Dateien aufgefordert wird, beschädigt zu werden.

Bei der Implementierung dieser Anforderung im Front-End stehen wir hauptsächlich vor zwei Herausforderungen: Eine ist, wie man den Blob-Stream korrekt segmentiert, und der andere ist, wie jeder segmentierte Clip WAV-Dateien korrekt generieren und abspielen kann. Im Folgenden finden Sie Code -Beispiele und -Lösungen:

 React, {Useref, Usestate} aus 'React' '
Import {reactmic, reactmicStopevent} aus 'React-mic' '
{button} aus 'AntD' importieren

const audioreCorder = () => {
    const [record, setRecord] = usustate (false)
    const resref = useref <blob> ([])
    const audiochunksref = useref <blob> ([])
    const intervalref = useref <nodejs.timer null> (NULL)
    const firstblob = useref <blob undefiniert> (undefiniert)

    const createwavHeader = (numchannels, sampled, bytelength) => {
        const header = new ArrayBuffer (44);
        const view = new Dataview (Header);

        View.SetUint32 (0, 1380533830, False); // "Riff"
        View.SetUint32 (4, Bytelength 36, False);
        View.SetUint32 (8, 1718449184, Falsch); // "WELLE"
        view.setuint32 (12, 1684108385, falsch); // "fmt"
        View.SetUint32 (16, 16, wahr); // 16 für PCM
        view.setUint16 (20, 1, true); // PCM
        view.setUint16 (22, numchannels, true);
        View.SetUint32 (24, Probenplan, wahr);
        View.SetUint32 (28, Sampled * Numchannels * 2, True);
        view.setUint16 (32, numchannels * 2, true);
        view.setUint16 (34, 16, true); // 16 Bit
        View.SetUint32 (36, 1684108385, False); // "Daten"
        View.SetUint32 (40, Bytelength, True);

        Return Header;
    };

    const SaveFile = async () => {
        const chunkList = Resref.Current;
        für (lass i = 0; i <chunkslist.length i const audiobuffer="new" uint8array auf chunklist .arraybuffer header="createwavHeader" audiobuffer.length angenommen mono und wavblob="neuer" blob url="url.createObjecturl" a="document.createelement" a.reif="url;" a.download="`Aufzeichnung" .wav a.click url.revokeobjecturl startercording="()"> {
        setRecord (true)
        audiochunksref.current = [] // Die vorherigen Aufzeichnungsdaten löschen // Teilen Sie das Aufzeichnungsintervalref.current = setInterval (() => {
            const curblob = neuer Blob (AudiochunksRef.Current, {Typ: 'Audio/Wav'})
            const startIndex = audiochunksref.current.indexof (firstblob.current als Blob)
            const blob = curblob.slice (startIndex === -1? 0: startIndex, -1, 'audio/wav')
            firstblob.current = audiochunksref.current.at (-1)
            // Verarbeiten Sie die aktuelle Aufzeichnungsdatenkonsole.log ('Segment der aktuellen Aufzeichnungsdaten:', Blob)
            resref.current.push (Blob)
        }, 5000)
    }

    const stoprecording = () => {
        setRecord (falsch)
        Intervalref.Current && ClearInterval (Intervalref.Current) // Timer Clear}}

    const ondata = (recordedBlob: blob) => {
        audiochunksref.current.push (recordblob) // Aufzeichnungsdaten} speichern}

    const onStop = (recordedBlob: reactmicStopEvent) => {
        console.log ('aufgezeichnet abgeschlossen:', Recordblob)
    }

    const SaveFile1 = () => {
        Const ChunksList = Resref.Current
        ChunksList.map (Async (v, i) => {
            const Dateiname = 'aaa.wav' '
            const Datei: Datei = neue Datei ([v], Dateiname, {type: 'audio/wav'})
            const FileSize = Datei.Size

            console.log ('fileside', filesize)
            // Erstellen Sie einen Download -Link const url = url.createObjecturl (Datei)
            const a = document.createelement ('a')
            a.reif = url
            A.Download = `Aufzeichnung $ {i} .wav` // Legen Sie den Namen der Download -Datei ein.
        })
    }

    const SaveFinalResult = () => {
        const Dateiname = 'aaa.wav' '
        const -Datei: Datei = neue Datei (AudiochunksRef.Current, Dateiname, {Typ: 'Audio/Wav'})
        const FileSize = Datei.Size

        console.log ('fileside', filesize)
        // Erstellen Sie einen Download -Link const url = url.createObjecturl (Datei)
        const a = document.createelement ('a')
        a.reif = url
        A.Download = `Aufzeichnung $ {date.now ()}. WAV` // Setzen Sie den Namen der Download -Datei A.click () // Trigger Download // URL -Ressourcen -URL.revokeObjecturl (URL) veröffentlichen.
    }

    Zurückkehren (
        <div>
            <reactmic record="{record}" onstop="{onStop}" ondata="{ondata}" mimetype="audio /wav"></reactmic>
            <button onclick="{startercording}"> starten Sie die Aufzeichnung </button>
            <button onclick="{stoprecording}"> Aufnahme von Aufnahme </button>
            <button onclick="{SaveFile}"> Download </button>
            <button onclick="{SaveFinalResult}"> Finale </button> herunterladen
        </div>
    )
}

Standard -Audiorecorder exportieren</chunkslist.length></blob></nodejs.timer></blob></blob>
Nach dem Login kopieren

Während des Versuchs, den Blob -Stream zu teilen und die WAV -Datei zu generieren, wurde festgestellt, dass das manuelle Hinzufügen der WAV -Header -Informationen das Problem nicht lösen würde. Der Grund dafür ist, dass die Struktur der WAV -Datei relativ streng ist. Wenn die Header -Informationen nach der Segmentierung nicht korrekt hinzugefügt werden, kann die Datei beschädigt werden.

Ein Vorschlag zur Lösung dieses Problems ist die Verwendung der WASM -Version von FFMPEG, einer Bibliothek mit Audio- und Videoverarbeitung, die im Browser ausgeführt werden kann. Damit können Sie das Audio problemlos segmentieren und das richtige WAV -Dateiformat erstellen. Sie können in Betracht ziehen, das Projekt FFMPEG. GWASM zu verwenden, um diese Funktion zu implementieren.

Das obige ist der detaillierte Inhalt vonWie teilen Sie einen aufgezeichneten Blob -Stream mit JavaScript in mehrere 5 -Sekunden -WAV -Dateien auf und stellen Sie sicher, dass er normal abgespielt wird?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Bitcoin -Preis heute Bitcoin -Preis heute Apr 28, 2025 pm 07:39 PM

Die heutigen Preisschwankungen von Bitcoin werden von vielen Faktoren wie Makroökonomie, Richtlinien und Marktstimmungen beeinflusst. Anleger müssen auf die technische und grundlegende Analyse achten, um fundierte Entscheidungen zu treffen.

Welche der zehn besten Währungsplattformen der Welt sind die neueste Version der zehn besten Währungshandelsplattformen Welche der zehn besten Währungsplattformen der Welt sind die neueste Version der zehn besten Währungshandelsplattformen Apr 28, 2025 pm 08:09 PM

Zu den zehn Top -Kryptowährungs -Handelsplattformen der Welt gehören Binance, OKX, Gate.io, Coinbase, Kraken, Huobi Global, Bitfinex, Bittrex, Kucoin und Poloniex, die alle eine Vielzahl von Handelsmethoden und leistungsstarken Sicherheitsmaßnahmen bieten.

Was sind die zehn Top -Apps für virtuelle Währungshandel? Die neuesten Ranglisten für digitale Währung Exchange Was sind die zehn Top -Apps für virtuelle Währungshandel? Die neuesten Ranglisten für digitale Währung Exchange Apr 28, 2025 pm 08:03 PM

Die zehn Top -Börsen für digitale Währungen wie Binance, OKX, Gate.io haben ihre Systeme, effiziente diversifizierte Transaktionen und strenge Sicherheitsmaßnahmen verbessert.

Wie viel ist Bitcoin wert? Wie viel ist Bitcoin wert? Apr 28, 2025 pm 07:42 PM

Der Preis von Bitcoin liegt zwischen 20.000 und 30.000 US -Dollar. 1. Bitcoin's Preis hat seit 2009 dramatisch geschwankt und im Jahr 2017 fast 20.000 US -Dollar und im Jahr 2021 in Höhe von fast 60.000 USD erreicht. 2. Die Preise werden von Faktoren wie Marktnachfrage, Angebot und makroökonomischem Umfeld beeinflusst. 3. Erhalten Sie Echtzeitpreise über Börsen, mobile Apps und Websites. V. 5. Es hat eine gewisse Beziehung zu den traditionellen Finanzmärkten und ist von den globalen Aktienmärkten, der Stärke des US-Dollars usw. betroffen. 6. Der langfristige Trend ist optimistisch, aber Risiken müssen mit Vorsicht bewertet werden.

Decryption Gate.io Strategy Upgrade: Wie definieren Sie das Krypto -Asset -Management in Memebox 2.0? Decryption Gate.io Strategy Upgrade: Wie definieren Sie das Krypto -Asset -Management in Memebox 2.0? Apr 28, 2025 pm 03:33 PM

Memebox 2.0 definiert das Krypto -Asset -Management durch innovative Architektur- und Leistungsbrachdurchbrüche. 1) Es löst drei Hauptschmerzpunkte: Vermögenssetsilos, Einkommensverfall und Paradox der Sicherheit und Bequemlichkeit. 2) Durch intelligente Asset-Hubs werden dynamische Risikomanagement- und Renditeverstärkungsmotoren die Übertragungsgeschwindigkeit, die durchschnittliche Ertragsrate und die Reaktionsgeschwindigkeit für Sicherheitsvorfälle verbessert. 3) Nutzern die Integration von Asset Visualisierung, Richtlinienautomatisierung und Governance -Integration zur Verfügung stellen und die Rekonstruktion des Benutzerwerts realisieren. 4) Durch ökologische Zusammenarbeit und Compliance -Innovation wurde die Gesamtwirksamkeit der Plattform verbessert. 5) In Zukunft werden intelligente Vertragsversicherungspools, die Prognosemarktintegration und die KI-gesteuerte Vermögenszuweisung gestartet, um weiterhin die Entwicklung der Branche zu leiten.

Empfohlene zuverlässige Handelsplattformen für digitale Währung. Top 10 Digitalwährungsbörsen in der Welt. 2025 Empfohlene zuverlässige Handelsplattformen für digitale Währung. Top 10 Digitalwährungsbörsen in der Welt. 2025 Apr 28, 2025 pm 04:30 PM

Empfohlene zuverlässige Handelsplattformen für digitale Währung: 1. OKX, 2. Binance, 3. Coinbase, 4. Kraken, 5. Huobi, 6. Kucoin, 7. Bitfinex, 8. Gemini, 9. Bitstamp, 10. Poloniex, diese Plattformen sind für ihre Sicherheit, Benutzererfahrung und verschiedene Funziktionen, geeignet für Benutzer, geeignet für Benutzer, geeignet für Benutzer, geeignet für Benutzer, geeignet für Ufers, für Benutzer, geeignet für Ufersniveaus, in unterschiedlichen Digitalverkehrsniveaus, in unterschiedlichen Niveaus, bei Digitalwährung, für Nutzer, für Benutzer, in unterschiedliche Ebenen von Digitalwährung, für Benutzer, die für Nutzer, für Benutzer, in unterschiedlichen Digitalverkehrsniveaus, auf Digitalwährung, auf Digitalwährung, auf Digitalwährung, bei Digitalwährung, auf Digitalwährung bekannt

Laden Sie die offizielle Website der Ouyi Exchange App für Apple Mobile herunter Laden Sie die offizielle Website der Ouyi Exchange App für Apple Mobile herunter Apr 28, 2025 pm 06:57 PM

Die Ouyi Exchange -App unterstützt das Herunterladen von Apple Mobile Phones, besuchen Sie die offizielle Website, klicken Sie auf die Option "Apple Mobile", erhalten und installieren sie im App Store, registrieren oder melden Sie sich an, um Kryptowährungshandel durchzuführen.

Welche der zehn besten Währungshandelsplattformen der Welt gehören 2025 zu den zehn Top -Währungshandelsplattformen Welche der zehn besten Währungshandelsplattformen der Welt gehören 2025 zu den zehn Top -Währungshandelsplattformen Apr 28, 2025 pm 08:12 PM

Zu den zehn Top -Kryptowährungsbörsen der Welt im Jahr 2025 gehören Binance, OKX, Gate.io, Coinbase, Kraken, Huobi, Bitfinex, Kucoin, Bittrex und Poloniex, die alle für ihr hohes Handelsvolumen und ihre Sicherheit bekannt sind.

See all articles