找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 1975|回复: 0
打印 上一主题 下一主题
收起左侧

基于51单片机HX711传感器电子秤设计

[复制链接]
跳转到指定楼层
楼主
ID:744211 发表于 2020-5-4 23:15 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
/**********************************************************************

***********************************************************************/

#include "main.h"
#include "HX711.h"
#include "uart.h"
#include "LCD1602.h"

unsigned long HX711_Buffer = 0;
unsigned long Weight_Maopi = 0;
long Weight_Shiwu = 0;

unsigned char flag = 0;
bit Flag_ERROR = 0;
sbit speak= P1^7;

//校准参数
//因为不同的传感器特性曲线不是很一致,因此,每一个传感器需要矫正这里这个参数才能使测量值很准确。
//当发现测试出来的重量偏大时,增加该数值。
//如果测试出来的重量偏小时,减小改数值。
//该值可以为小数
#define GapValue 400


//****************************************************
//主函数
//****************************************************
void main()
{
    Uart_Init();
    Send_Word("Welcome to use!\n");
    Send_Word("Made by Beetle Electronic Technology!\n");
        
        Init_LCD1602();
        LCD1602_write_com(0x80);
        LCD1602_write_word("Welcome to use!");
        Delay_ms(1000);                 //延时,等待传感器稳定

        Get_Maopi();                                //称毛皮重量
        
        while(1)
        {
                EA = 0;
                Get_Weight();                        //称重
                EA = 1;

                Scan_Key();

                //显示当前重量
                if( Flag_ERROR == 1)
                {
            Send_Word("ERROR\n");
                        
                        LCD1602_write_com(0x80+0x40);
                        LCD1602_write_word("ERROR ");
                        speak=0;
                }               
                else
                {         
                              speak=1;
            Send_ASCII(Weight_Shiwu/1000 + 0X30);
            Send_ASCII(Weight_Shiwu%1000/100 + 0X30);
            Send_ASCII(Weight_Shiwu%100/10 + 0X30);
            Send_ASCII(Weight_Shiwu%10 + 0X30);
            Send_Word(" g\n");
                        
                        LCD1602_write_com(0x80+0x40);
                        LCD1602_write_data(Weight_Shiwu/1000 + 0X30);
            LCD1602_write_data(Weight_Shiwu%1000/100 + 0X30);
            LCD1602_write_data(Weight_Shiwu%100/10 + 0X30);
            LCD1602_write_data(Weight_Shiwu%10 + 0X30);
                        LCD1602_write_word(" g");
                }
               
        }
}

//扫描按键
void Scan_Key()
{
        if(KEY1 == 0)
        {
                Delay_ms(5);
                if(KEY1 == 0)
                {
                        while(KEY1 == 0);
                        Get_Maopi();                        //去皮
                }        
        }
}

//****************************************************
//称重
//****************************************************
void Get_Weight()
{
        Weight_Shiwu = HX711_Read();
        Weight_Shiwu = Weight_Shiwu - Weight_Maopi;                //获取净重
        if(Weight_Shiwu > 0)                        
        {        
                Weight_Shiwu = (unsigned int)((float)Weight_Shiwu/GapValue);         //计算实物的实际重量
                                                                                                                                                
                                                                                                                                                
                if(Weight_Shiwu > 5000)                //超重报警
                {
                        Flag_ERROR = 1;        
                }
                else
                {
                        Flag_ERROR = 0;
                }
        }
        else
        {
                Weight_Shiwu = 0;
        //        Flag_ERROR = 1;                                //负重报警
        }
        
}

//****************************************************
//获取毛皮重量
//****************************************************
void Get_Maopi()
{
        Weight_Maopi = HX711_Read();        
}

//****************************************************
//MS延时函数(12M晶振下测试)
//****************************************************
void Delay_ms(unsigned int n)
{
        unsigned int  i,j;
        for(i=0;i<n;i++)
                for(j=0;j<123;j++);
}

HX711.7z

1.25 MB, 下载次数: 24, 下载积分: 黑币 -5

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶1 踩
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表