作者:楚风狂 | 更新时间:2016-06-01 | 浏览量:7164
夏普GP2Y1010AU0F图片
GP2Y1010AU0F引脚图
序号 | 名称 | 作用 |
---|---|---|
1 | V-LED | LED供电 |
2 | LED-GND | LED GND |
3 | LED | LED控制 |
4 | S-GND | 传感器GND |
5 | VO | 检测结果电压模拟量输出 |
6 | VCC | 供电 |
GP2Y1010AU0F接线图
程序代码
/* Arduino连接夏普GP2Y1010AU0F空气质量传感器检测PM2.5 些程序也适用于用 Arduino IDE 开发 ESP8266 */ /* 定义引脚 */ #define PIN_DATA_OUT A0 //连接空气质量传感器模拟量输出的IO口 #define PIN_LED_VCC 2 //空气质量传感器中为内部Led供电的引脚 /* 定义时间 */ const int DELAY_BEFORE_SAMPLING = 280; //采样前等待时间 const int DELAY_AFTER_SAMPLING = 40; //采样后等待时间 const int DELAY_LED_OFF = 9680; //间隔时间 /** 读取输出电压 */ double getOutputV() { digitalWrite(PIN_LED_VCC, LOW); delayMicroseconds(DELAY_BEFORE_SAMPLING); double analogOutput = analogRead(PIN_DATA_OUT); delayMicroseconds(DELAY_AFTER_SAMPLING); digitalWrite(PIN_LED_VCC, HIGH); delayMicroseconds(DELAY_LED_OFF); //Arduino模拟量读取值的范围为0~1023,以下换算为0~5v double outputV = analogOutput / 1024 * 5; return outputV; } /** 根据输出电压计算灰尘密度 */ double getDustDensity(double outputV) { //输出电压和灰尘密度换算公式: ug/m3 = (V - 0.9) / 5 * 1000 double ugm3 = (outputV - 0.9) / 5 * 1000; //去除检测不到的范围 if (ugm3 < 0) { ugm3 = 0; } return ugm3; } /** 根据灰尘密度计算AQI 环境空气质量指数(AQI)技术规定(试行)](http://kjs.mep.gov.cn/hjbhbz/bzwb/dqhjbh/jcgfffbz/201203/t20120302_224166.htm */ double getAQI(double ugm3) { double aqiL = 0; double aqiH = 0; double bpL = 0; double bpH = 0; double aqi = 0; //根据pm2.5和aqi对应关系分别计算aqi if (ugm3 >= 0 && ugm3 <= 35) { aqiL = 0; aqiH = 50; bpL = 0; bpH = 35; } else if (ugm3 > 35 && ugm3 <= 75) { aqiL = 50; aqiH = 100; bpL = 35; bpH = 75; } else if (ugm3 > 75 && ugm3 <= 115) { aqiL = 100; aqiH = 150; bpL = 75; bpH = 115; } else if (ugm3 > 115 && ugm3 <= 150) { aqiL = 150; aqiH = 200; bpL = 115; bpH = 150; } else if (ugm3 > 150 && ugm3 <= 250) { aqiL = 200; aqiH = 300; bpL = 150; bpH = 250; } else if (ugm3 > 250 && ugm3 <= 350) { aqiL = 300; aqiH = 400; bpL = 250; bpH = 350; } else if (ugm3 > 350) { aqiL = 400; aqiH = 500; bpL = 350; bpH = 500; } //公式aqi = (aqiH - aqiL) / (bpH - bpL) * (desity - bpL) + aqiL; aqi = (aqiH - aqiL) / (bpH - bpL) * (ugm3 - bpL) + aqiL; return aqi; } /** 根据aqi获取级别描述 */ String getGradeInfo(double aqi) { String gradeInfo; if (aqi >= 0 && aqi <= 50) { gradeInfo = String("Perfect"); } else if (aqi > 50 && aqi <= 100) { gradeInfo = String("Good"); } else if (aqi > 100 && aqi <= 150) { gradeInfo = String("Mild polluted"); } else if (aqi > 150 && aqi <= 200) { gradeInfo = String("Medium polluted"); } else if (aqi > 200 && aqi <= 300) { gradeInfo = String("Heavily polluted"); } else if (aqi > 300 && aqi <= 500) { gradeInfo = String("Severely polluted"); } else { gradeInfo = String("Broken roof!!!"); } return gradeInfo; } void setup() { Serial.begin(115200); pinMode(PIN_DATA_OUT, INPUT); //定义为输入(ADC读取模拟量) pinMode(PIN_LED_VCC, OUTPUT); //定义为输出 } void loop() { double outputV = getOutputV(); //采样获取输出电压 double ugm3 = getDustDensity(outputV); //计算灰尘浓度 double aqi = getAQI(ugm3); //计算aqi String gradeInfo = getGradeInfo(aqi); //计算级别 //打印到串口 Serial.println(String("outputV=") + outputV + "\tug/m3=" + ugm3 + "\tAQI=" + aqi + "\tgradeInfo=" + gradeInfo); //间隔1秒执行下次检测 delay(1000); }
输出结果
outputV=1.05 ug/m3=29.96 AQI=42.80 gradeInfo=Perfect outputV=1.36 ug/m3=92.46 AQI=121.83 gradeInfo=Mild polluted outputV=1.29 ug/m3=77.81 AQI=103.52 gradeInfo=Mild polluted outputV=1.16 ug/m3=51.45 AQI=70.56 gradeInfo=Good outputV=1.12 ug/m3=43.63 AQI=60.79 gradeInfo=Good outputV=1.26 ug/m3=72.93 AQI=97.41 gradeInfo=Good
本文大多摘自http://blog.fantasymaker.cn/2016/01/10/pm25-aqi-detector-based-on-nodemcu/
更多信息请自行查看
关于联网请参考网站文档,这里不在重复。
关于数据上传这里给大家分享一个函数格式供大家参考
void update1(int did, int inputid1, int inputid2,int inputid3,float value1 ,float value2,float value3) // 定义一次传递3个参数的函数
{
String str1="{\"M\":\"update\",\"ID\":\"";
str1+=did;
str1+="\",\"V\":{\"";
str1+=inputid1;
str1+="\":\"";
str1+=value1;
str1+="\",\"" ;
str1+=inputid2;
str1+="\":\"";
str1+=value2;
str1+="\",\"" ;
str1+=inputid3;
str1+="\":\"";
str1+=value3;
str1+="\"" ;
str1+="}}\n";
client.print(str1);
//下面是串口打印 传递到服务器的信息,以便调试
Serial.print("update:");
Serial.print(inputid1);
Serial.print("->");
Serial.println(value1);
Serial.print("update:");
Serial.print(inputid2);
Serial.print("->");
Serial.println(value2);
Serial.print("update:");
Serial.print(inputid3);
Serial.print("->");
Serial.println(value3);
}
此函数出自网友 疯狂的小车 借鉴网友 在路上 的劳动成果并发表的 ”用ESP8266传递BMP180的温度的气压到贝壳云“一文
*所有图片和程序均来源于互连网,本人只是重新整理发布。如有侵权请及时联系网站管理员或作者。谢谢