Jadual Kandungan
Gunakan JavaScript untuk memecah aliran gumpalan yang direkodkan dan menghasilkan fail wav 5 saat
Rumah hujung hadapan web tutorial js Bagaimana untuk memisahkan aliran gumpalan yang direkodkan ke dalam beberapa fail wav 5 saat menggunakan JavaScript dan pastikan ia bermain secara normal?

Bagaimana untuk memisahkan aliran gumpalan yang direkodkan ke dalam beberapa fail wav 5 saat menggunakan JavaScript dan pastikan ia bermain secara normal?

Apr 04, 2025 pm 02:39 PM
nodejs pelayar ai

Gunakan JavaScript untuk memecah aliran gumpalan yang direkodkan dan menghasilkan fail wav 5 saat

Apabila merakam menggunakan React-Mic, saya menghadapi keperluan: Saya perlu memecah aliran BLOB yang direkodkan ke dalam fail WAV 5 saat. Walau bagaimanapun, selepas mencuba, saya mendapati bahawa hanya fail WAV berpecah pertama yang boleh dimainkan secara normal, dan seluruh fail diminta untuk rosak.

Apabila melaksanakan keperluan ini di bahagian depan, kami menghadapi dua cabaran: satu adalah cara untuk segmen aliran gumpalan yang betul, dan yang lain adalah bagaimana untuk memastikan setiap klip bersegmen dapat menghasilkan dan memainkan fail WAV dengan betul. Berikut adalah contoh kod dan penyelesaian:

 Import React, {useref, useState} dari 'React'
import {reactmic, reactmicstopevent} dari 'react-mic'
import {butang} dari 'antd'

const audiorecorder = () => {
    const [rekod, setRecord] = useState (palsu)
    const resref = useref <blob> ([])
    const audiochunksref = useref <blob> ([])
    const intervalRef = useref <nodejs.timer null> (null)
    const firstBlob = useref <blob undefined> (undefined)

    const createewavheader = (numChannels, samplerate, bytelength) => {
        header const = ArrayBuffer baru (44);
        Const View = DataView baru (header);

        view.setuint32 (0, 1380533830, palsu); // "riff"
        view.setuint32 (4, bytelength 36, false);
        view.setuint32 (8, 1718449184, palsu); // "Gelombang"
        view.setuint32 (12, 1684108385, palsu); // "fmt"
        view.setuint32 (16, 16, benar); // 16 untuk PCM
        view.setuint16 (20, 1, benar); // pcm
        view.setuint16 (22, numchannels, true);
        view.setuint32 (24, samplerate, true);
        view.setuint32 (28, samplerate * numchannels * 2, true);
        view.setuint16 (32, numchannels * 2, true);
        view.setuint16 (34, 16, benar); // 16 bit
        view.setuint32 (36, 1684108385, palsu); // "Data"
        view.setuint32 (40, bytelength, true);

        header kembali;
    };

    const saveFile = async () => {
        const chunkslist = resref.current;
        untuk (biarkan i = 0; i <chunkslist.length i const audiobuffer="new" uint8array chunkslist .arraybuffer header audiobuffer.length menganggap mono dan wavblob="new" blob url="url.createObjectUrl" a="document.createElement" a.href="url;" a.download="`rakaman" .wav a.click url.revokeobjecturl startrecording="()"> {
        setRecord (benar)
        audiochunksref.current = [] // Kosongkan data rakaman sebelumnya // berpecah intervalref.current rakaman = setInterval (() => {
            const curblob = gumpalan baru (audiochunksref.current, {type: 'audio/wav'})
            const startIndex = audiochunksref.current.indexof (firstblob.current as gumpalan)
            const blob = curblob.slice (startIndex === -1? 0: startIndex, -1, 'audio/wav')
            FirstBlob.Current = audiochunksref.current.at (-1)
            // Proses Console.log data rakaman semasa ('Segmen data rakaman semasa:', gumpalan)
            resref.current.push (gumpalan)
        }, 5000)
    }

    const stopRecording = () => {
        setRecord (palsu)
        intervalref.current && clearInterval (intervalref.current) // pemasa yang jelas}

    const ondata = (RECOREDBLOB: Blob) => {
        audiochunksref.current.push (recordedBlob) // simpan data rakaman}

    const onStop = (recordedBlob: reactMicStOpEvent) => {
        Console.log ('Dirakam selesai:', RECOREDBLOB)
    }

    const saveFile1 = () => {
        const chunkslist = resref.current
        chunkslist.map (async (v, i) => {
            const filename = 'aaa.wav'
            Const File: File = File Baru ([V], FileName, {Type: 'Audio/Wav'})
            const fileSize = file.size

            Console.log ('FileSize', memfailkan)
            // Buat pautan muat turun const url = url.createObjectUrl (fail)
            const a = document.createeelement ('a')
            A.Href = url
            a.download = `Rakaman $ {i} .wav` // Tetapkan nama fail muat turun a.click () // Trigger Download // Release URL Sumber Url.RevokeObjectUrl (URL)
        })
    }

    const saveFinalResult = () => {
        const filename = 'aaa.wav'
        Const File: File = File Baru (AudioChunksRef.Current, FileName, {Type: 'Audio/Wav'})
        const fileSize = file.size

        Console.log ('FileSize', memfailkan)
        // Buat pautan muat turun const url = url.createObjectUrl (fail)
        const a = document.createeelement ('a')
        A.Href = url
        a.download = `rakaman $ {date.now ()}. wav` // tetapkan nama fail muat turun a.click () // Trigger Download // Release URL Sumber URL.RevokeObjectUrl (URL)
    }

    Kembali (
        <dana>
            <reactmic record="{record}" onstop="{onStop}" ondata="{ondata}" mimetype="audio /wav"></reactmic>
            <butang onclick="{startrecording}"> Mula rakaman </butang>
            <butang onclick="{stopRecording}"> berhenti rakaman </butang>
            <butang onclick="{SaveFile}"> muat turun </butang>
            <button onclick="{SaveFinalResult}"> Muat turun Final </button>
        
    )
}

Eksport audiorecorder lalai</dana></chunkslist.length></blob></nodejs.timer></blob></blob>
Salin selepas log masuk

Semasa proses cuba memecah aliran gumpalan dan menghasilkan fail WAV, didapati secara manual menambah maklumat header WAV tidak akan menyelesaikan masalah. Sebabnya ialah struktur fail WAV agak ketat. Jika maklumat header tidak ditambah dengan betul selepas segmentasi, fail mungkin rosak.

Satu cadangan untuk menyelesaikan masalah ini ialah menggunakan versi WASM FFMPEG, perpustakaan audio dan pemprosesan video yang boleh dijalankan dalam penyemak imbas. Dengan itu, anda boleh dengan mudah segmen audio dan menghasilkan format fail WAV yang betul. Anda boleh mempertimbangkan menggunakan projek ffmpeg.wasm untuk melaksanakan fungsi ini.

Atas ialah kandungan terperinci Bagaimana untuk memisahkan aliran gumpalan yang direkodkan ke dalam beberapa fail wav 5 saat menggunakan JavaScript dan pastikan ia bermain secara normal?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Muat turun laman web rasmi aplikasi Exchange Ouyi untuk telefon bimbit Apple Muat turun laman web rasmi aplikasi Exchange Ouyi untuk telefon bimbit Apple Apr 28, 2025 pm 06:57 PM

Aplikasi Exchange OUYI menyokong memuat turun telefon bimbit Apple, lawati laman web rasmi, klik pilihan "Apple Mobile", dapatkan dan pasang di App Store, daftar atau log masuk untuk menjalankan perdagangan cryptocurrency.

Bagaimana cara menggunakan Perpustakaan Chrono di C? Bagaimana cara menggunakan Perpustakaan Chrono di C? Apr 28, 2025 pm 10:18 PM

Menggunakan perpustakaan Chrono di C membolehkan anda mengawal selang masa dan masa dengan lebih tepat. Mari kita meneroka pesona perpustakaan ini. Perpustakaan Chrono C adalah sebahagian daripada Perpustakaan Standard, yang menyediakan cara moden untuk menangani selang waktu dan masa. Bagi pengaturcara yang telah menderita dari masa. H dan CTime, Chrono tidak diragukan lagi. Ia bukan sahaja meningkatkan kebolehbacaan dan mengekalkan kod, tetapi juga memberikan ketepatan dan fleksibiliti yang lebih tinggi. Mari kita mulakan dengan asas -asas. Perpustakaan Chrono terutamanya termasuk komponen utama berikut: STD :: Chrono :: System_Clock: Mewakili jam sistem, yang digunakan untuk mendapatkan masa semasa. Std :: Chron

Platform perdagangan mata wang teratas yang manakah di dunia adalah versi terbaru dari Platform Perdagangan Top Top Top Platform perdagangan mata wang teratas yang manakah di dunia adalah versi terbaru dari Platform Perdagangan Top Top Top Apr 28, 2025 pm 08:09 PM

Sepuluh platform perdagangan cryptocurrency teratas di dunia termasuk Binance, OKX, Gate.io, Coinbase, Kraken, Huobi Global, Bitfinex, Bittrex, Kucoin dan Poloniex, yang semuanya menyediakan pelbagai kaedah perdagangan dan langkah -langkah keselamatan yang kuat.

Bagaimana untuk mengukur prestasi benang di C? Bagaimana untuk mengukur prestasi benang di C? Apr 28, 2025 pm 10:21 PM

Mengukur prestasi thread di C boleh menggunakan alat masa, alat analisis prestasi, dan pemasa tersuai di perpustakaan standard. 1. Gunakan perpustakaan untuk mengukur masa pelaksanaan. 2. Gunakan GPROF untuk analisis prestasi. Langkah -langkah termasuk menambah pilihan -pg semasa penyusunan, menjalankan program untuk menghasilkan fail gmon.out, dan menghasilkan laporan prestasi. 3. Gunakan modul Callgrind Valgrind untuk melakukan analisis yang lebih terperinci. Langkah -langkah termasuk menjalankan program untuk menghasilkan fail callgrind.out dan melihat hasil menggunakan kcachegrind. 4. Pemasa tersuai secara fleksibel dapat mengukur masa pelaksanaan segmen kod tertentu. Kaedah ini membantu memahami sepenuhnya prestasi benang dan mengoptimumkan kod.

Apakah sepuluh aplikasi perdagangan mata wang maya teratas? Kedudukan pertukaran mata wang digital terkini Apakah sepuluh aplikasi perdagangan mata wang maya teratas? Kedudukan pertukaran mata wang digital terkini Apr 28, 2025 pm 08:03 PM

Sepuluh pertukaran mata wang digital teratas seperti Binance, OKX, Gate.io telah meningkatkan sistem mereka, urus niaga yang pelbagai dan langkah -langkah keselamatan yang ketat.

Apakah platform perdagangan mata wang teratas? 10 pertukaran mata wang maya terkini Apakah platform perdagangan mata wang teratas? 10 pertukaran mata wang maya terkini Apr 28, 2025 pm 08:06 PM

Saat ini disenaraikan di antara sepuluh mata wang mata wang maya yang teratas: 1. Binance, 2 Okx, 3. Gate.io, 4. Perpustakaan duit syiling, 5. Siren, 6. Huobi Global Station, 7. Bybit, 8. Kucoin, 9.

Bagaimana cara menggunakan aliran rentetan di C? Bagaimana cara menggunakan aliran rentetan di C? Apr 28, 2025 pm 09:12 PM

Langkah -langkah utama dan langkah berjaga -jaga untuk menggunakan aliran rentetan dalam C adalah seperti berikut: 1. Buat aliran rentetan output dan tukar data, seperti menukar integer ke dalam rentetan. 2. Memohon untuk berseri struktur data kompleks, seperti menukar vektor ke dalam rentetan. 3. Beri perhatian kepada isu -isu prestasi dan mengelakkan penggunaan aliran rentetan yang kerap apabila memproses sejumlah besar data. Anda boleh mempertimbangkan menggunakan kaedah tambahan std :: string. 4. Perhatikan pengurusan ingatan dan elakkan penciptaan dan pemusnahan objek stream rentetan yang kerap. Anda boleh menggunakan semula atau menggunakan std :: stringstream.

Berapa bernilai bitcoin Berapa bernilai bitcoin Apr 28, 2025 pm 07:42 PM

Harga Bitcoin berkisar antara $ 20,000 hingga $ 30,000. 1. Harga Bitcoin telah berubah secara dramatik sejak tahun 2009, mencapai hampir $ 20,000 pada tahun 2017 dan hampir $ 60,000 pada tahun 2021. Harga dipengaruhi oleh faktor -faktor seperti permintaan pasaran, bekalan, dan persekitaran makroekonomi. 3. Dapatkan harga masa nyata melalui pertukaran, aplikasi mudah alih dan laman web. 4. Harga Bitcoin sangat tidak menentu, didorong oleh sentimen pasaran dan faktor luaran. 5. Ia mempunyai hubungan tertentu dengan pasaran kewangan tradisional dan dipengaruhi oleh pasaran saham global, kekuatan dolar AS, dan sebagainya. 6. Trend jangka panjang adalah yakin, tetapi risiko perlu dinilai dengan berhati-hati.

See all articles