【esp32】点阵屏

共阳型和共阴性原理

共阳型点阵屏需要在行为高电平时点亮,而列需要在对应的位为低电平时点亮

代码

bitRead(hex_array[i],j)用于读取hex_array[i]中第j位的值,然后通过!运算符取反,以适应共阳型点阵屏的逻辑。

digitalWrite(row_array[i],HIGH)

使用前要将行列初始化为灭的状态

 for(int i=0;i<8;i++){
    pinMode(row_array[i],OUTPUT);
    digitalWrite(row_array[i],LOW);
  }
  //列初始化高
  for(int i=0;i<8;i++){
    pinMode(col_array[i],OUTPUT);
    digitalWrite(col_array[i],HIGH);
  }

以共阳性为例,行低电平(0)为亮,列高电平(1)为亮

for(int i=0;i<8;i++){
    for(int j=0;j<8;j++){
    //  Serial.print(bitRead(hex_array[i],j));
      digitalWrite(col_array[j],!bitRead(hex_array[i],j));//第j列,赋值
    }
    digitalWrite(row_array[i],HIGH);
    delay(1);
    digitalWrite(row_array[i],LOW);
  }

摇杆控制点阵屏

通常情况下,模拟输入的取值范围是0到4095(对应于12位模拟输入)。因此,4095/2的结果是2047,这是模拟输入值的中间值。

由此判断上下左右,与共阳和共阴型无关

 //检测x轴是否移动
  if(x_value>4095/2+500 && led_pos[0]<7){
    led_pos[0]+=1;
  }
  else if(x_value<4095/2-500 && led_pos[0]>0){
    led_pos[0]-=1;
  }

   //检测y轴是否移动
  if(y_value>4095/2+300 && led_pos[1]>0){
    led_pos[1]-=1;
  }
  else if(y_value<4095/2-300 && led_pos[1]<7){
    led_pos[1]+=1;
  }

你可能感兴趣的:(算法,数据结构,单片机)