SDL播放pcm

SDL播放pcm

获取pcm

先随便找个mp4,给转成pcm

ffmpeg -i 1.mp4 -ar 48000 -ac 2 -f s16le 1.pcm

示例代码

uint8_t* pcm_pos = NULL;
uint32_t buf_len = 0;

void cb(void* udata, Uint8* stream, int len)
{
	if (buf_len <= 0 || !pcm_pos)
	{
		return;
	}

	SDL_memset(stream, 0, len);
	
	len = len < buf_len ? len : buf_len;
	SDL_MixAudio(stream, pcm_pos, len, SDL_MIX_MAXVOLUME);

	pcm_pos += len;
	buf_len -= len;
}

void PlayPCM()
{
	SDL_Init(SDL_INIT_AUDIO);

	FILE* wj = fopen("1.pcm", "rb");
	if (NULL == wj)
	{
		std::cout << "fopen failed" << std::endl;
		return;
	}

	std::vector<uint8_t> v(4096);
	SDL_AudioSpec spec;
	spec.freq = 44100;
	spec.format = AUDIO_S16SYS;
	spec.channels = 2;
	spec.silence = 0;
	spec.samples = 1024;
	spec.callback = cb;
	spec.userdata = NULL;

	SDL_OpenAudio(&spec, NULL);

	SDL_PauseAudio(0);
	while (1)
	{
		buf_len = fread(v.data(), 1, v.size(), wj);
		if (buf_len <= 0)
		{
			break;
		}

		pcm_pos = v.data();

		if (pcm_pos < (v.data() + buf_len))
		{
			SDL_Delay(20);
		}
	}

	fclose(wj);
	SDL_Quit();
}

直接跑就行了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值