main.c
#include "sys.h"
#include "iic.h"
#include "ds1302.h"
uint volt;
uchar H = 0; //湿度
void WorkMode();
void main()
{
InitSystem();
Set_DS1302();
damp = Read_AT24C02(0x00);
while(1)
{
ReadAIN3();
volt = rb2*1.96+0.2;
H = volt*0.198;
Get_DS1302();
KeyScans();
DisplaySMG();
WorkMode();
DisplayBit(5,damp % 10);
}
}
void WorkMode()
{
if(mode == 0) //自动工作状态
{
OperateLed(1,0);
OperateLed(2,1);
if(H < damp)
{
Operatews(0x10,1);
}
else
{
Operatews(0x10,0);
}
}
else //手动工作状态
{
OperateLed(1,1);
OperateLed(2,0);
if((H < damp) && (k6 == 0))
{
Operatews(0x40,1);
}
else if((H >= damp) || (k6 == 1))
{
Operatews(0x40,0);
}
}
}
sys.c
#include "sys.h"
void Select_74HC138(uchar channel)
{
switch(channel)
{
case 0: P2 = P2 & 0X1F; break;
case 4: P2 = (P2 & 0X1F) | 0X80; break;
case 5: P2 = (P2 & 0X1F) | 0XA0; break;
case 6: P2 = (P2 & 0X1F) | 0XC0; break;
case 7: P2 = (P2 & 0X1F) | 0XE0; break;
}
}
void InitSystem()
{
Select_74HC138(4);
P0 = 0XFF;
Select_74HC138(5);
P0 = 0X00;
Select_74HC138(0);
}
void Delay(uint ms)
{
uint i;
for(ms; ms > 0; ms--)
for(i = 921; i > 0; i--);
}
void OperateLed(uchar who,status)
{
static uchar temp;
uchar zt;
switch(status)
{
case 0:
temp = temp | _crol_(0x01,who-1);
P0 = ~temp;
break;
case 1:
if(who == 0xff)
{
P0 = 0xff;
temp = 0;
}
else
{
zt = (~temp) | _crol_(0x01,who-1);
if(temp != (~zt))
temp = (~zt);
P0 = ~temp;
}
break;
case 2:
P0 = ~who;
temp = who;
break;
default: break;
}
Select_74HC138(4);
Select_74HC138(0);
}
void Operatews(uchar num,status)
{
static uchar temp;
if(status)
{
temp = num;
P0 = temp;
}
else
{
temp = temp & (~num);
P0 = temp;
}
Select_74HC138(5);
Select_74HC138(0);
}
nixie.c
#include "sys.h"
#include "iic.h"
#include "ds1302.h"
uchar code nixie[] = {0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0xbf,0xff};
uchar damp = 50;
uchar interface = 0;
void DisplayBit(uchar pos,value)
{
P0 = 0X00;
Select_74HC138(6);
Select_74HC138(0);
P0 = nixie[value];
Select_74HC138(7);
Select_74HC138(0);
P0 = _crol_(0x01,pos);
Select_74HC138(6);
Select_74HC138(0);
Delay(1);
}
void DisplayH()
{
DisplayBit(0,Time[2] / 10);
DisplayBit(1,Time[2] % 10);
DisplayBit(2,10);
DisplayBit(3,Time[1] / 10);
DisplayBit(4,Time[1] % 10);
DisplayBit(6,H / 10);
DisplayBit(7,H % 10);
}
void DisplayDamp()
{
DisplayBit(0,10);
DisplayBit(1,10);
DisplayBit(6,damp / 10);
DisplayBit(7,damp % 10);
}
void DisplaySMG()
{
switch(interface)
{
case 0: DisplayH(); break;
case 1: DisplayDamp(); break;
}
}
key.c
#include "sys.h"
#include "iic.h"
bit mode = 0; //工作模式
bit k6 = 0;
void KeyScans()
{
if(s4 == 0)
{
Delay(10);
if(mode == 1)
{
Operatews(0x10,0);
}
if(interface == 1)
{
damp -= 1;
if(damp == -1)
damp = 0;
}
while(s4 == 0)
{
DisplaySMG();
}
}
if(s5 == 0)
{
Delay(10);
if(mode == 1)
{
Operatews(0x10,1);
}
if(interface == 1)
{
damp += 1;
if(damp == 100)
damp = 99;
}
while(s5 == 0)
{
DisplaySMG();
}
}
if(s6 == 0)
{
Delay(10);
if(mode == 0)
{
interface = !interface;
if(interface == 0)
Write_AT24C02(0x00,damp);
}
if(mode == 1)
{
k6 = ~k6;
}
while(s6 == 0)
{
DisplaySMG();
}
}
if(s7 == 0)
{
Delay(10);
mode = ~mode;
while(s7 == 0)
{
DisplaySMG();
}
}
}
sys.h
#ifndef _SYS_H_
#define _SYS_H_
#include <STC15F2K60S2.H>
#include <intrins.h>
sbit s4 = P3^3;
sbit s5 = P3^2;
sbit s6 = P3^1;
sbit s7 = P3^0;
#define uchar unsigned char
#define uint unsigned int
extern unsigned char H;
extern unsigned char interface;
extern bit mode;
extern unsigned char damp;
extern bit k6;
//sys.c
void Select_74HC138(unsigned char channel);
void InitSystem();
void Delay(unsigned int ms);
void OperateLed(unsigned char who,status);
void Operatews(unsigned char num,status);
//nixie.c
void DisplayBit(unsigned char pos,value);
void DisplayH();
void DisplayDamp();
void DisplaySMG();
//key.c
void KeyScans();
#endif