wwwyyy317 发表于 2017-4-13 19:32:46

攀藤G1 LCD12864显示(含中美标准)

本人新手,借鉴网上诸位大神的代码(不胜感谢),修修补补改改。终于拼凑出一套代码,可以在LCD 12864上显示PM1 PM2.5 PM10中美两种参数了(左为国标,右为美标)。给有需要的玩家参考,也请高手不吝指教!

下一步计划加入时钟,温湿度等传感器,实现翻页显示!/**
* PM2.5&温湿度显示
* 激光PM2.5传感器:攀藤 G1 PMS1003
* Arduino MEGA 2560
* LCD 12864 ST7920
* 2017-4-12
*/

#include <U8glib.h>
#include <SoftwareSerial.h>

SoftwareSerial mySerial(10, 11);         //定义G1软串口接口(RX TX)
U8GLIB_ST7920_128X64 u8g(3, 9, 8, U8G_PIN_NONE);//SPI    接线

struct PARAMS {
//中国标准
long P1;//显示PM1.0
long _P1;//读取PM1.0
long P2;//显示PM2.5
long _P2;//读取PM2.5
long P3;//显示PM10
long _P3;//读取PM10
//美国标准
long FP1;//显示PM1.0
long _FP1;//读取PM1.0
long FP2;//显示PM2.5
long _FP2;//读取PM2.5
long FP3;//显示PM10
long _FP3;//读取PM10
} _params;

//G5 相关变量
static unsigned char ucRxBuffer;
static unsigned char ucRxCnt = 0;

//循环计数器
unsigned char loopCnt = 0;

void setup() {
Serial.begin(9600);
//软串口读取G1
mySerial.begin(9600);
delay(500);
//设置屏幕字体和背景颜色
u8g.setColorIndex(255);
u8g.setHiColorByRGB(255, 255, 255);
delay(800);
}
//中国标准参数部分字体位置 设置
void showPM1(void) {
int x = 0, y = 0;//PM1.0显示位置
//画LOGO
u8g.drawRFrame(x, y, 15, 15, 1);
u8g.setFont(u8g_font_04b_03b);
u8g.setPrintPos(x + 3, y + 5);
u8g.print("pm");
u8g.setPrintPos(x + 6, y + 12);
u8g.print("1");
u8g.setFont(u8g_font_timB10);
u8g.setPrintPos(x + 18, y + 12);
u8g.print(":");
//设置双倍大小字体显示
u8g.setScale2x2();
u8g.setPrintPos(x / 2 + 11, y / 2 + 7);
u8g.setFont(u8g_font_orgv01);
u8g.print(_params.P1);
u8g.undoScale();
}
void showPM25(void) {
int x = 0, y = 17;//PM2.5显示位置
//画LOGO
u8g.drawRFrame(x, y, 15, 15, 1);
u8g.setFont(u8g_font_04b_03b);
u8g.setPrintPos(x + 3, y + 5);
u8g.print("pm");
u8g.setPrintPos(x + 2, y + 12);
u8g.print("2.5");
u8g.setFont(u8g_font_timB10);
u8g.setPrintPos(x + 18, y + 12);
u8g.print(":");
//设置双倍大小字体显示
u8g.setScale2x2();
u8g.setPrintPos(x / 2 + 11, y / 2 + 7);
   u8g.setFont(u8g_font_orgv01);
u8g.print(_params.P2);
u8g.undoScale();
}
void showPM10(void) {
int x = 0, y = 34;//PM2.5显示位置
//画LOGO
u8g.drawRFrame(x, y, 15, 15, 1);
u8g.setFont(u8g_font_04b_03b);
u8g.setPrintPos(x + 3, y + 5);
u8g.print("pm");
u8g.setPrintPos(x + 4, y + 12);
u8g.print("10");
u8g.setFont(u8g_font_timB10);
u8g.setPrintPos(x + 18, y + 12);
u8g.print(":");
//设置双倍大小字体显示
u8g.setScale2x2();
u8g.setPrintPos(x / 2 + 11, y / 2 + 7);
   u8g.setFont(u8g_font_orgv01);
u8g.print(_params.P3);
u8g.undoScale();
}


//美国标准
void showFPM1(void) {
int x = 64, y = 0;//PM1.0显示位置
//画LOGO
u8g.drawRFrame(x, y, 15, 15, 1);
u8g.setFont(u8g_font_04b_03b);
u8g.setPrintPos(x + 3, y + 5);
u8g.print("pm");
u8g.setPrintPos(x + 6, y + 12);
u8g.print("1");
u8g.setFont(u8g_font_timB10);
u8g.setPrintPos(x + 18, y + 12);
u8g.print(":");
//设置双倍大小字体显示
u8g.setScale2x2();
u8g.setPrintPos(x / 2 + 11, y / 2 + 7);
u8g.setFont(u8g_font_orgv01);
u8g.print(_params.FP1);
u8g.undoScale();
}
void showFPM25(void) {
int x = 64, y = 17;//PM2.5显示位置
//画LOGO
u8g.drawRFrame(x, y, 15, 15, 1);
u8g.setFont(u8g_font_04b_03b);
u8g.setPrintPos(x + 3, y + 5);
u8g.print("pm");
u8g.setPrintPos(x + 2, y + 12);
u8g.print("2.5");
u8g.setFont(u8g_font_timB10);
u8g.setPrintPos(x + 18, y + 12);
u8g.print(":");
//设置双倍大小字体显示
u8g.setScale2x2();
u8g.setPrintPos(x / 2 + 11, y / 2 + 7);
   u8g.setFont(u8g_font_orgv01);
u8g.print(_params.FP2);
u8g.undoScale();
}
void showFPM10(void) {
int x = 64, y = 34;//PM10 显示位置
//画LOGO
u8g.drawRFrame(x, y, 15, 15, 1);
u8g.setFont(u8g_font_04b_03b);
u8g.setPrintPos(x + 3, y + 5);
u8g.print("pm");
u8g.setPrintPos(x + 4, y + 12);
u8g.print("10");
u8g.setFont(u8g_font_timB10);
u8g.setPrintPos(x + 18, y + 12);
u8g.print(":");
//设置双倍大小字体显示
u8g.setScale2x2();
u8g.setPrintPos(x / 2 + 11, y / 2 + 7);
u8g.setFont(u8g_font_orgv01);
u8g.print(_params.FP3);
u8g.undoScale();

}



//画界面
void draw(void) {
showPM1();
showPM25();
showPM10();
showFPM1();
showFPM25();
showFPM10();
}




//获取PM2.5的值
void getPM25(unsigned char ucData) {

ucRxBuffer = ucData;

if (ucRxBuffer != 0x42 && ucRxBuffer != 0x4D){
    ucRxCnt = 0;
}
if (ucRxCnt > 31) {
_params._P1 = (float)ucRxBuffer * 256 + (float)ucRxBuffer;   
_params._P2 = (float)ucRxBuffer * 256 + (float)ucRxBuffer;
   _params._P3 = (float)ucRxBuffer * 256 + (float)ucRxBuffer; //中国标准
_params._FP1 = (float)ucRxBuffer * 256 + (float)ucRxBuffer;   
_params._FP2 = (float)ucRxBuffer * 256 + (float)ucRxBuffer;
   _params._FP3 = (float)ucRxBuffer * 256 + (float)ucRxBuffer; //美国标准
    ucRxCnt = 0;

return ucRxCnt;
}
}
//中位值平均滤波,处理PM1.0的值
#define FILTER_N 5
int Filter1() {
int i;
int filter_sum = 0;
int filter_max, filter_min;
int filter_buf;
for (i = 0; i < FILTER_N; i++) {
filter_buf = _params._P1;
delay(1);
}
filter_max = filter_buf;
filter_min = filter_buf;
filter_sum = filter_buf;
for (i = FILTER_N - 1; i > 0; i--) {
if (filter_buf > filter_max)
filter_max = filter_buf;
else if (filter_buf < filter_min)
filter_min = filter_buf;
filter_sum = filter_sum + filter_buf;
filter_buf = filter_buf;
}
i = FILTER_N - 2;
filter_sum = filter_sum - filter_max - filter_min + i / 2; // +i/2 的目的是为了四舍五入
filter_sum = filter_sum / i;
return filter_sum;
}
//中位值平均滤波,处理PM2.5的值
#define FILTER_N 5
int Filter2() {
int i;
int filter_sum = 0;
int filter_max, filter_min;
int filter_buf;
for (i = 0; i < FILTER_N; i++) {
filter_buf = _params._P2;
delay(1);
}
filter_max = filter_buf;
filter_min = filter_buf;
filter_sum = filter_buf;
for (i = FILTER_N - 1; i > 0; i--) {
if (filter_buf > filter_max)
filter_max = filter_buf;
else if (filter_buf < filter_min)
filter_min = filter_buf;
filter_sum = filter_sum + filter_buf;
filter_buf = filter_buf;
}
i = FILTER_N - 2;
filter_sum = filter_sum - filter_max - filter_min + i / 2; // +i/2 的目的是为了四舍五入
filter_sum = filter_sum / i;
return filter_sum;
}
//中位值平均滤波,处理PM10的值
#define FILTER_N 5
int Filter3() {
int i;
int filter_sum = 0;
int filter_max, filter_min;
int filter_buf;
for (i = 0; i < FILTER_N; i++) {
filter_buf = _params._P3;
delay(1);
}
filter_max = filter_buf;
filter_min = filter_buf;
filter_sum = filter_buf;
for (i = FILTER_N - 1; i > 0; i--) {
if (filter_buf > filter_max)
filter_max = filter_buf;
else if (filter_buf < filter_min)
filter_min = filter_buf;
filter_sum = filter_sum + filter_buf;
filter_buf = filter_buf;
}
i = FILTER_N - 2;
filter_sum = filter_sum - filter_max - filter_min + i / 2; // +i/2 的目的是为了四舍五入
filter_sum = filter_sum / i;
return filter_sum;
}

//美国标准数据过滤
#define FILTER_N 5
int Filter4() {
int i;
int filter_sum = 0;
int filter_max, filter_min;
int filter_buf;
for (i = 0; i < FILTER_N; i++) {
filter_buf = _params._FP1;
delay(1);
}
filter_max = filter_buf;
filter_min = filter_buf;
filter_sum = filter_buf;
for (i = FILTER_N - 1; i > 0; i--) {
if (filter_buf > filter_max)
filter_max = filter_buf;
else if (filter_buf < filter_min)
filter_min = filter_buf;
filter_sum = filter_sum + filter_buf;
filter_buf = filter_buf;
}
i = FILTER_N - 2;
filter_sum = filter_sum - filter_max - filter_min + i / 2; // +i/2 的目的是为了四舍五入
filter_sum = filter_sum / i;
return filter_sum;
}
//中位值平均滤波,处理PM2.5的值
#define FILTER_N 5
int Filter5() {
int i;
int filter_sum = 0;
int filter_max, filter_min;
int filter_buf;
for (i = 0; i < FILTER_N; i++) {
filter_buf = _params._FP2;
delay(1);
}
filter_max = filter_buf;
filter_min = filter_buf;
filter_sum = filter_buf;
for (i = FILTER_N - 1; i > 0; i--) {
if (filter_buf > filter_max)
filter_max = filter_buf;
else if (filter_buf < filter_min)
filter_min = filter_buf;
filter_sum = filter_sum + filter_buf;
filter_buf = filter_buf;
}
i = FILTER_N - 2;
filter_sum = filter_sum - filter_max - filter_min + i / 2; // +i/2 的目的是为了四舍五入
filter_sum = filter_sum / i;
return filter_sum;
}
//中位值平均滤波,处理PM10的值
#define FILTER_N 5
int Filter6() {
int i;
int filter_sum = 0;
int filter_max, filter_min;
int filter_buf;
for (i = 0; i < FILTER_N; i++) {
filter_buf = _params._FP3;
delay(1);
}
filter_max = filter_buf;
filter_min = filter_buf;
filter_sum = filter_buf;
for (i = FILTER_N - 1; i > 0; i--) {
if (filter_buf > filter_max)
filter_max = filter_buf;
else if (filter_buf < filter_min)
filter_min = filter_buf;
filter_sum = filter_sum + filter_buf;
filter_buf = filter_buf;
}
i = FILTER_N - 2;
filter_sum = filter_sum - filter_max - filter_min + i / 2; // +i/2 的目的是为了四舍五入
filter_sum = filter_sum / i;
return filter_sum;
}
void loop() {

while (mySerial.available())   {
    getPM25(mySerial.read());
}
   _params.P1 = Filter1();
    _params.P2 = Filter2();
   _params.P3 = Filter3();
   _params.FP1 = Filter4();
    _params.FP2 = Filter5();
   _params.FP3 = Filter6();


u8g.firstPage();
do {
    draw();
} while ( u8g.nextPage());
}

wwwyyy317 发表于 2017-4-13 20:20:35

:loveliness:

hnyzcj 发表于 2017-4-17 10:29:39

不错的
页: [1]
查看完整版本: 攀藤G1 LCD12864显示(含中美标准)