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

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

?? camera.cpp

?? linux和arm下usb攝像頭圖像的獲取
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
		exit_fatal ("could't set video palette Abort !");

	if (vd->grabMethod)
	{
		if(debug)
			printf (" grabbing method default MMAP asked \n");
		
		// MMAP VIDEO acquisition
		memset (&(vd->videombuf), 0, sizeof (vd->videombuf));
		
		if (ioctl (vd->fd, VIDIOCGMBUF, &(vd->videombuf)) < 0)
		{
			perror (" init VIDIOCGMBUF FAILED\n");
		}
		
		if(debug) 
			printf ("VIDIOCGMBUF size %d  frames %d  offets[0]=%d offsets[1]=%d\n",
			
		vd->videombuf.size, vd->videombuf.frames,
		vd->videombuf.offsets[0], vd->videombuf.offsets[1]);
		vd->pFramebuffer = (unsigned char *) mmap (0, vd->videombuf.size, PROT_READ | PROT_WRITE, MAP_SHARED, vd->fd, 0);
		vd->mmapsize = vd->videombuf.size;
		vd->vmmap.height = vd->hdrheight;
		vd->vmmap.width = vd->hdrwidth;
		vd->vmmap.format = vd->formatIn;
		
		for (f = 0; f < vd->videombuf.frames; f++)
		{
			vd->vmmap.frame = f;
			
			if (ioctl (vd->fd, VIDIOCMCAPTURE, &(vd->vmmap)))
			{
				perror ("cmcapture");
			}
		}
		
		vd->vmmap.frame = 0;
	}
	else
	{
		/* read method */
		/* allocate the read buffer */
		vd->pFramebuffer = (unsigned char *) realloc (vd->pFramebuffer, (size_t) vd->framesizeIn);
		
		if(debug)
			printf (" grabbing method READ asked \n");
		
		if (ioctl (vd->fd, VIDIOCGWIN, &(vd->videowin)) < 0)
			perror ("VIDIOCGWIN failed \n");
		
		vd->videowin.height = vd->hdrheight;
		vd->videowin.width = vd->hdrwidth;
		
		if (ioctl (vd->fd, VIDIOCSWIN, &(vd->videowin)) < 0)
			perror ("VIDIOCSWIN failed \n");
		
		if(debug)
			printf ("VIDIOCSWIN height %d  width %d \n", vd->videowin.height, vd->videowin.width);
	}
	
  vd->frame_cour = 0;
  return erreur;
}

void Camera::exit_fatal(char *messages)
{
	printf("%s \n",messages);
	exit(1);
}

int Camera::GetStreamId (const char *BridgeName)
{
	int i = -1;
	int match = -1;
	
	/* return Stream_id otherwhise -1 */
	if ((match = isSpcaChip (BridgeName)) < 0)
	{
		if(debug) printf ("Not an Spca5xx Camera !!\n");
		return match;
	}
	
	switch (match)
	{
		case BRIDGE_SPCA505:
		case BRIDGE_SPCA506:
		{
			i = YYUV;
			break;
		}
		
		case BRIDGE_SPCA501:
		{
			i = YUYV;
			break;
		}

		case BRIDGE_SPCA508:
		{
			i = YUVY;
			break;
		}
      
		case BRIDGE_SPCA536:
		case BRIDGE_SPCA504:
		case BRIDGE_SPCA500:
		case BRIDGE_SPCA504B:
		case BRIDGE_SPCA533:
		case BRIDGE_SPCA504C:
		case BRIDGE_ZR364XX:
		case BRIDGE_ZC3XX:
		case BRIDGE_CX11646:
		case BRIDGE_SN9CXXX:
		case BRIDGE_MR97311: 
		{
			i = JPEG;
			break;
		}
      
		case BRIDGE_ETOMS:
		case BRIDGE_SONIX:
		case BRIDGE_SPCA561:
		case BRIDGE_TV8532:
		{
			i = GBRG;
     			break;
		}
     	 
		default:
		{
			i = UNOW; // -1;
			if(debug)
				printf ("Unable to find a StreamId !!\n");
			break;
		}
	}

	return i;
}

int Camera::isSpcaChip (const char *BridgeName)
{
	int i = -1;
	int find = -1;
	int size = 0;
  
	/* Spca506 return more with channel video, cut it */
  
	/* return Bridge otherwhise -1 */
	for (i = 0; i < MAX_BRIDGE -1; i++)
	{
		size = strlen(Blist[i].name) ;
		
		if(debug) 
			printf ("is_spca %s \n",Blist[i].name);
		
		if (strncmp (BridgeName, Blist[i].name, size) == 0)
		{
			find = i;
			break;
		}
	}

	return find;
}

void Camera::spcaPrintParam (int fd, struct video_param *videoparam)
{
	if(ioctl(fd,SPCAGVIDIOPARAM, videoparam) == -1)
		printf ("wrong spca5xx device\n");
	else 
		printf("quality %d autoexpo %d Timeframe %d \n", 
		videoparam->quality,videoparam->autobright,videoparam->time_interval);
}

int Camera::SetVideoPict (struct vdIn *vd)
{
	if (ioctl (vd->fd, VIDIOCSPICT, &vd->videopict) < 0)
	{
		printf("vd->fd = %d\n", vd->fd);
		exit_fatal ("Couldnt set videopict params with VIDIOCSPICT");
	}
		

	if(debug) 
		printf ("VIDIOCSPICT brightnes=%d hue=%d color=%d contrast=%d whiteness=%d"
			"depth=%d palette=%d\n", vd->videopict.brightness,
			vd->videopict.hue, vd->videopict.colour, vd->videopict.contrast,
			vd->videopict.whiteness, vd->videopict.depth,
			vd->videopict.palette);

	return 0;
}

 int Camera::GetVideoPict (struct vdIn *vd)
{
	if (ioctl (vd->fd, VIDIOCGPICT, &vd->videopict) < 0)
		exit_fatal ("Couldnt get videopict params with VIDIOCGPICT");

	if(debug) 
		printf ("VIDIOCGPICT brightnes=%d hue=%d color=%d contrast=%d whiteness=%d"
			"depth=%d palette=%d\n", vd->videopict.brightness,
			vd->videopict.hue, vd->videopict.colour, vd->videopict.contrast,
			vd->videopict.whiteness, vd->videopict.depth,
			vd->videopict.palette);

	return 0;
}

void* Camera::grab(void* arg)
{
	int err = 0;
	struct vdIn videoIn = *(struct vdIn *)arg;
	videoIn.signalquit = 1;
	
	for (;;)
	{
		//if(debug) printf("I am the GRABBER !!!!! \n");
		err = Camera::v4lGrab(&videoIn);
		
		if (!videoIn.signalquit || (err < 0))
		{
			if(debug)
				printf("GRABBER going out !!!!! \n");
			printf("err=%d\n", err);
			printf("videoIn.signalquit =%d\n", videoIn.signalquit);
			
			break;
			
		}
	}

	return 0;
}

int Camera::v4lGrab (struct vdIn *vd )
{
	struct frame_t *headerframe;
	double timecourant =0;
	static int frame = 0;
	double temps = 0;
	int jpegsize = 0;
	int erreur = 0;
	int size;
	int len;  
	
	timecourant = ms_time();
	
	if (vd->grabMethod == methodMmap)
	{     
		vd->vmmap.height = vd->hdrheight;
		vd->vmmap.width = vd->hdrwidth;
		vd->vmmap.format = vd->formatIn;
		
		if (ioctl (vd->fd, VIDIOCSYNC, &vd->vmmap.frame) < 0)
		{
			perror ("cvsync err\n");
			erreur = -1;
		}
     
		/* Is there someone using the frame */  
		while((vd->framelock[vd->frame_cour] != 0) && vd->signalquit)
			usleep(1000);
		
		pthread_mutex_lock (&vd->grabmutex);
		
		temps = ms_time();
		jpegsize= convertframe(vd->ptframe[vd->frame_cour]+ sizeof(struct frame_t),
							vd->pFramebuffer + vd->videombuf.offsets[vd->vmmap.frame],
							vd->hdrwidth,vd->hdrheight,vd->formatIn,vd->framesizeIn);
	
		headerframe=(struct frame_t*)vd->ptframe[vd->frame_cour];
		snprintf(headerframe->header,5,"%s","SPCA"); 
		headerframe->seqtimes = ms_time();
		headerframe->deltatimes=(int)(headerframe->seqtimes-timecourant); 
		headerframe->w = vd->hdrwidth;
		headerframe->h = vd->hdrheight;
		headerframe->size = (( jpegsize < 0)?0:jpegsize);
		headerframe->format = vd->formatIn;
		headerframe->nbframe = frame++;
		
		pthread_mutex_unlock (&vd->grabmutex); 
		
		/************************************/
	
		if ((ioctl (vd->fd, VIDIOCMCAPTURE, &(vd->vmmap))) < 0)
		{
			perror ("cmcapture");
			
			if(debug) 
				printf (">>cmcapture err \n");
			
			erreur = -1;
		}
		
		vd->vmmap.frame = (vd->vmmap.frame + 1) % vd->videombuf.frames;
		vd->frame_cour = (vd->frame_cour +1) % OUTFRMNUMB;	  
	}
	else if(vd->grabMethod == methodRead)
	{
		/* read method */
		size = vd->framesizeIn;
		len = read (vd->fd, vd->pFramebuffer, size);
		
		if (len < 0 )
		{
			if(debug)
				printf ("v4l read error\n");
			
			if(debug)
				printf ("len %d asked %d \n", len, size);
			
			return 0;
		}
	
		/* Is there someone using the frame */
		while((vd->framelock[vd->frame_cour] != 0)&& vd->signalquit)
			usleep(1000);
		
		pthread_mutex_lock (&vd->grabmutex);

		temps = ms_time();
		jpegsize= convertframe(vd->ptframe[vd->frame_cour]+ sizeof(struct frame_t),
							vd->pFramebuffer ,
							vd->hdrwidth,vd->hdrheight,vd->formatIn,vd->framesizeIn); 
	
		headerframe=(struct frame_t*)vd->ptframe[vd->frame_cour];
		snprintf(headerframe->header,5,"%s","SPCA"); 
		headerframe->seqtimes = ms_time();
		headerframe->deltatimes=(int)(headerframe->seqtimes-timecourant); 
		headerframe->w = vd->hdrwidth;
		headerframe->h = vd->hdrheight;
		headerframe->size = (( jpegsize < 0)?0:jpegsize); 
		headerframe->format = vd->formatIn; 
		headerframe->nbframe = frame++; 	
		vd->frame_cour = (vd->frame_cour +1) % OUTFRMNUMB;  
		
		pthread_mutex_unlock (&vd->grabmutex); 	     
	}
	
	return erreur;
}

double Camera::ms_time (void)
{
	static struct timeval tod;
	
	gettimeofday(&tod, NULL);	
	return ((double) tod.tv_sec * 1000.0 + (double) tod.tv_usec / 1000.0);
}

int Camera::convertframe(unsigned char *dst,unsigned char *src, int width,int height, int formatIn, int size)
{
	int jpegsize =0;
	
	switch (formatIn)
	{
		case VIDEO_PALETTE_JPEG:
		{
			jpegsize = get_jpegsize(src, size);
			if (jpegsize < 0)
				break;
			memcpy(dst,src,jpegsize);	
			break;
		}
		
		default:
			break;
	}
	
	return jpegsize;
}

int Camera::get_jpegsize (unsigned char *buf, int insize)
{
	int i; 
	
	for ( i= 1024 ; i< insize; i++) 
	{
		if ((buf[i] == 0xFF) && (buf[i+1] == 0xD9)) 
			return i+10;
	}
	
	return -1;
}

int Camera::close_v4l (struct vdIn *vd)
{
	int i;
	
	if (vd->grabMethod)
	{
		if(debug) 
			printf ("unmapping frame buffer\n");
		
		munmap (vd->pFramebuffer, vd->mmapsize);
	} 
	else 
	{
		free(vd->pFramebuffer);
		vd->pFramebuffer = NULL;
	}
	
	if(debug) 
		printf ("close video_device\n");  
	
	close (vd->fd);
	
	/* dealloc the whole buffers */
	if (vd->videodevice)
	{
		free (vd->videodevice);
		vd->videodevice = NULL;
	}
	
	if (vd->cameraname)
	{
		free (vd->cameraname);
		vd->cameraname = NULL;
	}
	
	for (i = 0; i < OUTFRMNUMB; i++)
	{
		if (vd->ptframe[i])
		{
			free (vd->ptframe[i]);
			vd->ptframe[i] = NULL;
			vd->framelock[i] = 0;
			
			if(debug) 
				printf ("freeing output buffer %d\n",i);
		}
	}
	
	pthread_mutex_destroy (&vd->grabmutex);

	return 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品久久一二三区| 日韩精品一区二区三区视频播放| 欧美视频一区二区三区四区| 欧美成人免费网站| 一区二区免费看| 欧美精品xxxxbbbb| 国产女人18毛片水真多成人如厕 | 91激情在线视频| 精品久久一二三区| 天天综合日日夜夜精品| 成人性生交大片免费看在线播放| 欧美精品一二三四| 亚洲视频香蕉人妖| 东方欧美亚洲色图在线| 日韩久久免费av| 婷婷综合另类小说色区| 99re热视频精品| 中文字幕在线观看不卡| 国内偷窥港台综合视频在线播放| 欧美日韩在线三级| 一区二区免费视频| 在线观看日韩国产| 伊人一区二区三区| av中文字幕一区| 中文字幕中文字幕一区二区 | 91理论电影在线观看| 国产精品日韩成人| 成人精品在线视频观看| 国产亚洲欧美激情| 粉嫩高潮美女一区二区三区| 国产亚洲欧美一级| 粉嫩aⅴ一区二区三区四区五区| 久久先锋影音av鲁色资源网| 老色鬼精品视频在线观看播放| 日韩亚洲欧美综合| 久久精品国产精品亚洲精品| 亚洲精品在线免费观看视频| 精品一二线国产| 久久蜜桃香蕉精品一区二区三区| 精品一区二区三区免费播放| 久久综合中文字幕| 国产福利一区二区三区| 国产精品日产欧美久久久久| 99久久综合99久久综合网站| 亚洲精选视频免费看| 91福利小视频| 日韩电影网1区2区| 久久精品夜色噜噜亚洲a∨| 粉嫩av亚洲一区二区图片| 亚洲精品网站在线观看| 欧美日韩视频专区在线播放| 麻豆一区二区99久久久久| 欧美电影免费观看完整版| 懂色av一区二区夜夜嗨| 亚洲天堂2014| 中文字幕亚洲一区二区av在线| 9i看片成人免费高清| 亚洲成a人v欧美综合天堂 | 中文字幕不卡的av| 99久久免费精品| 天天av天天翘天天综合网| 精品人伦一区二区色婷婷| 成人av在线影院| 亚洲成人av中文| 久久久久久97三级| 欧美在线视频日韩| 国内精品嫩模私拍在线| 中文字幕字幕中文在线中不卡视频| 欧美精品日韩一本| 粉嫩av亚洲一区二区图片| 亚洲成人av一区二区三区| 国产日韩欧美精品电影三级在线 | 久久众筹精品私拍模特| 91麻豆swag| 国产一区二区h| 亚洲高清在线视频| 国产日韩欧美不卡在线| 欧美少妇一区二区| 成人综合婷婷国产精品久久免费| 亚洲午夜影视影院在线观看| 国产欧美一区二区三区在线老狼| 欧美日韩免费一区二区三区| 国产高清无密码一区二区三区| 亚洲电影在线播放| 中文字幕av一区二区三区| 91精品在线免费观看| 91蝌蚪porny| 国产成人免费在线观看| 日本亚洲视频在线| 一区二区三区久久久| 国产精品视频一二三区| 精品人在线二区三区| 亚洲精品一二三四区| 中文字幕免费观看一区| 日韩午夜在线播放| 欧美午夜片在线看| 成人激情午夜影院| 国产一区二区三区免费| 久久精品国产免费| 青青草国产成人av片免费| 亚洲成a人片综合在线| 一区二区三区资源| **网站欧美大片在线观看| 久久这里都是精品| 欧美mv日韩mv国产| 日韩欧美一区二区视频| 91精品国产综合久久久蜜臀粉嫩| 日本精品一区二区三区高清| 99久久国产综合精品女不卡| 成人蜜臀av电影| voyeur盗摄精品| 成人国产精品免费观看动漫| 福利电影一区二区| 成人一区在线观看| 不卡av电影在线播放| 成人av资源在线| 波多野洁衣一区| 波多野结衣在线一区| 成人动漫精品一区二区| 不卡av在线网| 91碰在线视频| 欧洲视频一区二区| 欧美三级资源在线| 欧美精品粉嫩高潮一区二区| 日韩小视频在线观看专区| 日韩精品电影在线观看| 麻豆精品视频在线| 国产一区二区三区在线观看免费| 久久99国产精品久久99| 国产精品综合网| 成人污污视频在线观看| 99天天综合性| 欧美日韩一区 二区 三区 久久精品| 欧美在线|欧美| 51午夜精品国产| 久久久国产精品不卡| 亚洲婷婷综合久久一本伊一区 | 欧美激情中文不卡| 亚洲免费av网站| 日韩国产欧美一区二区三区| 狠狠色综合色综合网络| 国产精品一区二区在线播放| 99riav久久精品riav| 欧美日韩中文精品| 久久综合九色综合欧美亚洲| 亚洲欧美在线视频观看| 午夜精品久久一牛影视| 国产一区二区三区日韩| 日本精品视频一区二区三区| 日韩精品一区二区三区三区免费| 国产精品亲子乱子伦xxxx裸| 亚洲第一综合色| 国内精品视频一区二区三区八戒| 91美女片黄在线| 精品国产制服丝袜高跟| 亚洲欧美另类图片小说| 精品综合久久久久久8888| 91在线无精精品入口| 日韩亚洲欧美一区| 亚洲欧美日韩中文字幕一区二区三区| 日韩电影网1区2区| 91在线精品一区二区三区| 91精品国产aⅴ一区二区| 国产欧美日韩精品在线| 琪琪久久久久日韩精品| 日本精品裸体写真集在线观看| 日韩欧美二区三区| 亚洲激情中文1区| 国产不卡视频一区| 日韩欧美国产综合| 亚洲综合丝袜美腿| 成人激情图片网| 2021中文字幕一区亚洲| 无吗不卡中文字幕| 91在线高清观看| 国产欧美一区二区精品仙草咪| 日韩精品成人一区二区在线| 91久久奴性调教| 国产精品久久久一本精品| 精品一区二区三区蜜桃| 91精品午夜视频| 亚洲一区二区视频在线观看| 成人自拍视频在线| 国产日韩亚洲欧美综合| 另类调教123区| 日韩网站在线看片你懂的| 亚洲一区二区三区三| 色综合久久九月婷婷色综合| 中文字幕在线观看不卡| 成人一区二区三区视频| 久久一夜天堂av一区二区三区| 蜜臀精品久久久久久蜜臀| 欧美精品亚洲二区| 亚洲成av人在线观看| 欧美日韩国产三级| 亚洲成在线观看| 日韩码欧中文字| 99久久99久久精品免费看蜜桃| 亚洲国产成人私人影院tom| 丁香婷婷综合色啪|