hx711.c 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. #include "hx711.h"
  2. #include "public.h"
  3. //校准参数
  4. //因为不同的传感器特性曲线不是很一致,因此,每一个传感器需要矫正这里这个参数才能使测量值很准确。
  5. //当发现测试出来的重量偏大时,增加该数值。
  6. //如果测试出来的重量偏小时,减小改数值。
  7. //该值可以为小数
  8. #define GapValue 710 //5kg量程对应参数430附近,3kg量程对应710附近,1kg量程对应2150附近
  9. //报警值,单位是g
  10. #define AlarmValue 10000 //100kg
  11. unsigned long HX711_Buffer = 0; //用来存放HX711读取出来的数据
  12. unsigned long Weight_Maopi = 0; //用来存放毛皮数据
  13. long Weight_Shiwu = 0; //用来存放实物重量
  14. void Get_Maopi(void);
  15. long Get_Weight(void);
  16. void Hx711Init(void);
  17. void Hx711Init(void)
  18. {
  19. HX711_DOUT_PIN_OUT();
  20. HX711_SCK_PIN_OUT();
  21. }
  22. //****************************************************
  23. //读取HX711
  24. //****************************************************
  25. unsigned long HX711_Read(void) //增益128
  26. {
  27. unsigned long count;
  28. unsigned int timeout=0;
  29. unsigned char i;
  30. HX711_DOUT_PIN_OUT();
  31. HX711_DOUT_PIN=1;
  32. system_delay_us(1);
  33. HX711_SCK_PIN=0;
  34. count=0;
  35. HX711_DOUT_PIN_IN();
  36. while((HX711_DOUT_PIN)&&(++timeout<3000));
  37. for(i=0;i<24;i++)
  38. {
  39. HX711_SCK_PIN=1;
  40. count=count<<1;
  41. HX711_SCK_PIN=0;
  42. HX711_DOUT_PIN_IN();
  43. if(HX711_DOUT_PIN)
  44. count++;
  45. }
  46. HX711_SCK_PIN=1;
  47. count=count^0x800000;//第25个脉冲下降沿来时,转换数据
  48. system_delay_us(1);
  49. HX711_SCK_PIN=0;
  50. return(count);
  51. }
  52. //****************************************************
  53. //获取毛皮重量
  54. //****************************************************
  55. void Get_Maopi(void)
  56. {
  57. Weight_Maopi = HX711_Read();
  58. }
  59. //****************************************************
  60. //称重
  61. //****************************************************
  62. long Get_Weight(void)
  63. {
  64. Weight_Shiwu = HX711_Read();
  65. Weight_Shiwu = Weight_Shiwu - Weight_Maopi; //获取净重
  66. if(Weight_Shiwu >= 0)
  67. {
  68. Weight_Shiwu = (unsigned long)((float)Weight_Shiwu/GapValue); //计算实物的实际重量
  69. }
  70. else
  71. {
  72. Weight_Shiwu = 0;
  73. }
  74. return Weight_Shiwu;
  75. }