STM32与拉力传感器通信

4 篇文章 1 订阅
4 篇文章 0 订阅

目录

 第一部分、设备通信图

 第二部分、设备接线

HX711与传感器的接线

HX711与MCU的接线

 第三部分、驱动代码

HX711引脚初始化(Dout,CLK)

HX711读取数据函数

HX711获取传感器的值

头文件定义:

实验结果: 


第一部分、设备通信图

物联网节点设备分为三部分:MCU(STM32),医疗传感器(RSS01B拉压力传感器),HX711(24AD)

HX711负责将传感器的电压值转换为数字量发送给MCU,MCU对数据进行处理分析

HX711模块图

RSS01B模块图

 第二部分、设备接线

HX711与传感器的接线

HX711与MCU的接线

第三部分、驱动代码

HX711引脚初始化(Dout,CLK)


void hx711_Init(void)
{

  GPIO_InitTypeDef GPIO_InitStruct = {0};

  /* GPIO Ports Clock Enable */
  __HAL_RCC_GPIOE_CLK_ENABLE();
  __HAL_RCC_GPIOA_CLK_ENABLE();

  /*Configure GPIO pin Output Level */
  HAL_GPIO_WritePin(GPIOE, GPIO_PIN_5, GPIO_PIN_RESET);

  /*Configure GPIO pin : PE5 */
  GPIO_InitStruct.Pin = GPIO_PIN_5;
  GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
  GPIO_InitStruct.Pull = GPIO_NOPULL;
  GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  HAL_GPIO_Init(GPIOE, &GPIO_InitStruct);

  /*Configure GPIO pin : PE6 */
  GPIO_InitStruct.Pin = GPIO_PIN_6;
  GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
  GPIO_InitStruct.Pull = GPIO_NOPULL;
  HAL_GPIO_Init(GPIOE, &GPIO_InitStruct);

}

HX711读取数据函数

unsigned long HX711_Read_01()        
{
			unsigned long count; 
			unsigned char i; 
		
			HX711_SCK_0; 
			count=0; 
			delay_us(1);
			while(HAL_GPIO_ReadPin(HX711_DOUT_GPIO,HX711_DOUT) ==GPIO_PIN_SET);
			for(i=0;i<24;i++)
			{ 
				HX711_SCK_1; 
				count=count<<1; 
				delay_us(1);
				HX711_SCK_0; 
				if(HAL_GPIO_ReadPin(HX711_DOUT_GPIO,HX711_DOUT) == GPIO_PIN_SET) 
                count++; 
				delay_us(1);
			} 
			HX711_SCK_1; 
			count=count^0x800000;
			delay_us(1);
			HX711_SCK_0;  
			return(count);
}

HX711获取传感器的值

void Get_Maopi_01()  //获取标定值(初始化重物重量)
{
	 Weight_Maopi_01 = HX711_Read_01();
	
}

float Get_Weight()   //获取重物去皮后的重量
{
	float Weight_Shiwu = 0;
	float Weight_Maopi = 0;
	weight.Real_Weight = HX711_Read_01();
	printf("weight.Real_Weight£º%f\n",weight.Real_Weight);
	if(weight.Real_Weight > Weight_Maopi_01)			
	{
		Weight_Shiwu = weight.Real_Weight;
		
		Weight_Maopi = Weight_Maopi_01;
		printf("%f\n",Weight_Maopi);
		Weight_Shiwu = Weight_Shiwu - Weight_Maopi;		
	
		Weight_Shiwu = (float)(Weight_Shiwu/weight.GapValue); 
	}
	return Weight_Shiwu;
}

头文件定义:

	
typedef struct 
{
		float GapValue;			//传感器的比例值	    
		float MaoPi; 			//传感器的初始值(重量的标定值)		     
		float Real_Weight;    	//传感器的真实值(去皮值)   
}Weight;

extern Weight weight;

#define HX711_DOUT_GPIO GPIOE
#define HX711_SCK_GPIO  GPIOE

#define HX711_DOUT  GPIO_PIN_6
#define HX711_SCK   GPIO_PIN_5

//PE6 IO口操作
#define HX711_DOUT_0 HAL_GPIO_WritePin(HX711_DOUT_GPIO,HX711_DOUT,GPIO_PIN_RESET)
#define HX711_DOUT_1 HAL_GPIO_WritePin(HX711_DOUT_GPIO,HX711_DOUT,GPIO_PIN_SET)

//PE5 IO口操作
#define HX711_SCK_0  HAL_GPIO_WritePin(HX711_SCK_GPIO,HX711_SCK,GPIO_PIN_RESET)
#define HX711_SCK_1  HAL_GPIO_WritePin(HX711_SCK_GPIO,HX711_SCK,GPIO_PIN_SET)

实验结果: 

  • 4
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
import android.app.Service; import android.content.Context; import android.graphics.Canvas; import android.graphics.Color; import android.graphics.Paint; import android.graphics.RectF; import android.hardware.Sensor; import android.hardware.SensorEvent; import android.hardware.SensorEventListener; import android.hardware.SensorManager; import android.util.Log; import android.view.SurfaceHolder; import android.view.SurfaceView; import android.view.SurfaceHolder.Callback; /** *@author Himi *@Sensor 加速度传感器 ,也称为重力传感器 *@SDK 1.5(api 3)就支持传感器了 *@解释:此传感器不仅对玩家反转手机的动作可以检测到,而且会根据反转手机的程度,得到传感器的值也会不同! */ public class MySurfaceView extends SurfaceView implements Callback, Runnable { private Thread th = new Thread(this); private SurfaceHolder sfh; private Canvas canvas; private Paint paint; private SensorManager sm; private Sensor sensor; private SensorEventListener mySensorListener; private int arc_x, arc_y;// 圆形的x,y位置 private float x = 0, y = 0, z = 0; public MySurfaceView(Context context) { super(context); this.setKeepScreenOn(true); sfh = this.getHolder(); sfh.addCallback(this); paint = new Paint(); paint.setAntiAlias(true); setFocusable(true); setFocusableInTouchMode(true); //通过服务得到传感器管理对象 sm = (SensorManager) MainActivity.ma.getSystemService(Service.SENSOR_SERVICE); sensor = sm.getDefaultSensor(Sensor.TYPE_ACCELEROMETER);//得到一个重力传感器实例 //TYPE_ACCELEROMETER 加速度传感器(重力传感器)类型。 //TYPE_ALL 描述所有类型的传感器。 //TYPE_GYROSCOPE 陀螺仪传感器类型 //TYPE_LIGHT 光传感器类型 //TYPE_MAGNETIC_FIELD 恒定磁场传感器类型。 //TYPE_ORIENTATION 方向传感器类型。 //TYPE_PRESSURE 描述一个恒定的压力传感器类型 //TYPE_PROXIMITY 常量描述型接近传感器 //TYPE_TEMPERATURE 温度传感器类型描述 mySensorListener = new SensorEventListener() { @Override //传感器获取值发生改变时在响应此函数 public void onSensorChanged(SensorEvent event) {//备注1 //传感器获取值发生改变,在此处理 x = event.values[0]; //手机横向翻滚 //x>0 说明当前手机左翻 x<0右翻 y = event.values[1]; //手机纵向翻滚 //y>0 说明当前手机下翻 y<0上翻 z = event.values[2]; //屏幕的朝向 //z>0 手机屏幕朝上 z<0 手机屏幕朝下 arc_x -= x;//备注2 arc_y += y; } @Override //传感器的精度发生改变时响应此函数 public void onAccuracyChanged(Sensor sensor, int accuracy) { // TODO Auto-generated method stub } }; sm.registerListener(mySensorListener, sensor, SensorManager.SENSOR_DELAY_GAME); //第一个参数是传感器监听器,第二个是需要监听的传感实例 //最后一个参数是监听的传感器速率类型: 一共一下四种形式 //SENSOR_DELAY_NORMAL 正常 //SENSOR_DELAY_UI 适合界面 //SENSOR_DELAY_GAME 适合游戏 (我们必须选这个呀 哇哈哈~) //SENSOR_DELAY_FASTEST 最快 } public void surfaceCreated(SurfaceHolder holder) { arc_x = this.getWidth() / 2 - 25; arc_y = this.getHeight() / 2 - 25; th.start(); } public void draw() { try { canvas = sfh.lockCanvas(); if (canvas != null) { canvas.drawColor(Color.BLACK); paint.setColor(Color.RED); canvas.drawArc(new RectF(arc_x, arc_y, arc_x + 50, arc_y + 50), 0, 360, true, paint); paint.setColor(Color.YELLOW); canvas.drawText("当前重力传感器的值:", arc_x - 50, arc_y-30, paint); canvas.drawText("x=" + x + ",y=" + y + ",z=" + z, arc_x - 50, arc_y, paint); String temp_str = "Himi提示: "; String temp_str2 = ""; String temp_str3 = ""; if (x < 1 && x > -1 && y < 1 && y > -1) { ..................... .....................

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值