芯片SD7218A实例程序8X8位LED数码管驱动

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

LED 数码管驱动专用 IC - SD 7218A
特别功能:内置两线式串行接口、 I2C接口,但没有字节地址,所以不能像AT24C04那样使用。

8 × 8 数码管接口、 64 键键盘接口、 100Bytes 静态 RAM 、最多可级联 8 片
概述
SD 7218A 是一片具有两线式串行接口的、可同时驱动 8 位共阴式数码管 ( 或 64 只独立 LED) 、
100Bytes 静态 RAM 的智能显示驱动芯片,该芯片同时还可连接多达 64 键的键盘矩阵。

SD 7218A 内部含有译码器,可直接接受 16 进制码, SD 7218A 还具有多种控制指令,如消隐、闪烁、左移、右移、段寻址等。

SD 7218A 内部含有 100Bytes 静态 RAM ,可通过串行方式读写,用于存储通用数据。

SD 7218A 可通过两线串行接口最多可级联 8 片,此时 LED 数为64 × 8 。

SD 7218A 有 DIP28 和 SOIC28 两种封装形式。

管脚设置
• 、管脚功能
************************************************** ; 奥宇星单片机工作室
;
; Copyright 2009 aoyux McuStudio
; All rights Reserved
;作者:奥宇星 QQ:393193589
;AT89S52 晶振频率为11.0592MHz 指令周期:1.085069us
功能说明:SD7218A 循环左移显示实例程序
;******************************************************************************************* */ /
#include "reg52.h"
#include "intrins.h"
#define uchar unsigned char
#define uint unsigned int
sbit sda=P1^1;//;模拟I2C 数据传送位
sbit scl=P1^2;//;模拟I2C 时钟控制状态标志
void delay1(uint z)//延时为 1ms
{
uchar x,x1;
for(;z>0;z--)
{
for(x=0;x<114;x++)
{
for(x1=0;x1<1;x1++);
}
}
}
void delay()//30us延时
{
uchar i;
i=30;
while(i>0)
{
i--;
}
void star()//开始
{
sda=1;
delay();//5us延时
scl=1;
delay();//5us延时
sda=0;
delay();//5us延时
}
void stop()//停止
{
sda=0;
delay();//5us延时
scl=1;
delay();//5us延时
sda=1;
delay();//5us延时
}
void ack()//应答
{ uchar z=0;
while((sda==1)&&(z<50))z++;//条件判断, sda=1,则没有应答。

如果没有应答则延时:z<50,z++;后返回
scl=0;
delay();//延时
}
///写一个数据函数
//器件写地址 slave_write_address
//字节地址 byte_address
//待写入数据 data_data
void write(uchar slave_write_address,uchar data_data)//写一个数据
uchar temp,temp1,i,ii;
star();//开始
for(ii=0;ii<2;ii++)//根据 24CXX文档资料,和时序图,按顺序送:器件写地址,字节地址,数据{
if(ii==0)
{
temp=slave_write_address;//送器件写地址
temp1=slave_write_address;
}
else if(ii==1)
{
temp=data_data;//送数据
temp1=data_data;
}
for(i=0;i<8;i++)
{
scl=0;
delay();//延时
temp=temp1;
temp=temp&0x80;// 相与后,把不相关的位清零
if(temp==0x80)//根据前面相与后,判断 temp是否等于0x80,是则该位为 1
sda=1;
else
sda=0;
delay();//延时
scl=1;
delay();//延时
scl=0;
delay();//延时
temp1=temp1<<1;//向左移出1位
sda=1;
delay();//延时
scl=1;
delay();//延时
ack();
}
stop();//停止
}
///读一个数据函数
//器件写地址 slave_write_address
//器件读地址 slave_read_address
//字节地址 byte_address
//读出的数据 data_data
read(uchar slave_write_address)//读一个数据
{
uchar temp,temp1,i,x,data_data;
star();//开始
temp=slave_write_address;//送器件写地址
temp1=slave_write_address;
for(i=0;i<8;i++)//开始读数据
{
scl=0;
delay();//5us延时
temp=temp1;
temp=temp&0x80;// 相与后,把不相关的位清零
if(temp==0x80)//根据前面相与后,判断 temp是否等于0x80,是则该位为 1
sda=1;
else
sda=0;
delay();//延时
scl=1;
delay();//延时
scl=0;
delay();//延时
temp1=temp1<<1;//向左移出1位
}
sda=1;
delay();//延时
scl=1;
delay();//延时
ack();//应答
for(x=0;x<8;x++)
{
data_data=data_data<<1;//向左移入1位
sda=1;
delay();//延时
scl=0;
delay();//延时
scl=1;
delay();//延时
if(sda==1)//判断数据线是否是高电平
data_data|=0x01;//把读到的数据或 0X01
//else
//data_data|=0x00;
}
ack();//应答
stop();//停止
return data_data;//返回读到的数据
}
void init()//0x50 是器件写地址;0xff 是待写入的数据或指令){
while(1)
{
//write(0x50,0x6a);//测试指令:
//write(0x50,0x68);//复位(清除)指令:
//write(0x50,0x61);//左移指令:
//write(0x50,0x62);//右移指令:
delay1(1000);
write(0x50,0x63);//循环左移指令:
//write(0x50,0x64);//循环右移指令:
}
}
void main()
{
uchar temp;
init();
//delay1(1000);//写与读的时间间隔应大于5ms,取决于器件 24C02的响应速度//向器件读一个数据
temp=read(0x51);//向器件读一个数据:(0xa0 是器件写地址;读出数据)
while(1);//跳转,相当于汇编指令 JUMP $
}。

相关文档
最新文档