arduino ide esp32矩阵键盘无源蜂鸣器

文章介绍了如何使用Arduino和矩阵键盘来控制音阶,通过按键操作改变八度,同时调整板载LED的状态。代码展示了如何获取按键输入并调用LED和音频函数进行响应。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 矩阵键盘从左到右分别连接gpio13,gpio12,gpio14,gpio27,gpio26,gpio25,gpio33,gpio32,无源蜂鸣器接gpio15,键盘从左到右从上到下分别为do,升do,re,升re,mi,fa,升fa,sol,升sol,la,升la,ti,升高一个八度,降低一个八度,回到中声(第四八度),调整板载led状态。每个音持续250毫秒,总共1-7 7个八度

#include<Keypad.h>
const int row1=13,row2=12,row3=14,row4=27,col1=26,col2=25,col3=33,col4=32,led=2,bp=15,channel=0;
const byte rows=4,cols=4;
bool p=1;
uint8_t y=4;
uint16_t x=250;
char hk[rows][cols]=
{
  {'d','D','r','R'},
  {'m','f','F','s'},  
  {'S','a','A','t'},
  {'+','-','4','l'}
};
byte rowpines[rows]={row1,row2,row3,row4};
byte colpines[cols]={col1,col2,col3,col4};
Keypad ck=Keypad(makeKeymap(hk),rowpines,colpines,rows,cols);
void setup()
{
  // put your setup code here, to run once:
  for(int i=0;i<rows;i++)
  {
    pinMode(rowpines[i],OUTPUT);
    pinMode(colpines[i],OUTPUT);
  }
  pinMode(led,OUTPUT);

  ledcSetup(channel,20000,10);
  ledcAttachPin(bp,channel);

  Serial.begin(921600);
}
void loop()
{
  // put your main code here, to run repeatedly:
  char cK=ck.getKey();
  if(cK)
  {
    Serial.println(cK);
    switch(cK)
    {
      case 'l' :
      {
        digitalWrite(led,int(p));
        p=!p;
        break;
      }
      case 'd' :
      {
        ledcWriteNote(0,NOTE_C,y);
        delay(x);
        ledcWriteTone(channel,0);
        break;
      }
      case 'D' :
      {
        ledcWriteNote(0,NOTE_Cs,y);
        delay(x);
        ledcWriteTone(channel,0);
        break;
      }
      case 'r' :
      {
        ledcWriteNote(0,NOTE_D,y);
        delay(x);
        ledcWriteTone(channel,0);
        break;
      }
      case 'R' :
      {
        ledcWriteNote(0,NOTE_Eb,y);
        delay(x);
        ledcWriteTone(channel,0);
        break;
      }
      case 'm' :
      {
        ledcWriteNote(0,NOTE_E,y);
        delay(x);
        ledcWriteTone(channel,0);
        break;
      }
      case 'f' :
      {
        ledcWriteNote(0,NOTE_F,y);
        delay(x);
        ledcWriteTone(channel,0);
        break;
      }
      case 'F' :
      {
        ledcWriteNote(0,NOTE_Fs,y);
        delay(x);
        ledcWriteTone(channel,0);
        break;
      }
      case 's' :
      {
        ledcWriteNote(0,NOTE_G,y);
        delay(x);
        ledcWriteTone(channel,0);
        break;
      }
      case 'S' :
      {
        ledcWriteNote(0,NOTE_Gs,y);
        delay(x);
        ledcWriteTone(channel,0);
        break;
      }
      case 'a' :
      {
        ledcWriteNote(0,NOTE_A,y);
        delay(x);
        ledcWriteTone(channel,0);
        break;
      }
      case 'A' :
      {
        ledcWriteNote(0,NOTE_Bb,y);
        delay(x);
        ledcWriteTone(channel,0);
        break;
      }
      case 't' :
      {
        ledcWriteNote(0,NOTE_B,y);
        delay(x);
        ledcWriteTone(channel,0);
        break;
      }
      case '+' :
      {
        if(y<7)
        {
          y++;
        }
        break;
      }
      case '-' :
      {
        if(y>1)
        {
          y--;
        }
        break;
      }
      case '4' :
      {
        y=4;
        break;
      }
    }
  }
}

#include<Keypad.h>

const int row1=13,row2=12,row3=14,row4=27,col1=26,col2=25,col3=33,col4=32,led=2,bp=15,channel=0;

const byte rows=4,cols=4;

bool p=1;

uint8_t y=4;

uint16_t x=250;

char hk[rows][cols]=

{

  {'d','D','r','R'},

  {'m','f','F','s'},  

  {'S','a','A','t'},

  {'+','-','4','l'}

};

byte rowpines[rows]={row1,row2,row3,row4};

byte colpines[cols]={col1,col2,col3,col4};

Keypad ck=Keypad(makeKeymap(hk),rowpines,colpines,rows,cols);

void setup()

{

  // put your setup code here, to run once:

  for(int i=0;i<rows;i++)

  {

    pinMode(rowpines[i],OUTPUT);

    pinMode(colpines[i],OUTPUT);

  }

  pinMode(led,OUTPUT);

  ledcSetup(channel,20000,10);

  ledcAttachPin(bp,channel);

  Serial.begin(921600);

}

void loop()

{

  // put your main code here, to run repeatedly:

  char cK=ck.getKey();

  if(cK)

  {

    Serial.println(cK);

    switch(cK)

    {

      case 'l' :

      {

        digitalWrite(led,int(p));

        p=!p;

        break;

      }

      case 'd' :

      {

        ledcWriteNote(0,NOTE_C,y);

        delay(x);

        ledcWriteTone(channel,0);

        break;

      }

      case 'D' :

      {

        ledcWriteNote(0,NOTE_Cs,y);

        delay(x);

        ledcWriteTone(channel,0);

        break;

      }

      case 'r' :

      {

        ledcWriteNote(0,NOTE_D,y);

        delay(x);

        ledcWriteTone(channel,0);

        break;

      }

      case 'R' :

      {

        ledcWriteNote(0,NOTE_Eb,y);

        delay(x);

        ledcWriteTone(channel,0);

        break;

      }

      case 'm' :

      {

        ledcWriteNote(0,NOTE_E,y);

        delay(x);

        ledcWriteTone(channel,0);

        break;

      }

      case 'f' :

      {

        ledcWriteNote(0,NOTE_F,y);

        delay(x);

        ledcWriteTone(channel,0);

        break;

      }

      case 'F' :

      {

        ledcWriteNote(0,NOTE_Fs,y);

        delay(x);

        ledcWriteTone(channel,0);

        break;

      }

      case 's' :

      {

        ledcWriteNote(0,NOTE_G,y);

        delay(x);

        ledcWriteTone(channel,0);

        break;

      }

      case 'S' :

      {

        ledcWriteNote(0,NOTE_Gs,y);

        delay(x);

        ledcWriteTone(channel,0);

        break;

      }

      case 'a' :

      {

        ledcWriteNote(0,NOTE_A,y);

        delay(x);

        ledcWriteTone(channel,0);

        break;

      }

      case 'A' :

      {

        ledcWriteNote(0,NOTE_Bb,y);

        delay(x);

        ledcWriteTone(channel,0);

        break;

      }

      case 't' :

      {

        ledcWriteNote(0,NOTE_B,y);

        delay(x);

        ledcWriteTone(channel,0);

        break;

      }

      case '+' :

      {

        if(y<7)

        {

          y++;

        }

        break;

      }

      case '-' :

      {

        if(y>1)

        {

          y--;

        }

        break;

      }

      case '4' :

      {

        y=4;

        break;

      }

    }

  }

}

### ESP32 矩阵键盘使用教程 #### 一、环境准备 为了在ESP32上使用矩阵键盘,需先安装好ESP-IDF开发环境。确保已正确配置工具链以及相关依赖库。 对于项目初始化,在命令行输入如下指令创建新工程并设置必要的构建选项[^4]: ```bash idf.py create-project matrix_keyboard_example cd matrix_keyboard_example ``` #### 二、硬件连接说明 通常情况下,矩阵键盘通过行列扫描方式工作。每根线对应按键的一端,另一端则分别接到不同的I/O引脚上。具体连线方法取决于所使用的矩阵键盘型号及其规格书中的描述。 #### 三、软件编程要点 下面给出一段简单的C语言程序来读取矩阵键盘的状态: ```c #include "freertos/FreeRTOS.h" #include "freertos/task.h" #include "driver/gpio.h" #define ROW_PINS {GPIO_NUM_18, GPIO_NUM_19} // 行引脚定义 #define COL_PINS {GPIO_NUM_5, GPIO_NUM_17, GPIO_NUM_16} // 列引脚定义 void setup_keypad(void); uint8_t read_keypad(); static void keypad_task(void *arg); // 初始化函数 void setup_keypad() { const int row_num = sizeof(ROW_PINS)/sizeof(int); const int col_num = sizeof(COL_PINS)/sizeof(int); for (int i=0; i<row_num; ++i){ gpio_set_direction(ROW_PINS[i], GPIO_MODE_OUTPUT); } for (int j=0; j<col_num; ++j){ gpio_set_pull_mode(COL_PINS[j], GPIO_PULLUP_ONLY); gpio_set_level(COL_PINS[j], 1); gpio_set_direction(COL_PINS[j], GPIO_MODE_INPUT); } } // 扫描获取当前按下的键值 uint8_t read_keypad(){ static uint8_t keymap[]={ '1','2','3', '4','5','6' }; ... } ``` 上述代码片段展示了如何配置GPIO引脚作为矩阵键盘接口,并提供了一个基础的任务处理流程用于持续监测按键状态变化。完整的`read_keypad()`实现逻辑需要依据实际应用需求进一步完善。 #### 四、编译与烧录固件 完成码编写之后,可以通过以下命令进行编译链接操作,并将生成的目标文件刷入到目标板卡中: ```bash idf.py build idf.py -p /dev/ttyUSB0 flash monitor ``` 注意替换为实际使用的串口号。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值