Как записать в файл .wav, используя сгенерированный массив wave [complex]? - PullRequest
0 голосов
/ 19 февраля 2020

Я хотел бы знать, как записать в файл .wav, я написал следующий код, который предположительно записывает данные в файл. Но когда я пытаюсь воспроизвести звуковой файл, он говорит, что файл поврежден / пуст.

 try
            {
                SaveFileDialog save = new SaveFileDialog();
                save.Filter = "Wave File (*.wav)|*.wav;";
                if (save.ShowDialog() != System.Windows.Forms.DialogResult.OK)
                    return;

                using (FileStream FS = new FileStream(save.FileName, FileMode.Open, FileAccess.Write))
                {
                    BinaryWriter wr = new BinaryWriter(FS);

                    int subchunk1Size = 16;
                    short audioFormat = 1;
                    short bitsPerSample = 64;
                    short numChannels = 2;
                    int sampleRate = Convert.ToInt32(samplingRateBox.Text);
                    int byteRate = sampleRate * numChannels * (bitsPerSample / 8);
                    short blockAlign = (short)(numChannels * (bitsPerSample / 8));
                    int numSamples = Convert.ToInt32(numberOfsamplesBox.Text);

                    int subChunk2Size = numSamples * numChannels * (bitsPerSample / 8);

                    int chunkSize = 4 + (8 + subchunk1Size) + (8 + subChunk2Size);

                    wr.Write(getBytes("RIFF"));
                    wr.Write(chunkSize);
                    wr.Write(getBytes("WAVE"));
                    wr.Write(getBytes("fmt"));
                    wr.Write((byte)32);
                    wr.Write(subchunk1Size);
                    wr.Write(audioFormat);
                    wr.Write(numChannels);
                    wr.Write(sampleRate);
                    wr.Write(byteRate);
                    wr.Write(blockAlign);
                    wr.Write(bitsPerSample);
                    wr.Write(getBytes("data"));
                    wr.Write(subChunk2Size);

                    double[] primArray = new double[samples.Length];
                    byte[] byteArray = new byte[samples.Length * 8];

                    for (int i = 0; i < samples.Length; i++)
                    {
                        primArray[i] = Convert.ToDouble(samples[i].Real);
                    }

                    byteArray = doubleToBytes(primArray);

                    for (int i = 0; i < samples.Length; i++)
                    {
                        wr.Write(byteArray[i]);
                    }


                    for (int i = 0; i < samples.Length; i++)
                    {
                        primArray[i] = Convert.ToDouble(samples[i].Imaginary);
                    }

                    byteArray = doubleToBytes(primArray);

                    for (int i = 0; i < samples.Length; i++)
                    {
                        wr.Write(byteArray[i]);
                    }

                    wr.Close();
                    wr.Dispose();
                }
            }
            catch (Exception e)
            {
                MessageBox.Show(e.Message);
            }

Как вы можете видеть, я пытался конвертировать из Complex в double, плюс заголовок. Частота дискретизации и количество выборок все взяты из текстовых полей. Кроме того, я предполагаю, что битовая глубина равна двойной.

1 Ответ

0 голосов
/ 20 февраля 2020

Я также пытался использовать этот метод, однако длина аудиофайла равна 0.

При этом использовалась библиотека NAudio.

NAudio.Wave.WaveFileWriter waveWriter = null;
            WaveIn wi = new WaveIn();

            double[] primArray = new double[samples.Length];

            for (int i = 0; i < samples.Length; i++)
            {
                primArray[i] = Convert.ToDouble(samples[i].Real);
            }

            SaveFileDialog save = new SaveFileDialog();
            save.Filter = "Wave File (*.wav)|*.wav;";
            if (save.ShowDialog() != System.Windows.Forms.DialogResult.OK)
                return;

            wi = new NAudio.Wave.WaveIn();
            wi.WaveFormat = new WaveFormat(samplingRate,1);

            waveWriter = new WaveFileWriter(save.FileName, wi.WaveFormat);

            byte[] byteArray = new byte[samples.Length*8];

            byteArray = doubleToBytes(primArray);

            waveWriter.Write(byteArray, 0, byteArray.Length);
...