亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? zfileman.c

?? 16位采樣的Wav文件讀寫源碼.
?? C
字號:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <limits.h>
#include <ctype.h>
#include <time.h>

/* for speech file header: SPH_Header */
#include "zFileMan.h"


/*************************************
/* Special Notes for multichannel
/*------------------------------------
/* Chunk: fmt
/*	ChannelNo:    uChannelNo
/*	BytePerSec:   uChannelNo x uSmpBytes (2) x uSmpRate 
/*	BlockAlign:   uChannelNo x uSmpBytes (2)
/* Chunk: data
/*	ChunkSize:    uChannelNo x uSmpBytes (2) x lSmpSize per Channel
/************************************/

short fnReadRAWHeaderInfo(SPH_Header *gSphHead, FILE *hInFile)
{
	/* fill in the information to header file */
	gSphHead->uSmpBytes = 2;	/* 16 bit only */
	gSphHead->uSmpRate = 0;		/* sample rate not specified */
	gSphHead->uChannelNo = 0;	/* channel number not specified */

	/* size in samples for all channels*/ 
	fseek(hInFile, 0, SEEK_END);
	gSphHead->lSmpSize = ftell(hInFile)/gSphHead->uSmpBytes;	
	fseek(hInFile, 0, SEEK_SET);
	return(1);
}

short fnReadWAVHeaderInfo(SPH_Header *gSphHead, FILE *hInFile)
{
	unsigned char rgchStr[5];
	unsigned long lTmp, lFileLen;
	unsigned short uTmp;

	rgchStr[4]='\0';

	/* CHUNK: RIFF */
	fread(rgchStr, sizeof(unsigned char), 4, hInFile);
	if (0!=strcmp(rgchStr, "RIFF")) {
		printf("%s is not in RIFF format\n", gSphHead->pchName);
		return(-1);
	}
	
	fread(&lTmp, sizeof(unsigned long), 1, hInFile);	/* Chunk Size */	
   	fread(rgchStr,sizeof(unsigned char), 4, hInFile);	/* File Type */
	if (0!=strcmp(rgchStr, "WAVE")) {
		printf("%s is not in WAVE sound file\n", gSphHead->pchName);
		return(-1);
	}

	/* CHUNK: fmt */
	fread(rgchStr, sizeof(unsigned char), 4, hInFile);
	while (0!=strcmp(rgchStr, "fmt ")) {	 /* keep reading until seeing "fmt "*/ 
		if (0!=ferror(hInFile)) {
			printf("Format chunk not found.\n");
			return(-1);
		}
		fread(&lTmp, sizeof(unsigned long), 1, hInFile);		/* get the length */
		fseek(hInFile, sizeof(unsigned char)*lTmp, SEEK_CUR);	/* skip unused chunk */
		fread(rgchStr, sizeof(unsigned char), 4, hInFile);		/* get next chunk */
	}

	fread(&lFileLen, sizeof(unsigned long), 1, hInFile);	/* Chunk Size */
	fread(&uTmp, sizeof(unsigned short), 1, hInFile);		/* Format Tag */
	if (uTmp!=1) {
		printf("Only 16-bit linear PCM data supported\n");	/* linear PCM only */
		return(-1);
	}
	fread(&uTmp, sizeof(unsigned short), 1, hInFile);		/* Channel No */
	gSphHead->uChannelNo = (unsigned short) uTmp;

	fread(&lTmp, sizeof(unsigned long), 1, hInFile);		/* Sampling Rate */
	gSphHead->uSmpRate = (unsigned short) lTmp;				
 	fread(&lTmp, sizeof(unsigned long), 1, hInFile);		/* Bytes Per Sec */
	fread(&uTmp, sizeof(unsigned short), 1, hInFile);		/* Block Alignment */
	gSphHead->uSmpBytes = uTmp / gSphHead->uChannelNo;
	 
	fread(&uTmp, sizeof(unsigned short), 1, hInFile);		/* Bits Per Sample */
	if (uTmp!=16) {
		printf("Only 16-bit data supported\n");
		return(-1);
	}

	lFileLen -= 16;	/* skip other information */										
	if (lFileLen!=0) fseek(hInFile, sizeof(unsigned char)*lFileLen, SEEK_CUR);

	/* Chunk: data */
	fread(rgchStr, sizeof(unsigned char), 4, hInFile);	
	while (0!=strcmp(rgchStr, "data")) {	/* keep reading until seeing "data"*/
		if (0!=ferror(hInFile)) {
			printf("Format chunk not found.\n");
			return(-1);
		}
		fread(&lTmp, sizeof(unsigned long), 1, hInFile);
		fseek(hInFile, sizeof(unsigned char)*lTmp, SEEK_CUR);
		fread(rgchStr, sizeof(unsigned char), 4, hInFile);
	}

	/* length of data in bytes */
	fread(&lTmp, sizeof(unsigned long), 1, hInFile);

	/* only consider 16-bit and 8-bit data */
	gSphHead->lSmpSize = lTmp / gSphHead->uSmpBytes;

 	//fseek(hInFile, 44, SEEK_SET);

	return(1);
}

/* designed to take care of any different files,
   The program look for the '.' to determined the file extension name
 */
short fnReadHeaderInfo(SPH_Header *gSphHead, FILE *hInFile)
{
	short i, n, wResult;
	char  *pchPtr, *pchPtr1;
	char  *rgchExtension;

	/* find the length of the extension name */
	pchPtr = strchr(gSphHead->pchName, '.');
	pchPtr++; 				/* point to the next character */
	pchPtr1 = strchr(gSphHead->pchName, '\0');
	n = (short) (pchPtr1-pchPtr)/sizeof(char);

	/* allocate the memory for the extension */
	rgchExtension = malloc((n+1)*sizeof(char));
	strcpy(rgchExtension, pchPtr);

	/* make sure every character is in lower case */
	for(i=0; i<n; i++) {
		if(isupper(rgchExtension[i]))
			rgchExtension[i] = tolower(rgchExtension[i]);
	}

	/* different type of header */
	if (0==strcmp(rgchExtension, "raw"))
		wResult = fnReadRAWHeaderInfo(gSphHead, hInFile);
	else if (0==strcmp(rgchExtension, "wav"))
		wResult = fnReadWAVHeaderInfo(gSphHead, hInFile);
	else wResult = (-1);
	free(rgchExtension);

	return(wResult);
}

void fnWriteWAVHeaderInfo(SPH_Header *gSphHead, FILE *hInFile)
{
	/* only support 16-bit, single channel */
	unsigned char rgchTmp[5]="RIFF";
	unsigned long lTmp, lDataLen;
	unsigned short uTmp;

	lDataLen = gSphHead->lSmpSize*gSphHead->uChannelNo*gSphHead->uSmpBytes;
	/* CHUNK: RIFF */
	fwrite(rgchTmp, sizeof(unsigned char), 4, hInFile);	/* Chunk Name */
	lTmp = 36 + lDataLen;
	fwrite(&lTmp, sizeof(unsigned long), 1, hInFile);	/* Chunk Size */
	strcpy(rgchTmp, "WAVE");
	fwrite(rgchTmp, sizeof(unsigned char), 4, hInFile); /* File Type */

	/* CHUNK: fmt */
	strcpy(rgchTmp, "fmt ");
	fwrite(rgchTmp, sizeof(unsigned char), 4, hInFile);	/* Chunk Name */
	lTmp = 16;
 	fwrite(&lTmp, sizeof(unsigned long), 1, hInFile);	/* Chunk Size */
	uTmp = 1; /* for linear PCM */
 	fwrite(&uTmp, sizeof(unsigned short), 1, hInFile);	/* Data Format */
	uTmp = gSphHead->uChannelNo; /* for multi-channel, v2.03 MCH */
 	fwrite(&uTmp, sizeof(unsigned short), 1, hInFile);	/* Channel No */
	lTmp = (unsigned long) gSphHead->uSmpRate;			
 	fwrite(&lTmp, sizeof(unsigned long), 1, hInFile);	/* Sampling Rate */
	uTmp = gSphHead->uSmpBytes*gSphHead->uChannelNo;
	lTmp *= uTmp;
	fwrite(&lTmp, sizeof(unsigned long), 1, hInFile);	/* Bytes Per Sec */
 	fwrite(&uTmp, sizeof(unsigned short), 1, hInFile);	/* Block Alignment */
	uTmp = gSphHead->uSmpBytes*8;
	fwrite(&uTmp, sizeof(unsigned short), 1, hInFile);	/* Bits Per Sample */
	
	/* data chunk */
 	strcpy(rgchTmp, "data");
	fwrite(rgchTmp, sizeof(unsigned char), 4, hInFile);
	/* total number of bytes */
	fwrite(&lDataLen, sizeof(unsigned long), 1, hInFile);

	return;
}

/* designed to take care of any different files,
   The program look for the '.' to determined the file extension name
   Now support .raw and .wav only 
 */
void fnWriteHeaderInfo(SPH_Header *gSphHead, FILE *hInFile)
{
	short i, n;
	char  *pchPtr, *pchPtr1;
	char  *pchExtension;

	/* find the length of the extension name */
	pchPtr= strchr(gSphHead->pchName, '.');
	if (pchPtr!=NULL) {
		pchPtr++; 				/* point to the next character */
		pchPtr1 = strchr(gSphHead->pchName, '\0');
		n = (int) (pchPtr1-pchPtr)/sizeof(char);

		/* allocate the memory for the extension */
		pchExtension = malloc((n+1)*sizeof(char));
		strcpy(pchExtension, pchPtr);
	} else {
		pchExtension=malloc(4*sizeof(char));
		strcpy(pchExtension, "raw");
	}

	/* make sure every character is in lower case */
	for(i=0; i<n; i++) {
		if(isupper(pchExtension[i])) 
			pchExtension[i] = tolower(pchExtension[i]);
	}

	/* different type of header */
	if (0==strcmp(pchExtension, "wav")) 
		fnWriteWAVHeaderInfo(gSphHead, hInFile);
	else if (0==strcmp(pchExtension, "raw")) {
		//gSphHead->uSmpBytes = 2; /* for 16 bits */
	} else {
		pchExtension[3]='\0';
		printf("Do not support this kind of voice file: %s \n", pchExtension);
		exit(-1);
	}
	free(pchExtension);
	return;
}

/* update length info, v2.02 */
void fnUpdateHeaderInfo(SPH_Header *gSphHead, FILE *hInFile)
{
	short i, n;
	char  *pchPtr, *pchPtr1;
	char  *pchExtension;
	unsigned long lTmp;
	
	/* find the length of the extension name */
	pchPtr = strchr(gSphHead->pchName, '.');
	if (pchPtr!=NULL) {
		pchPtr++; 				/* point to the next character */
		pchPtr1 = strchr(gSphHead->pchName, '\0');
		n = (int) (pchPtr1-pchPtr)/sizeof(char);

		/* allocate the memory for the extension */
		pchExtension = malloc((n+1)*sizeof(char));
		strcpy(pchExtension, pchPtr);
		for(i=0; i<n; i++) if(isupper(pchExtension[i]))
			pchExtension[i] = tolower(pchExtension[i]);
		if (0==strcmp(pchExtension, "wav")) {
			lTmp = gSphHead->lSmpSize*gSphHead->uChannelNo*gSphHead->uSmpBytes;
			fseek(hInFile, 40, SEEK_SET);
			fwrite(&lTmp, sizeof(unsigned long), 1, hInFile);	/* BYTE 40-43: total # of bytes */
			lTmp += 36;
			fseek(hInFile, 4, SEEK_SET);
			fwrite(&lTmp, sizeof(unsigned long), 1, hInFile);	/* BYTE 4-7: 36+(total# of bytes) */
		}
		free(pchExtension);
	}
	return;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色屁屁一区二区| 欧美一级一级性生活免费录像| 亚洲成人先锋电影| 久久精品日韩一区二区三区| 欧美亚洲国产怡红院影院| 懂色一区二区三区免费观看| 日韩国产精品久久久久久亚洲| 国产精品美女久久久久aⅴ| 日韩精品资源二区在线| 欧美日韩成人综合| 在线一区二区三区做爰视频网站| 国产一区二区不卡| 免费成人在线影院| 亚洲妇熟xx妇色黄| 亚洲乱码国产乱码精品精可以看| 久久久美女艺术照精彩视频福利播放| 欧美日韩极品在线观看一区| 色婷婷激情一区二区三区| 成人福利视频网站| 国产aⅴ综合色| 国产成人精品亚洲777人妖| 久久99久久99| 精品一区二区三区影院在线午夜 | 日韩欧美成人激情| 欧美日韩国产一二三| 在线一区二区三区四区五区 | 婷婷久久综合九色国产成人| 亚洲精品久久嫩草网站秘色| 国产精品久久久久久久久快鸭| 久久久99久久精品欧美| 精品国产电影一区二区| 精品999在线播放| 欧美电影免费观看高清完整版在线 | 欧美一级二级三级乱码| 欧美丰满嫩嫩电影| 在线成人午夜影院| 亚洲精品va在线观看| 国产精品久久久久久久久动漫| 国产欧美综合在线观看第十页 | 国产精品午夜春色av| 久久蜜桃香蕉精品一区二区三区| 欧美成人女星排名| 欧美www视频| 国产婷婷色一区二区三区| 中文字幕av免费专区久久| 国产精品美女一区二区在线观看| 国产精品久久久久影院亚瑟| 综合激情成人伊人| 亚洲精品国产a| 天堂午夜影视日韩欧美一区二区| 日韩电影在线免费看| 久久99在线观看| 岛国精品在线观看| 色婷婷av一区二区三区软件 | 亚洲精品在线三区| 日本一区二区免费在线| 亚洲日本韩国一区| 亚洲国产视频一区二区| 免费黄网站欧美| 粉嫩av一区二区三区粉嫩| 色拍拍在线精品视频8848| 91精品国产一区二区三区蜜臀 | 成人中文字幕电影| 色系网站成人免费| 日韩一级在线观看| 中文字幕不卡三区| 亚洲bt欧美bt精品777| 91麻豆精品国产91久久久久| 欧美一区二视频| 国产欧美综合在线| 亚洲一区精品在线| 国产一区二区美女诱惑| 日本韩国欧美三级| 精品福利一区二区三区| 1区2区3区欧美| 日韩精品亚洲一区二区三区免费| 国产精品一二一区| 欧美日韩一本到| 欧美激情一二三区| 日韩在线一区二区三区| 成人av影院在线| 4438成人网| 中文字幕一区二区三区视频| 天天影视涩香欲综合网 | 岛国精品在线观看| 制服丝袜国产精品| 国产欧美一区二区在线观看| 五月天激情综合网| 成人精品一区二区三区四区 | 国产91丝袜在线播放0| 欧美午夜一区二区| 国产日韩精品一区二区三区在线| 亚洲综合视频网| 丰满亚洲少妇av| 欧美精品在线视频| 亚洲美女免费视频| 国产一区二区三区免费| 欧美日韩视频不卡| 一区免费观看视频| 国产一区二区不卡老阿姨| 欧美日韩精品一区二区三区蜜桃| 国产精品久久久久久久久久免费看 | 亚洲女子a中天字幕| 国产福利一区在线| 欧美一区二区三区免费视频| 亚洲欧美国产77777| 粉嫩13p一区二区三区| 午夜视频在线观看一区二区 | 麻豆成人久久精品二区三区小说| 一本大道久久精品懂色aⅴ| 久久久国产午夜精品| 麻豆91免费观看| 91精品国产欧美一区二区18| 亚洲裸体xxx| av在线一区二区三区| 久久久久国产成人精品亚洲午夜| 男女男精品视频| 欧美精品第一页| 亚洲成国产人片在线观看| 色94色欧美sute亚洲线路一ni| 欧美国产激情二区三区 | av电影在线观看不卡| 国产区在线观看成人精品| 国产尤物一区二区| 久久久噜噜噜久噜久久综合| 九九九精品视频| 精品国产一区二区在线观看| 六月丁香婷婷色狠狠久久| 日韩一级精品视频在线观看| 日韩精品国产精品| 欧美一区二区啪啪| 美女视频黄久久| 欧美精品一区二区三区久久久| 美洲天堂一区二卡三卡四卡视频| 日韩一区二区三区观看| 日本视频一区二区三区| 日韩欧美一区电影| 国内精品伊人久久久久av一坑| 精品国产乱码久久久久久1区2区| 国产精品原创巨作av| 国产欧美精品区一区二区三区| 成人午夜电影小说| 中文字幕亚洲欧美在线不卡| jvid福利写真一区二区三区| 自拍偷自拍亚洲精品播放| 91麻豆123| 日韩精品电影一区亚洲| 日韩欧美一级二级三级久久久| 国内精品写真在线观看| 中文久久乱码一区二区| 91一区二区在线观看| 午夜精品免费在线| 欧美电影免费观看高清完整版在| 国产一区二区三区精品欧美日韩一区二区三区 | 99久久免费视频.com| 亚洲欧美区自拍先锋| 欧美老女人在线| 精品一区二区在线免费观看| 中文字幕欧美日韩一区| 91农村精品一区二区在线| 亚洲va在线va天堂| 欧美精品一区男女天堂| 91亚洲精品一区二区乱码| 亚洲va在线va天堂| 久久影院午夜片一区| 91香蕉视频污在线| 奇米777欧美一区二区| 中文字幕乱码一区二区免费| 91黄色免费看| 国产一区二区精品久久91| 亚洲视频免费在线观看| 欧美一区二区久久| 99热精品国产| 麻豆国产欧美一区二区三区| 激情小说欧美图片| 日韩美女久久久| 日韩欧美久久久| 日本高清免费不卡视频| 九色|91porny| 一区二区三区免费看视频| 欧美xingq一区二区| 91视频免费观看| 国产一区二区福利视频| 五月综合激情日本mⅴ| 欧美极品美女视频| 日韩欧美资源站| 在线观看视频91| 国产成人av电影在线观看| 日本一不卡视频| 亚洲美女少妇撒尿| 中文欧美字幕免费| 日韩色在线观看| 在线欧美一区二区| 成人一区二区三区在线观看| 美女一区二区在线观看| 亚洲免费av在线| 国产精品国产成人国产三级| 精品三级在线看| 91精品国产欧美一区二区成人| 色婷婷av一区二区三区软件|