齐护机器人方位传感器指南针罗盘陀螺仪

一、方位传感器原理及功能说明

齐护方位传感器是一款集成了三轴磁传感器芯片的方位传感器模块。适用于无人机、机器人、移动和个人手持设备中的罗盘(指南针)、导航和游戏等高精度应用。模块可以感应XYZ平面角度外,还可实现1°至2°的水平面角度罗盘航向精度(平面指向角度),采用i2c串行总线接口。

硬件功能说明

二、常用主控接线

连接: 所有主控都要使用I2C管脚连接模块!

三、图形化编程块功能说明

四、编程示例

4-1.获取方位角

角度对应关系如下图所示,以北面为0点,顺时针为正,逆时针为负。

注:在Micropython下编程时角度是从0-360度的,没有负角度!

例程功能说明:打印当前方位角,当方位角小于50时,13号IO的灯亮起,否则关灯,延时0.25秒,防传感器刷新过快看不清数据或传感器卡死。

齐护编程软件程序如下图所示:

Mixly软件编程程序如下图所示:

Arduino代码编程如下:

#include <Arduino.h>
#include <QH_Compass.h>

QH_Compass compass;

void setup() {
  compass.init();
  Serial.begin(9600);
  pinMode(13, OUTPUT);
}

void loop() {
  compass.read();
  Serial.println(compass.getAzimuth());
  if (compass.getAzimuth() < 50) {
    digitalWrite(13, 1);
  }
  else{
    digitalWrite(13, 0);
  }
  delay(0.25 * 1000);
}

Micropython编程如下:

这里把控制IO变为IO2,且在Micropython下编程时方向角只有0-360度数据,没有负值!

Micropython代码编程如下:

import machine, QH_Compass, time
from machine import Pin

compass=QH_Compass.QH_Compass(sda=21,scl=22)

pin2 = Pin(2, Pin.OUT)
while True:
  compass.read();
  print(compass.heading())
  if compass.heading() < 50:
    pin2.value(0)
  else:
    pin2.value(1)
  time.sleep_ms(int(0.25 * 1000))

4-2.获取方位

将方位角转换为0~15的方位,如下图所示从0(360°)位置开始每22.5度代表一个方向,如则返回0为北面,1为北东北,2为东北,同理类推。

QH_FW_Img00

齐护编程Scratch程序如下图所示:

Mixly软件程序如下图所示:

Arduino代码编程如下:

#include <Arduino.h>
#include <QH_Compass.h>

QH_Compass compass;

void setup() {
  compass.init();
  Serial.begin(9600);
}

void loop() {
  compass.read();
  Serial.println(compass.getBearing(compass.getAzimuth()));
  delay(0.25 * 1000);
}

4-3.获取传感器XYZ的值

获取传感器XYZ平面的原始值,类似于陀螺仪的角度,箭头表示在正常测量配置中产生正输出读数的磁场方向。

齐护编程Scratch软件程序如下图所示:

Mixly软件程序如下图所示:

Arduino代码编程如下:

#include <Arduino.h>
#include <QH_Compass.h>

QH_Compass compass;

void setup() {
  compass.init();
  Serial.begin(9600);
}

void loop() {
  compass.read();
  Serial.println((String((String((String("X:") + String(compass.getX()))) + String((String(" Y:") + String(compass.getX()))))) + String((String(" Z:") + String(compass.getX())))));
  delay(0.25 * 1000);
}

Micropython编程如下:

Micropython代码编程如下:

import machine, QH_Compass, time

compass=QH_Compass.QH_Compass(sda=21,scl=22)

while True:
  compass.read();
  print((str('X:') + str(str(compass.read_rawXYZ(0)) + str(str('Y:') + str(str(compass.read_rawXYZ(1)) + str(str('Z:') + str(compass.read_rawXYZ(2))))))))
  time.sleep_ms(int(0.25 * 1000))

五、附件示例程序下载

【方位传感器】

相关推荐
bohu832 小时前
亚博microros小车-原生ubuntu支持系列:16 机器人状态估计
ubuntu·机器人·imu·localization·microros·imu_tools
Big David9 小时前
机器人基础&&深度学习基础
机器人·具身智能
luoganttcc11 小时前
松灵机器人 scout ros2 驱动 安装
机器人
xwz小王子11 小时前
ICLR 2025收录论文:为什么动作分块对于机器人灵活性至关重要?
人工智能·机器人
古月居GYH14 小时前
边缘计算与ROS结合:如何实现分布式机器人智能决策?
机器人·ros·边缘计算
oioihoii1 天前
春晚舞台上的人形机器人:科技与文化的奇妙融合
人工智能·科技·机器人
机器小乙2 天前
昆虫机器人:从仿生设计到未来应用
机器人
弥途3 天前
自制一个入门STM32 四足机器人具体开发顺序
stm32·单片机·机器人
Big David4 天前
机器人抓取与操作经典规划算法(深蓝)——2
算法·机器人·具身智能
max5006004 天前
机器人介绍
机器人