3、Arduino#

3.1、Arduino IDE和驱动的安装#

当我们拿到开发板时,首先我们要安装Arduino IDE和驱动,相关文件我们可以在官网上找到,以下链接是包含各种系统、各种版本的Arduino IDE和驱动任你选择。

https://www.arduino.cc/en/Main/OldSoftwareReleases#1.5.x

下面我们介绍下Arduino-1.5.6 版本IDE在Windows系统的安装方法。

下载下来的文件是一个arduino-1.5.6-r2-windows.zip的压缩文件夹,解压出来到硬盘。

双击Arduino-1.5.6 .exe文件

../_images/f5f98943a74471640eefe95e3cccd0ee.png

然后

../_images/44384a228758644aca47e983417e0079.png

然后

../_images/704e73c99bcc5eed53d0ab210107b5e1.png

等待安装完成.点击close,安装完成。

../_images/742a2a6ad75dbc8f8d55cc25c2dc61ca.png

1.5.6版本安装后的样子。

../_images/4baf5095962e49c1f3ebeb6c2da823f0.png

接下来是开发板驱动的安装,这次我们安装的是Keyes UNO R3开发板的驱动,Keyes 2560 R3开发板安装驱动方法和这个类似,驱动文件可以用同一个文件。

不同的系统,安装驱动的方法也有一些细小的区别,下面我们介绍在WIN 7系统安装驱动的方法。

第一次Keyes UNO R3开发板连接电脑时,点击计算机--属性--设备管理器,显示如下图。

../_images/ef888e8d5fad0b30e4da671933f8842c.png

点击 Unknown device 安装驱动,如下图。

../_images/231c0059b83eb424215dbc17edb21afb.png

进入下图,选择

../_images/1b36a09374634af82cf432f86cb8843f.png

找到Arduino安装位置的drivers文件夹

../_images/19f226835eac31a0ed12516dcefcfc53.png

点击“Next”,今天下图选择,开始安装驱动

image1image2

安装驱动完成,出现下图点击Close。

这样驱动就装好了。点击计算机--属性--设备管理器,我们可看见如下图。

../_images/af9806622ecf816c62f7597448a3cc5f.png

3.2、Arduino IDE的使用方法#

Keyes UNO R3开发板的USB驱动安装成功之后,我们可以在Windows设备管理器中找到相应的串口。

下面示范第一个程序的烧写,串口监视器中显示“Hello World!”。

测试代码为:

int val;

int ledpin=13;

void setup()

{

    Serial.begin(9600);

    pinMode(ledpin,OUTPUT);

}

void loop()

{

    val=Serial.read();

    if(val=='R')

    {

        digitalWrite(ledpin,HIGH);

        delay(500);

        digitalWrite(ledpin,LOW);

        delay(500);

        Serial.println("Hello World!");

    }

}

我们打开Arduino 的软件,编写一段程序让Keyes UNO R3开发板接受到我们发的指令就显示“Hello World!”字符串;我们再借用一下Keyes UNO R3 开发板上的 D13的指示灯,让Keyes UNO R3开发板接受到指令时指示灯闪烁一下,再显示“Hello World!”。

打开Arduino 的软件,设置板,如下。

../_images/43d9c16b238cfa52845c3a1b553cc630.png

设置COM端口,如下

../_images/025e24eacb26620c8831c8a3571412f6.png

点击image3编译程序,检查程序是否错误;点击image4上传程序;Keyes UNO R3 开发板设置OK后右下脚显示如下图,和设备管理器中显示一致。

../_images/add2f4f32678fe555861ae1763488afd.png

上传成功,输入R,点击发送,Keyes UNO R3 开发板上的 D13的指示灯闪烁一次,串口监视器中显示 Hello World! 如下图

../_images/fa8f2de13c41710b9dbbfde0833eca74.png

那么恭喜你,你的第一个程序已经成功了!!!

3.3、实验课程#

实验一 LED 闪烁实验#

实验说明

LED 闪烁实验是比较基础的实验之一,上一个“ Hello World!”实验里已经利用到了Arduino 自带的LED,这次我们利用其他I/O口和外接直插LED 灯来完成这个实验。

实验器材

开发板*1

USB线*1

LED*1

220Ω 电阻*1

面包板*1

面包板连接线若干

接线图

../_images/2af89e5285face0b57f35a4caf172f3d.jpeg

测试代码

int led = 2; //定义数字口2

void setup()

{

  pinMode(led, OUTPUT);     //设置led为输出

}

void loop()

{

  digitalWrite(led, HIGH);   //开启led

  delay(1000); //延迟1秒

  digitalWrite(led, LOW);    //关闭led

  delay(1000);//延迟1秒

}

测试结果

下载完程序就可以看到我们的IO口外接小灯在闪烁了,这样我们的实验现象为LED不停闪烁,间隔大约为1秒。

实验二 呼吸灯实验#

实验说明

上一课程中我们只是控制LED的亮和灭,那么我们可以怎么控制LED的亮度呢?本课程中我们把LED接到PWM口中,然后通过改变PWM数值,调节LED亮度,使LED逐渐变亮,和逐渐变暗,从而达到呼吸灯的效果。

实验器材

开发板*1

USB线*1

LED*1

220Ω 电阻*1

面包板*1

面包板连接线若干

接线图

../_images/6b6a8822a62acd33c10c59915afe97fb.jpeg

测试代码

int ledPin = 3; // 定义数字口3

void setup()

{

    pinMode(ledPin, OUTPUT);// 将ledPin设置为输出

}

void loop()

{

    for (int a=0; a<=255;a++)// 设置使LED逐渐变亮

    {

        analogWrite(ledPin,a); //开启led,调节亮度,范围是0-255,在255时led最亮

        delay(10); // 延迟0.01S

    }

    for (int a=255; a>=0;a--) // 设置使LED逐渐变暗

    {

        analogWrite(ledPin,a); //开启led,调节亮度,范围是0-255,在255时led最亮

        delay(10); // 延迟0.01秒

    }

    delay(1000);// 延迟1秒

}

测试结果

下载完程序就可以看到我们的IO口外接小灯显示出呼吸灯的效果,小灯先逐渐变亮,后逐渐变暗,循环交替。

实验三 广告灯实验#

实验说明

在生活中我们经常会看到一些由各种颜色的led灯组成的广告牌,广告牌上各个位置上癿led灯不断的变话,形成各种效果。本节实验就是利用led灯编程模拟广告灯效果。

实验器材

开发板*1

USB线*1

LED*5

220Ω 电阻*5

面包板*1

面包板连接线若干

接线图

../_images/5f396bc342428dce0d4c32c162161817.jpeg

测试代码

int BASE = 2 ; //第一个 LED 接的 I/O 口

int NUM = 5; //LED 的总数

void setup()

{

    for (int i = BASE; i < BASE + NUM; i ++)

    {

        pinMode(i, OUTPUT); //设定数字I/O口为输出

    }
}

void loop()

{

    for (int i = BASE; i < BASE + NUM; i ++)

    {

        digitalWrite(i, HIGH); //设定数字I/O口输出为"高",即逐渐开灯

        delay(200); //延迟

    }

    for (int i = BASE; i < BASE + NUM; i ++)

    {

        digitalWrite(i, LOW); //设定数字I/O口输出为"低",即逐渐关灯

        delay(200); //延迟

    }

}

测试结果

下载完程序就可以看到我们的IO口外接小灯先逐渐变亮,然后逐渐变暗,循环交替。

实验四 交通灯实验#

实验说明

前面我们已经完成了单个小灯的控制实验,接下来我们就来做一个稍微复杂一点的交通灯实验,其实聪明的朋友们可以看出来这个实验就是将上面单个小灯的实验扩展成3个颜色的小灯,就可以实现我们模拟交通灯的实验了。

实验器材

红色LED*1

黄色LED*1

绿色LED*1

220Ω电阻*3

面包板*1

面包板连接线若干

接线图

../_images/a05594d6f47a47fdd3af019846cdbf4a.jpeg

测试代码

int redled =10; //定义数字10 接口

int yellowled =7; //定义数字7 接口

int greenled =4; //定义数字4 接口

void setup()

{

    pinMode(redled, OUTPUT);//定义红色小灯接口为输出接口

    pinMode(yellowled, OUTPUT); //定义黄色小灯接口为输出接口

    pinMode(greenled, OUTPUT); //定义绿色小灯接口为输出接口

}

void loop()

{

    digitalWrite(greenled, HIGH);////点亮 绿灯

    delay(5000);//延时5秒

    digitalWrite(greenled, LOW); //熄灭 绿灯

    for(int i=0;i<3;i++)//闪烁交替三次,黄灯闪烁效果

    {

        delay(500);//延时0.5 秒

        digitalWrite(yellowled, HIGH);//点亮 黄灯

        delay(500);//延时0.5 秒

        digitalWrite(yellowled, LOW);//熄灭 黄灯

    }

    delay(500);//延时0.5 秒

    digitalWrite(redled, HIGH);//点亮 红灯

    delay(5000);//延时5 秒

    digitalWrite(redled, LOW);//熄灭 红灯

}

测试结果

按照接线图接好线,上传完程序,上电后,我们就可以看到我们自己设计控制的交通灯了。实验效果为绿灯亮5秒,绿灯熄灭,黄灯循环闪烁3次,红灯亮5秒,依次循环。

实验五 按键控制LED实验#

实验说明

I/O 口的意思即为INPUT 接口和OUTPUT接口,到目前为止我们设计的小灯实验都还只是应用到Arduino 的I/O口的输出功能,这个实验我们来尝试一下使用Arduino的I/O口的输入功能即为读取外接设备的输出值,我们用一个按键和一个LED小灯完成一个输入输出结合使用的实验,让大家能简单了解I/O 的作用。

实验器材

开发板 *1

USB线*1

LED*1

轻触按键*1

220Ω 电阻*1

10KΩ 电阻*1

面包板*1

面包板连接线若干

接线图

../_images/225d0ea6c84efe2bcebb87ad2119c1e3.jpeg

测试代码

int ledPin = 11; //定义数字口11

int inputPin = 3; //定义数字口3

void setup()

{

    pinMode(ledPin, OUTPUT); //将ledPin设置为输出

    pinMode(inputPin, INPUT); //将inputPin设置为输入

}

void loop()

{

    int val = digitalRead(inputPin);//设置数字变量val,读取到数字口3的数值,并赋值给 val

    if (val == LOW) //当val为低电平时,LED变暗

    {

        digitalWrite(ledPin, LOW); // LED变暗

    }

    else

    {

        digitalWrite(ledPin, HIGH); // LED亮起

    }

}

测试结果

下载完程序,上电后,当按键按下时小灯亮起,否则小灯不亮。

实验六 抢答器实验#

实验说明

完成上面的实验以后相信已经有很多朋友可以独立完成这个实验了,我们可以将上面的按键控制小灯的实验扩展成4个按键对应3个小灯,占用7个数字I/O接口。为方便接线,我们把3个小灯用一个RGB灯代替。RGB灯可通过 R、 G、B三个引脚的PWM电压输入可以调节三种基色(红/蓝/绿)的强度从而实现全彩的混色效果。

本实验中我们利用4个按键控制3个PWM口,控制RGB模块发光颜色从而达到抢答器的效果。RGB灯接口说明如下图。

../_images/7a592a156b62255e7d898013c09246c8.jpeg

实验器材

开发板*1

USB线*1

RGB灯*1

轻触按键*4

10KΩ 电阻*4

220Ω 电阻*1

面包板*1

面包板连接线若干

杜邦线若干

接线图

../_images/073deae1e1239378efc14ad904baacce.jpeg

测试代码

// 引脚定义
int redled = 9;       // 红色LED引脚(PWM)
int greenled = 10;    // 绿色LED引脚(PWM)
int blueled = 11;     // 蓝色LED引脚(PWM)

int redpin = 5;       // 红色按钮引脚
int greenpin = 4;     // 绿色按钮引脚
int bluepin = 3;      // 蓝色按钮引脚
int restpin = 2;      // 复位按钮引脚

// 状态变量
int red;              // 红色按钮状态
int green;            // 绿色按钮状态
int blue;             // 蓝色按钮状态

void setup()
{
  // 初始化LED引脚为输出模式
  pinMode(redled, OUTPUT);
  pinMode(greenled, OUTPUT);
  pinMode(blueled, OUTPUT);

  // 初始化按钮引脚为输入模式
  pinMode(redpin, INPUT);
  pinMode(greenpin, INPUT);
  pinMode(bluepin, INPUT);
}

void loop()
{
  // 读取按钮状态
  red = digitalRead(redpin);
  green = digitalRead(greenpin);
  blue = digitalRead(bluepin);

  // 检查按钮按下状态
  if(red == LOW) RED_YES();
  if(green == LOW) GREEN_YES();
  if(blue == LOW) BLUE_YES();
}

// 红色模式
void RED_YES()
{
  while(digitalRead(restpin) == 1)
  {  // 等待复位按钮按下
    color(255, 0, 0);                // 显示红色
  }
  clear_led();                       // 清除显示
}

// 绿色模式
void GREEN_YES()
{
  while(digitalRead(restpin) == 1)
  {  // 等待复位按钮按下
    color(0, 255, 0);                // 显示绿色
  }
  clear_led();                       // 清除显示
}

// 蓝色模式
void BLUE_YES()
{
  while(digitalRead(restpin) == 1)
  {  // 等待复位按钮按下
    color(0, 0, 255);                // 显示蓝色
  }
  clear_led();                       // 清除显示
}

// 清除所有LED
void clear_led()
{
  color(0, 0, 0);                   // 输出黑色(全灭)
}

// 颜色控制函数(注意:使用反向控制逻辑)
void color(unsigned char red, unsigned char green, unsigned char blue)
{
  analogWrite(redled, 255-red);     // 红色通道反向控制
  analogWrite(greenled, 255-green); // 绿色通道反向控制
  analogWrite(blueled, 255-blue);   // 蓝色通道反向控制
}

测试结果

下载完程序,上电后,一个简单的抢答器就做好了,我们根据RGB灯显示的颜色判断是谁抢答成功。在复位后。RGB灯关闭。

实验七 滚珠开关控制LED灯#

实验说明

滚珠开关也就是倾斜开关,它的工作原理是当开关一端低于水平位置倾斜,开关寻通;当另一端低于水平位置倾斜,开关停止。这个实验中滚珠开关提供数字信号,然后控制一个LED灯的亮灭。

实验器材

开发板*1

USB线*1

LED*1

倾斜开关*1

220Ω 电阻*1

10KΩ 电阻*1

面包板*1

面包板连接线若干

接线图

../_images/7943a58096d0046be9d6a828a788a683.jpeg

测试代码

int ledPin = 6; //定义数字口6

int inputPin = 7; //定义数字口7

void setup()

{

    pinMode(ledPin, OUTPUT); //将ledPin设置为输出

    pinMode(inputPin, INPUT); //将inputPin设置为输入

}

void loop()

{

    int val = digitalRead(inputPin);

    //设置数字变量val,读取到数字口7的数值,并赋值给 val

    if (val == LOW) //当val为低电平时,LED变暗

    {

        digitalWrite(ledPin, LOW); // LED变暗

    }

    else

    {

        digitalWrite(ledPin, HIGH); // LED亮起

    }

}

测试结果

按照上图接好线,烧录好代码,上电后,通过倾斜开关可控制一个LED的亮灭,倾斜一一边LED亮起,倾斜另一边,LED熄灭。

实验八 电位器调控灯光亮度实验#

实验说明

在第二课程中我们直接通过PWM口控制灯的亮度,从而达到呼吸灯的效果。在这课程中我们通过一个电位器,利用电位器调节PWM值,从而控制灯的亮度。

实验器材

开发板*1

USB线*1

LED*1

220Ω 电阻*1

可调电位器*1

面包板*1

面包板连接线若干

接线图

../_images/c7c1042f29b371ffcec19b88dcafa82c.jpeg

测试代码

int ledpin=11;//定义数字接口11(PWM 输出)

void setup()

{

    pinMode(ledpin,OUTPUT);//定义数字接口11 为输出

    Serial.begin(9600);//设置波特率为9600

}

void loop()

{

    int val=analogRead(0);//读取模拟口A0口的值

    val = map(val, 0, 1023, 0, 255);//从0-1023映射到0-255

    Serial.println(val);//显示val 变量

    analogWrite(ledpin,val);// 打开LED 并设置亮度

    delay(100);//延时0.1 秒

}

测试结果

下载完程序后。我们可以通过旋转可调电位器控制小灯的亮度,打开串口监视器,设置波特率为9600,就可看到调节LED亮度的PWM值。

实验九 有源蜂鸣器实验#

实验说明

蜂鸣器可分为有源蜂鸣器和无源蜂鸣器两种。本课程中主要用到了有源蜂鸣器,有源蜂鸣器内部有一简单的振荡电路,能将恒定的直流电转化成一定频率的脉冲信号。实验中中我们只需要给蜂鸣器输入一个高电平信号,蜂鸣器响起。

实验器材

开发板*1

USB线*1

有源蜂鸣器*1

面包板*1

面包板连接线若干

接线图

../_images/3e80e4203f2c8348467ff55054686f65.jpeg

测试代码

int buzzer = 2; //定义数字口2

void setup()

{

  pinMode(buzzer, OUTPUT);     //设置buzzer为输出

}

void loop()

{

  digitalWrite(buzzer, HIGH);   //开启buzzer

  delay(1000); //延迟1S

  digitalWrite(buzzer, LOW);    //关闭buzzer

  delay(1000);//延迟1S

}

测试结果

下载完程序后,我们可以听到蜂鸣器响1秒,停止响起1秒,循环交替。

实验十 感光灯实验#

实验说明

完成以上的各种实验后,我们对Arduino的应用也应该有一些认识和了解了,在基本的数字量输入输出和模拟量输入以及PWM的产生都掌握以后,我们就可以开始进行一些传感器的应用了。

本次实验我们先进行一个较为简单的光敏电阻的使用实验。光敏电阻既然是可以根据光强改变阻值的元件,自然也需要模拟口读取模拟值了,本实验可以借鉴电位器调控灯光亮度实验,将电位计换做光敏电阻实现当光强不同时LED小灯的亮度也会有相应的变化。

实验器材

开发板*1

USB线*1

LED*1

220Ω 电阻*1

10KΩ 电阻*1

光敏电阻*1

面包板*1

面包板连接线若干

接线图

../_images/c856b30fd7731d1332143c3310bd1dff.jpeg

测试代码

int ledpin=11;//定义数字接口11(PWM 输出)

void setup()

{

    pinMode(ledpin,OUTPUT);//定义数字接口11 为输出

    Serial.begin(9600);//设置波特率为9600

}

void loop()

{

    int val=analogRead(0);//读取模拟口A0口的值

    Serial.println(val);//显示val 变量

    val = map(val, 0, 1023, 0, 255);//从0-1023映射到0-255

    analogWrite(ledpin,255-val);// 打开LED 并设置亮度

    delay(10);//延时0.01 秒

}

测试结果

下载完程序后,光敏电阻感应到灯光越亮,小灯越暗;光敏电阻感应到灯光越暗,小灯越亮。打开串口监视器,设置波特率为9600,就可看到光敏电阻感应到外界光强所得的模拟值。

实验十一 红外遥控器实验#

实验说明

红外遥控器发出的信号是一连串的二进制脉冲码。为了使其在无线传输过程中免受其他红外信号的干扰,通常都是先将其调制在特定的载波频率上,然后再经红外发射二极管发射出去,而红外线接收装置则要滤除其他杂波,叧接收该特定频率的信号并将其还原成二进制脉冲码,也就是解调.

实验中我们用一个红外遥控和一个红外接收头控制6个LED灯的亮和灭。实验前,我们要对红外遥控进行解码。

实验器材

开发板*1

USB线*1

红外遥控*1

红外接收 VS1838B*1

红色LED*6

220Ω 电阻*6

面包板*1

面包板连接线若干

接线图

红外解码接线

../_images/3ecd10319939ba8f817a1cefa6a99843.jpeg

红外控灯实验接线

../_images/25966a6ed6ddb5ecdb465ecb06cb8330.jpeg

测试代码

红外解码

#include <IRremote.h>          // 红外遥控库头文件

int RECV_PIN = 11;             // 红外接收器数据引脚(必须支持外部中断)
IRrecv irrecv(RECV_PIN);       // 创建红外接收对象
decode_results results;        // 存储解码结果的结构体

void setup()
{
  Serial.begin(9600);          // 初始化串口通信(9600bps)
  irrecv.enableIRIn();         // 启动红外接收器
}

void loop()
{
  if (irrecv.decode(&results))
  {   // 检查是否收到红外信号
    Serial.println(results.value, HEX);  // 以16进制打印红外编码
    irrecv.resume();              // 准备接收下一个信号
  }
}

红外控灯实验

#include <IRremote.h>          // 红外遥控库

// 引脚定义
int RECV_PIN = 11;             // 红外接收器信号引脚
int LED1 = 2;                  // LED1控制引脚
int LED2 = 3;                  // LED2控制引脚
int LED3 = 4;                  // LED3控制引脚
int LED4 = 5;                  // LED4控制引脚
int LED5 = 6;                  // LED5控制引脚
int LED6 = 7;                  // LED6控制引脚

// 红外遥控键码定义(需根据实际遥控器设置)
long on1 = 0x00FF6897;         // LED1开键码
long off1 = 0x00FF9867;        // LED1关键码
long on2 = 0x00FFB04F;         // LED2开键码
long off2 = 0x00FF30CF;        // LED2关键码
long on3 = 0x00FF18E7;         // LED3开键码
long off3 = 0x00FF7A85;        // LED3关键码
long on4 = 0x00FF10EF;         // LED4开键码
long off4 = 0x00FF38C7;        // LED4关键码
long on5 = 0x00FF5AA5;         // LED5开键码
long off5 = 0x00FF42BD;        // LED5关键码
long on6 = 0x00FF4AB5;         // LED6开键码
long off6 = 0x00FF52AD;        // LED6关键码

IRrecv irrecv(RECV_PIN);       // 创建红外接收对象
decode_results results;        // 存储解码结果

void setup()
{
  // 引脚模式设置
  pinMode(RECV_PIN, INPUT);    // 红外接收引脚设为输入
  pinMode(LED1, OUTPUT);       // LED1设为输出
  pinMode(LED2, OUTPUT);       // LED2设为输出
  pinMode(LED3, OUTPUT);       // LED3设为输出
  pinMode(LED4, OUTPUT);       // LED4设为输出
  pinMode(LED5, OUTPUT);       // LED5设为输出
  pinMode(LED6, OUTPUT);       // LED6设为输出

  irrecv.enableIRIn();         // 启动红外接收
}

// 状态变量
int on = 0;                    // 状态标志位(未直接使用)
unsigned long last = millis(); // 最后接收时间戳

void loop()
{
  if (irrecv.decode(&results)) // 检查是否收到红外信号
  {
    // 防抖处理:250ms内不重复响应
    if (millis() - last > 250)
    {
      on = !on;               // 切换状态标志(实际未使用)
    }

    // LED控制逻辑
    if (results.value == on1) digitalWrite(LED1, HIGH);  // LED1开
    else if (results.value == off1) digitalWrite(LED1, LOW); // LED1关

    if (results.value == on2) digitalWrite(LED2, HIGH);  // LED2开
    else if (results.value == off2) digitalWrite(LED2, LOW); // LED2关

    if (results.value == on3) digitalWrite(LED3, HIGH);  // LED3开
    else if (results.value == off3) digitalWrite(LED3, LOW); // LED3关

    if (results.value == on4) digitalWrite(LED4, HIGH);  // LED4开
    else if (results.value == off4) digitalWrite(LED4, LOW); // LED4关

    if (results.value == on5) digitalWrite(LED5, HIGH);  // LED5开
    else if (results.value == off5) digitalWrite(LED5, LOW); // LED5关

    if (results.value == on6) digitalWrite(LED6, HIGH);  // LED6开
    else if (results.value == off6) digitalWrite(LED6, LOW); // LED6关

    last = millis();           // 更新时间戳
    irrecv.resume();           // 准备接收下个信号
  }
}

注意:在上传程序前,要把IRremote 文件夹放到编译器安装目录下的Arduinolibraries里。不然编译不过。例如我的:C:Program FilesArduinolibraries

测试结果

按照接线图接好线,上传好代码,上电后,红外解码时,红外遥控对准红外接收头按下按键,即可在Arduino IDE的串口监视器中看到对应的编码,详细编码如下图。

../_images/e8c16d5775711130f33efa80fc34d3c5.jpeg

红外控灯实验时,我们将遥控器对准红外接收头,按下1 2 3 4 5 6 7 8 9 * 0 # 共12个按键就可控制6个LED灯的亮与灭。

实验十二 一位数码管显示实验#

实验说明

数码管是一种半导体发光器件,其基本单元是发光二极管。数码管按段数分为七段数码管和八段数码管,八段数码管比七段数码管多一个发光二极管单元(多一个小数点显示),本实验所使用的是八段数码管。数码管共有七段显示数字的段,还有一个显示小数点的段。当让数码管显示数字时,只要将相应的段点亮即可。

实验器材

开发板 *1

USB线*1

一位数码管*1

220Ω 电阻*8

面包板*1

面包板连接线若干

接线图

../_images/cfe68ae021ed63f147120e32a976719f.jpeg

测试代码

/设置控制各段的数字IO 脚

int a=7;//定义数字接口7 连接a 段数码管

int b=6;// 定义数字接口6 连接b 段数码管

int c=5;// 定义数字接口5 连接c 段数码管

int d=10;// 定义数字接口11 连接d 段数码管

int e=11;// 定义数字接口10 连接e 段数码管

int f=8;// 定义数字接口8 连接f 段数码管

int g=9;// 定义数字接口9 连接g 段数码管

int dp=4;// 定义数字接口4 连接dp 段数码管

void digital_1(void) //显示数字1

{

    unsigned char j;

    digitalWrite(c,HIGH);//给数字接口5 引脚高电平,点亮c 段

    digitalWrite(b,HIGH);//点亮b 段

    for(j=7;j<=11;j++)//熄灭其余段

        digitalWrite(j,LOW);

    digitalWrite(dp,LOW);//熄灭小数点DP 段

}

void digital_2(void) //显示数字2

{

    unsigned char j;

    digitalWrite(b,HIGH);

    digitalWrite(a,HIGH);

    for(j=9;j<=11;j++)

        digitalWrite(j,HIGH);

    digitalWrite(dp,LOW);

    digitalWrite(c,LOW);

    digitalWrite(f,LOW);

}

void digital_3(void) //显示数字3

{

    unsigned char j;

    digitalWrite(g,HIGH);

    digitalWrite(d,HIGH);

    for(j=5;j<=7;j++)

        digitalWrite(j,HIGH);

    digitalWrite(dp,LOW);

    digitalWrite(f,LOW);

    digitalWrite(e,LOW);

}

void digital_4(void) //显示数字4

{

    digitalWrite(c,HIGH);

    digitalWrite(b,HIGH);

    digitalWrite(f,HIGH);

    digitalWrite(g,HIGH);

    digitalWrite(dp,LOW);

    digitalWrite(a,LOW);

    digitalWrite(e,LOW);

    digitalWrite(d,LOW);

}

void digital_5(void) //显示数字5

{

    unsigned char j;

    for(j=7;j<=9;j++)

        digitalWrite(j,HIGH);

    digitalWrite(c,HIGH);

    digitalWrite(d,HIGH);

    digitalWrite(dp,LOW);

    digitalWrite(b,LOW);

    digitalWrite(e,LOW);

}

void digital_6(void) //显示数字6

{

    unsigned char j;

    for(j=7;j<=11;j++)

        digitalWrite(j,HIGH);

    digitalWrite(c,HIGH);

    digitalWrite(dp,LOW);

    digitalWrite(b,LOW);

}

void digital_7(void) //显示数字7

{

    unsigned char j;

    for(j=5;j<=7;j++)

        digitalWrite(j,HIGH);

    digitalWrite(dp,LOW);

    for(j=8;j<=11;j++)

        digitalWrite(j,LOW);

}

void digital_8(void) //显示数字8

{

    unsigned char j;

    for(j=5;j<=11;j++)

        digitalWrite(j,HIGH);

    digitalWrite(dp,LOW);

}

void setup()

{

    int i;//定义变量

    for(i=4;i<=11;i++)

        pinMode(i,OUTPUT);//设置4~11 引脚为输出模式

}

void loop()

{

    while(1)

    {

        digital_1();//显示数字1

        delay(2000);//延时2s

        digital_2();//显示数字2

        delay(1000); //延时1s

        digital_3();//显示数字3

        delay(1000); //延时1s

        digital_4();//显示数字4

        delay(1000); //延时1s

        digital_5();//显示数字5

        delay(1000); //延时1s

        digital_6();//显示数字6

        delay(1000); //延时1s

        digital_7();//显示数字7

        delay(1000); //延时1s

        digital_8();//显示数字8

        delay(1000); //延时1s

    }

}

测试结果

下载完程序后,数码管循环显示1~8 数字。

实验十三 1602液晶显示实验#

实验说明

本次试验使用keyes UNO R3直接驱动1602液晶显示文字。1602液晶在应用中非常广泛,它的显示容量为16×2个字符,芯片工作电压为4.5~5.5V。1602液晶在接keyes UNO R3控制板显示文字时有两种接线法,分别为4位接法和8位接法,本实验中都会有相关说明介绍。

实验器材

开发板*1

USB线*1

1602 LCD*1

可调电位器*1

面包板*1

面包板连接线若干

接线图

四位接法

../_images/3e7492982bd91f9eac3417534af0adea.jpeg

八位接法

../_images/f028edea9f5f65d4fdc9a419db0bdb92.jpeg

测试代码

四位接法

/*
  LiquidCrystal Library - Hello World
  演示16x2 LCD显示屏的使用
  兼容Hitachi HD44780驱动器的LCD均可使用
  电路连接:
  * LCD RS引脚 → 数字引脚2
  * LCD Enable引脚 → 数字引脚3
  * LCD D4引脚 → 数字引脚4
  * LCD D5引脚 → 数字引脚5
  * LCD D6引脚 → 数字引脚6
  * LCD D7引脚 → 数字引脚7
  * LCD R/W引脚 → 接地
  * LCD VSS引脚 → 接地
  * LCD VCC引脚 → 5V
  * 10K电位器:
    - 两端接5V和地
    - 中间接LCD VO引脚
*/

#include <LiquidCrystal.h>      // 包含LCD驱动库

// 初始化LCD对象,指定接口引脚
LiquidCrystal lcd(2, 3, 4, 5, 6, 7);  // (RS, E, D4, D5, D6, D7)

void setup()
{
  // 设置LCD显示尺寸(16列x2行)
  lcd.begin(16, 2);            // 初始化LCD

  // 在第一行显示信息
  lcd.setCursor(2, 0);         // 设置光标位置(列,行)
  lcd.print("Hello, world!");  // 输出文本

  // 在第二行显示信息
  lcd.setCursor(2, 1);         // 设置光标位置(列,行)
  lcd.print("Hello, keyes!");  // 输出文本
}

void loop()
{
  // 主循环无需重复操作
}

注意:在上传程序前,要把LiquidCrystal文件夹放到 编译器安装目录下的Arduinolibraries里。不然编译不过。例如我的:C:Program FilesArduinolibraries

八位接法

int DI = 12;

int RW = 11;

int DB[] = {3, 4,5, 6,7 ,8, 9, 10};//使用数组来定义总线需要的管脚

int Enable = 2;

void LcdCommandWrite(int value)
{

    // 定义所有引脚

    int i = 0;

    for (i=DB[0]; i <= DI; i++) //总线赋值

    {

        digitalWrite(i,value &01);//因为1602液晶信号识别是D7-D0(不是D0-D7),这里是用来反转信号。

        value >>= 1;

    }

    digitalWrite(Enable,LOW);

    delayMicroseconds(1);

    digitalWrite(Enable,HIGH);

    delayMicroseconds(1); // 延时1ms

    digitalWrite(Enable,LOW);

    delayMicroseconds(1); // 延时1ms

}

void LcdDataWrite(int value)
{

    // 定义所有引脚

    int i = 0;

    digitalWrite(DI, HIGH);

    digitalWrite(RW, LOW);

    for (i=DB[0]; i <= DB[7]; i++)
    {

        digitalWrite(i,value & 01);

        value >>= 1;

    }

    digitalWrite(Enable,LOW);

    delayMicroseconds(1);

    digitalWrite(Enable,HIGH);

    delayMicroseconds(1);

    digitalWrite(Enable,LOW);

    delayMicroseconds(1); // 延时1ms

}

void setup (void)
{

    int i = 0;

    for (i=Enable; i <= DI; i++)
    {

        pinMode(i,OUTPUT);

    }

    delay(100);

    // 短暂的停顿后初始化LCD

    // 用于LCD控制需要

    LcdCommandWrite(0x38); // 设置为8-bit接口,2行显示,5x7文字大小

    delay(64);

    LcdCommandWrite(0x38); // 设置为8-bit接口,2行显示,5x7文字大小

    delay(50);

    LcdCommandWrite(0x38); // 设置为8-bit接口,2行显示,5x7文字大小

    delay(20);

    LcdCommandWrite(0x06); // 输入方式设定

    // 自动增量,没有显示移位

    delay(20);

    LcdCommandWrite(0x0E); // 显示设置

    // 开启显示屏,光标显示,无闪烁

    delay(20);

    LcdCommandWrite(0x01); // 屏幕清空,光标位置归零

    delay(100);

    LcdCommandWrite(0x80); // 显示设置

    // 开启显示屏,光标显示,无闪烁

    delay(20);

}

void loop (void)
{

    LcdCommandWrite(0x01); // 屏幕清空,光标位置归零

    delay(10);

    LcdCommandWrite(0x80+2);

    delay(10);

    // 写入欢迎信息

    LcdDataWrite('H');

    LcdDataWrite('e');

    LcdDataWrite('l');

    LcdDataWrite('l');

    LcdDataWrite('o');

    LcdDataWrite(',');

    LcdDataWrite(' ');

    LcdDataWrite('w');

    LcdDataWrite('o');

    LcdDataWrite('r');

    LcdDataWrite('l');

    LcdDataWrite('d');

    LcdDataWrite('!');

    delay(10);

    LcdCommandWrite(0xc0+2); // 定义光标位置为第二行第二个位置

    delay(10);

    LcdDataWrite('H');

    LcdDataWrite('e');

    LcdDataWrite('l');

    LcdDataWrite('l');

    LcdDataWrite('o');

    LcdDataWrite(',');

    LcdDataWrite(' ');

    LcdDataWrite('k');

    LcdDataWrite('e');

    LcdDataWrite('y');

    LcdDataWrite('e');

    LcdDataWrite('s');

    LcdDataWrite('!');

    LcdDataWrite(' ');

    delay(5000);

}

测试结果

无论是四位接法还是八位接法,接好线,烧录程序上电后,通过旋转电位器调节背光,即可在1602 LCD上看到设置的显示字符。四位接法和八位接法显示一样,第一行显示"Hello, world!"字符,第二行显示"Hello, keyes!"字符。

实验十四 DHT11温湿度传感器#

实验说明

本实验我们主要用来检测DHT11温湿度传感器。它是一款含有已校准数字信号输出的温湿度复合传感器,它应用专用的数字模块采集技术和温湿度传感技术,确保产品具有极高的可靠性和卓越的长期稳定性。

实验中将传感器的信号端接到开发板的数字口3,在Arduino IDE的串口监视器上可看到当前环境中的温度值和湿度值。

实验器材

开发板*1

USB线*1

DHT11温湿度传感器*1

杜邦线若干

接线图

../_images/da17c1dfcaa509b4967232b12d24ccb4.jpeg

测试代码

#include <dht11.h>              // 包含DHT11温湿度传感器库

dht11 DHT;                      // 创建传感器对象实例

#define DHT11_PIN 3             // 定义传感器数据引脚为数字引脚3

void setup()
{
  Serial.begin(9600);           // 初始化串口通信(9600bps)
  Serial.println("DHT TEST PROGRAM"); // 打印程序标题
  Serial.print("LIBRARY VERSION: ");  // 打印库版本信息
  Serial.println(DHT11LIB_VERSION);   // 打印实际库版本号
  Serial.println();                   // 空行
  // 打印数据表头(使用制表符对齐)
  Serial.println("Type,\tstatus,\tHumidity (%),\tTemperature (C)");
}

void loop()
{
  int chk;                      // 存储传感器状态码

  Serial.print("DHT11, \t");    // 打印传感器类型标识(注意空格)

  chk = DHT.read(DHT11_PIN);    // 读取传感器数据(返回状态码)

  // 根据状态码显示对应状态信息
  switch (chk)
  {
    case DHTLIB_OK:             // 读取成功
      Serial.print("OK,\t");    // 打印正常状态
      break;
    case DHTLIB_ERROR_CHECKSUM: // 校验和错误
      Serial.print("Checksum error,\t");
      break;
    case DHTLIB_ERROR_TIMEOUT:  // 通信超时
      Serial.print("Time out error,\t");
      break;
    default:                    // 其他未知错误
      Serial.print("Unknown error,\t");
      break;
  }

  // 显示数据(注意原注释拼写错误保留)
  Serial.print(DHT.humidity,1); // 打印湿度值(保留1位小数)
  Serial.print(",\t");          // 打印分隔符
  Serial.println(DHT.temperature,1); // 打印温度值并换行

  delay(1000);                  // 每次采样间隔1秒
}

注意:在上传程序前,要把Dht11文件夹放到器安装目录下的Arduinolibraries里。不然编译不过。例如我的:C:Program FilesArduinolibraries

测试结果

按照上图接好线,上传好代码,上电后,我们可在软件串口监视器中看到当前环境中的温度值和湿度值,如下图。

../_images/cbb34dc84381f3f2b04630dcfeec6b7e.png

实验十五 超声波传感器#

实验说明

本实验我们主要用来检测超声波传感器。该传感器主要用于测距,它具有高精度、盲区(2cm)超近、性能稳定的特点。

实验中将传感器的信号端接到开发板的数字口7和数字口8,在Arduino IDE的串口监视器上可看到超声波传感器和前方障碍物之间的距离。

实验器材

开发板*1

USB线*1

超声波传感器*1

杜邦线若干

接线图

../_images/ea285494d408b86f07331703de2ba811.jpeg

测试代码

#define echoPin 7              // 超声波模块Echo引脚连接数字引脚7
#define trigPin 8              // 超声波模块Trig引脚连接数字引脚8
#define LEDPin 13              // 板载LED指示灯引脚(用于距离指示)

int maximumRange = 200;        // 最大有效测量范围(单位:厘米)
int minimumRange = 0;          // 最小有效测量范围(单位:厘米)
long duration, distance;       // 存储声波持续时间(微秒)和计算距离

void setup()
{
  Serial.begin(9600);          // 初始化串口通信(9600波特率)
  pinMode(trigPin, OUTPUT);    // 设置Trig引脚为输出模式
  pinMode(echoPin, INPUT);     // 设置Echo引脚为输入模式
  pinMode(LEDPin, OUTPUT);     // 设置LED引脚为输出模式(可选)
}

void loop()
{
  /* 超声波测距原理:
     1. 通过Trig引脚发送10μs高电平脉冲
     2. 测量Echo引脚高电平持续时间
     3. 根据声速计算距离 */

  digitalWrite(trigPin, LOW);   // 确保Trig引脚初始为低电平
  delayMicroseconds(2);         // 稳定2微秒
  digitalWrite(trigPin, HIGH);  // 发送10微秒触发脉冲
  delayMicroseconds(10);
  digitalWrite(trigPin, LOW);   // 结束脉冲

  duration = pulseIn(echoPin, HIGH);  // 测量回声高电平持续时间(微秒)

  // 计算距离(单位:厘米),声速换算公式:340m/s ≈ 58.2μs/cm
  distance = duration/58.2;     // 保留原始计算公式

  // 距离有效性检查
  if (distance >= maximumRange || distance <= minimumRange)
  {
    /* 超出测量范围时:
       - 串口发送-1
       - 点亮LED表示异常 */
    Serial.println("-1");       // 发送超出范围标识
    digitalWrite(LEDPin, HIGH); // 点亮LED
  }
  else
  {
    /* 正常测量范围内:
       - 输出实际距离值(厘米)
       - 熄灭LED表示正常 */
    Serial.println(distance);   // 输出距离值
    digitalWrite(LEDPin, LOW);  // 熄灭LED
  }

  delay(50);                   // 每次测量间隔50毫秒(保持原始值)
}

测试结果

按照上图接好线,上传好代码,上电后,打开串口监视器,即可看到超声波传感器和前方障碍物之间的距离,单位为cm,显示如下图。

../_images/9d204e83d501811a8c38fe49567c817a.png

实验十六 人体红外热释电传感器#

实验说明

本实验我们主要用来人体红外热释电传感器。它是基于红外线技术的自动控制产品。它具有灵敏度高、可靠性强、超低功耗,超低电压工作模式等特点,广泛应用于各类自动感应电器设备,尤其是干电池供电的自动控制产品。我们可以通过调节两个电位器调节感应距离和感应延时。调节距离电位器顺时针旋转,感应距离增大(约7米),反之,感应距离减小(约3米)。调节延时电位器顺时针旋转,感应延时加长(约300S),反之,感应延时减短(约5S)。

实验中我们用到了Arduino UNO 板上自带的D13的指示灯,通过传感器感应附近是否有人体运动,控制D13 的指示灯的亮灭。

实验器材

开发板*1

USB线*1

人体红外热释电传感器*1

杜邦线若干

接线图

../_images/9e9ea504bb5011fd16d1d808e73ce1f4.jpeg

测试代码

byte sensorPin = 3;//定义数字口3

byte indicator = 13;//定义数字口13

void setup()

{
    pinMode(sensorPin,INPUT);//设置数字口3位输入

    pinMode(indicator,OUTPUT);//设置数字口13为输出

    Serial.begin(9600);//设置波特率
}

void loop()

{
    byte state = digitalRead(sensorPin);//读取到数字口3的数值赋值给state

    digitalWrite(indicator,state);//控制数值口13的状态

    if(state ==1)//当数值口3位高电平时,串口监视器输出对应字符,并自动换行

    Serial.println("Somebody is in this area!");

    else if(state == 0)
    //当数值口3位低电平时,串口监视器输出对应字符,并自动换行

    Serial.println("No one!");

    delay(500);//延迟0.5秒
}

测试结果

按照上图接好线,上传好代码,上电后,检测到人体运动时Arduino UNO板上D13的指示灯亮起,串口监视器中显示"Somebody is in this area!";没有检测到人体运动时Arduino UNO板上D13的指示灯熄灭,串口监视器中显示"No one!"。

../_images/855ae7997253b7ec304fbb5aa3403f5d.png