猫耳FM导出音频转换为音频格式(m4a/mp3)


提示:仅为个人学习使用,不得用于任何商业用途

旧方法(不可用)

  1. 找到文件:打开文件管理-内部储存-MaoerFM-Download-sound_blob
  2. 将下载的文件后缀名改为mp3

新方法

参考此文:猫耳FM音频转换成MP3格式-space9bug,原方法可以用,只是我懒得用控制台了。(22.6.13突然发现原博客有demo,大伙可以试试先,选择“普通下载”)修改了几个地方,亲测可以直接在编译器编译运行使用,步骤为:

  1. 给文件添加mp3后缀名
  2. 放到下方代码文件的相同路径下,修改char input_file_name[100] = “2185209.mp3”;这一句引号内的数字,跟自己的文件的一致即可
  3. 运行下方代码,输出文件在同一文件夹下

代码如下:

#include <iostream>
#include <stdio.h>
#include <string.h>
#include <cstdint>
using namespace std;

#define CHUNK_SIZE 4096
#define HEADER_SIZE 12

int main()
{
	FILE *inFp = NULL;
	FILE *outFp = NULL;
	uint32_t read_temp_size;
	char buff[CHUNK_SIZE];
	char file_header[HEADER_SIZE];
	uint32_t file_start_addr, file_size;
    char input_file_name[100] = "2185209.mp3";

	char targetName[strlen(input_file_name) + 10];
	strncpy(targetName, input_file_name, strlen(input_file_name));

	inFp = fopen(input_file_name, "rb");
	if (inFp == NULL)
	{
		printf("open file fail\n");
	}

	fseek(inFp, 20, SEEK_SET);
	fread(&file_start_addr, 1, sizeof(file_start_addr), inFp);
	printf("start:%d\n", file_start_addr);

	fseek(inFp, 40, SEEK_SET);
	fread(&file_size, 1, sizeof(file_size), inFp);
	printf("end:%ld\n", file_size);

	fseek(inFp, file_start_addr, SEEK_SET);
	fread(&file_header, HEADER_SIZE, 1, inFp);

	if ((file_header[0] == 0x49 && file_header[1] == 0x44 && file_header[2] == 0x33) || (file_header[0] == 0xFF && file_header[1] == 0xfb))
	{
		printf("MP3 file\n");
		strcat(targetName, ".mp3");
	}
	else if ((file_header[4] == 0x66 && file_header[5] == 0x74 && file_header[6] == 0x79 && file_header[7] == 0x70 && file_header[8] == 0x4D && file_header[9] == 0x34 && file_header[10] == 0x41) || (file_header[0] == 0x4D && file_header[1] == 0x34 && file_header[2] == 0x41 && file_header[3] == 0x20))
	{
		printf("M4A file\n");
		strcat(targetName, ".m4a");
	}
	else
	{
		printf("OTHER file\n");
		strcat(targetName, ".temp");
	}

	outFp = fopen(targetName, "wb");
	if (outFp == NULL)
	{
		printf("open file fail\n");
	}

	fseek(inFp, file_start_addr, SEEK_SET);
	while (file_size != 0)
	{
		/* 使用右移和按位与优化代码 */
		// read_temp_size = file_size / CHUNK_SIZE ? CHUNK_SIZE : file_size % CHUNK_SIZE;
		read_temp_size = file_size >> 12 ? CHUNK_SIZE : file_size & (CHUNK_SIZE - 1);

		fread(&buff, read_temp_size, 1, inFp);
		fwrite(&buff, read_temp_size, 1, outFp);

		file_size -= read_temp_size;
	}

	fclose(inFp);
	inFp = NULL;

	fclose(outFp);
	outFp = NULL;

	return 0;
}

在本章中,我们将深入探讨基于块匹配的全景图像拼接技术,这是一种广泛应用于计算机视觉和图像处理领域的技术。在深度学习和机器学习的背景下,这种方法的实现与整合显得尤为重要,因为它们能够提升图像处理的效率和精度。下面,我们将会详细阐述相关知识点。 我们要了解什么是全景图像拼接。全景图像拼接是一种将多张有限视角的图像合并成一个宽视角或全方位视角图像的技术,常用于虚拟现实、地图制作、监控系统等领域。通过拼接,我们可以获得更广阔的视野,捕捉到单个图像无法覆盖的细节。 块匹配是全景图像拼接中的核心步骤,其目的是寻找两张图片中对应区域的最佳匹配。它通常包括以下几个关键过程: 1. **图像预处理**:图像的预处理包括灰度化、直方图均衡化、降噪等操作,以提高图像质量,使匹配更加准确。 2. **特征提取**:在每张图像上选择特定区域(块)并计算其特征,如灰度共生矩阵、SIFT(尺度不变特征变换)、SURF(加速稳健特征)等,这些特征应具备旋转、缩放和光照不变性。 3. **块匹配**:对于每一张图像的每个块,计算与另一张图像所有块之间的相似度,如欧氏距离、归一化互信息等。找到最相似的块作为匹配对。 4. **几何变换估计**:根据匹配对确定对应的几何关系,例如仿射变换、透视变换等,以描述两张图像之间的相对位置。 5. **图像融合**:利用估计的几何变换,对图像进行融合,消除重叠区域的不一致性和缝隙,生成全景图像。 在MATLAB环境中实现这一过程,可以利用其强大的图像处理工具箱,包括图像读取、处理、特征检测和匹配、几何变换等功能。此外,MATLAB还支持编程和脚本,方便算法的调试和优化。 深度学习和机器学习在此处的角色主要是改进匹配过程和图像融合。例如,通过训练神经网络模型,可以学习到更具鲁棒性的特征表示,增强匹配的准确性。同时,深度学习方法也可以用于像素级别的图像融合,减少拼接的失真和不连续性。 在实际应用中,我们需要注意一些挑战,比如光照变化、遮挡、动态物体等,这些因素可能会影响匹配效果。因此,往往需要结合其他辅助技术,如多视图几何、稀疏重建等,来提高拼接的稳定性和质量。 基于块匹配的全景图像拼接是通过匹配和融合多张图像来创建全景视图的过程。在MATLAB中实现这一技术,可以结合深度学习和机器学习的先进方法,提升匹配精度和图像融合质量。通过对压缩包中的代码和数据进行学习,你可以更深入地理解这一技术,并应用于实际项目中。
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值