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

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

?? decode.c

?? DVD轉換到AVI的源代碼
?? C
字號:
/* 
 *	Copyright (C) Aaron Holtzman - May 1999
 *
 *  This file is part of ac3dec, a free Dolby AC-3 stream decoder.
 *	
 *  ac3dec is free software; you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License as published by
 *  the Free Software Foundation; either version 2, or (at your option)
 *  any later version.
 *   
 *  ac3dec is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU General Public License for more details.
 *   
 *  You should have received a copy of the GNU General Public License
 *  along with GNU Make; see the file COPYING.  If not, write to
 *  the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. 
 *
 */

#include "../global.h"
#include "ac3.h"
#include "bitstream.h"

void bit_allocate(uint_16 fscod, bsi_t *bsi, audblk_t *audblk);

static audblk_t audblk;
static bsi_t bsi;
static syncinfo_t syncinfo;

// the floating point samples for one audblk
static stream_samples_t samples;

// the integer samples for the entire frame (with enough space for 2 ch out)
// if this size change, be sure to change the size when muting
static sint_16 s16_samples[2 * 6 * 256];

// storage for the syncframe
#define BUFFER_MAX_SIZE 4096
static uint_8 buffer[BUFFER_MAX_SIZE];
static sint_32 buffer_size;

uint_32 decode_buffer_syncframe(syncinfo_t *syncinfo, uint_8 **start, uint_8 *end)
{
	uint_8 *cur = *start;
	uint_16 syncword = syncinfo->syncword;
	uint_32 ret = 0;

	// find an ac3 sync frame
resync:
	while(syncword != 0x0b77)
	{
		if(cur >= end)
			goto done;
		syncword = (syncword << 8) + *cur++;
	}

	// need the next 3 bytes to decide how big the frame is
	while(buffer_size < 3)
	{
		if(cur >= end)
			goto done;

		buffer[buffer_size++] = *cur++;
	}
	
	parse_syncinfo(syncinfo, buffer);

	if (syncinfo->frame_size==0)		// CRITICAL CONDITION
		goto done;

	while (buffer_size < (syncinfo->frame_size<<1) - 2)
	{
		if(cur >= end)
			goto done;

		buffer[buffer_size++] = *cur++;
	}

	// check the crc over the entire frame
	if (crc_process_frame(buffer, (syncinfo->frame_size<<1) - 2))
	{
		SetDlgItemText(hDlg, IDC_DEBUG, "A.E.");

		syncword = 0xffff;
		buffer_size = 0;
		goto resync;
	}

	// if we got to this point, we found a valid ac3 frame to decode
	bitstream_init(buffer);
	// get rid of the syncinfo struct as we already parsed it
	bitstream_get(24);

	// reset the syncword for next time
	syncword = 0xffff;
	buffer_size = 0;
	ret = 1;

done:
	syncinfo->syncword = syncword;
	*start = cur;
	return ret;
}

void decode_mute(void)
{
	// mute the frame
	memset(s16_samples, 0, sizeof(sint_16) * 256 * 2 * 6);
	error_flag = 0;
}

sint_32 ac3_decode_data(uint_8 *data_start, int size)
{
	uint_8 *data_end = data_start + size;
	uint_32 i, j=0;

	while (decode_buffer_syncframe(&syncinfo, &data_start, data_end))
	{
		if (error_flag)
		{
			SetDlgItemText(hDlg, IDC_DEBUG, "A.E.");

			decode_mute();
			continue;
		}

		parse_bsi(&bsi);

		for (i=0; i<6; i++)
		{
			ZeroMemory(samples, sizeof(double) * 256 * (bsi.nfchans + bsi.lfeon));

			parse_audblk(&bsi, &audblk);

			exponent_unpack(&bsi, &audblk); 
			if(error_flag)
				goto error;

			bit_allocate(syncinfo.fscod, &bsi, &audblk);

			coeff_unpack(&bsi, &audblk, samples);
			if(error_flag)
				goto error;

			if(bsi.acmod == 0x2)
				rematrix(&audblk, samples);

			imdct(&bsi, &audblk, samples);

			downmix(&audblk, &bsi, samples, &s16_samples[i * 512]);

			sanity_check(&syncinfo, &bsi, &audblk);
			if(error_flag)
				goto error;
		}

		memcpy(&AC3Dec_Buffer[j*6144], s16_samples, 6144);
		j++;

error:
		;
	}

	return j*6144;
}

void InitialAC3()
{
	error_flag = buffer_size = 0;
	ds_x1 = ds_x2 = ds_y1 = ds_y2 = 0;

	ZeroMemory(&syncinfo, sizeof(syncinfo));
	ZeroMemory(&bsi, sizeof(bsi));
	ZeroMemory(&audblk, sizeof(audblk));

	srand(0);

	drc_init();
	imdct_init();
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色综合 综合色| 亚洲综合在线第一页| 久久国产综合精品| 精品免费99久久| 国产一区二区女| 国产亚洲一本大道中文在线| 福利电影一区二区| 中文字幕一区二区在线播放| 在线欧美日韩国产| 日韩激情av在线| 精品久久久影院| 99视频精品在线| 亚洲福利电影网| 久久综合久久综合亚洲| 懂色av中文一区二区三区| 亚洲裸体在线观看| 欧美一区二区视频免费观看| 精品在线亚洲视频| 亚洲日本丝袜连裤袜办公室| 91精品国产综合久久久久久久久久| 美女视频网站黄色亚洲| 国产精品女主播在线观看| 色999日韩国产欧美一区二区| 亚洲大型综合色站| 26uuu久久综合| 色天天综合久久久久综合片| 奇米四色…亚洲| 国产精品久久久久影视| 在线观看91av| 成人黄色免费短视频| 午夜视频在线观看一区二区三区| 久久综合色8888| 欧美精选午夜久久久乱码6080| 免费精品99久久国产综合精品| 亚洲国产精品二十页| 欧美日本一道本在线视频| 国产成人精品免费在线| 日韩高清中文字幕一区| 国产精品不卡在线观看| 91精品国产综合久久精品app| 高清不卡在线观看av| 午夜精品爽啪视频| 中文字幕在线一区| 日韩欧美国产小视频| 91免费在线看| 国产成人免费视频一区| 日韩中文欧美在线| 自拍av一区二区三区| 精品国产凹凸成av人网站| 日本高清视频一区二区| 成人国产精品免费观看视频| 久久99久久久久久久久久久| 一区二区三区在线观看欧美| 中文字幕第一区| 久久先锋影音av鲁色资源| 欧美三电影在线| 91在线一区二区| 粉嫩aⅴ一区二区三区四区 | 宅男在线国产精品| 91成人国产精品| 97精品久久久午夜一区二区三区| 韩国成人精品a∨在线观看| 久久日一线二线三线suv| 欧美日韩午夜在线视频| 91亚洲午夜精品久久久久久| 懂色av一区二区三区免费观看 | 99综合影院在线| 国产精品 欧美精品| 激情av综合网| 黑人巨大精品欧美黑白配亚洲| 日本亚洲天堂网| 日本视频免费一区| 男男gaygay亚洲| 男人的j进女人的j一区| 日韩高清不卡一区二区三区| 午夜精品久久一牛影视| 视频一区视频二区在线观看| 中文字幕va一区二区三区| 欧美日韩国产一二三| 欧美日韩在线三级| 欧美高清视频www夜色资源网| 欧美日韩一区在线观看| 欧美三级电影在线看| 欧美精品成人一区二区三区四区| 欧美天堂亚洲电影院在线播放| 欧美在线播放高清精品| 7799精品视频| 日韩欧美国产综合| 精品国精品国产尤物美女| 久久久久99精品国产片| 国产精品你懂的| 亚洲视频 欧洲视频| 亚洲国产另类av| 日本不卡123| 国产成人亚洲综合a∨婷婷图片 | 亚洲国产精品t66y| 亚洲欧美视频在线观看视频| 亚洲综合男人的天堂| 日韩精品高清不卡| 国产麻豆成人传媒免费观看| www.欧美亚洲| 欧美体内she精高潮| 欧美www视频| 国产精品视频看| 亚洲一区二区三区在线| 久久精品二区亚洲w码| 国产夫妻精品视频| 欧洲激情一区二区| 欧美一级生活片| 国产精品少妇自拍| 亚洲国产综合人成综合网站| 久久99国产精品久久99 | 精品亚洲porn| 不卡视频在线观看| 欧美日韩电影在线| 中文字幕精品一区二区精品绿巨人| 中文字幕亚洲视频| 日韩中文字幕麻豆| 国产成人福利片| 欧美久久一二区| 中文字幕不卡一区| 免费在线观看一区| 95精品视频在线| 精品国产成人系列| 亚洲高清视频的网址| 国产高清一区日本| 欧美日韩国产美| 亚洲国产电影在线观看| 男男视频亚洲欧美| 91黄色在线观看| 欧美国产欧美综合| 蜜桃av一区二区三区| 99re免费视频精品全部| 久久网站热最新地址| 亚洲一级二级在线| 国产91在线观看丝袜| 欧美一区二区视频免费观看| 又紧又大又爽精品一区二区| 国产一区亚洲一区| 在线不卡中文字幕| 亚洲欧美色图小说| 国产不卡视频在线播放| 欧美一区二区三区四区视频 | 亚洲一区二区三区四区在线观看| 久久不见久久见免费视频7 | 视频一区二区国产| k8久久久一区二区三区| 精品欧美一区二区久久| 亚洲成人www| 日本精品一区二区三区高清| 国产精品美女www爽爽爽| 精品一区二区在线看| 日韩三级免费观看| 亚洲123区在线观看| 欧美视频在线一区二区三区| 亚洲免费资源在线播放| 99国产精品一区| 1024国产精品| www.亚洲精品| 中文字幕免费在线观看视频一区| 黄色资源网久久资源365| 日韩视频在线你懂得| 日本视频免费一区| 日韩三级.com| 捆绑调教美女网站视频一区| 91精品欧美综合在线观看最新| 亚洲国产一区二区三区| 在线观看免费亚洲| 亚洲综合视频在线观看| 在线国产电影不卡| 夜夜爽夜夜爽精品视频| 91黄色免费看| 丝袜亚洲另类欧美综合| 制服视频三区第一页精品| 偷窥少妇高潮呻吟av久久免费| 欧美日韩一区二区三区高清 | 日韩久久久精品| 久久精品国产澳门| 久久蜜桃av一区二区天堂| 国产精品亚洲人在线观看| 久久精品视频在线看| 成人国产免费视频| 亚洲精品美国一| 欧美三级中文字| 青青草97国产精品免费观看无弹窗版| 91精品国产综合久久久蜜臀图片| 蜜臀久久99精品久久久久久9| 精品免费视频.| 成人丝袜视频网| 亚洲成人久久影院| 日韩欧美一级片| www.亚洲精品| 日韩精品午夜视频| 久久久综合视频| 日本国产一区二区| 日韩精品一区第一页| 精品av久久707| 91在线精品一区二区三区| 午夜精品在线视频一区| 日韩丝袜情趣美女图片|