0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

如何制作数字指南针

454398 来源:wv 2019-10-12 14:19 次阅读

第1步:所需零件

对于此项目,您将只需要一个Arduino开发板和一个MEMS磁力计即可测量地磁场。我将使用包含MC5883L 3轴磁力计的GY – 80分支板。

在继续执行该项目的源代码之前,如果您需要更多详细信息,请参见MEMS磁力计如何工作以及如何通过I2C通信连接和使用GY-80接线板,

第2步:Arduino源代码

我们首先需要做的是将草图上传到Arduino板,该板将读取来自磁力计的数据,并将其发送到Processing IDE。这是Arduino源代码:

/* Arduino Compass

*

* by Dejan Nedelkovski,

* www.HowToMechatronics.com

*

*/

#include //I2C Arduino Library

#define Magnetometer_mX0 0x03

#define Magnetometer_mX1 0x04

#define Magnetometer_mZ0 0x05

#define Magnetometer_mZ1 0x06

#define Magnetometer_mY0 0x07

#define Magnetometer_mY1 0x08

int mX0, mX1, mX_out;

int mY0, mY1, mY_out;

int mZ0, mZ1, mZ_out;

float heading, headingDegrees, headingFiltered, declination;

float Xm,Ym,Zm;

#define Magnetometer 0x1E //I2C 7bit address of HMC5883

void setup(){

//Initialize Serial and I2C communications

Serial.begin(115200);

Wire.begin();

delay(100);

Wire.beginTransmission(Magnetometer);

Wire.write(0x02); // Select mode register

Wire.write(0x00); // Continuous measurement mode

Wire.endTransmission();

}

void loop(){

//---- X-Axis

Wire.beginTransmission(Magnetometer); // transmit to device

Wire.write(Magnetometer_mX1);

Wire.endTransmission();

Wire.requestFrom(Magnetometer,1);

if(Wire.available()《=1)

{

mX0 = Wire.read();

}

Wire.beginTransmission(Magnetometer); // transmit to device

Wire.write(Magnetometer_mX0);

Wire.endTransmission();

Wire.requestFrom(Magnetometer,1);

if(Wire.available()《=1)

{

mX1 = Wire.read();

}

//---- Y-Axis

Wire.beginTransmission(Magnetometer); // transmit to device

Wire.write(Magnetometer_mY1);

Wire.endTransmission();

Wire.requestFrom(Magnetometer,1);

if(Wire.available()《=1)

{

mY0 = Wire.read();

}

Wire.beginTransmission(Magnetometer); // transmit to device

Wire.write(Magnetometer_mY0);

Wire.endTransmission();

Wire.requestFrom(Magnetometer,1);

if(Wire.available()《=1)

{

mY1 = Wire.read();

}

//---- Z-Axis

Wire.beginTransmission(Magnetometer); // transmit to device

Wire.write(Magnetometer_mZ1);

Wire.endTransmission();

Wire.requestFrom(Magnetometer,1);

if(Wire.available()《=1)

{

mZ0 = Wire.read();

}

Wire.beginTransmission(Magnetometer); // transmit to device

Wire.write(Magnetometer_mZ0);

Wire.endTransmission();

Wire.requestFrom(Magnetometer,1);

if(Wire.available()《=1)

{

mZ1 = Wire.read();

}

//---- X-Axis

mX1=mX1《《8;

mX_out =mX0+mX1; // Raw data

// From the datasheet: 0.92 mG/digit

Xm = mX_out*0.00092; // Gauss unit

//* Earth magnetic field ranges from 0.25 to 0.65 Gauss, so these are the values that we need to get approximately.

//---- Y-Axis

mY1=mY1《《8;

mY_out =mY0+mY1;

Ym = mY_out*0.00092;

//---- Z-Axis

mZ1=mZ1《《8;

mZ_out =mZ0+mZ1;

Zm = mZ_out*0.00092;

// ==============================

//Calculating Heading

heading = atan2(Ym, Xm);

// Correcting the heading with the declination angle depending on your location

// You can find your declination angle at: http://www.ngdc.noaa.gov/geomag-web/

// At my location it‘s 4.2 degrees =》 0.073 rad

declination = 0.073;

heading += declination;

// Correcting when signs are reveresed

if(heading 《0) heading += 2*PI;

// Correcting due to the addition of the declination angle

if(heading 》 2*PI)heading -= 2*PI;

headingDegrees = heading * 180/PI; // The heading in Degrees unit

// Smoothing the output angle / Low pass filter

headingFiltered = headingFiltered*0.85 + headingDegrees*0.15;

//Sending the heading value through the Serial Port to Processing IDE

Serial.println(headingFiltered);

delay(50);

}

步骤3:处理IDE源代码

在我们上传了之前的Arduino草图之后,我们需要将数据接收到Processing IDE中并绘制Digital Compass。指南针由背景图像,箭头的固定图像和指南针主体的旋转图像组成。因此,使用Arduino计算出的耳磁场的值将用来旋转罗盘。

以下是Processing IDE的源代码:

/* Arduino Compass

*

* by Dejan Nedelkovski,

* www.HowToMechatronics.com

*

*/

import processing.serial.*;

import java.awt.event.KeyEvent;

import java.io.IOException;

Serial myPort;

PImage imgCompass;

PImage imgCompassArrow;

PImage background;

String data=“”;

float heading;

void setup() {

size (1920, 1080, P3D);

smooth();

imgCompass = loadImage(“Compass.png”);

imgCompassArrow = loadImage(“CompassArrow.png”);

background = loadImage(“Background.png”);

myPort = new Serial(this, “COM4”, 115200); // starts the serial communication

myPort.bufferUntil(’ ‘);

}

void draw() {

image(background,0, 0); // Loads the Background image

pushMatrix();

translate(width/2, height/2, 0); // Translates the coordinate system into the center of the screen, so that the rotation happen right in the center

rotateZ(radians(-heading)); // Rotates the Compass around Z - Axis

image(imgCompass, -960, -540); // Loads the Compass image and as the coordinate system is relocated we need need to set the image at -960x, -540y (half the screen size)

popMatrix(); // Brings coordinate system is back to the original position 0,0,0

image(imgCompassArrow,0, 0); // Loads the CompassArrow image which is not affected by the rotateZ() function because of the popMatrix() function

textSize(30);

text(“Heading: ” + heading,40,40); // Prints the value of the heading on the screen

delay(40);

}

// starts reading data from the Serial Port

void serialEvent (Serial myPort) {

data = myPort.readStringUntil(’ ‘);// reads the data from the Serial Port and puts it into the String variable “data”。

heading = float(data); // Convering the the String value into Float value

}

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 指南针
    +关注

    关注

    2

    文章

    16

    浏览量

    10803
收藏 人收藏

    评论

    相关推荐

    目标主力能源:华为智能光伏的时代指南针

    真正让光伏能源走向舞台中央,还需要一枚技术与产业中的指南针
    的头像 发表于 01-25 09:57 2702次阅读
    目标主力能源:华为智能光伏的时代<b class='flag-5'>指南针</b>

    地磁定位技术简介和基本原理

    人类使用地磁信息进行导航具有悠久的历史。远有我国古代发明的指南针、航海罗盘等,近有十四、十五世纪欧洲人使用罗盘进行远洋航行,发现新大陆等壮举,这都与地磁导航是分不开的。
    的头像 发表于 01-20 10:45 978次阅读
    地磁定位技术简介和基本原理

    电学基础之磁场与电磁的概念介绍

    说起磁,我们都很熟悉,通常将能吸引铁、镍、钴的物体称为磁铁或磁体,如常见的磁铁、指南针等。
    的头像 发表于 01-11 13:37 342次阅读

    磁力计LIS2MDL开发(2)----电子罗盘

    本文将介绍如何使用 LIS2MDL 传感器来读取数据来转化为指南针
    的头像 发表于 12-18 11:01 727次阅读
    磁力计LIS2MDL开发(2)----电子罗盘

    你知道指南针如何自己制作吗?防迷路必备神器,跟我来看一看吧!

    电源led电路电子技术电池
    学习电子知识
    发布于 :2023年08月23日 20:57:55

    __17.使用 Arduino接口 HMC5883L_QMC5883数字指南针 #硬声创作季

    电路开发伺服电机程序
    充八万
    发布于 :2023年08月08日 22:00:37

    Arm通用中断控制器GICv3/v4详解

    不同,因为它们状态保存在内存中,而不是寄存器中。LPI是消息信号中断(MSIs)由中断翻译服务(ITS)提供的翻译。 本指南针对的是任何需要了解MSIs如何由GIC翻译的人以及如何管理所得到的LPI
    发表于 08-02 09:20

    学习架构-通用定时器用户指南

    指南介绍了通用定时器,这是一种用于A配置文件PE的定时器框架。指南介绍了现代SoC中定时器框架的不同组件,并涵盖可用于软件的编程接口。 该指南针对的是编写低级软件以初始化或使用基于手臂的系统。本
    发表于 08-02 08:50

    57 采用方向传感器实现指南针 - 第1节57 采用方向传感器实现指南针 - 第1节

    软件编程程序
    充八万
    发布于 :2023年07月29日 23:23:43

    西门子博途:扫描操作数的信号下降沿

    使用“扫描操作数的信号下降沿”指令,可以确定所指定操作数()的信号状态是否从“1”变为“0”。
    的头像 发表于 07-17 10:51 1917次阅读
    西门子博途:扫描操<b class='flag-5'>作数</b>的信号下降沿

    PowerNavigator 数字多相用户指南

    PowerNavigator 数字多相用户指南
    发表于 07-07 19:16 0次下载
    PowerNavigator <b class='flag-5'>数字</b>多相用户<b class='flag-5'>指南</b>

    扫描操作数的信号上升沿

    使用“扫描操作数的信号上升沿”指令,可以确定所指定操作数()的信号状态是否从“0”变为“1”。
    的头像 发表于 06-27 09:39 1715次阅读
    扫描操<b class='flag-5'>作数</b>的信号上升沿

    使用Arduino和加速度计陀螺仪传感器MPU9250制作指南针

    电子发烧友网站提供《使用Arduino和加速度计陀螺仪传感器MPU9250制作指南针.zip》资料免费下载
    发表于 06-26 10:24 0次下载
    使用Arduino和加速度计陀螺仪传感器MPU9250<b class='flag-5'>制作</b><b class='flag-5'>指南针</b>

    通过ESP32制作数码相册

    电子发烧友网站提供《通过ESP32制作数码相册.zip》资料免费下载
    发表于 06-16 11:30 2次下载
    通过ESP32<b class='flag-5'>制作数</b>码相册

    Arduino RC汽车向北行驶并使用指南针调整位置

    电子发烧友网站提供《Arduino RC汽车向北行驶并使用指南针调整位置.zip》资料免费下载
    发表于 06-09 10:08 0次下载
    Arduino RC汽车向北行驶并使用<b class='flag-5'>指南针</b>调整位置