音频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下载地址(任选一个)

相关推荐
我是海飞4 小时前
Tensorflow Lite 的yes/no语音识别音频预处理模型训练教程
python·学习·tensorflow·音视频·嵌入式·语音识别
音视频牛哥4 小时前
具身智能的工程落地:视频-控制闭环的实践路径
人工智能·音视频·人工智能+·具身智能rtsp方案·具身智能rtmp方案·智能机器人rtsp方案·智能机器人rtmp低延迟
lichong9515 小时前
【混合开发】Android+Webview+VUE播放视频之视频解析工具mediainfo-Macos
android·macos·架构·vue·音视频·api·postman
百度智能云技术站15 小时前
百度智能云「智能集锦」自动生成短剧解说,三步实现专业级素材生产
人工智能·音视频
HelloRevit18 小时前
让B站视频4倍速度播放
前端·javascript·音视频
Ai工具分享18 小时前
视频增强AI哪个效果好?实战对比帮你找到最适合的工具
人工智能·音视频
wan5555cn19 小时前
【警惕】疑似一种新型金融黑灰产骗局大规模爆发
笔记·深度学习·音视频·生活
ai产品老杨19 小时前
打破技术壁垒,推动餐饮食安标准化进程的明厨亮灶开源了
前端·javascript·算法·开源·音视频
东风西巷21 小时前
Topaz Video AI:AI驱动的视频增强与修复工具
人工智能·音视频
水印云1 天前
2025年热门视频转文字工具测评,助你快速把视频转成文字稿!
音视频