基于单片机的电子秤设计

简介: 基于单片机的电子秤设计

protues仿真


2020092921483835.png

程序

#include<reg51.h>
#include<intrins.h>
#include <absacc.h>
#include <math.h>
#define uchar unsigned char
#define uint   unsigned int
#define BUSY  0x80          //³£Á¿¶¨Òå
#define DATAPORT P0
//ADC0832µÄÒý½Å
sbit ADCS =P3^5;  //ADC0832 chip seclect
sbit ADDI =P3^7;  //ADC0832 k in
sbit ADDO =P3^7;  //ADC0832 k out
sbit ADCLK =P3^6;  //ADC0832 clock signal
sbit LCM_RS=P2^0;
sbit LCM_RW=P2^1;
sbit LCM_EN=P2^2;
uchar ad_data,key;
uchar rrr=0xff;
uchar alldata[12]={0};
uchar love[14];
uchar exit=0,yes=0,kind=0,fu=0,pfu=0,position1=0,position2=0;
unsigned long  data1=0,data2=0,data3=0,ddata=0;    //²ÉÑùÖµ´æ´¢
sbit Alarm_led_red =P3^0;                         //³¬¹ýÖØÁ¿±íÁ¿³Ì×î´óÖµºìÉ«led±¨¾¯¶¨Òå
sbit Alarm_led_green=P3^1;                        //µÍÓÚÁã±íÁ¿³Ì×îСֵÂÌÉ«led±¨¾¯¶¨Òå
//adc²ÉÑùÖµ´æ´¢µ¥Ôª
char press_data;                                  //±ê¶È±ä»»´æ´¢µ¥Ôª
unsigned char ad_alarm;                           //±¨¾¯Öµ´æ´¢µ¥Ôª
unsigned char press_ge=0;                        //ÏÔʾֵ°Ùλ
unsigned char press_shifen=0;                      //ÏÔʾֵʮλ
unsigned char press_baifen=0;                       //ÏÔʾֵ¸öλ
unsigned char press_qianfen=0;                      //ÏÔʾֵʮ·Öλ
uchar code str0[]={"Weight:  .   Kg "};
uchar code str2[]={"Price: "};
uchar code str3[]={"Total:          "};
void delay(uint);
void lcd_wait(void);
void delay_LCM(uint);                         //LCDÑÓʱ×Ó³ÌÐò
void initLCM( void);                        //LCD³õʼ»¯×Ó³ÌÐò
void lcd_wait(void);                        //LCD¼ì²âæ×Ó³ÌÐò
void WriteCommandLCM(uchar WCLCM,uchar BusyC);      //дָÁîµ½ICM×Óº¯Êý
void WriteDataLCM(uchar WDLCM);                     //дÊý¾Ýµ½LCM×Óº¯Êý
void DisplayOneChar(uchar X,uchar Y,uchar DData);        //ÏÔʾָ¶¨×ø±êµÄÒ»¸ö×Ö·û×Óº¯Êý
void DisplayListChar(uchar X,uchar Y,uchar code *DData); //ÏÔʾָ¶¨×ø±êµÄÒ»´®×Ö·û×Óº¯Êý
void error(void);
unsigned long shi(uchar k);
void out(void);                     
uchar keyscan(void);                   
void display(void); 
void  display(uchar); 
void  keydisplay(uchar);
void  prodis(void);    
void  clear(void);
void  datapc(void);
void remove0(void);
void  data3dis(void);                                       //ϵͳÏÔʾ×Óº¯Êý
uchar Adc0832(unsigned char channel);                             
void alarm(void);
void data_pro(void);
/**********main funcation************/
void main(void)
{ 
    delay(500);                      //ϵͳÑÓʱ500msÆô¶¯
  ad_data=0;                       //²ÉÑùÖµ´æ´¢µ¥Ôª³õʼ»¯Îª0
    initLCM( );
    WriteCommandLCM(0x01,1);        //ÇåÏÔʾÆÁ
    DisplayListChar(0,0,str0);
//   WriteCommandLCM(0x01,0);   //????????
    DisplayListChar(0,1,str2);
  while(1)
    {
     ad_data =Adc0832(0);    //²ÉÑùÖµ´æ´¢µ¥Ôª³õʼ»¯Îª0
     alarm();
       data_pro();
     display();
     key=keyscan();
     delay(5);
     if(exit==1)
      keydisplay(key);   
   }
 }
/*********ÑÓʱK*1ms,12.000Mhz**********/
void delay(uint k)
{
    uint i,j;
    for(i=0;i<k;i++)
     for(j=0;j<60;j++);
}   
/**********дָÁîµ½ICM×Óº¯Êý************/
void WriteCommandLCM(uchar WCLCM,uchar BusyC)
{
    if(BusyC)
  lcd_wait();
  DATAPORT=WCLCM;
    LCM_RS=0;                   // Ñ¡ÖÐÖ¸Áî¼Ä´æÆ÷
    LCM_RW=0;                 // дģʽ 
    LCM_EN=1;    
  _nop_();   
  _nop_();
  _nop_(); 
    LCM_EN=0;
}
/**********дÊý¾Ýµ½LCM×Óº¯Êý************/
void WriteDataLCM(uchar WDLCM)
{ 
    lcd_wait( );             //¼ì²âæÐźŠ   
  DATAPORT=WDLCM;
    LCM_RS=1;                // Ñ¡ÖÐÊý¾Ý¼Ä´æÆ÷
    LCM_RW=0;              // дģʽ
    LCM_EN=1;
    _nop_();
  _nop_();
  _nop_();
    LCM_EN=0;
}
/***********lcmÄÚ²¿µÈ´ýº¯Êý*************/
void lcd_wait(void)
{
    DATAPORT=0xff;       //¶ÁLCDÇ°Èôµ¥Æ¬»úÊä³öµÍµçƽ,¶ø¶Á³öLCDΪ¸ßµçƽ,Ôò³åÍ»,Proteus·ÂÕæ»áÓÐÏÔʾÂß¼­»ÆÉ«
  LCM_EN=1;
    LCM_RS=0;   
    LCM_RW=1;   
    _nop_();
    _nop_();
  _nop_();
    while(DATAPORT&BUSY)  
  {  LCM_EN=0;
     _nop_();
     _nop_();
     LCM_EN=1;
     _nop_();
     _nop_();
     }   
    LCM_EN=0; 
}
/**********LCM³õʼ»¯×Óº¯Êý***********/
void initLCM( )
{   
  DATAPORT=0; 
  delay(15);
  WriteCommandLCM(0x38,0);    //Èý´ÎÏÔʾģʽÉèÖ㬲»¼ì²âæÐźÅ
    delay(5); 
    WriteCommandLCM(0x38,0);
    delay(5); 
    WriteCommandLCM(0x38,0);
    delay(5); 
    WriteCommandLCM(0x38,1);    //8bitÊý¾Ý´«ËÍ£¬2ÐÐÏÔʾ£¬5*7×ÖÐÍ£¬¼ì²âæÐźÅ
    WriteCommandLCM(0x08,1);    //¹Ø±ÕÏÔʾ£¬¼ì²âæÐźÅ
    WriteCommandLCM(0x01,1);    //ÇåÆÁ£¬¼ì²âæÐźÅ
    WriteCommandLCM(0x06,1);    //ÏÔʾ¹â±êÓÒÒÆÉèÖ㬼ì²âæÐźÅ
    WriteCommandLCM(0x0c,1);    //ÏÔʾÆÁ´ò¿ª£¬¹â±ê²»ÏÔʾ£¬²»ÉÁ˸£¬¼ì²âæÐźÅ
}
/****ÏÔʾָ¶¨×ø±êµÄÒ»¸ö×Ö·û×Óº¯Êý****/
void DisplayOneChar(uchar X,uchar Y,uchar DData)
{
    Y&=0x01;
    X&=0x0f;
    if(Y)X|=0x40;               //ÈôyΪ1£¨ÏÔʾµÚ¶þÐУ©£¬µØÖ·Âë+0X40
    X|=0x80;                    //Ö¸ÁîÂëΪµØÖ·Âë+0X80
    WriteCommandLCM(X,1);
    WriteDataLCM(DData);
}
/*******ÏÔʾָ¶¨×ø±êµÄÒ»´®×Ö·û×Óº¯Êý*****/
void DisplayListChar(uchar X,uchar Y,uchar code *DData)
  {
    uchar ListLength=0;
    Y&=0x01;
    X&=0x0f;
    while(X<16)
    {
        DisplayOneChar(X,Y,DData[ListLength]);
        ListLength++;
        X++;
    }
  }
void error(void)
{
  uchar derror[8]={'E','R','R','O','R','!','!','!'};
  uchar k;
  for(k=0;k<=7;k++)
  {
   WriteCommandLCM(0xc8+k,0);
   WriteDataLCM(derror[k]);
   DisplayOneChar(7,1,derror[k]);
   delay(5);
  }
}
void out(void)
{
   uchar k;
   uchar dout[12]={'O','U','T',' ','O','F',' ','R','A','N','G','E'};
   for(k=0;k<=11;k++)
  {
   WriteCommandLCM(0xc4+k,0);
   WriteDataLCM(dout[k]);
   DisplayOneChar(7,1,dout[k]);
   delay(5);
  }
}
unsigned long shi(uchar n)
{
   int m=1;
   while(n!=0)
    {
     m=m*10;
     n--;
    }
 return(m);
}
     /*¼üÅÌɨÃè×Ó³ÌÐò*/
uchar keyscan()
{
  uchar i=0,j=0;
  P1=0xf0;
  if(((~P1) & 0xf0)!=0)
   {
     delay(10);
     if(((~P1) & 0xf0)!=0)
      {
        exit=1;
        P1=0xfe;
        while(((~P1) & 0x0f)!=0) 
        {
          if(((~P1) & 0xf0)!=0) 
          {
              switch((~P1) & 0xf0)
          {
          case 0x10:
          j=0;break;
          case 0x20:
          j=1;break;
          case 0x40:
          j=2;break;
          case 0x80:
          j=3;break;
          }
        return(4*i+j);
      }
      else
      {  
       P1=P1<<1;
       i++;
      }
   }
  }
}
exit=0;
return(key);
}
 /*****************ϵͳÏÔʾ×Óº¯Êý*****************/
void display(void)
{
    WriteCommandLCM(0x0c,1);            //ÏÔʾÆÁ´ò¿ª£¬¹â±ê²»ÏÔʾ£¬²»ÉÁ˸£¬¼ì²âæÐźŠ 
  DisplayListChar(0,0,str0);  
  DisplayListChar(0,1,str2);  
  DisplayOneChar(8,0,press_ge+0x30);
  DisplayOneChar(10,0,press_shifen+0x30);
  DisplayOneChar(11,0,press_baifen+0x30);
    DisplayOneChar(12,0,press_qianfen+0x30);
  delay(1000);                               //Îȶ¨ÏÔʾ
}
/**********************************¼üÅÌÏÔʾ×Óº¯Êý**********************************/
void keydisplay(uchar C)
{
  WriteCommandLCM(0x0c,1); 
  DisplayListChar(0,1,str2);
 switch(C)
 {
   case 0:clear();
          break;
   case 1:prodis();
          alldata[rrr]=0;
          WriteDataLCM('0');
          break;
   case 2:prodis();
          WriteDataLCM('=');       
          kind=kind+10;
          position2=rrr;
          datapc();
          remove0();
          data3dis();
          break;
   case 3:prodis();
          kind=kind+1;             //¼Ó·¨ÔËË㣬 kind=1
          position1=rrr;
          WriteDataLCM('+');
          break;
   case 4:prodis();
          alldata[rrr]=1;
          WriteDataLCM('1');
          break;
   case 5:prodis();
          alldata[rrr]=2;
          WriteDataLCM('2');
          break;
   case 6:prodis();
          alldata[rrr]=3;
          WriteDataLCM('3');
          break;
   case 7:prodis();
          kind=kind+5;             //¼õ·¨ÔËË㣬 kind=5
          position1=rrr;
          WriteDataLCM('-');
          break;
   case 8:prodis();
          alldata[rrr]=4;
          WriteDataLCM('4');
          break;
   case 9:prodis();
          alldata[rrr]=5;
          WriteDataLCM('5');
          break;
   case 10:prodis();
           alldata[rrr]=6;
           WriteDataLCM('6');
          break;
   case 11:prodis();
           kind=kind+25;             //³Ë·¨ÔËË㣬 kind=25
           position1=rrr;
           WriteDataLCM('*');
           break;
   case 12:prodis();
           alldata[rrr]=7;
           WriteDataLCM('7');
           break;
   case 13:prodis();
           alldata[rrr]=8;
           WriteDataLCM('8');
           break;
   case 14:prodis();
           alldata[rrr]=9;
           WriteDataLCM('9'); 
           break;
   case 15:prodis();
           kind=kind+125;              //³ý·¨ÔËË㣬 kind=125
           position1=rrr;
           WriteDataLCM('/');   
           break;
   default:
   break;
   }
    }
void datapc(void)
{
  uchar k;
  if((position1==0) || (position2==(position1+1)))
       yes=1;
  else
   {
    for(k=0;k<position1;k++)
    {
      ddata=shi(position1-1-k);
      data1=data1+(alldata[k])*ddata;  
    }
    for(k=position1+1;k<position2;k++)
    {
       ddata=shi(position2-1-k);
       data2=data2+(alldata[k])*ddata;  
    }
  if((data1 > 50000) || (data2 > 50000))
         {yes=2;}
  else
    {
      switch (kind)
        {
         case 11:data3=data1+data2;yes=0;
             break;
         case 15: if(data1<data2)
                 {
           ddata=data1;
           data1=data2;
           data2=ddata;
           fu=1;
          }
               data3=data1-data2;yes=0;
          break;
         case 35:data3=data1*data2;yes=0;
              break;
         case 135:data3=data1/data2;yes=0;
              break;
         default:yes=1;
        }
    }
}
if(yes==0)
 {
   love[0]=data3 / 1000000000;
   love[1]=data3 / 100000000-love[0]*10;
   love[2]=data3 / 10000000-love[0]*100-love[1]*10;
   love[3]=data3 / 1000000-love[0]*1000-love[1]*100-love[2]*10;
   love[4]=data3 / 100000-love[0]*10000-love[1]*1000-love[2]*100-love[3]*10;
   love[5]=data3 / 10000-love[0]*100000-love[1]*10000-love[2]*1000-love[3]*100-love[4]*10;
   love[6]=(data3 % 10000)/1000;
   love[7]=(data3 % 1000)/100;
   love[8]=(data3 % 100)/10;
   love[9]= data3 % 10;
 }
if(kind==135)
 {
   love[10]=0xfe;
   love[11]=((data1 % data2)*10)/data2;
   love[12]=((((data1 % data2)*10)%data2)*10)/data2;
   love[13]=((((((data1 % data2)*10)%data2)*10)%data2)*10)/data2;
  }
}
void remove0(void)
{
  uchar k=0;
  while((love[k]==0) && (k<=8))
   {
    love[k]=0xf0;
    k++;
    }
  pfu=k;
}


相关文章
|
8月前
|
传感器 监控 IDE
基于单片机的温度监控系统设计
基于单片机的温度监控系统设计
275 0
|
8月前
|
传感器 5G 人机交互
基于51单片机的简易电子秤
基于51单片机的简易电子秤
基于51单片机的智能电子秤设计课程设计毕业设计
具体功能: 1、数码管显示当前的重量,单位是g; 2、有去皮和清零功能,可以通过三个按键微调校准重量; 3、最大称重9.999kg,超过最大量程声光报警。
229 0
|
传感器 监控 数据处理
基于单片机的液体点滴速度监控设计
基于单片机的液体点滴速度监控设计
220 0
基于单片机的液体点滴速度监控设计
|
传感器 存储 缓存
基于51单片机的蓝牙电子秤设计
基于51单片机的蓝牙电子秤设计
|
存储 安全 网络性能优化
基于单片机的交通灯控制系统设计
基于单片机的交通灯控制系统设计
434 0
基于单片机的交通灯控制系统设计
|
芯片 内存技术
基于单片机步进电机控制器设计(正转反转指示灯挡位)
基于单片机步进电机控制器设计(正转反转指示灯挡位)
255 0
基于单片机步进电机控制器设计(正转反转指示灯挡位)
|
传感器
基于51单片机直流电机PWM控制器设计
基于51单片机直流电机PWM控制器设计
266 0
基于51单片机直流电机PWM控制器设计
|
存储 传感器 数据采集
基于单片机的智能健康监护仪的设计(心电、心音、体温、脉搏、血压采集)
基于单片机的智能健康监护仪的设计(心电、心音、体温、脉搏、血压采集)
395 0
基于单片机的智能健康监护仪的设计(心电、心音、体温、脉搏、血压采集)
|
存储 安全 前端开发
基于单片机的多功能电子医药盒设计
基于单片机的多功能电子医药盒设计
259 0
基于单片机的多功能电子医药盒设计