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

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

?? jpeg_test.c

?? 三星 s3c6400測試代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <stdarg.h>

#include "sysc.h"
#include "system.h"
#include "intc.h"
#include "jpeg.h"
#include "lcd.h"
#include "camera.h"
#include "glib.h"
#include "post.h"
#include "option.h"
#include "library.h"
#include "sdhc.h"
#include "fat.h"
#include "uart.h"

#ifndef PREPARED_JPEG
#define PREPARED_JPEG      "./jpg/144_96_420.jpg"
#endif

#define CAPTURED_JPEG      "Captured.jpg"
#define YUV_FILE_NAME      "Captured.yuv"

static POST	oPost;
static SDHC   oSdhc;

static u32 uRawImgHSz_Dec, uRawImgVSz_Dec, uRawImgAddr;
static u32 uRawImgHsz_Enc, uRawImgVsz_Enc, uGlibAddr;
static CSPACE eRawImgFormat;
static u32 uLcdFbAddr, uLcdHSz, uLcdVSz;
static CSPACE eLcdBpp;
static u32 uJpgAddr;
static JPEG_TYPE eJpgFormat;
static u32 uJpgSize;
static JPEG_STATUS eJpgStatus;
static bool bIsJpgLoaded;
static bool bIsOneStep;
static u32 uIntCnt;

#if 1
#define WaitForSet(bDone) while (!bDone)
#else
#define WaitForSet(bDone) \
	for (int i=0; !bDone; i++) \
	{ \
		Delay(100); \
		if (i == 100) \
		{ \
			printf(" Abnormal termination !!!\n"); \
			return; \
		} \
	}
#endif

#if 0   // Polling mode
#define WaitForConversionDone(bDone) while(!CIM_IsProcessingDone())
#else   // Interrupt mode
#define WaitForConversionDone(bDone) while(!bDone)
#endif

static volatile bool bCamifDone;

void __irq Isr_Camif_P(void)
{
	LCD_Trigger();
	//bPreviewDone = true;
	//printf("P");
	CAMERA_SetClearPreviewInt();
	INTC_ClearVectAddr();		
}

void __irq Isr_Camif_C(void)
{
	INTC_Disable(NUM_CAMIF_C );
	bCamifDone = true;	
	CAMERA_SetClearCodecInt();
	INTC_Disable(NUM_CAMIF_C );
	INTC_ClearVectAddr();
}

static volatile bool bJpegDone;

void __irq Isr_Jpeg(void)
{
	INTC_Disable(NUM_JPEG);
	if ( (bIsOneStep == false) || ((bIsOneStep == true)&&(uIntCnt == 1)) )
	{
		JPEG_ReadAndClearStatus(&eJpgStatus);
		uIntCnt = 0;
	}
	//INTC_ClearPending(INT_JPEG);
	bJpegDone = true;
	uIntCnt++;
	printf("bJpegDone: %d\n", bJpegDone); 

	INTC_Enable(NUM_JPEG);
	INTC_ClearVectAddr();	
}

#define MJPEG_FRAME_NUM	5
#define MJPEG_MAX_SZ		0x8000
#define MJPEG_STREAM_ST	(uJpgAddr)
#define MJPEG_YUV_ST		(MJPEG_STREAM_ST+MJPEG_MAX_SZ*MJPEG_FRAME_NUM)	// after 10 frame

static volatile u32  uMjpgCount;
static volatile bool bMjpgEncDone;

void __irq Isr_EncMotion(void)
{
	u32 uResult; //, cnt;
	//Assert(0);
	INTC_Disable(NUM_JPEG);

	uMjpgCount++;
	JPEG_SetNextFrameStartAddr(MJPEG_STREAM_ST + MJPEG_MAX_SZ*(uMjpgCount+1));
	JPEG_CheckDone(&uResult);

	if (uResult)
	{
		JPEG_GetEncodedStreamLen(&uJpgSize);
		if (uMjpgCount >= MJPEG_FRAME_NUM)
		{
			bMjpgEncDone = 1;
		}
	}
	else
	{
		JPEG_GetEncodedStreamLen(&uJpgSize);
		printf("JPEG Encoding: Done abnormally. %x\n", uJpgSize);
		bMjpgEncDone = 0;
	}
	printf("JPEG Encoding frame = %d Done.\n", uJpgSize);
	INTC_Enable(NUM_JPEG);
	INTC_ClearVectAddr();	
}

static void TestDscSubsys(void)
{
	char x=0;
	u32 uSrcHsz ,uSrcVsz ;
	u32 uCaptureHsz, uCaptureVsz;
	u32 uCodecAddr = uJpgAddr + 0x500000;

	CSPACE eDstDataFmt = RGB16;
	IMG_SIZE eCodecSz = UXGA;

	// 1. Initialize LCD
	//========================================
	LCD_InitLDI(MAIN);
	LCD_InitDISPC(eDstDataFmt, uLcdFbAddr, WIN0, false);
	LCD_GetFrmSz(&uLcdHSz, &uLcdVSz, WIN0);
	LCD_Start();

	// 2. Initialize Interrupt
	//========================================
	INTC_Init();
	INTC_SetVectAddr(NUM_JPEG, Isr_Jpeg);
	INTC_SetVectAddr(NUM_CAMIF_C, Isr_Camif_C);	
	//INTC_SetVectAddr(NUM_CAMIF_P, Isr_Camif_P);	
	INTC_Enable(NUM_JPEG);
	INTC_Enable(NUM_CAMIF_C);
	//INTC_Enable(NUM_CAMIF_P);	

	// 3. Initialize camera and run the  process of preview path.
	//========================================
	CAMERA_InitSensor();		//CAMERA_InitSensor1(ePreviewSz, CCIR601, YCBYCR);
	CAMERA_SetSensorSize(eCodecSz);
	CAMERA_GetSrcImgSz(&uSrcHsz, &uSrcVsz);
	
	uSrcHsz = (uSrcHsz > uLcdHSz) ? uLcdHSz : uSrcHsz;
	uSrcVsz = (uSrcVsz > uLcdVSz) ? uLcdVSz : uSrcVsz;

	CAMERA_InitPreviewPath(uSrcHsz, uSrcVsz, uLcdFbAddr, eLcdBpp, FLIP_NO, ROT_0);
	CAMERA_StartPreviewPath();

	while(true)
	{
		printf("x = Turn off Camera, s = Capture IMG(Enocoded To JPEG), c = Change IMG Size : ");
		x = getchar();
		
		printf("%c\n", x);

		if(x == 'x' || x=='X')
		{
			CAMERA_StopPreviewPath();
			break;
		}
		else if(x=='s' || x=='S')
		{
			CAMERA_StopPreviewPath();
			CAMERA_SetSensorSize(eCodecSz);

			bCamifDone = false;

			ConvertImgSzToNumber(eCodecSz, &uCaptureHsz, &uCaptureVsz);
			eDstDataFmt = YCBYCR;
			CAMERA_InitCodecPath(uCaptureHsz, uCaptureVsz, uCodecAddr,  eDstDataFmt, FLIP_NO, ROT_0);
			CAMERA_StartCodecPath(1);

			while(!CAMERA_IsProcessingDone());
			//WaitForConversionDone(bCamifDone);			

			CAMERA_ClearFrameEndStatus();
			printf("Capturing raw image  ... \n");				
			
			bJpegDone = false;
			JPEG_StartEncodingOneFrame(uCaptureHsz, uCaptureVsz, uCodecAddr, eDstDataFmt, uJpgAddr, eJpgFormat);
			WaitForSet(bJpegDone);
			Assert(eJpgStatus == OK_ENC_OR_DEC);
			//JPEG_Wait_Done();

			JPEG_GetEncodedStreamLen(&uJpgSize);
/*
			//+daedoo 061212
			CIM_SetSensorSize(ePreviewSz);
			CIM_InitPreviewPath(uSrcHsz, uSrcVsz, uLcdFbAddr, eDstDataFmt, FLIP_NO, ROT_0);
			CIM_StartPreviewPath();
*/			

#if	 SEMIHOSTING
			printf("Saving image to file ... \n");
			SaveToFile(CAPTURED_JPEG, uJpgSize, uJpgAddr);
#else
			// Under Construction. SD/MMC will be used.
#endif
			
		}

		else if(x=='c' || x=='C')
		{
			printf("1 = UXGA, 2 = SXGA, 3 = SVGA, 4 = VGA : ");
			//x = Getc();
			x = getchar();

			printf("%c\n", x);

			eCodecSz =  (x=='11') ? UXGA : (x=='22') ? SXGA : (x=='33') ? SVGA : (x=='44') ? VGA : SVGA;
		}
		else
			printf("Invalid input! Retry!!\n");
	}
	CAMERA_StopPreviewPath();

}

static void TestOneStepDecoding(void)
{
	bIsOneStep = true;
	
	if (bIsJpgLoaded == false)
	{
		printf("ERROR! Load a raw image first!!\n");
		return;
	}

	INTC_Init();
	INTC_SetVectAddr(NUM_JPEG, Isr_Jpeg);
	INTC_Enable(NUM_JPEG);

	uRawImgAddr = uJpgAddr+((uJpgSize+16)/16)*16;
	bJpegDone = false;
	JPEG_StartDecodingOneFrame(uJpgAddr, uRawImgAddr, false);
	WaitForSet(bJpegDone);
	//Assert(eJpgStatus == OK_ENC_OR_DEC);
	JPEG_Wait_Done();
	
	JPEG_GetDecodedWidthAndHeight(&uRawImgHSz_Dec, &uRawImgVSz_Dec);
	if ( uRawImgHSz_Dec == 0 || uRawImgVSz_Dec == 0 )
		printf("Error! Widht or Height is zero\n");
	else 
		printf(" Hsz = %d, Vsz = %d\n", uRawImgHSz_Dec, uRawImgVSz_Dec);

	/*
	CIM_InitDmaInPath(uRawImgHSz_Dec, uRawImgVSz_Dec, uRawImgAddr, YCBYCR,
		uLcdHSz, uLcdVSz, uLcdFbAddr, eLcdBpp, FLIP_NO, ROT_0, C_PATH);

	bCamifDone = false;
	CIM_StartDmaInPath();
	WaitForConversionDone(bCamifDone);
	*/

	POST_InitIp(
		uRawImgHSz_Dec, uRawImgVSz_Dec, uRawImgAddr, CRYCBY,
		//uLcdHSz, uLcdVSz, uLcdFbAddr, eLcdBpp, 1, false, ONE_SHOT, &oPost);
		320, 240, uLcdFbAddr, eLcdBpp, 1, false, ONE_SHOT, &oPost);

	POST_StartProcessing(&oPost);
	while (!POST_IsFreeRunDone(&oPost));
	
}

static void TestTwoStepDecoding(void)
{
	char pType[30];

	bIsOneStep = false;	
	
	if (bIsJpgLoaded == false)
	{
		printf("ERROR! Load a raw image first !!\n");
		return;
	}

	INTC_Init();
	INTC_SetVectAddr(NUM_JPEG, Isr_Jpeg);
	INTC_SetVectAddr(NUM_CAMIF_C, Isr_Camif_C);
	INTC_Enable(NUM_JPEG);
	INTC_Enable(NUM_CAMIF_C);

	// Header Parsing
	bJpegDone = false;
	JPEG_StartParsingHeader(uJpgAddr);
	WaitForSet(bJpegDone);
	
	Assert(eJpgStatus == OK_HD_PARSING);

	JPEG_GetJpegType1(pType);
	printf(" 1. Sub-Sampling Mode = %s\n", pType);

	JPEG_GetDecodedWidthAndHeight(&uRawImgHSz_Dec, &uRawImgVSz_Dec);
	if ( uRawImgHSz_Dec == 0 || uRawImgVSz_Dec == 0 )
		printf("Error! Width or Height is zero\n");
	else
		printf(" 2. Resolution : Width = %d, Height = %d\n", uRawImgHSz_Dec, uRawImgVSz_Dec);

	// Decoding body.
	uRawImgAddr = uJpgAddr+((uJpgSize+16)/16)*16;
	printf(" uRawImgAddr = 0x%x\n",uRawImgAddr);
	bJpegDone = false;
	JPEG_StartDecodingBody(uRawImgAddr, false);
	WaitForSet(bJpegDone);
	Assert(eJpgStatus == OK_ENC_OR_DEC);
	
	//printf("After JpegDone\n");

	#if 0	// camera dma

	CAMERA_InitDmaInPath(uRawImgHSz_Dec, uRawImgVSz_Dec, uRawImgAddr, YCBYCR,
		//uLcdHSz, uLcdVSz, uLcdFbAddr, eLcdBpp, FLIP_NO, ROT_0, C_PATH);
		320, 240, uLcdFbAddr, eLcdBpp, FLIP_NO, ROT_0, C_PATH);

	bCamifDone = false;
	CAMERA_StartDmaInPath();
	WaitForConversionDone(bCamifDone);

	#else

	POST_InitIp(
		uRawImgHSz_Dec, uRawImgVSz_Dec, uRawImgAddr, CRYCBY,
		uLcdHSz, uLcdVSz, uLcdFbAddr, eLcdBpp, 1, false, ONE_SHOT, &oPost);
	POST_StartProcessing(&oPost);
	while (!POST_IsFreeRunDone(&oPost));

	#endif

}

#if	 SEMIHOSTING
static void GetJpegStreamFromPc(void)
{
	const char *pFileName = PREPARED_JPEG;
	printf(" Loading %s from PC ...\n", pFileName);
	LoadFromFile1(pFileName, uJpgAddr, &uJpgSize);

	printf(" Stream size = %d bytes\n", uJpgSize);
	bIsJpgLoaded = true;
}
#endif

static void GetJpegStreamFromSd(void)
{
	u32 uTotalNumOfFiles, i;
	int sel;
	char pFileName[50];

	if (!SDHC_OpenMedia(SDHC_HCLK, &oSdhc) || !FAT_LoadFileSystem(&oSdhc))
		Assert(0);
	
	FAT_GetTotalNumOfFiles(&uTotalNumOfFiles, &oSdhc);
	for (i=0; i<uTotalNumOfFiles; i++)
	{
		FAT_GetFileName(i, pFileName, &oSdhc);
		printf("%02d -- %s\n", i, pFileName);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
不卡一区二区在线| 亚洲不卡在线观看| 成人av第一页| **欧美大码日韩| 在线视频国产一区| 日韩国产欧美在线观看| 欧美一级在线免费| 国内精品免费在线观看| 国产欧美久久久精品影院| 成人激情av网| 亚洲一区中文在线| 91精品国产入口在线| 精品一区二区av| 国产精品人妖ts系列视频| 99re8在线精品视频免费播放| 亚洲精品日产精品乱码不卡| 欧美亚洲高清一区| 久久爱www久久做| 国产精品黄色在线观看| 欧美午夜在线一二页| 麻豆精品新av中文字幕| 中文字幕乱码日本亚洲一区二区| 91麻豆高清视频| 日韩精品亚洲专区| 国产日韩欧美在线一区| 色噜噜狠狠色综合中国| 美女在线一区二区| 亚洲裸体xxx| 欧美成人国产一区二区| 99这里只有精品| 日精品一区二区三区| 国产嫩草影院久久久久| 欧美日韩一区二区欧美激情| 国产麻豆视频精品| 亚洲v日本v欧美v久久精品| 久久久久久久久免费| 欧美色视频一区| 国v精品久久久网| 日韩和欧美一区二区三区| 久久久久久久网| 制服丝袜中文字幕一区| av在线综合网| 国产一区在线不卡| 爽爽淫人综合网网站| 日韩一区在线看| 久久久久久亚洲综合影院红桃| 精品视频在线免费| 成人成人成人在线视频| 国内精品在线播放| 免费在线观看视频一区| 一区二区三区四区视频精品免费 | 欧美日韩一区二区在线视频| 精品一区二区在线视频| 亚洲综合免费观看高清完整版| 国产午夜精品在线观看| 日本一区二区三区高清不卡| 日韩一区二区三区电影在线观看 | 美脚の诱脚舐め脚责91 | 日韩成人一级大片| 亚洲综合色自拍一区| 国产精品久线在线观看| 久久久精品免费网站| 日韩欧美国产综合一区 | 丁香五精品蜜臀久久久久99网站 | 国产视频一区不卡| 精品久久久久久久久久久久包黑料 | 久久亚洲精品小早川怜子| 91精品免费在线| 欧美三级电影在线看| 色呦呦日韩精品| 91麻豆免费看| 色综合天天性综合| 色综合一个色综合| 91伊人久久大香线蕉| 丁香亚洲综合激情啪啪综合| 国产一区二区三区av电影| 美国欧美日韩国产在线播放| 日韩不卡在线观看日韩不卡视频| 亚洲一区二区av在线| 亚洲一区二区三区激情| 亚洲主播在线播放| 亚洲男人的天堂在线观看| 1区2区3区欧美| 亚洲欧美国产高清| 亚洲综合色噜噜狠狠| 亚洲图片一区二区| 不卡的av在线| 99精品久久只有精品| 色噜噜狠狠成人网p站| 在线观看成人小视频| 欧美美女一区二区三区| 欧美一级专区免费大片| 欧美精品一区二区三区蜜臀| 精品成人免费观看| 国产亚洲精品久| 亚洲三级电影网站| 亚洲地区一二三色| 久草这里只有精品视频| 国产69精品一区二区亚洲孕妇| 国产成人99久久亚洲综合精品| 成a人片国产精品| 欧美性欧美巨大黑白大战| 欧美一区三区二区| 国产精品视频麻豆| 亚洲一区二区三区在线播放| 爽好多水快深点欧美视频| 国产老女人精品毛片久久| 99国产一区二区三精品乱码| 欧美日韩国产123区| 精品国一区二区三区| 中文字幕在线不卡| 日韩1区2区日韩1区2区| 成人免费高清视频| 8x8x8国产精品| 国产精品午夜久久| 婷婷夜色潮精品综合在线| 国产精品一品二品| 欧美日韩一区三区四区| 国产亚洲精品资源在线26u| 一区二区三区.www| 国产乱人伦精品一区二区在线观看| 91美女在线看| 久久亚洲二区三区| 午夜天堂影视香蕉久久| 成人毛片视频在线观看| 91精品国产综合久久香蕉的特点| 国产欧美精品一区二区色综合朱莉 | 色av一区二区| 精品欧美久久久| 亚洲一区二区在线免费看| 国产剧情在线观看一区二区| 欧美三级午夜理伦三级中视频| 国产清纯在线一区二区www| 日韩av一二三| 色狠狠av一区二区三区| 国产精品色一区二区三区| 青青草精品视频| 欧美性生交片4| 日韩美女精品在线| 国产成a人亚洲| 精品少妇一区二区三区在线播放 | 久久夜色精品国产噜噜av| 亚洲最快最全在线视频| 成人精品免费网站| 欧美成人video| 日精品一区二区| 欧美日韩日本视频| 亚洲日本在线视频观看| 国产精一区二区三区| 欧美一区二区三区色| 一区二区三区 在线观看视频| 不卡的电视剧免费网站有什么| 久久一区二区视频| 韩国女主播成人在线观看| 欧美一区三区四区| 日韩成人免费电影| 欧美一区日本一区韩国一区| 亚洲va国产天堂va久久en| 91久久精品一区二区| 亚洲视频图片小说| 97精品超碰一区二区三区| 中文字幕亚洲区| 99在线精品一区二区三区| 中文字幕亚洲一区二区av在线 | 亚洲天天做日日做天天谢日日欢 | 色综合久久中文综合久久97| 欧美激情一区二区三区全黄| 国产一区二区三区国产| 国产色产综合色产在线视频| 国产激情一区二区三区桃花岛亚洲| 91精品国产色综合久久不卡蜜臀| 日韩中文字幕一区二区三区| 欧美喷水一区二区| 日本不卡一二三| 久久综合色婷婷| 国产v日产∨综合v精品视频| 欧美国产日韩亚洲一区| 91网页版在线| 午夜电影一区二区| 日韩一区二区三区av| 国产麻豆日韩欧美久久| 国产精品国模大尺度视频| 91香蕉国产在线观看软件| 亚洲一区免费在线观看| 91精品国产日韩91久久久久久| 麻豆国产精品官网| 久久久午夜电影| 色综合久久88色综合天天免费| 亚洲最大的成人av| 日韩三级.com| 国产iv一区二区三区| 一区二区三区在线视频播放| 欧美男女性生活在线直播观看| 蜜臀a∨国产成人精品| 国产欧美日本一区视频| 日本道精品一区二区三区| 日本不卡视频在线观看| 国产精品日韩精品欧美在线| 欧美性生活久久| 国产一区二区不卡|