土壤湿度检测仪c语言代码,单片机测土壤湿度可自动浇水并报警 带C#上位机源码...
#include //调用单片机头文件
#define uchar unsigned char //无符号字符型 宏定义 变量范围0~255
#define uint unsigned int //无符号整型 宏定义 变量范围0~65535
#include
sbit SCL=P1^4; //SCL定义为P1口的第3位脚,连接ADC0832SCL脚
sbit DO=P1^5; //DO定义为P1口的第4位脚,连接ADC0832DO脚
sbit CS=P1^3; //CS定义为P1口的第4位脚,连接ADC0832CS脚
sbit beep = P3^3; //蜂鸣器IO口定义
uint temperature,s_temp ; //温度的变量
uchar shidu; //湿度等级
uchar s_high = 70,s_low = 25; //湿度报警参数
sbit dianji = P1^6; //电机IO定义
bit flag_300ms ;
uchar key_can; //按键值的变量
uchar menu_1; //菜单设计的变量
uchar receive[4]; //定义串口接收数组
uchar jyh=0; //定义校验和
uchar uart_flag=0; //串口接收一帧数据成功标志位
uchar count=0; //代表接收数组的下标志
uchar send[7]; //发送数组
uchar fsxb=0; //代表发送数组的下标
//这三个引脚参考资料
sbit rs=P1^0; //1602数据/命令选择引脚 H:数据 L:命令
sbit rw=P1^1; //1602读写引脚 H:数据寄存器 L:指令寄存器
sbit e =P1^2; //1602使能引脚 下降沿触发
uchar code table_num[]="0123456789abcdefg";
/********************************************************************
* 名称 : delay_uint()
* 功能 : 小延时。
* 输入 : 无
* 输出 : 无
***********************************************************************/
void delay_uint(uint q)
{
while(q--);
}
void UsartInit()
{
SCON=0X50;//设置串口工作方式1
// TMOD=TMOD&0x0f|0X20;//设置定时器1为工作方式2
PCON=0x80;//使波特率加倍
TH1=0XF3;//计数器加初值
TL1=0XF3;
ES=1; //打开串口接收中断
EA=1; //打开总中断
TR1=1; //打开计数器
}
/********************************************************************
* 名称 : write_com(uchar com)
* 功能 : 1602命令函数
* 输入 : 输入的命令值
* 输出 : 无
***********************************************************************/
void write_com(uchar com)
{
e=0;
rs=0;
rw=0;
P0=com;
delay_uint(3);
e=1;
delay_uint(25);
e=0;
}
/********************************************************************
* 名称 : write_data(uchar dat)
* 功能 : 1602写数据函数
* 输入 : 需要写入1602的数据
* 输出 : 无
***********************************************************************/
void write_data(uchar dat)
{
e=0;
rs=1;
rw=0;
P0=dat;
delay_uint(3);
e=1;
delay_uint(25);
e=0;
}
/********************************************************************
* 名称 : write_sfm2(uchar hang,uchar add,uchar date)
* 功能 : 显示2位十进制数,如果要让第一行,第五个字符开始显示"23" ,调用该函数如下
write_sfm1(1,5,23)
* 输入 : 行,列,需要输入1602的数据
* 输出 : 无
***********************************************************************/
void write_sfm2(uchar hang,uchar add,uint date)
{
if(hang==1)
write_com(0x80+add);
else
write_com(0x80+0x40+add);
write_data(0x30+date/10%10);
write_data(0x30+date%10);
}
/********************************************************************
* 名称 : write_string(uchar hang,uchar add,uchar *p)
* 功能 : 改变液晶中某位的值,如果要让第一行,第五个字符开始显示"ab cd ef" ,调用该函数如下
write_string(1,5,"ab cd ef;")
* 输入 : 行,列,需要输入1602的数据
* 输出 : 无
***********************************************************************/
void write_string(uchar hang,uchar add,uchar *p)
{
if(hang==1)
write_com(0x80+add);
else
write_com(0x80+0x40+add);
while(1)
{
if(*p == '\0') break;
write_data(*p);
p++;
}
}
/********************************************************************
* 名称 : init_1602()
* 功能 : 初始化1602液晶
* 输入 : 无
* 输出 : 无
***********************************************************************/
void init_1602()
{
write_com(0x38);
write_com(0x38);
write_com(0x0c);
write_com(0x06);
delay_uint(1000);
write_string(1,0," shidu:00% ");
write_string(2,0," SH:00% SL:00% ");
write_sfm2(2,4,s_high); //显示湿度上限
write_sfm2(2,12,s_low); //显示湿度下限
}
/***********************1ms延时函数*****************************/
void delay_1ms(uint q)
{
uint i,j;
for(i=0;i
for(j=0;j<120;j++);
}
/***********读数模转换数据********************************************************/
//请先了解ADC0832模数转换的串行协议,再来读本函数,主要是对应时序图来理解,本函数是模拟0832的串行协议进行的
// 1 0 0 通道
// 1 1 1 通道
unsigned char ad0832read(bit SGL,bit ODD)
{
unsigned char i=0,value=0,value1=0;
SCL=0;
DO=1;
CS=0; //开始
SCL=1; //第一个上升沿
SCL=0;
DO=SGL;
SCL=1; //第二个上升沿
SCL=0;
DO=ODD;
SCL=1; //第三个上升沿
SCL=0; //第三个下降沿
DO=1;
for(i=0;i<8;i++)
{
SCL=0;
SCL=1; //开始从第四个下降沿接收数据
value<<=1;
if(DO)
value++;
}
for(i=0;i<8;i++)
{ //接收校验数据
value1>>=1;
if(DO)
value1+=0x80;
SCL=1;
SCL=0;
}
SCL=1;
if(value==value1) //与校验数据比较,正确就返回数据,否则返回0
return value;
return 0;
}
unsigned int Adc0832(unsigned char channel)
{
uchar i=0;
uchar j;
uint dat=0;
uchar ndat=0;
uchar Vot=0;
if(channel==0)channel=2;
if(channel==1)channel=3;
DO=1;
_nop_();
_nop_();
CS=0;//拉低CS端
_nop_();
_nop_();
SCL=1;//拉高CLK端
_nop_();
_nop_();
SCL=0;//拉低CLK端,形成下降沿1
_nop_();
_nop_();
SCL=1;//拉高CLK端
DO=channel&0x1;
_nop_();
_nop_();
SCL=0;//拉低CLK端,形成下降沿2
_nop_();
_nop_();
SCL=1;//拉高CLK端
DO=(channel>>1)&0x1;
_nop_();
_nop_();
SCL=0;//拉低CLK端,形成下降沿3
DO=1;//控制命令结束
_nop_();
_nop_();
dat=0;
for(i=0;i<8;i++)
{
dat|=DO;//收数据
SCL=1;
_nop_();
_nop_();
SCL=0;//形成一次时钟脉冲
_nop_();
_nop_();
dat<<=1;
if(i==7)dat|=DO;
}
for(i=0;i<8;i++)
{
j=0;
j=j|DO;//收数据
SCL=1;
_nop_();
_nop_();
SCL=0;//形成一次时钟脉冲
_nop_();
_nop_();
j=j<<7;
ndat=ndat|j;
if(i<7)ndat>>=1;
}
CS=1;//拉低CS端
SCL=0;//拉低CLK端
DO=1;//拉高数据端,回到初始状态
dat<<=8;
dat|=ndat;
return(dat); //return ad data
}
/*************定时器0初始化程序***************/
void time_init()
{
// EA = 1; //开总中断
TMOD = 0X21; //定时器0、定时器1工作方式1
ET0 = 1; //开定时器0中断
TR0 = 1; //允许定时器0定时
}
/********************独立按键程序*****************/
uchar key_can; //按键值
void key() //独立按键程序
{
static uchar key_new;
key_can = 20; //按键值还原
P3 |= 0xf0;
if((P3 & 0xf0) != 0xf0) //按键按下
{
delay_1ms(1); //按键消抖动
if(((P3 & 0xf0) != 0xf0) && (key_new == 1))
{ //确认是按键按下
key_new = 0;
switch(P3 & 0xf0)
{
case 0xd0: key_can = 3; break; //得到k2键值
case 0xb0: key_can = 2; break; //得到k3键值
case 0x70: key_can = 1; break; //得到k4键值
}
}
}
else
key_new = 1;
}
/****************按键处理显示函数***************/
void key_with()
{
if(key_can == 1) //设置键
{
menu_1 ++;
if(menu_1 >= 3)
{
menu_1 = 0;
init_1602() ; //初始化显示
}
}
if(menu_1 == 1) //设置湿度上限
{
if(key_can == 2)
{
s_high ++ ; //湿度上限值加1
if(s_high > 99)
s_high = 99;
}
if(key_can == 3)
{
s_high -- ; //湿度上限值减1
if(s_high <= s_low)
s_high = s_low + 1 ;
}
write_sfm2(2,4,s_high); //显示湿度上限
write_sfm2(2,12,s_low); //显示湿度下限
write_com(0x80+0x40+4); //将光标移动到第2行第到3位
write_com(0x0f); //显示光标并且闪烁
}
if(menu_1 == 2) //设置湿度下限
{
if(key_can == 2)
{
s_low ++ ; //湿度下限值加1
if(s_low >= s_high)
s_low = s_high - 1;
}
if(key_can == 3)
{
s_low --; //湿度下限值减1
if(s_low <= 1)
s_low = 1;
}
write_sfm2(2,4,s_high); //显示湿度上限
write_sfm2(2,12,s_low); //显示湿度下限
write_com(0x80+0x40+12); //将光标移动到第2行第到3位
write_com(0x0f); //显示光标并且闪烁
}
}
/****************报警函数***************/
void clock_h_l()
{
static uchar value,value1;
if(shidu <= s_low)
{
value ++;
if(value >= 2)
{
value = 10;
beep = ~beep; //蜂鸣器报警
dianji = 0; //打开电机
}
}else
beep = 1; //关闭蜂鸣器
if(shidu >= s_high)
{
value1 ++;
if(value1 >= 2)
{
value1 = 10;
beep = 1; //关闭蜂鸣器
dianji = 1; //关机电机
}
}else
value1 = 0;
}
/***************主函数*****************/
void main()
{
init_1602();
UsartInit(); //1602液晶初始化
time_init(); //初始化定时器
while(1)
{
key(); //独立按键程序
if(key_can < 10)
{
key_with(); //按键按下要执行的程序
}
if(flag_300ms == 1)
{
flag_300ms = 0;
clock_h_l(); //报警函数
if(beep == 1)
{
shidu = Adc0832(0); //读出湿度
shidu = 99 - shidu * 99 / 255;
if(uart_flag==1) //接收到了上位机发过来的获取重量的命令
{
if(receive[2]==0x01) //有效位是0x01
{
send[0]=0xaa;
send[1]=0x55;
send[2]=shidu/1000;
send[3]=shidu%1000/100;
send[4]=shidu%100/10; //校验和
send[5]=shidu%10;
send[6]=send[2]+send[3]+send[4]+send[5];
fsxb=0;
SBUF=send[fsxb]; //串口发送 第一个字节
fsxb++;
}
uart_flag=0;
}
}
if(menu_1 == 0)
{
write_sfm2(1,9,shidu); //显示湿度等级
}
}
delay_1ms(1);
}
}
/*************定时器0中断服务程序***************/
void time0_int() interrupt 1
{
static uchar value;
TH0 = 0x3c;
TL0 = 0xb0; // 50ms
value ++;
if(value % 6 == 0)
{
flag_300ms = 1; //300ms
value = 0;
}
}
void Usart() interrupt 4
{
if(TI==1) //判断是否发生了发送中断
{
TI=0;
if(fsxb!=7) //发送 send[1] send[2] send[3] send[4]
{
SBUF=send[fsxb]; //串口发送 第一个字节
fsxb++;
}
}
else //判断是否发生了接受中断
{
RI=0;
receive[count]=SBUF;
if(count==0&&receive[count]==0xaa)
{
count=1;
}
else if(count==1&&receive[count]==0x55)
{
count=2;
}
else if(count>=2&&count<3) //2 3
{
jyh+=receive[count]; //jyh=jyh+receive[count];
count++;
}
else if(count==3&&receive[count]==jyh)
{
count=0;
uart_flag=1; //串口接收成功标志位置
jyh=0;
}
else
{
count=0; //判断不满足条件就将校标清零
}
}
}
土壤湿度检测仪c语言代码,单片机测土壤湿度可自动浇水并报警 带C#上位机源码...相关推荐
- 网站QQ全屏PHP代码,QQ技术导航升级版 超级导航美化版带后台版 PHP源码
QQ技术导航升级版 超级导航美化版带后台版改进F2样式,主针对QQ教程网.卡盟.博客.提供更好收录的位置.改进QQ技术导航背景,增加整体美观效果.去掉死链页面,站长操作使用更加有扩大空间.优化后台登陆 ...
- 基于51单片机智能浇花自动浇水灌溉
基于51单片机智能浇花自动浇水灌溉(源程序+原理图+论文+实物图) 资料编号:004 功能介绍: 51单片机控制的自动浇水系统,实现室内盆花浇水的自动化系统. 该系统可对土壤的湿度进行监控,并对作物进 ...
- 商品详情页html代码获取,直播带货小程序源码中,商品详情页是如何获取html图片的...
在搭建直播带货小程序源码过程中,需要为商品构建详情页,而商品页中的图片是要通过html获取并展示到本地的,那么这个过程是如何实现的?接下来小编将通过代码演示一下: 1.配置webView mWebVi ...
- C#松下PLC通信源代码,支持松下Mewtocol协议,支持网口通信和串口通信,部分代码稍作修改后可直接copy到自己的上位机软件使用
C#松下PLC通信源代码,支持松下Mewtocol协议,支持网口通信和串口通信,部分代码稍作修改后可直接copy到自己的上位机软件使用 主要功能: 1.支持I/O实时监控,可自由改变要监控的I/O 2 ...
- Modbus RTU 51单片机从机源码与组态软件通信支持485和232串口通信,该从机源码可直接用于51系列和STC12系列单片机的
Modbus RTU 51单片机从机源码与组态软件通信支持485和232串口通信,该从机源码可直接用于51系列和STC12系列单片机的,支持功能码01,02,03,04,05,06,0F,10等常用功 ...
- 16、基于51单片机智能浇花自动浇水灌溉土壤湿度检测报警系统设计
毕设帮助.开题指导.技术解答(有偿)见文末. 目录 摘要 一.硬件方案 二.设计功能 三.实物图 四.原理图 五.PCB图 六.Proteus仿真 七.程序源码 八.资料包括 摘要 本次盆栽植物自动浇 ...
- C语言实现贪吃蛇小游戏!(超简单详细)详细思路+源码分享
贪吃蛇(也叫做贪食蛇)游戏是一款休闲益智类游戏,有PC和手机等多平台版本.既简单又耐玩.该游戏通过控制蛇头方向吃蛋,从而使得蛇变得越来越长. 我们的今天的目标就是:用C语言来实现一个贪吃蛇项目,也不用 ...
- java门户网站项目代码_基于jsp的企业门户网站-JavaEE实现企业门户网站 - java项目源码...
基于jsp+servlet+pojo+mysql实现一个javaee/javaweb的企业门户网站, 该项目可用各类java课程设计大作业中, 企业门户网站的系统架构分为前后台两部分, 最终实现在线上 ...
- C语言在BST中找到最接近目标的值的算法(附完整源码)
C语言在BST中找到最接近目标的值的算法 C语言在BST中找到最接近目标的值的算法完整源码(定义,实现,main函数测试) C语言在BST中找到最接近目标的值的算法完整源码(定义,实现,main函数测 ...
最新文章
- 哈尔滨金融学院计算机系学生会,哈尔滨金融学院计算机系实习报告(毕业分散实习).doc...
- Android JNI 报错(signal 6 (SIGABRT), code -1 (SI_QUEUE), fault addr )
- 微服务架构下的组件需求
- Java数据库篇8——索引、视图、存储过程、触发器
- 滑动加载怎么做 php,vue之UI框架如何实现滑动加载数据
- 制作网页版电子时钟特效
- 视觉控每天盯着桌面,少不了桌面手机壁纸图片,请收好
- Python+OpenGL实现物体快速运动时的模糊效果
- 探秘亚马逊最特别的机器人工厂:800只机器人在奔跑,人类却没有被淘汰?
- Solr全文检索学习笔记·记录
- windows进程/线程创建过程 --- windows操作系统学习
- ssh框架 mysql 配置文件_SSH框架与配置文件的简单搭建
- wps公式如何加序号_WPS满满干货教程分享:你就是下一个职场大神
- 大学,不是学习的终点,而是起点。
- 冒泡排序和鸡尾酒排序
- 游戏玩到这种程度,酱紫真的好吗?
- 外部h5网页跳转微信指定页面
- 【Pytorch with fastai】第 11 章 :使用 fastai 的中级 API 进行数据处理
- 一招技巧解决360搜索结果页展示网站LOGO
- 二级C语言上机考试评分标准,浅谈二级C语言上机考试评分原理