专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
51单片机
谁哪里有成熟,稳定,高清,有码的TM1628的驱动程序发上来共同探讨研究呀?
2020-02-05 08:52
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
51单片机
6265
14
14
RT
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
13条回答
xcodes
1楼-- · 2020-02-05 12:38
我有tm1629B的 可行?
加载中...
john78
2楼-- · 2020-02-05 13:43
要程序就直接说,讨论研究先放上你的,我只有TM1638的
void WR_TM1628_Byte(uchar TM_dat)
{
uchar i;
for(i=0;i<8;i++)
{
if(TM_dat&0x01) TM_DIO=1;
else TM_DIO=0;
TM_CLK=0; //
TM_dat>>=1; //数据右移位
TM_CLK=1; //
}
}
void Wr_TM_CMD(uchar TMcmd)
{
TM_STB=0; //片选,0有效
WR_TM1628_Byte(TMcmd);
TM_STB=1; //片选,1无效
TM_DIO=1;
}
uchar Read_TM_Byte()
{
uchar i,k;
k=0;
for(i=0;i<8;i++)
{
TM_CLK=0;
k=k>>1;
_nop_();
_nop_();
_nop_();
if(TM_DIO)
{
k|=0x80;
}//1000 0000
TM_CLK=1;
_nop_();
}
return (k);
}
char Read_keynumber()//读TM1628的key值并入5个数组里面
{
TM_STB=0; //片选,0有效
WR_TM1628_Byte(0x42);//读键值命令0x42
TM_DIO = 1; //少了这句还不行
_nop_();
_nop_();
key[0]=Read_TM_Byte();//读key值
key[1]=Read_TM_Byte();//读key值
key[2]=Read_TM_Byte();//读key值
key[3]=Read_TM_Byte();//读key值
TM_STB=1; //片选,置高,无效
return 1;
}
//数码管显示
void ledout()
{
led_power = 1;
ledstatus[0] = LedDot[led_val];
Wr_TM_CMD(0x03);//显示模式
Wr_TM_CMD(0x40);//地址自动加一
TM_STB=0;
WR_TM1628_Byte(0xc0);//地址0开始
WR_TM1628_Byte(ledstatus[0]); //8
WR_TM1628_Byte(ledstatus[1]);
WR_TM1628_Byte(ledstatus[2]); //LED
WR_TM1628_Byte(ledstatus[3]);
WR_TM1628_Byte(ledstatus[4]);
TM_STB=1; //片选,置高无效
Wr_TM_CMD(0x8a); //显示开
}
加载中...
xcodes
3楼-- · 2020-02-05 18:09
/*
函数功能:发送一个数据到SPI从器件
入口参数:要发送的字节
返回值:无
*/
void SPI_Write(uint8 SendByte)
{
uint8 N;
CLR_CS;
for(N=0;N<8;N++)
{
CLR_SCLK;
CLR_DIO;
if((SendByte&0x01)!=0)
SET_DIO;
SendByte>>=1;
WDT_Clear();
SET_SCLK;
WDT_Clear();
}
}
/*
函数功能:
入口参数:要发送内容的指针
返回值:无
*/
void TM1629_Write(uint8 *pSend)
{
uint8 Len;
SET_CS;
SET_DIO;
SET_SCLK;
SPI_Write(0x40); //地址自增加模式
SET_CS;
SPI_Write(0xC0); //数据起始地址
for(Len=0;Len<16;Len++)
{
SPI_Write(*pSend);
pSend++;
}
SET_CS;
SPI_Write(0x8A);
SET_CS;
}
/*
读键盘内容到键盘缓冲区
*/
void SPI_Read(uint8 *KeyBuff)
{
uint8 N;
uint8 i;
uint8 RetDat=0;
SET_CS;
SET_DIO;
SET_SCLK;
SPI_Write(0x42); //发送读键盘命令
for(i=0;i<4;i++)
{
for(N=0;N<8;N++)
{
CLR_SCLK;
SET_SCLK;
if(DIO)RetDat|=0x80;
RetDat>>=1;
}
*(KeyBuff+i)=RetDat;
RetDat=0;
}
SET_CS;
}
加载中...
mkliop
4楼-- · 2020-02-05 22:03
精彩回答 2 元偷偷看……
加载中...
dengxiaofeng
5楼-- · 2020-02-05 23:33
我记得 很久前 在 google 上找到一个现成的 再次google 未验证
--------------------------------------------------------
#include<reg52.h>
#define uchar unsigned char
#define uint unsigned int
sbit TM_dio=P2^1;
sbit TM_stb=P2^2;
sbit TM_clk=P2^3;
uchar data TAB_keynum[5];//这5个数据来保存键值
#define knum1 TAB_keynum[0]
#define knum2 TAB_keynum[1]
#define knum3 TAB_keynum[2]
#define knum4 TAB_keynum[3]
#define knum5 TAB_keynum[4]
//共阴的数码管表格0-f
uchar code TAB_duan[]={0x3f,0x6,0x5b,0x4f,0x66,0x6d,0x7d,0x7,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};
void delay_ms(uint x)//廷时1ms*x
{
uint a,b;
for(b=x;b>0;b--)
for(a=125;a>0;a--);
}
void delayus(){}//延时4us
void WR_TM1628_Byte(uchar TM_dat)
{
uchar i;
for(i=0;i<8;i++)
{
TM_dio=(bit)(TM_dat&0x01);//强制转成:位,低位先发送
TM_clk=0;//---------|
TM_dat>>=1;//-------|
TM_clk=1;//---------|___|----/上升沿有效
}
}
uchar Read_TM_Byte()
{
uchar i,k;
for(i=0;i<8;i++)
{
TM_clk=0;
k>>=1;
TM_clk=1;
if(TM_dio==1){k|=0x80;}//1000 0000
// else k&=0x7f;
}
return (k);
}
void Wr_TM_CMD(uchar TMcmd)
{
TM_stb=0;//片选,0有效
WR_TM1628_Byte(TMcmd);
TM_stb=1;//片选,0有效
TM_dio=1;
}
void Read_keynumber()//读TM1628的key值并入5个数组里面
{
uchar i;
TM_stb=0;//片选,0有效
WR_TM1628_Byte(0x42);//读键值命令0x42
TM_dio=1;//****************这一句很关键/在读数据时,一定要释放DIO=1
delayus();//必要的delay
for(i=0;i<5;i++)
{
TAB_keynum
=Read_TM_Byte();//读key值
}
TM_stb=1;//片选,0有效
}
void TM1628_display(uchar dat1,uchar dat2,uchar dat3,uchar dat4,uchar dat5,uchar dat6,uchar dat7)
{
Wr_TM_CMD(0x03);//显示模式
Wr_TM_CMD(0x40);//地址自动加一
TM_stb=0;//片选,0有效
WR_TM1628_Byte(0xc0);//地址0开始
WR_TM1628_Byte(dat1);
WR_TM1628_Byte(0xff);
WR_TM1628_Byte(dat2);
WR_TM1628_Byte(0xff);
WR_TM1628_Byte(dat3);
WR_TM1628_Byte(0xff);
WR_TM1628_Byte(dat4);
WR_TM1628_Byte(0xff);
WR_TM1628_Byte(dat5);
WR_TM1628_Byte(0xff);
WR_TM1628_Byte(dat6);
WR_TM1628_Byte(0xff);
WR_TM1628_Byte(dat7);
WR_TM1628_Byte(0xff);
TM_stb=1;//片选,0有效
Wr_TM_CMD(0x8f);//送亮度指令
}
void TM1628_init()
{
TM_dio=1;
TM_stb=1;
TM_clk=1;
}
void main()
{
delay_ms(300);
TM1628_init();
//乱写二个数玩玩
TM1628_display(TAB_duan[8],TAB_duan[2],TAB_duan[3],TAB_duan[4],TAB_duan[8],0xff,0xff);
delay_ms(3000);
while(1)
{
Read_keynumber();//读键值
delay_ms(100);
//显示键值
TM1628_display(TAB_duan[knum1],TAB_duan[knum2],TAB_duan[knum3],TAB_duan[knum4],TAB_duan[knum5],0xff,0xff);
delay_ms(100);
}
加载中...
xcodes
6楼-- · 2020-02-06 02:36
回复【5楼】dengxiaofeng 天下的人
我记得 很久前 在 google 上找到一个现成的 再次google 未验证
--------------------------------------------------------
void TM1628_display(uchar dat1,uchar dat2,uchar dat3,uchar dat4,uchar dat5,uchar dat6,uchar dat7)
-----------------------------------------------------------------------
用指针啊用指针
加载中...
1
2
3
下一页
一周热门
更多
>
相关问题
【东软载波ESF0654 PDS开发板活动】开箱
1 个回答
东软载波ESF0654 PDS开发板外部中断
1 个回答
东软载波ESF0654 PDS开发板高级控制定时器AD16C4T
1 个回答
用串口调试助手为什么只能在hex模式接收发送而在文本模式不行
9 个回答
触摸芯片SC02B/SC04B在地砖灯的设计方案
1 个回答
东软载波ESF0654 PDS开发板串口USART0代码分享
1 个回答
普通32位单片机使用linux的应用代码
5 个回答
东软载波ESF0654 PDS开发板AT24C04的调试
9 个回答
相关文章
51单片机与蓝牙模块连接
0个评论
51单片机的硬件结构
0个评论
基于51单片机的无线遥控器制作
0个评论
51单片机 AD转换
0个评论
51单片机数码管递增显示
0个评论
如何实现对单片机寄存器的访问
0个评论
基于51单片机的指纹密码锁
0个评论
×
关闭
采纳回答
向帮助了您的网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
51单片机
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
关闭
您已邀请
15
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
void WR_TM1628_Byte(uchar TM_dat)
{
uchar i;
for(i=0;i<8;i++)
{
if(TM_dat&0x01) TM_DIO=1;
else TM_DIO=0;
TM_CLK=0; //
TM_dat>>=1; //数据右移位
TM_CLK=1; //
}
}
void Wr_TM_CMD(uchar TMcmd)
{
TM_STB=0; //片选,0有效
WR_TM1628_Byte(TMcmd);
TM_STB=1; //片选,1无效
TM_DIO=1;
}
uchar Read_TM_Byte()
{
uchar i,k;
k=0;
for(i=0;i<8;i++)
{
TM_CLK=0;
k=k>>1;
_nop_();
_nop_();
_nop_();
if(TM_DIO)
{
k|=0x80;
}//1000 0000
TM_CLK=1;
_nop_();
}
return (k);
}
char Read_keynumber()//读TM1628的key值并入5个数组里面
{
TM_STB=0; //片选,0有效
WR_TM1628_Byte(0x42);//读键值命令0x42
TM_DIO = 1; //少了这句还不行
_nop_();
_nop_();
key[0]=Read_TM_Byte();//读key值
key[1]=Read_TM_Byte();//读key值
key[2]=Read_TM_Byte();//读key值
key[3]=Read_TM_Byte();//读key值
TM_STB=1; //片选,置高,无效
return 1;
}
//数码管显示
void ledout()
{
led_power = 1;
ledstatus[0] = LedDot[led_val];
Wr_TM_CMD(0x03);//显示模式
Wr_TM_CMD(0x40);//地址自动加一
TM_STB=0;
WR_TM1628_Byte(0xc0);//地址0开始
WR_TM1628_Byte(ledstatus[0]); //8
WR_TM1628_Byte(ledstatus[1]);
WR_TM1628_Byte(ledstatus[2]); //LED
WR_TM1628_Byte(ledstatus[3]);
WR_TM1628_Byte(ledstatus[4]);
TM_STB=1; //片选,置高无效
Wr_TM_CMD(0x8a); //显示开
}
函数功能:发送一个数据到SPI从器件
入口参数:要发送的字节
返回值:无
*/
void SPI_Write(uint8 SendByte)
{
uint8 N;
CLR_CS;
for(N=0;N<8;N++)
{
CLR_SCLK;
CLR_DIO;
if((SendByte&0x01)!=0)
SET_DIO;
SendByte>>=1;
WDT_Clear();
SET_SCLK;
WDT_Clear();
}
}
/*
函数功能:
入口参数:要发送内容的指针
返回值:无
*/
void TM1629_Write(uint8 *pSend)
{
uint8 Len;
SET_CS;
SET_DIO;
SET_SCLK;
SPI_Write(0x40); //地址自增加模式
SET_CS;
SPI_Write(0xC0); //数据起始地址
for(Len=0;Len<16;Len++)
{
SPI_Write(*pSend);
pSend++;
}
SET_CS;
SPI_Write(0x8A);
SET_CS;
}
/*
读键盘内容到键盘缓冲区
*/
void SPI_Read(uint8 *KeyBuff)
{
uint8 N;
uint8 i;
uint8 RetDat=0;
SET_CS;
SET_DIO;
SET_SCLK;
SPI_Write(0x42); //发送读键盘命令
for(i=0;i<4;i++)
{
for(N=0;N<8;N++)
{
CLR_SCLK;
SET_SCLK;
if(DIO)RetDat|=0x80;
RetDat>>=1;
}
*(KeyBuff+i)=RetDat;
RetDat=0;
}
SET_CS;
}
--------------------------------------------------------
#include<reg52.h>
#define uchar unsigned char
#define uint unsigned int
sbit TM_dio=P2^1;
sbit TM_stb=P2^2;
sbit TM_clk=P2^3;
uchar data TAB_keynum[5];//这5个数据来保存键值
#define knum1 TAB_keynum[0]
#define knum2 TAB_keynum[1]
#define knum3 TAB_keynum[2]
#define knum4 TAB_keynum[3]
#define knum5 TAB_keynum[4]
//共阴的数码管表格0-f
uchar code TAB_duan[]={0x3f,0x6,0x5b,0x4f,0x66,0x6d,0x7d,0x7,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};
void delay_ms(uint x)//廷时1ms*x
{
uint a,b;
for(b=x;b>0;b--)
for(a=125;a>0;a--);
}
void delayus(){}//延时4us
void WR_TM1628_Byte(uchar TM_dat)
{
uchar i;
for(i=0;i<8;i++)
{
TM_dio=(bit)(TM_dat&0x01);//强制转成:位,低位先发送
TM_clk=0;//---------|
TM_dat>>=1;//-------|
TM_clk=1;//---------|___|----/上升沿有效
}
}
uchar Read_TM_Byte()
{
uchar i,k;
for(i=0;i<8;i++)
{
TM_clk=0;
k>>=1;
TM_clk=1;
if(TM_dio==1){k|=0x80;}//1000 0000
// else k&=0x7f;
}
return (k);
}
void Wr_TM_CMD(uchar TMcmd)
{
TM_stb=0;//片选,0有效
WR_TM1628_Byte(TMcmd);
TM_stb=1;//片选,0有效
TM_dio=1;
}
void Read_keynumber()//读TM1628的key值并入5个数组里面
{
uchar i;
TM_stb=0;//片选,0有效
WR_TM1628_Byte(0x42);//读键值命令0x42
TM_dio=1;//****************这一句很关键/在读数据时,一定要释放DIO=1
delayus();//必要的delay
for(i=0;i<5;i++)
{
TAB_keynum=Read_TM_Byte();//读key值
}
TM_stb=1;//片选,0有效
}
void TM1628_display(uchar dat1,uchar dat2,uchar dat3,uchar dat4,uchar dat5,uchar dat6,uchar dat7)
{
Wr_TM_CMD(0x03);//显示模式
Wr_TM_CMD(0x40);//地址自动加一
TM_stb=0;//片选,0有效
WR_TM1628_Byte(0xc0);//地址0开始
WR_TM1628_Byte(dat1);
WR_TM1628_Byte(0xff);
WR_TM1628_Byte(dat2);
WR_TM1628_Byte(0xff);
WR_TM1628_Byte(dat3);
WR_TM1628_Byte(0xff);
WR_TM1628_Byte(dat4);
WR_TM1628_Byte(0xff);
WR_TM1628_Byte(dat5);
WR_TM1628_Byte(0xff);
WR_TM1628_Byte(dat6);
WR_TM1628_Byte(0xff);
WR_TM1628_Byte(dat7);
WR_TM1628_Byte(0xff);
TM_stb=1;//片选,0有效
Wr_TM_CMD(0x8f);//送亮度指令
}
void TM1628_init()
{
TM_dio=1;
TM_stb=1;
TM_clk=1;
}
void main()
{
delay_ms(300);
TM1628_init();
//乱写二个数玩玩
TM1628_display(TAB_duan[8],TAB_duan[2],TAB_duan[3],TAB_duan[4],TAB_duan[8],0xff,0xff);
delay_ms(3000);
while(1)
{
Read_keynumber();//读键值
delay_ms(100);
//显示键值
TM1628_display(TAB_duan[knum1],TAB_duan[knum2],TAB_duan[knum3],TAB_duan[knum4],TAB_duan[knum5],0xff,0xff);
delay_ms(100);
}
我记得 很久前 在 google 上找到一个现成的 再次google 未验证
--------------------------------------------------------
void TM1628_display(uchar dat1,uchar dat2,uchar dat3,uchar dat4,uchar dat5,uchar dat6,uchar dat7)
-----------------------------------------------------------------------
用指针啊用指针
一周热门 更多>