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

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

?? camera.cpp

?? linux和arm下usb攝像頭圖像的獲取
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
#include "camera.h"

//Construct a camera, get init camera parameter
Camera::Camera(char *deviceIn, int widthIn, int heightIn, int formatIn, int grabmethodIn)
{
	memset (&videoIn, 0, sizeof (struct vdIn));
	memset(videodevice, 0, sizeof(videodevice));
	
	if(NULL == deviceIn)
	{
		printf("No device specifyed, using default device:%s\n", defaultDev);
		memcpy(videodevice, defaultDev, strlen(defaultDev));		
	}
	else if(strlen(deviceIn) > sizeof(videodevice))
	{
		printf("The video device name is too long, using default device:%s\n", defaultDev);
		memcpy(videodevice, defaultDev, strlen(defaultDev));
	}
	else
	{
		memcpy(videodevice, deviceIn, strlen(deviceIn));
	}
		//for(;;);
	printf("videodevice=%s\n", videodevice);


	if(widthIn == 320 || widthIn || 640)
	{
		width = widthIn;
	}
	else
	{
		printf("With parameter error, support width is 320 and 640, Using default wotdh: 320\n");
		width = 320;
	}

	if(heightIn == 240 || heightIn == 480)
	{
		height =heightIn;
	}
	else
	{
		printf("Helght parameter error, support height is 240 and 480, Using default height: 240\n");
		height = 240;
	}

	if(formatIn != VIDEO_PALETTE_JPEG)
	{
		printf("Format error, suppot format is: VIDEO_PALETTE_JPEG=21, using default format: VIDEO_PALETTE_JPEG\n");
		format = VIDEO_PALETTE_JPEG;
	}
	else
	{
		format = formatIn;
	}
		

	if(grabmethodIn== methodRead || grabmethodIn== methodMmap)
	{
		grabmethod = grabmethodIn;
	}
	else
	{
		printf("Grab image method error, support method is methodRead =0 and methodMmap = 1, using default method: methodRead\n");
		grabmethod = methodRead;
	}

	initBlist();
}
//overload construct function for convenience 
/*Camera::Camera()
{	
	memcpy(videodevice, "/dev/v4l/video0", strlen("/dev/v4l/video0"));
	format = VIDEO_PALETTE_JPEG;
	grabmethod = methodRead;
	height = 240;
	width = 320;		
}*/
//destroy a camera, just close it
Camera::~Camera()
{
	close_v4l (&videoIn);
}

void Camera::initBlist()
{

	for(int i = 0; i < 21; i++)
	{
		memset(Blist[i].name, 0, sizeof(Blist[i].name));
	}
	
	memcpy(Blist[0].name, "SPCA505", strlen("SPCA505"));
	Blist[0].num = BRIDGE_SPCA505 ;
	
	memcpy(Blist[1].name, "SPCA506", strlen("SPCA506"));
	Blist[1].num = BRIDGE_SPCA506;
	
	memcpy(Blist[2].name, "SPCA501", strlen("SPCA501"));
	Blist[2].num = BRIDGE_SPCA501;
	
	memcpy(Blist[3].name, "SPCA508", strlen("SPCA508"));
	Blist[3].num = BRIDGE_SPCA508;
	
	memcpy(Blist[4].name, "SPCA504", strlen("SPCA504"));
	Blist[4].num = BRIDGE_SPCA504;
	
	memcpy(Blist[5].name, "SPCA500", strlen("SPCA500"));
	Blist[5].num = BRIDGE_SPCA500;
	memcpy(Blist[0].name, "SPCA504B", strlen("SPCA504B"));
	Blist[0].num = BRIDGE_SPCA504B;
	
	memcpy(Blist[6].name, "SPCA533", strlen("SPCA533"));
	Blist[6].num = BRIDGE_SPCA533;
	
	memcpy(Blist[7].name, "SPCA504C", strlen("SPCA504C"));
	Blist[7].num = BRIDGE_SPCA504C;
	
	memcpy(Blist[8].name, "SPCA561", strlen("SPCA561"));
	Blist[8].num = BRIDGE_SPCA561;
	
	memcpy(Blist[9].name, "SPCA536", strlen("SPCA536"));
	Blist[9].num = BRIDGE_SPCA536;
	
	memcpy(Blist[10].name, "SN9C102", strlen("SN9C102"));
	Blist[10].num = BRIDGE_SONIX;
	
	memcpy(Blist[11].name, "ZR364XX", strlen("ZR364XX"));
	Blist[11].num = BRIDGE_ZR364XX;
	
	memcpy(Blist[12].name, "ZC301-2", strlen("ZC301-2"));
	Blist[12].num = BRIDGE_ZC3XX;
	
	memcpy(Blist[13].name, "CX11646", strlen("CX11646"));
	Blist[13].num = BRIDGE_CX11646;
	
	memcpy(Blist[14].name, "TV8532", strlen("TV8532"));
	Blist[14].num = BRIDGE_TV8532;
	
	memcpy(Blist[15].name, "ET61XX51", strlen("ET61XX51"));
	Blist[15].num = BRIDGE_ETOMS;
	
	memcpy(Blist[16].name, "SN9CXXX", strlen("SN9CXXX"));
	Blist[16].num = BRIDGE_SN9CXXX;
	
	memcpy(Blist[17].name, "MR97311", strlen("MR97311"));
	Blist[17].num = BRIDGE_MR97311;
	
	memcpy(Blist[18].name, "UNKNOW", strlen("UNKNOW"));
	Blist[18].num = BRIDGE_UNKNOW;
	
	Blist[19].num = -1;
}
//Init the camera, and create a thread to grab image
void Camera::openCamera()
{
	pthread_attr_t attr;

	 pthread_attr_init(&attr); 
        pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_DETACHED); 
	init_videoIn(&videoIn, videodevice, width, height, format,grabmethod);	
	pthread_create (&grabImgThrdId, NULL, grab, (void*)&videoIn);
	//pthread_create (&grabImgThrdId, &attr, Camera::grab, NULL);
	//pthread_create (&grabImgThrdId, NULL, test, (void*)&tmp);
	 signal(SIGPIPE, SIG_IGN);	/* Ignore sigpipe */

	sigchld_handler();
	sigemptyset(&sa.sa_mask);
	sa.sa_flags = SA_RESTART;
}

void Camera::sigchld_handler()
{
	videoIn.signalquit = 0;
}

//close the cameara
void Camera::closeCamera()
{
	close_v4l (&videoIn);
}

int Camera::readFrame(char *buf)
{
	//int ret;
	int frameout = 1;
	//unsigned char wakeup = 0;
	struct frame_t *headerframe;
	 
	while ((frameout == videoIn.frame_cour) && videoIn.signalquit) 
	{
		printf("Image is not ready, waiting 1 ms\n");
	   	usleep(1000);		
	}	
   
	videoIn.framelock[frameout]++;
	headerframe = (struct frame_t *) videoIn.ptframe[frameout];	
	memcpy(buf, (unsigned char*)(videoIn.ptframe[frameout]+sizeof(struct frame_t)), headerframe->size);
	videoIn.framelock[frameout]--;
	frameout = (frameout+1)%4;     
	return headerframe->size;     
}

void Camera::upbright()
{
	unsigned short bright =0;
	
	bright = videoIn.videopict.brightness;
	
	if(( bright+0x200) < 0xffff)
	{
		bright += 0x200;
		videoIn.videopict.brightness = bright;
		if (SetVideoPict (&videoIn) < 0)
    		{
      			printf("Upbright bright failed\n");
		}
	}
}

void Camera::downbright()
{
	unsigned short bright =0;
	
	bright = videoIn.videopict.brightness;
	
	if(( bright-0x200) > 0)
	{
		bright -= 0x200;
		videoIn.videopict.brightness = bright;
		if (SetVideoPict (&videoIn) < 0)
    		{
      			printf("Down bright failed\n");
		}
	}
}

void Camera::upcontrast()
{
	unsigned short contrast =0;
	
	contrast = videoIn.videopict.contrast;
	
	if((contrast+0x200) < 0xffff)
	{
		contrast += 0x200;
		videoIn.videopict.contrast = contrast;
		
		if (SetVideoPict (&videoIn) < 0)
    		{
      			printf("Up contrast  failed\n");
    		}	
	}
}

void Camera::downcontrast()
{
	unsigned short contrast =0;
	
	contrast = videoIn.videopict.contrast;
	
	if((contrast-0x200) > 0)
	{
		contrast -= 0x200;
		videoIn.videopict.contrast = contrast;
		
		if (SetVideoPict (&videoIn) < 0)
    		{
      			printf("Down contrast  failed\n");
    		}	
	}
}


int Camera::init_videoIn (struct vdIn *vd, char *device, int width, int height, int format, int grabmethod)
{
	int err = -1;
	int i;
	
	if (vd == NULL || device == NULL)
		return -1;
	
	if (width == 0 || height == 0)
		return -1;
	
	if(grabmethod < 0 || grabmethod > 1)		
		grabmethod = 1; //read by default;
		
	// check format 
	vd->videodevice = NULL;
	vd->cameraname = NULL;
	vd->videodevice = NULL;
	vd->videodevice = (char *) realloc (vd->videodevice, 16);
	vd->cameraname = (char *) realloc (vd->cameraname, 32);
	snprintf (vd->videodevice, 12, "%s", device);
	
	if(debug) 
		printf("video %s \n",vd->videodevice);
	
	memset (vd->cameraname, 0, sizeof (vd->cameraname));
	memset(vd->bridge, 0, sizeof(vd->bridge));
	vd->signalquit = 1;
	vd->hdrwidth = width;
	vd->hdrheight = height;
  	/*compute the max frame size   */
	vd->formatIn = format; 
	vd->bppIn = GetDepth (vd->formatIn);
	vd->grabMethod = grabmethod;		//mmap or read 
	vd->pFramebuffer = NULL;
	/* init and check all setting */
	err = init_v4l (vd);
	/* allocate the 4 frames output buffer */
 
	for (i = 0; i < OUTFRMNUMB; i++)
	{
		vd->ptframe[i] = NULL;
		vd->ptframe[i] = (unsigned char *) realloc (vd->ptframe[i], sizeof(struct frame_t) + (size_t) vd->framesizeIn );
		vd->framelock[i] = 0;
	}
 
	vd->frame_cour = 0;  
	pthread_mutex_init (&vd->grabmutex, NULL);
	return err;
}

int Camera::GetDepth (int format)
{
	int depth;
	switch (format)
	{   
		case VIDEO_PALETTE_JPEG:
		{
			depth = 8;
			 break;
		}  
		
		case VIDEO_PALETTE_RAW:
		{
			depth = 8;
			 break;
		}
     
		case VIDEO_PALETTE_YUV420P:
		{
			depth = (8 * 3) >> 1;
			 break;
		}

		case VIDEO_PALETTE_RGB565:
      		{
			depth = 16;
			break;
		}
		
		case VIDEO_PALETTE_RGB24:
		{
			depth = 24;
			break;
		}
		
		case VIDEO_PALETTE_RGB32:
		{
			depth = 32;
			break;
		}
      
		default:
		{
			depth = -1;
			break;
		}
	}
	
	return depth;
}

int Camera::init_v4l (struct vdIn *vd)
{
	int f;
	int erreur = 0;
	
	if ((vd->fd = open (vd->videodevice, O_RDWR)) == -1)
		exit_fatal ("ERROR opening V4L interface");

	if (ioctl (vd->fd, VIDIOCGCAP, &(vd->videocap)) == -1)
		exit_fatal ("Couldn't get videodevice capability");

	if(debug) 
		printf ("Camera found: %s \n", vd->videocap.name);
		snprintf (vd->cameraname, 32, "%s", vd->videocap.name);

	erreur = GetVideoPict (vd);
	if (ioctl (vd->fd, VIDIOCGCHAN, &vd->videochan) == -1)
	{
		if(debug) printf ("Hmm did not support Video_channel\n");
			vd->cameratype = UNOW;
	}
	else
	{
		if (vd->videochan.name)
		{
			if(debug) printf ("Bridge found: %s \n", vd->videochan.name);
				snprintf (vd->bridge, 9, "%s", vd->videochan.name);
			vd->cameratype = GetStreamId (vd->videochan.name);
			spcaPrintParam (vd->fd,&vd->videoparam);
		}
		else
		{
			if(debug) 
				printf ("Bridge not found not a spca5xx Webcam Probing the hardware !!\n");
			vd->cameratype = UNOW;
		}
	}

	/* Only jpeg webcam allowed */
	if(vd->cameratype != JPEG)
	{
		exit_fatal ("Not a JPEG webcam sorry Abort !");
	}
	
	if(debug)
		printf ("StreamId: %d  Camera\n", vd->cameratype);
	
	vd->videopict.palette = vd->formatIn;
	vd->videopict.depth = GetDepth (vd->formatIn);
	vd->bppIn = GetDepth (vd->formatIn);
  
    
	vd->framesizeIn = (vd->hdrwidth * vd->hdrheight >> 2 );
	printf("vd->formatIn=%d\n", vd->formatIn);
	  printf("vd->videopict.depth=%d\n", vd->videopict.depth);
	    printf("vd->bppIn=%d\n", vd->bppIn);
		printf("vd->hdrwidth=%d, vd->hdrheight=%d, vd->framesizeIn=%d\n", vd->hdrwidth, vd->hdrheight,  vd->framesizeIn);
printf("vd->fd=%d\n", vd->fd);
	erreur = SetVideoPict (vd);
	erreur = GetVideoPict (vd);
	
	if (vd->formatIn != vd->videopict.palette || vd->bppIn != vd->videopict.depth)
		exit_fatal ("could't set video palette Abort !");
	
	if (erreur < 0)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
丝袜亚洲另类欧美| 国产麻豆成人精品| 91高清视频在线| 国产精品成人免费在线| 国产成人av电影免费在线观看| 欧美电视剧在线观看完整版| 奇米综合一区二区三区精品视频| 欧美性极品少妇| 亚洲亚洲精品在线观看| 在线视频欧美精品| 亚洲伦在线观看| 色婷婷综合在线| 亚洲美女视频在线| 欧美在线观看视频一区二区| 亚洲一区二区在线视频| 在线观看日韩电影| 亚洲福利电影网| 欧美老女人第四色| 日本不卡高清视频| 日韩精品一区在线观看| 精品一区二区久久| 久久久99精品免费观看| 国产成人综合自拍| 国产精品丝袜久久久久久app| 国产成人久久精品77777最新版本 国产成人鲁色资源国产91色综 | 国产午夜亚洲精品羞羞网站| 国产成人精品免费网站| 日本一区二区久久| av影院午夜一区| 亚洲激情在线激情| 欧美午夜宅男影院| 三级一区在线视频先锋 | 欧美一区二区三区视频在线观看| 日本成人中文字幕| 精品久久久久久久久久久久久久久| 国产在线麻豆精品观看| 欧美激情综合网| 在线看不卡av| 蜜臀久久99精品久久久久宅男| 久久久久国产精品免费免费搜索| 不卡区在线中文字幕| 一区二区三区资源| 欧美日本乱大交xxxxx| 精油按摩中文字幕久久| 国产精品午夜在线观看| 色吧成人激情小说| 日本sm残虐另类| 国产午夜精品久久| 色综合久久九月婷婷色综合| 日韩1区2区日韩1区2区| 国产无一区二区| 91免费在线播放| 日本欧美肥老太交大片| 久久精品一区二区三区四区| 欧美综合久久久| 激情综合网天天干| 成人免费一区二区三区在线观看| 欧美日韩日日骚| 狠狠色丁香婷婷综合| 亚洲视频一二三区| 欧美一区二区视频观看视频| 成人妖精视频yjsp地址| 天天爽夜夜爽夜夜爽精品视频| 精品国产sm最大网站免费看| 一本一道综合狠狠老| 蜜桃av噜噜一区| 亚洲免费成人av| 精品动漫一区二区三区在线观看| 93久久精品日日躁夜夜躁欧美| 麻豆精品在线播放| 综合久久一区二区三区| 91精品国产综合久久香蕉的特点 | 国产精一区二区三区| 亚洲乱码一区二区三区在线观看| 欧美mv和日韩mv的网站| 一本一道波多野结衣一区二区| 久久丁香综合五月国产三级网站| 1024精品合集| 欧美电影免费提供在线观看| 日本丰满少妇一区二区三区| 精品一区二区三区在线视频| 一区二区免费看| 欧美激情一区二区三区不卡| 日韩亚洲欧美在线| 欧美亚洲国产怡红院影院| 国产老肥熟一区二区三区| 午夜影院在线观看欧美| 亚洲欧洲日产国产综合网| 26uuu久久天堂性欧美| 欧美三片在线视频观看| 成人av电影免费在线播放| 免费成人在线观看| 亚洲一区二区成人在线观看| 亚洲国产高清aⅴ视频| 欧美www视频| 91麻豆精品久久久久蜜臀 | 99精品国产91久久久久久| 国内国产精品久久| 日本va欧美va欧美va精品| 亚洲一区视频在线| 亚洲视频一区在线| 中文一区在线播放| 久久久久久麻豆| 精品国产一区久久| 5566中文字幕一区二区电影| 欧美三级日韩三级国产三级| 97se亚洲国产综合自在线不卡| 国产成人av一区二区三区在线 | 蜜乳av一区二区三区| 亚洲成在线观看| 亚洲久本草在线中文字幕| 国产精品系列在线| 欧美极品少妇xxxxⅹ高跟鞋 | 制服.丝袜.亚洲.中文.综合| 欧美天堂一区二区三区| 色噜噜夜夜夜综合网| 成人av在线一区二区| 懂色av噜噜一区二区三区av| 国产一区欧美二区| 精品在线播放免费| 秋霞电影网一区二区| 青青草国产精品亚洲专区无| 日本aⅴ精品一区二区三区| 日韩主播视频在线| 日本不卡一区二区三区| 日韩制服丝袜av| 视频精品一区二区| 日本视频免费一区| 免费在线观看成人| 蜜臀av亚洲一区中文字幕| 日韩av一区二区三区| 午夜国产精品一区| 日韩国产精品久久久| 日韩精品国产精品| 奇米精品一区二区三区四区| 久久精品国产网站| 精品一区二区成人精品| 国产精品18久久久| 成人av网在线| 91丨九色丨蝌蚪富婆spa| 色狠狠综合天天综合综合| 欧美午夜精品一区二区蜜桃| 欧美久久久久久久久久| 欧美一区二区三区公司| 日韩精品一区二| 久久精品在这里| 综合欧美亚洲日本| 亚洲国产精品一区二区www在线 | 亚洲免费在线播放| 夜夜爽夜夜爽精品视频| 首页国产丝袜综合| 麻豆精品久久精品色综合| 国产美女精品人人做人人爽| 粉嫩av一区二区三区在线播放| av一区二区三区四区| 在线中文字幕不卡| 欧美丰满一区二区免费视频| 日韩欧美国产成人一区二区| 久久网这里都是精品| 国产精品久久久久7777按摩| 亚洲一区二区三区视频在线| 丝袜诱惑亚洲看片| 国产美女一区二区三区| 99精品久久久久久| 911国产精品| 久久久久久久久岛国免费| 亚洲视频网在线直播| 亚洲高清不卡在线观看| 精品一二三四在线| 97久久精品人人做人人爽 | 色猫猫国产区一区二在线视频| 欧美日韩成人激情| 久久久综合网站| 亚洲美女一区二区三区| 蜜桃av一区二区三区| 成人福利电影精品一区二区在线观看| 色欧美片视频在线观看| 91精品国产综合久久久蜜臀图片| 久久综合网色—综合色88| 亚洲视频免费观看| 裸体歌舞表演一区二区| hitomi一区二区三区精品| 7777精品伊人久久久大香线蕉完整版| 国产亚洲欧美一区在线观看| 一区二区三区高清在线| 久久99精品国产.久久久久久| 成人国产精品免费网站| 91麻豆精品国产| 国产精品午夜在线观看| 日韩影院在线观看| 成人sese在线| 91精品国产综合久久蜜臀| 中文字幕色av一区二区三区| 日韩成人av影视| 91网站在线观看视频| 日韩欧美一区电影| 一区二区高清视频在线观看| 国产福利精品一区| 9191久久久久久久久久久| 最新国产の精品合集bt伙计|