在好例子网,分享、交流、成长!
您当前所在位置:首页C/C++ 开发实例嵌入式开发 → 光照度计传感器

光照度计传感器

嵌入式开发

下载此实例
  • 开发语言:C/C++
  • 实例大小:6.16M
  • 下载次数:13
  • 浏览次数:96
  • 发布时间:2021-08-01
  • 实例类别:嵌入式开发
  • 发 布 人:残迹
  • 文件格式:.rar
  • 所需积分:2
 相关标签: 传感器

实例介绍

【实例简介】STM32_GY_39光照度计应用示例

【实例截图】

from clipboard

【核心代码】

#include <color.h>
#include <delay.h>
#include <oled.h>

u8 Rgena,Ggena,Bgena;
u16 Ramount,Gamount,Bamount;
u16 amount;

//float Max=0,Min=0;
//float Rhsv=0,Ghsv=0,Bhsv=0;
//float H=0,S=0,V=0;
u8 R=0x00,G=0x00,B=0x00;
//u16 RGB=0x0000;

void Color_Init(void)
{
	GPIO_InitTypeDef GPIO_InitStruct;
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE);
	
	GPIO_InitStruct.GPIO_Pin = GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_8|GPIO_Pin_9;
	GPIO_InitStruct.GPIO_Mode = GPIO_Mode_Out_PP;
	GPIO_InitStruct.GPIO_Speed = GPIO_Speed_50MHz;
	GPIO_Init(GPIOB,&GPIO_InitStruct);
	
	GPIO_SetBits(GPIOB, GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_8|GPIO_Pin_9);

}
//*************外部中断线7***************/
void EXTIX_Init(void)
{
	GPIO_InitTypeDef GPIO_InitStruct;
	EXTI_InitTypeDef EXTI_InitStruct;
	NVIC_InitTypeDef NVIC_InitStruct;
	
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB|RCC_APB2Periph_AFIO, ENABLE);
	
	GPIO_InitStruct.GPIO_Pin = GPIO_Pin_7;
	GPIO_InitStruct.GPIO_Mode = GPIO_Mode_AIN;
	GPIO_Init(GPIOB,&GPIO_InitStruct);
	GPIO_SetBits(GPIOB, GPIO_Pin_7);
	
	GPIO_EXTILineConfig(GPIO_PortSourceGPIOB, GPIO_PinSource7);
	
	EXTI_InitStruct.EXTI_Line = EXTI_Line7;
	EXTI_InitStruct.EXTI_LineCmd = ENABLE;
	EXTI_InitStruct.EXTI_Mode = EXTI_Mode_Interrupt;
	EXTI_InitStruct.EXTI_Trigger = EXTI_Trigger_Falling;
	EXTI_Init(&EXTI_InitStruct);
	
	NVIC_InitStruct.NVIC_IRQChannel = EXTI9_5_IRQn;
	NVIC_InitStruct.NVIC_IRQChannelCmd = ENABLE;
	NVIC_InitStruct.NVIC_IRQChannelPreemptionPriority = 0;
	NVIC_InitStruct.NVIC_IRQChannelSubPriority = 0;
	NVIC_Init(&NVIC_InitStruct);
}

void EXTI9_5_IRQHandler(void)
{
	amount  ;
	EXTI_ClearITPendingBit(EXTI_Line7);
}
/*******************************************
*
*		  白平衡
*
*******************************************/
void whitebalance(void)
{
	EXTI9_5_IRQHandler();		 //外部中断初始化
	S2=0;S3=0;//红色通道
	amount=0;			 //开始计数
	delay_ms(10);
	Rgena = amount;   //求出红色因子      
	amount=0;
//----------------------------------
	S2=1;S3=1;//绿色通道
	amount=0;
	delay_ms(10);
	Ggena = amount;	 //求出绿色因子
	amount=0;
//----------------------------------
	S2=0;S3=1;//蓝色通道
	amount=0;
	delay_ms(10);
	Bgena = amount;	  //求出蓝色因子
	amount=0;
	S2=1;S3=0;//关闭通道  	  
}
//********************************************
//读取RGB值
//********************************************
u16 Color_RED(void)
{
	S2=0;S3=0;
	amount=0;
	delay_ms(10);
	Ramount=(u32) amount*255/Rgena;	 //取R值
	if(Ramount>255) Ramount = 255;
	return Ramount;
//	amount=0;
}

u16 Color_GREEN(void)
{
	S2=1;S3=1;
	amount=0;
	delay_ms(10);
	Gamount=(u32) amount*255/Ggena;	//取G值
	if(Gamount>255) Gamount = 255;
	return Gamount;
//	amount=0;
}

u16 Color_BLUE(void)
{
	S2=0;S3=1;
	amount=0;
	delay_ms(10);
	Bamount=(u32) amount*255/Bgena;//去B值
	if(Bamount>255) Bamount = 255;
	return Bamount;
//	amount=0;
} 

void Color_HSV(void)
{
	//=================================================================================
		R = Color_RED();
		G = Color_GREEN();	//取RGB值
		B = Color_BLUE();	 
//================================================================================
//		Rhsv = (float) R/25/10;
//		Ghsv = (float) G/25/10;	 //RGB转换成0,1.
//		Bhsv = (float) B/25/10;

////=================================================================================
////RGB转HSV算法
///********************************************************/
//		Max = (Rhsv>Ghsv)?Rhsv:Ghsv;				
//		Max = (Max>Bhsv)?Max:Bhsv;		//取RGB最大值
//		Min = (Rhsv<Ghsv)?Rhsv:Ghsv;				
//		Min = (Min<Bhsv)?Min:Bhsv;		//去RGB最小值
//																
//		if(Rhsv==Max) H = (Ghsv-Bhsv)/(Max-Min);	
//		if(Ghsv==Max) H = 2 (Bhsv-Rhsv)/(Max-Min);	
//		if(Bhsv==Max) H = 4 (Rhsv-Ghsv)/(Max-Min);	
//		H =(int) (H*60);									                
//		if(H<0) H = H 360;													 
//																		   	  
//		V = (Rhsv>Ghsv)?Rhsv:Ghsv;											
//		V = (V>Bhsv)?V:Bhsv;		//取V的数值									
//																				 
//		S = (Max-Min)/Max;			//取S的数值								
//																				 
//		V = (int) (V*100);															
//		S = (int) (S*100);															 
//======================================================================================================
		OLED_ShowNum(0,0,R,5,12);  //显示一个数字
		OLED_ShowNum(0,12,G,5,12);  //显示一个数字
		OLED_ShowNum(0,24,B,5,12);  //显示一个数字
//		OLED_ShowNum(0,36,H,5,12);  //显示一个数字
//		OLED_ShowNum(0,48,V,5,12);  //显示一个数字
//		OLED_ShowNum(0,50,S,5,12);  //显示一个数字
		delay_ms(50);
}

标签: 传感器

实例下载地址

光照度计传感器

不能下载?内容有错? 点击这里报错 + 投诉 + 提问

好例子网口号:伸出你的我的手 — 分享

网友评论

发表评论

(您的评论需要经过审核才能显示)

查看所有0条评论>>

小贴士

感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。

  • 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
  • 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
  • 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
  • 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。

关于好例子网

本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明

;
报警