8*8点阵模块:修訂版本之間的差異

從 YFRobotwiki
跳到: 導覽搜尋
 
(由2名用戶作出的13個中途修訂版本未被顯示)
第 1 行: 第 1 行:
  
[[Image:点阵模块.jpg|400px|thumb|点阵模 ]]
+
[[Image:点阵模块.jpg|400px|thumb|点阵模 块V1]]
  
  
第 7 行: 第 7 行:
 
<br>
 
<br>
 
8*8点阵模块是采用2片74HC595芯片驱动红色8X8点阵管,只需要使用控制器3路IO口,根据点阵管动态扫描原理进行显示,可以显示多种图案。
 
8*8点阵模块是采用2片74HC595芯片驱动红色8X8点阵管,只需要使用控制器3路IO口,根据点阵管动态扫描原理进行显示,可以显示多种图案。
 +
 +
<font red >
 +
<font color="red">'''更新:新版模块使用PH2.0-5P接口,连接更加方便,使用方法相同。'''</font>
  
  
第 30 行: 第 33 行:
 
=== 应用示例 ===
 
=== 应用示例 ===
 
<br>
 
<br>
'''电路连接 示意图'''
+
'''电路连接'''
 
<br>
 
<br>
  
第 55 行: 第 58 行:
 
|}
 
|}
 
   
 
   
<!--[[Image: 点阵模块接线图.jpg|400px|center|点阵模块模块接线图]]-->
 
  
 +
'''电路连接示意图'''
  
 +
<img src="http://yfrobot.gitee.io/wiki/img/点阵显示.png"  alt="点阵显示" />
 +
 +
 +
库函数下载:[https://eyun.baidu.com/s/3o7EWj70 TimerOne]
  
 
'''示例代码'''
 
'''示例代码'''
第 64 行: 第 71 行:
 
<br><br>
 
<br><br>
 
<font color="seagreen">'''Face.ino:'''</font>
 
<font color="seagreen">'''Face.ino:'''</font>
<pre >
+
<source lang="c">
 
/**************************************************
 
/**************************************************
* Face
+
  Face
* ( 8x8 Led Dot Matrix with two 74HC595 on Arduino)
+
  ( 8x8 Led Dot Matrix with two 74HC595 on Arduino)
*
+
 
* by YFROBOT
+
  by YFROBOT
 
  ***************************************************/
 
  ***************************************************/
  
 
#include "TimerOne.h"
 
#include "TimerOne.h"
 
#include "face.h"
 
#include "face.h"
 
+
// 默认显示
 
#define ROW_DATA ((row[0]<<7)|(row[1]<<6)|(row[2]<<5)|(row[3]<<4)|(row[4]<<3)|(row[5]<<2)|(row[6]<<1)|(row[7]<<0))
 
#define ROW_DATA ((row[0]<<7)|(row[1]<<6)|(row[2]<<5)|(row[3]<<4)|(row[4]<<3)|(row[5]<<2)|(row[6]<<1)|(row[7]<<0))
 
#define COL_DATA ((col[0]<<7)|(col[1]<<6)|(col[2]<<5)|(col[3]<<4)|(col[4]<<3)|(col[5]<<2)|(col[6]<<1)|(col[7]<<0))
 
#define COL_DATA ((col[0]<<7)|(col[1]<<6)|(col[2]<<5)|(col[3]<<4)|(col[4]<<3)|(col[5]<<2)|(col[6]<<1)|(col[7]<<0))
 +
// 垂直翻转
 +
//#define ROW_DATA ((row[0]<<0)|(row[1]<<1)|(row[2]<<2)|(row[3]<<3)|(row[4]<<4)|(row[5]<<5)|(row[6]<<6)|(row[7]<<7))
 +
//#define COL_DATA ((col[0]<<0)|(col[1]<<1)|(col[2]<<2)|(col[3]<<3)|(col[4]<<4)|(col[5]<<5)|(col[6]<<6)|(col[7]<<7))
 +
 +
// flip horizontal
 +
#define flip_horizontal 7-screenCol    // 默认显示
 +
//#define flip_horizontal screenCol      // 水平翻转
  
 
//Pin connected to DS of 74HC595
 
//Pin connected to DS of 74HC595
第 102 行: 第 116 行:
  
 
void setup() {
 
void setup() {
   Timer1.initialize(100);
+
   //  Timer1.initialize(100);
 
   pinMode(RCK, OUTPUT);
 
   pinMode(RCK, OUTPUT);
 
   pinMode(SRCK, OUTPUT);
 
   pinMode(SRCK, OUTPUT);
 
   pinMode(SER, OUTPUT);
 
   pinMode(SER, OUTPUT);
   Timer1.attachInterrupt(doubleBuffer);
+
   //  Timer1.attachInterrupt(doubleBuffer);
 
   Serial.begin(9600);
 
   Serial.begin(9600);
 
 
}
 
}
  
 
void doubleBuffer() {
 
void doubleBuffer() {
   row[screenRow] = 0;
+
   int k = 8;
  col[screenCol] = 1;
+
  while (k--) {
 +
    row[screenRow] = 0;
 +
    col[screenCol] = 1;
  
  screenCol++;
+
    screenCol++;
  if (screenCol >= 8) {
+
    if (screenCol >= 8) {
    screenCol = 0;
+
      screenCol = 0;
    screenRow++;
+
      screenRow++;
    if (screenRow >= 8) {
+
      if (screenRow >= 8) {
       screenRow = 0;
+
        screenRow = 0;
 +
       }
 +
    }
 +
 
 +
    if ((screen[screenRow] >> flip_horizontal) & B1 == B1) {
 +
      row[screenRow] = 1;
 +
      col[screenCol] = 0;
 +
      digitalWrite(RCK, LOW);
 +
      shiftOut(SER, SRCK, MSBFIRST, COL_DATA); //先选择列
 +
      shiftOut(SER, SRCK, MSBFIRST, ROW_DATA); //再送行数据
 +
      digitalWrite(RCK, HIGH);
 
     }
 
     }
  }
 
  if ((screen[screenRow] >> screenCol) & B1 == B1) {
 
    row[screenRow] = 1;
 
    col[screenCol] = 0;
 
    digitalWrite(RCK, LOW);
 
    shiftOut(SER, SRCK, MSBFIRST, COL_DATA); //先选择列
 
    shiftOut(SER, SRCK, MSBFIRST, ROW_DATA); //再送行数据
 
    digitalWrite(RCK, HIGH);
 
 
   }
 
   }
 
}
 
}
  
void allOFF() {
+
void UpdataDate() {
 +
  if (animationIndex < animationFrames) {
 +
    for (int i = 0; i < 64; i++) {
 +
      int Dot = (animation[animationIndex][i / 4] >> (i % 4 * 2));
 +
      brightnesses[i] = (Dot & B1) || (Dot & B10);
 +
      screen[7 - i / 8] |= (brightnesses[i] << (i % 8)) ;
 +
    }
 +
  }
 +
  unsigned long startime = millis();
 +
  while (millis() - startime < animationDelays[animationIndex])
 +
  {
 +
    doubleBuffer();
 +
  }
 +
  animationIndex ++;
 +
  if (animationIndex >= animationFrames) {
 +
    //restart animation index
 +
    animationIndex = 0;
 +
  }
 
   for (int i = 0; i < 8; i++)
 
   for (int i = 0; i < 8; i++)
 
     screen[i] = B0;
 
     screen[i] = B0;
}
 
 
void allON() {
 
  for (int i = 0; i < 8; i++)
 
    screen[i] = B11111111;
 
 
}
 
}
  
 
void loop() {
 
void loop() {
 
   UpdataDate();
 
   UpdataDate();
  allOFF();
 
 
}
 
}
 
+
</source>
void UpdataDate() {
+
  if (animationIndex < animationFrames) {
+
    for (int i = 0; i < 64; i++) {
+
      brightnesses[i] = (animation[animationIndex][i / 4] >> (i % 4 * 2)) & B1;
+
      screen[7-i / 8] |= (brightnesses[i] << (i % 8)) ;
+
    }
+
    delay(animationDelays[animationIndex]);
+
    animationIndex ++;
+
    if (animationIndex >= animationFrames) {
+
      //restart animation index
+
      animationIndex = 0;
+
    }
+
  }
+
}
+
 
+
</pre>
+
 
<br>
 
<br>
 
<font color="seagreen">'''face.h:'''</font>
 
<font color="seagreen">'''face.h:'''</font>
 
<br>
 
<br>
<pre>
+
<source lang="c">
 
int animationFrames = 2;
 
int animationFrames = 2;
  
第 177 行: 第 189 行:
 
   { 0x5, 0x50, 0x5, 0x50, 0x0, 0x0, 0x40, 0x1, 0x40, 0x1, 0x0, 0x0, 0x4, 0x10, 0x50, 0x5 }
 
   { 0x5, 0x50, 0x5, 0x50, 0x0, 0x0, 0x40, 0x1, 0x40, 0x1, 0x0, 0x0, 0x4, 0x10, 0x50, 0x5 }
 
};
 
};
</pre>
+
</source>
 程序下载地址:[http://pan.baidu.com/s/1i351AIh Face]
+
 程序下载地址:[https://eyun.baidu.com/s/3qYkanve Face]
  
 
 程序运行结果:点阵模块显示笑脸和囧脸~
 
 程序运行结果:点阵模块显示笑脸和囧脸~
第 185 行: 第 197 行:
 
<br>
 
<br>
 
<br>
 
<br>
<font color="seagreen">'''face.h'''</font>文件通过[[ 点阵取模软件获得]]
+
<font color="seagreen">'''face.h'''</font>文件通过[https://eyun.baidu.com/s/3jIDsGL4  点阵取模软件获得:
 
<br>
 
<br>
 
<br>
 
<br>
第 209 行: 第 221 行:
 
-->
 
-->
  
点阵模块配合[http://www.yfrobot.com/wiki/index.php?title=%E6%AC%A7%E5%A7%86%E9%BE%99%E6%8C%89%E9%94%AE%E5%BC%80%E5%85%B3%E6%A8%A1%E5%9D%97        按键模块],做打乒乓游戏!请移步下面网址查看:[http://www.yfrobot.com/thread-2408-1-1.html Arduino驱动8*8点阵模块 附原理图及一个打乒乓球的游戏代码]
 
  
  
 +
点阵模块滚屏显示,请移步:[http://www.yfrobot.com/thread-11735-1-1.html 点阵模块滚屏显示]
 +
 +
点阵模块配合[http://www.yfrobot.com/wiki/index.php?title=%E6%AC%A7%E5%A7%86%E9%BE%99%E6%8C%89%E9%94%AE%E5%BC%80%E5%85%B3%E6%A8%A1%E5%9D%97 按键模块],做打乒乓游戏!请移步下面网址查看:[http://www.yfrobot.com/thread-2408-1-1.html Arduino驱动8*8点阵模块 附原理图及一个打乒乓球的游戏代码]
  
  
 +
乒乓游戏程序下载地址:[https://eyun.baidu.com/s/3qYE2wWG 乒乓游戏]
  
 
===参考资料===
 
===参考资料===
 
<br>
 
<br>
* [[ Media:点阵模块原理图.jpeg|点阵模块原理图 ]]
+
* [[ Media:点阵模块原理图.jpeg|点阵模块原理图 ]] [https://eyun.baidu.com/s/3gf9uWbL 备用地址]
* [http://pan.baidu.com/s/1pJORDAb 74HC595 datasheet]
+
* [https://eyun.baidu.com/s/3qYPrIOG 74HC595 datasheet]  [http://pan.baidu.com/s/1pJORDAb 备用地址]
* [http://pan.baidu.com/s/10pE4e 74HC595 中文数据手册]
+
* [https://eyun.baidu.com/s/3csAoUE 74HC595 中文数据手册]  [http://pan.baidu.com/s/10pE4e 备用地址]
  
  

2020年4月9日 (四) 08:42的最新修訂版本

創建縮圖錯誤: 檔案似乎遺失:
點陣模塊V1


產品簡介


8*8點陣模塊是採用2片74HC595芯片驅動紅色8X8點陣管,只需要使用控制器3路IO口,根據點陣管動態掃描原理進行顯示,可以顯示多種圖案。

更新:新版模塊使用PH2.0-5P接口,連接更加方便,使用方法相同。


規格參數


  • 供電電壓:DC5V
  • 使用芯片:74HC595
  • 模塊尺寸:32.5*32.5*14.7MM(長*寬*高)
  • 模塊重量:10.6g


引腳說明


  • 1. VCC -- Vcc(電源+5V)
  • 2. GND -- Gnd(地)
  • 3. SER -- 串行移位輸入
  • 4. RCK -- 存儲寄存器的時序輸入
  • 5. SRCK -- 移位寄存器的時序輸入


應用示例


電路連接

點陣模塊 Arduino UNO
VCC +5V
GND GND
SER D10
RCK D11
SRCK D12


電路連接示意圖

點陣顯示


庫函數下載:TimerOne

示例代碼

示例一:基本顯示

Face.ino:

/**************************************************
   Face
   ( 8x8 Led Dot Matrix with two 74HC595 on Arduino)
 
   by YFROBOT
 ***************************************************/
 
#include "TimerOne.h"
#include "face.h"
// 默认显示
#define ROW_DATA ((row[0]<<7)|(row[1]<<6)|(row[2]<<5)|(row[3]<<4)|(row[4]<<3)|(row[5]<<2)|(row[6]<<1)|(row[7]<<0))
#define COL_DATA ((col[0]<<7)|(col[1]<<6)|(col[2]<<5)|(col[3]<<4)|(col[4]<<3)|(col[5]<<2)|(col[6]<<1)|(col[7]<<0))
// 垂直翻转
//#define ROW_DATA ((row[0]<<0)|(row[1]<<1)|(row[2]<<2)|(row[3]<<3)|(row[4]<<4)|(row[5]<<5)|(row[6]<<6)|(row[7]<<7))
//#define COL_DATA ((col[0]<<0)|(col[1]<<1)|(col[2]<<2)|(col[3]<<3)|(col[4]<<4)|(col[5]<<5)|(col[6]<<6)|(col[7]<<7))
 
// flip horizontal
#define flip_horizontal 7-screenCol    // 默认显示
//#define flip_horizontal screenCol      // 水平翻转
 
//Pin connected to DS of 74HC595
int SER = 10;
//Pin connected to ST_CP of 74HC595
int RCK  = 11;
//Pin connected to SH_CP of 74HC595
int SRCK  = 12;
int row[8] = {
  0, 0, 0, 0, 0, 0, 0, 0
};
int col[8] = {
  0, 0, 0, 0, 0, 0, 0, 0
};
byte screen[8] = {
  0, 0, 0, 0, 0, 0, 0, 0
};
volatile byte screenRow = 0;
volatile byte screenCol = 0;
 
// A counter to know what frame we're showing
int animationIndex = 0;
// 8x8 Point temporary array
byte brightnesses[64];
 
void setup() {
  //  Timer1.initialize(100);
  pinMode(RCK, OUTPUT);
  pinMode(SRCK, OUTPUT);
  pinMode(SER, OUTPUT);
  //  Timer1.attachInterrupt(doubleBuffer);
  Serial.begin(9600);
}
 
void doubleBuffer() {
  int k = 8;
  while (k--) {
    row[screenRow] = 0;
    col[screenCol] = 1;
 
    screenCol++;
    if (screenCol >= 8) {
      screenCol = 0;
      screenRow++;
      if (screenRow >= 8) {
        screenRow = 0;
      }
    }
 
    if ((screen[screenRow] >> flip_horizontal) & B1 == B1) {
      row[screenRow] = 1;
      col[screenCol] = 0;
      digitalWrite(RCK, LOW);
      shiftOut(SER, SRCK, MSBFIRST, COL_DATA); //先选择列
      shiftOut(SER, SRCK, MSBFIRST, ROW_DATA); //再送行数据
      digitalWrite(RCK, HIGH);
    }
  }
}
 
void UpdataDate() {
  if (animationIndex < animationFrames) {
    for (int i = 0; i < 64; i++) {
      int Dot = (animation[animationIndex][i / 4] >> (i % 4 * 2));
      brightnesses[i] = (Dot & B1) || (Dot & B10);
      screen[7 - i / 8] |= (brightnesses[i] << (i % 8)) ;
    }
  }
  unsigned long startime = millis();
  while (millis() - startime < animationDelays[animationIndex])
  {
    doubleBuffer();
  }
  animationIndex ++;
  if (animationIndex >= animationFrames) {
    //restart animation index
    animationIndex = 0;
  }
  for (int i = 0; i < 8; i++)
    screen[i] = B0;
}
 
void loop() {
  UpdataDate();
}


face.h:

int animationFrames = 2;
 
int animationDelays[] = { 1000, 1000 };
 
// Animation is designed for 8x8 pixels
uint8_t animation[][16] = {
  { 0x55, 0x55, 0x11, 0x44, 0x5, 0x50, 0x1, 0x40, 0x51, 0x45, 0x11, 0x44, 0x11, 0x44, 0x55, 0x55 },
  { 0x5, 0x50, 0x5, 0x50, 0x0, 0x0, 0x40, 0x1, 0x40, 0x1, 0x0, 0x0, 0x4, 0x10, 0x50, 0x5 }
};

程序下載地址:Face

程序運行結果:點陣模塊顯示笑臉和囧臉~

囧臉.png笑臉.png

face.h文件通過點陣取模軟件 獲得:

點陣取模軟件演示1.png點陣取模軟件演示2.png



點陣模塊滾屏顯示,請移步:點陣模塊滾屏顯示

點陣模塊配合按鍵模塊,做打乒乓遊戲!請移步下面網址查看:Arduino驅動8*8點陣模塊 附原理圖及一個打乒乓球的遊戲代碼


乒乓遊戲程序下載地址:乒乓遊戲

參考資料





返回首頁

更多建議和問題歡迎反饋至 YFRobot論壇

購買方式:YFRobot 電子工作室