- 1、本文档共7页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
基于汇编语言的单片机led点阵显示(含c)
???? 8X8 LED点阵显示技术
在8X8 LED点阵上显示柱形,让其先从左到右平滑移动三次,其次从右到左平滑移动三次,再次从上到下平滑移动三次,最后从下到上平滑移动三次,如此循环下去。
?? 电路原理图
图4.24.1
???? 硬件电路连线
(1).? 把“单片机系统”区域中的P1端口用8芯排芯连接到“点阵模块”区域中的“DR1-DR8”端口上;
(2).? 把“单片机系统”区域中的P3端口用8芯排芯连接到“点阵模块”区域中的“DC1-DC8”端口上;
程序设计内容
(1).? 8X8 点阵LED工作原理说明
8X8点阵LED结构如下图所示
?
从图4.24.2中可以看出,8X8点阵共需要64个发光二极管组成,且每个发光二极管是放置在行线和列线的交叉点上,当对应的某一列置1电平,某一行置0电平,则相应的二极管就亮;因此要实现一根柱形的亮法,如图49所示,对应的一列为一根竖柱,或者对应的一行为一根横柱,因此实现柱的亮的方法如下所述:
一根竖柱:对应的列置1,而行则采用扫描的方法来实现。
一根横柱:对应的行置0,而列则采用扫描的方法来实现。
汇编源程序
ORG 00H
START: NOP
MOV R3,#3
LOP2: MOV R4,#8
MOV R2,#0
LOP1: MOV P1,#0FFH
MOV DPTR,#TABA
MOV A,R2
MOVC A,@A+DPTR
MOV P3,A
INC R2
LCALL DELAY
DJNZ R4,LOP1
DJNZ R3,LOP2
MOV R3,#3
LOP4: MOV R4,#8
MOV R2,#7
LOP3: MOV P1,#0FFH
MOV DPTR,#TABA
MOV A,R2
MOVC A,@A+DPTR
MOV P3,A
DEC R2
LCALL DELAY
DJNZ R4,LOP3
DJNZ R3,LOP4
?
MOV R3,#3
LOP6: MOV R4,#8
MOV R2,#0
LOP5: MOV P3,#00H
MOV DPTR,#TABB
MOV A,R2
MOVC A,@A+DPTR
MOV P1,A
INC R2
LCALL DELAY
DJNZ R4,LOP5
DJNZ R3,LOP6
MOV R3,#3
LOP8: MOV R4,#8
MOV R2,#7
LOP7: MOV P3,#00H
MOV DPTR,#TABB
MOV A,R2
MOVC A,@A+DPTR
MOV P1,A
DEC R2
LCALL DELAY
DJNZ R4,LOP7
DJNZ R3,LOP8
LJMP START
DELAY: MOV R5,#10
D2: MOV R6,#20
D1: MOV R7,#248
DJNZ R7,$
DJNZ R6,D1
DJNZ R5,D2
RET
TABA: DB 0FEH,0FDH,0FBH,0F7H,0EFH,0DFH,0BFH,07FH
TABB: DB 01H,02H,04H,08H,10H,20H,40H,80H
END
??? C语言源程序
#include AT89X52.H?
unsigned char code taba[]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};
unsigned char code tabb[]={0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80};
void delay(void)
{
unsigned char i,j;
for(i=10;i0;i--)
for(j=248;j0;j--);
}
void delay1(void)
{
unsigned char i,j,k;
for(k=10;k0;k--)
for(i=20;i0;i--)
for(j=248;j0;j--);
}
void main(void)
{
unsigned char i,j;
while(1)
{
for(j=0;j3;j++) //from left to right 3 time
{
for(i=0;i8;i++)
{
P3=taba[i];
P1=0xff;
您可能关注的文档
- 地震到底能否预报.doc
- 地震发生时---绝处求生.doc
- 地震台2015岗位绩效奖励的实施方案.doc
- 地震(山体滑坡泥石流等等)应急预案.doc
- 地震小屋活动项目的调整.doc
- 地震工程学导论.docx
- 地震应急演练方案2015512.doc
- 地震应急疏散演练计划.docx
- 地震应急预案201759.doc
- 地震应急预案演练计划.doc
- 个人借款合同范本(个人借款合同范本模板) .pdf
- 东营半导体材料项目投资计划书 .pdf
- 分析参考ntz0 xx swahili paper 1 hl markscheme里语.pdf
- 文稿教程说明.pdf
- 参考服务器软件asp net part 6.pdf
- latin paper 2 hl markscheme拉丁语级分数表.pdf
- 专论问答monographs questions and answersiarc专著.pdf
- mhz临界模式功率因数校正电路损耗模型.pdf
- 分析导入android app os mainactivity java主活动.pdf
- sigma-z共7 aldrich安全数据表.pdf
文档评论(0)