程序采用的是模块化写法,你写论文时也分开写两个小标题把代码粘贴进去就行了。

HX711的AD转换代码

#include "HX711.h"

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

//延时函数

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

void Delay__hx711_us(void)

{

_nop_();

_nop_();

}

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

//读取HX711

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

unsigned long HX711_Read(void)        //增益128

{

unsigned long count;

unsigned char i;

HX711_DOUT=1;

Delay__hx711_us();

HX711_SCK=0;

count=0;

while(HX711_DOUT);

for(i=0;i<48;i++)

{

HX711_SCK=1;

count=count<<1;

HX711_SCK=0;

if(HX711_DOUT)

count++;

}

HX711_SCK=1;

count=count^0x008000;//第25个脉冲下降沿来时,转换数据

Delay__hx711_us();

HX711_SCK=0;

return(count);

}

主函数程序

#include

#include

#include

#include "main.h"

#include "HX711.h"

#include "eeprom52.h"

#define uchar unsigned char

#define uint  unsigned int

uchar qianwei,baiwei,gewei,shiwei;

unsigned long HX711_Buffer = 0;

unsigned long Weight_Maopi = 0;

unsigned long Weight_Maopi_0 = 0;

long Weight_Shiwu = 0;

unsigned int qupi=0;

unsigned char p=0;

//键盘处理变量

unsigned char keycode;

unsigned char key_press_num=0;

uint GapValue,GapValue1;

bit flag_cz=0;

//uchar code  LEDData[]={0x5F,0x44,0x9D,0xD4,0xC6,0xD3,0xDB,0x57,0xDF,0xD7,0xCF,0xaA,0x9B,0xDC,0x9B,0x8B}; //数码管显示码表

//定义标识

volatile bit FlagTest = 0;                //定时测试标志,每0.5秒置位,测完清0

volatile bit FlagKeyPress = 0;  //有键按下标志,处理完毕清0

//校准参数

//因为不同的传感器特性曲线不是很一致,因此,每一个传感器需要矫正这里这个参数才能使测量值很准确。

//当发现测试出来的重量偏大时,增加该数值。

//如果测试出来的重量偏小时,减小改数值。

//该值可以为小数

//#define GapValue 349

sbit LED=P1^1;

sbit ROW1=P3^0;

sbit ROW2=P3^1;

sbit ROW3=P3^2;

sbit ROW4=P3^3;

//sbit DIAN = P0^6;                        //小数点

sbit rs=P0^7;

sbit rw=P0^6;

sbit en=P0^5;

sbit D1=P2^0;

volatile bit ClearWeighFlag = 0; //传感器调零标志位,清除0漂

/******************把数据保存到单片机内部eeprom中******************/

void write_eeprom()

{

SectorErase(0x1080);

GapValue1=GapValue&0x00ff;

byte_write(0x1000, GapValue1);

GapValue1=(GapValue&0xff00)>>8;

byte_write(0x1001, GapValue1);

byte_write(0x1060, a_a);

}

/******************把数据从单片机内部eeprom中读出来*****************/

void read_eeprom()

{

GapValue   = byte_read(0x1001);

GapValue   = (GapValue<<8)|byte_read(0x1000);

a_a      = byte_read(0x1060);

}

/**************开机自检eeprom初始化*****************/

void init_eeprom()

{

read_eeprom();                //先读

if(a_a == 1)                //新的单片机初始单片机内问eeprom

{

GapValue  = 3500;

a_a = 1;

write_eeprom();           //保存数据

}

}

void delayms(uint xms)                //延时

{

uchar i,j;

for(i=xms;i>0;i--)

for(j=110;j>0;j--);

}

void write_com(uchar com)                 //写命令

{

rs=0;

//        P2=change(com);

P2=com;

delayms(50);

en=1;

delayms(50);

en=0;

}

void write_dat(uchar dat)             //写数据

{

rs=1;

//        P2=change(dat);

P2=dat;

en=1;

delayms(50);

en=0;

}

void init()                                        //液晶初始化

{

rw=0;

write_com(0x38);

write_com(0x0c);

write_com(0x06);

//write_com(0x01);

}

/*****显示开机初始化等待画面*****/

/*

void Disp_init(void)

{

P0 = 0x80;      //显示----

P2 = 0xBF;                 //依次打开各位

Delay_ms(1);                 //延时

P2 = 0xEF;

Delay_ms(1);

P2 = 0xFB;

Delay_ms(1);

P2 = 0xFE;

Delay_ms(1);

P2 = 0xFF;         //关闭显示

}

*/

//显示重量,单位kg,两位整数,三位小数

void Display_Weight()

{                                                                                                                                                                                                                                                                                                                                            ;

qianwei=Weight_Shiwu/1000%10;

baiwei=Weight_Shiwu/100%10;                                                                                                                                                                                                                                                                                                                       ;

shiwei=Weight_Shiwu%100/10;

gewei=Weight_Shiwu%100%10;

write_com(0x80+2);

write_dat(qianwei+'0');

write_dat('.');

write_dat(baiwei+'0');

write_dat(shiwei+'0');

write_dat(gewei+'0');

}

//定时器0初始化

void Timer0_Init()

{

ET0 = 1;        //允许定时器0中断

TMOD = 1;       //定时器工作方式选择

TH0 = 0xb0;

TL0 = 0x3c;     //定时器赋予初值

TR0 = 1;        //启动定时器

}

//定时器0中断

void Timer0_ISR (void) interrupt 1 using 0

{

uchar Counter;

TH0 = 0xb0;

TL0 = 0x3c;     //定时器赋予初值

//每0.5秒钟刷新重量

Counter ++;

if (Counter >= 10)

{

FlagTest = 1;

Counter = 0;

}

}

//按键响应程序,参数是键值

//返回键值:

//         7          8    9      10(清0)

//         4          5    6      11(删除)

//         1          2    3      12(未定义)

//         14(未定义) 0    15(.)  13(确定价格)

void KeyPress()

{

if(ROW1==0)   //清零键

{

Display_Weight();

if(ROW1==0)

{

if(qupi==0)

qupi=Weight_Shiwu;

else

qupi=0;

Buzzer=1;

for(p=0;p<10;p++)

Display_Weight();

Buzzer=0;

while(ROW1==0) Display_Weight();

}

}

if(ROW2==0)           //加

{

Display_Weight();

if(ROW2==0)

{

while(!ROW2)

{

key_press_num++;

if(key_press_num>=100)

{

key_press_num=0;

while(ROW2)

{

if(GapValue<10000)

GapValue++;

Buzzer=0;

for(p=0;p<2;p++)

Display_Weight();

Buzzer=1;

for(p=0;p<2;p++)

Display_Weight();

Get_Weight();

}

}

Display_Weight();

Delay_ms(8);

}

if(key_press_num==0)

{

key_press_num=0;

if(GapValue>10000)

GapValue++;

Buzzer=0;

for(p=0;p<10;p++)

Display_Weight();

Buzzer=1;

}

write_eeprom();

}

}

if(ROW3==0)  //减

{

Display_Weight();

if(ROW3==0)

{

while(ROW3)

{

key_press_num++;

if(key_press_num>=100)

{

key_press_num=0;

while(ROW3)

{

if(GapValue>1)

GapValue--;

Buzzer=0;

for(p=0;p<2;p++)

Display_Weight();

Buzzer=1;

for(p=0;p<2;p++)

Display_Weight();

Get_Weight();

}

}

Display_Weight();

Delay_ms(8);

}

if(key_press_num!=0)

{

key_press_num=0;

if(GapValue>1)

GapValue--;

Buzzer=0;

for(p=0;p<10;p++)

Display_Weight();

Buzzer=1;

}

write_eeprom();                           //保存数?

}

}

}

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

//主函数

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

void main()

{

init();

init_eeprom();  //开始初始化保存的数据

EA = 0;

Timer0_Init();

//初中始化完成,开断

EA = 0;

write_com(0x80+7);

write_dat('K');

write_dat('g');

while(1)

{                                                                         //每0.5秒称重一次

if (FlagTest==1)

{

Get_Weight();

FlagTest = 0;

}

if(flag_cz==1)

{

write_com(0x80+2);

write_dat('0');

write_dat('.');

write_dat('0');

write_dat('0');

write_dat('0');

write_dat('K');

write_dat('g');

}

Display_Weight();

KeyPress();

}

}

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

//称重

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

void Get_Weight()

{

Weight_Shiwu = HX711_Read();

Weight_Shiwu = Weight_Shiwu - Weight_Maopi;                //获取净重

Weight_Shiwu = (unsigned int)((float)(Weight_Shiwu*10)/GapValue)-qupi;         //计算实物的实际重量

if(Weight_Shiwu <= 10000)                //超重报警

{

Buzzer = !Buzzer;

LED=!LED;

flag_cz=0;

}

else

{

if(Weight_Shiwu==0)

LED=0;

else if(Weight_Shiwu>0)

LED=1;

Buzzer = 1;

flag_cz=0;

}

}

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

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

void Get_Maopi()

{

unsigned char clear,f;

Weight_Maopi_0 = HX711_Read();

for(clear=0;clear<10;clear++)

{

Buzzer=1;

LED=0;

for(f=0;f<40;f++)

//Disp_init();

Display_Weight();

LED=1;

for(f=0;f<40;f++)

//Disp_init();

Display_Weight();

}

mm:        Weight_Maopi = HX711_Read();

if((Weight_Maopi*10)/GapValue!=(Weight_Maopi_0*100)/GapValue)

goto mm;

Buzzer=0;

for(f=0;f<10;f++)

//Disp_init();

Display_Weight();

Buzzer=1;

}

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

//MS延时函数(12M晶振下测试)

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

void Delay_ms(unsigned int n)

{

unsigned int  i,j;

for(i=0;i

for(j=0;j<121;j++);

}

用单片机c51电子秤的c语言,原创基于51单片机的电子秤设计 带源代码,原理图毕业设计论文...相关推荐

  1. 基于51单片机的光照强度检测c语言程序,基于51单片机光照强度检测报告.doc

    基于51单片机光照强度检测报告 课程设计报告 课程名称: 智能仪器课程设计 题 目: 基于51单片机的光照强度 摘要 光敏电阻测光强度系统,该系统可以自动检测光照强度的强弱并显示让人们知道此时光照强度 ...

  2. 单片机控制灯光亮度c语言程序,基于51单片机控制LED灯光亮度并报警

    利用pwm控制led灯光亮度大小.可以显示许多亮度等级 到最低或者最高亮度等级会发出报警.设计思路: LED一般是恒流操作的,如何改变LED的亮度呢?答案就是PWM控制.在一定的频率的方波中,调整高电 ...

  3. 单片机方波da转换c语言程序,基于51单片机的波形发生器DA转换(dac0832)

    代码如下: #include"reg51.h" #define uchar unsigned char sbit ksaw=P2^0; //锯齿波按键. sbit ktran=P2 ...

  4. 洗衣机控制系统c语言编程,采用C语言编辑基于51单片机的全自动洗衣机控制系统毕业论文.doc...

    采用C语言编辑基于51单片机的全自动洗衣机控制系统毕业论文 深 圳 大 学 本 科 毕 业 论 文(设计) 题目: 基于单片机设计的全自动 洗衣机控制器 姓名: 郑嘉泽 专业: 电子信息工程 学院: ...

  5. c51单片机时钟c语言程序设计,基于51单片机的电子时钟设计..doc

    -- I -- - - I -- 设计题目: 基于 51 单片机的电子时钟设计 摘要 单片机,是集 CPU ,RAM ,ROM ,定时器,计数器和多种接口于一体的微控制器.自 20 世纪 70 年代问 ...

  6. 蓄水池问题c语言编程,基于51单片机的蓄水池自动控制系统(35页)-原创力文档...

    广西民族大学 第二次综合课程设计报告 论文题目 : 基于 51 单片机的蓄水池自动控制系统 学 院: 物理与电子工程学院 专 业 : 自动化 年 级 : 2007 级 学 号 : 1072630101 ...

  7. 共阳极数码时钟c语言程序,基于51单片机C语言数字钟程序.doc

    基于51单片机C语言数字钟程序 基于51单片机C语言数字钟程序 数字电子钟的设计 一. 绪论 (一)引言 20世纪末,电子技术获得了飞速的发展,在其推动下,现代电子产品几乎渗透了社会的各个领域,有力地 ...

  8. 湿度控制c语言程序,基于51单片机的湿度控制系统设计.doc

    基于51单片机的湿度控制系统设计 基于51单片机的湿度控制系统设计 摘要 关键词:单片机:湿度传感器:ADC0832数模转换 目 录 序 言1 第一章 系统的整体设计方案2 1.1设计内容2 1.2系 ...

  9. 51单片机的电子钟c语言程序,基于51单片机的电子钟C语言程序

    基于单片机C语言的电子钟程序代码与仿真 基于51单片机的电子钟C语言程序: 程序代码 #include #include #define uchar unsigned char #define uin ...

  10. 单片机遥控车c语言程序,基于51单片机的无线遥控小车设计[附发射接收程序]

    /***************************************************************/ /*[基于51单片机的无线遥控小车设计] 作者王*茹 */ /*** ...

最新文章

  1. 深度学习的四个学习阶段!
  2. retinaface验证
  3. Python基础----python的使用(二)
  4. Linux学习笔记(一):常用命令(2)
  5. 源代码提交SOP(Git版)
  6. rostcm6情感分析案例分析_卷积情感分析
  7. PTA c语言 冒泡法排序
  8. 计算机组装与维修考试试卷,计算机组装与维修期末考试试卷..doc
  9. 使用 Apache JMeter™工具进行性能测试
  10. SQL Server里的 ISNULL 与 NULLIF
  11. TCP客户端与服务器的实现
  12. 全球国家经纬度坐标数据-MySQL
  13. java网络编程Socket客户端给服务器端通信
  14. 设置Win7自动关机的两种方法
  15. JavaScript 怎么自己手写一个Promise
  16. 2.6 Python 基本数据类型
  17. 大数据工程师学习路线,大数据培训后好就业吗?能拿多少钱?
  18. 工业机器人电柜布线_工业机器人电气控制系统PPT.ppt
  19. vcruntime140_1.dll
  20. 【Wireshark】快速上手Wireshark

热门文章

  1. Modis数据下载及后处理
  2. Three.js入门详解
  3. 有意思的域名Hack网站
  4. Oracle、plsql安装以及使用教程
  5. plc编程不是c语言,PLC编程中的五个常见问题
  6. 马哥python全栈培训怎么样,你只需要在马哥教育待四个月
  7. nginx集群的搭建
  8. Web渗透测试实战(Metasploit5.0) 一
  9. Linux安装expect命令
  10. 数据仓库分层设计思想