音频demo:将左右声道PCM数据合并

1、README

a. 编译
bash 复制代码
$ make 	# or `make CC=your-corosscompile-gcc`
b. 使用

合并两个声道成为双声道,例如:

bash 复制代码
$ ./pcm_channel_merge ./audio/test_22050_16_1-l.pcm ./audio/test_22050_16_1-r.pcm out_44100_16_2.pcm
$ ./pcm_channel_merge ./audio/test_44100_16_1-l.pcm ./audio/test_44100_16_1-r.pcm out_44100_16_2.pcm
c. demo目录架构
bash 复制代码
.
├── audio
│   ├── test_22050_16_1-l.pcm
│   ├── test_22050_16_1-r.pcm
│   ├── test_22050_16_2.pcm
│   ├── test_44100_16_1-l.pcm
│   ├── test_44100_16_1-r.pcm
│   └── test_44100_16_2.pcm
├── docs
│   └── PCM音频数据 - 简书.mhtml
├── main.c
├── Makefile
└── README.md

2、主要代码片段

main.c
c 复制代码
#include <stdio.h>
#include <stdlib.h>

int pcm_s16le_merge(const char* in_lfile, const char* in_rfile, const char* file);

int main(int argc, char *argv[])
{
	if (argc != 4)
	{	
		printf("Usage: %s in-channel-l.pcm in-channel-r.pcm out-channels-merge.pcm\n", argv[0]);
		printf("such as:\n"
			   "\t %s ./audio/test_22050_16_1-l.pcm ./audio/test_22050_16_1-r.pcm out_22050_16_2.pcm\n"
			   "\t %s ./audio/test_44100_16_1-l.pcm ./audio/test_44100_16_1-r.pcm out_44100_16_2.pcm\n",
			   argv[0], argv[0]);
		return -1;
	}

	/* 注意:分离左右声道的前提是输入的PCM文件(数据)是双声道 */
	pcm_s16le_merge(argv[1], argv[2], argv[3]);

	return 0;
}

int pcm_s16le_merge(const char* in_lfile, const char* in_rfile, const char* out_file)
{
	FILE *fp1 = fopen(in_lfile, "rb+");
	if (fp1 == NULL) {
		printf("open %s failed\n", in_lfile);
		return -1;
	}

	FILE *fp2 = fopen(in_rfile, "rb+");
	if (fp2 == NULL) {
		printf("open %s failed\n", in_rfile);
		return -1;
	}

	FILE *fp = fopen(out_file, "wb+");
	if (fp == NULL) {
		printf("open %s failed\n", out_file);
		return -1;
	}

	char * sample = (char *)malloc(4);
	while(1) {
		int readbytes = 0;
		// L
		readbytes += fread(sample, 1, 2, fp1);
		// R
		readbytes += fread(sample + 2, 1, 2, fp2);
		if(readbytes == 0)
		{
			// 没有数据就不要再写入到输出文件中了
			break;
		}	

		fwrite(sample, 1, 4, fp);
	}
	free(sample);

	fclose(fp);
	fclose(fp1);
	fclose(fp2);
	return 0;
}

3、demo下载地址(任选一个)

相关推荐
REDcker4 天前
WebCodecs VideoDecoder 的 hardwareAcceleration 使用
前端·音视频·实时音视频·直播·webcodecs·videodecoder
gihigo19984 天前
基于TCP协议实现视频采集与通信
网络协议·tcp/ip·音视频
山河君4 天前
四麦克风声源定位实战:基于 GCC-PHAT + 最小二乘法实现 DOA
算法·音视频·语音识别·信号处理·最小二乘法·tdoa
音视频牛哥4 天前
Android平台RTMP/RTSP超低延迟直播播放器开发详解——基于SmartMediaKit深度实践
android·人工智能·计算机视觉·音视频·rtmp播放器·安卓rtmp播放器·rtmp直播播放器
qq_416276424 天前
通用音频表征的对比学习
学习·音视频
美狐美颜sdk4 天前
Android全局美颜sdk实现方案详解
人工智能·音视频·美颜sdk·视频美颜sdk·美狐美颜sdk
EasyDSS5 天前
私有化部署EasyDSS视频点播能力:全链路视频技术赋能,打造企业级视听新体验
音视频·hls·m3u8·点播技术·智能转码
qq_416276425 天前
DeLoRes——一种通用的音频表征学习新方法(DeLoRes(基于 Barlow Twins 的冗余最小化方法)
学习·音视频
Q_4582838685 天前
从定位到视频:808 + 1078 在各行业的落地实践
音视频
山顶望月川5 天前
实测MiniMax-Hailuo-02:当“开工大吉“变成“无字天书“,国产AI视频模型的能与之不能
人工智能·音视频