新闻中心

EEPW首页>嵌入式系统>设计应用> 我的HD7279学习笔记——基于msp430g2553

我的HD7279学习笔记——基于msp430g2553

作者: 时间:2016-11-28 来源:网络 收藏
Createdon:2012-9-7

Author:zhangbin

本文引用地址://m.amcfsurvey.com/article/201611/322844.htm

学习笔记

formsp430g2553

redesignedbyzhangbin

2012-09-07

versions:12_09_01

All Rights Reserved

HD7279的基本说明如下:

HD7279是一片具有串行接口的,可同时驱动8位共阴式数码管(或64只独立led)的智能显示驱动芯片,该芯片同时还可连接多达64键的键盘矩阵,单片即可完成led显示、键盘接口的全部功能。

HD7279内部含有译码器,可直接接受BCD码或16进制码,并同时具有2种译码方式。此外,还具有多种控制指令,如消隐、闪烁、左移、右移、段寻址等。

HD7279具有片选信号,可方便地实现多于8位的显示或多于64键的键盘接口。

典型应用:

仪器仪表,工业控制,条形显示器,控制面板

特点:

1串行接口,无需外围元件可直接驱动led

2各位独立控制译码/不译码及消隐和闪烁属性

3(循环)左移/(循环)右移指令

4具有段寻址指令,方便控制独立led

564键键盘空盒子器,内含去抖动电路

6有DIP和SOIC两种封装形式供选择

2.引脚说明:
VDD:电源VSS:
CS:片选CLK:时钟输入端
DATA:串行数据输入/输出端CLK0:振荡输出端
KEY:按键有效输出端RES:复位端
SG-SA:段g—段a驱动输出
DP:小数点驱动输出DIG0-7:数位0-7驱动输出
RC:RC振荡器连接端

HD7279A的控制指令分为二大类——纯指令和带有数据的指令

具体的这两种指令的详解,参考数据手册。

上面的说明是摘录数据手册上的,只介绍了HD7279的基本大概情况,更详细的介绍如:读写时序、详细命令等,就要参考数据手册了。

单片机对各种外围芯片、器件进行操作的时候,主要是处理好相互的通信。那么就要特别注意手册上介绍的操作的时序,写程序的时候,要严格按照时序写就行了。

下面是我写的对HD7279进行操作的一个程序,是基于msp430g2553单片机的,可以控制4*4的16矩阵键盘。目前对led的操作还没有实现,需要继续完善程序,程序贴在了下面,注释的也比较详细:

//本程序是为了测试键盘、led驱动芯片HD7279所写的,主要完成HD7279读,写操作,控制4*4矩阵键盘和4led

//4个led分别接到了DIG0~DIG3

//目前这4个led还没有控制得住,要继续努力

#include

#include"ser_12864.h"

//HD7279各个管脚定义

#defineSET_CSP1OUT|=BIT0;

#defineCLR_CSP1OUT&=~BIT0;

#defineSET_CLKP1OUT|=BIT1;

#defineCLR_CLKP1OUT&=~BIT1;

#defineDATA_INP1DIR&=~BIT2;//data脚设为输入

#defineDATA_OUTP1DIR|=BIT2;//data脚设为输出

#defineSET_DATAP1OUT|=BIT2;

#defineCLR_DATAP1OUT&=~BIT2;

//#defineDATAP1IN&BIT2;

//#defineKEYP1IN&BIT3;

//HD7279基本命令定义

#defineCMD_RESET0xa4//复位(清除)指令

#defineCMD_TEST0xbf//测试指令

#defineRTL_UNCYL0xa1//左移指令

#defineRTR_UNCYL0xa0//右移指令

#defineRTL_CYCLE0xa3//循环左移指令

#defineRTR_CYCLE0xa2//循环右移指令

#defineDECODE00x80//方式0译码

#defineDECODE10xc8//方式1译码

#defineUNDECODE0x90//不带小数点显示

#defineBLINKCTL0x88//闪烁控制

#defineACTCTL0x98//消隐控制

#defineSEGON0xe0//段点亮指令

#defineSEGOFF0xc0//段关闭指令

#defineCMD_READ0x15//读取键盘数据指令

//long_delayshort_delay延时57us延时11us

#definelong_delay()delay_us(57);

#defineshort_delay()delay_us(11);

uintkey_code[]={61,36,37,38,44,45,46,52,53,54};//键盘上的数字键对应的键值,在程序中要进行处理,要转化为0~9

//数组中为数字0~9对应的键值,顺序不能变

ucharkey=0;//按下的键码

//向HD7279中发送指令相当于写纯指令

voidsend_byte(ucharcom)

{

uchari=0;

CLR_CS;

long_delay();

for(i=0;i<8;i++)//发送命令,高位在前一个时钟脉冲,送一位数据到7279中

{

if(com&0x80)//高位在前

{

SET_DATA;

}

else

{

CLR_DATA;

}

SET_CLK;//发生脉冲

short_delay();

CLR_CLK;

short_delay();

com<<=1;//左移一位

}

CLR_DATA;

}

//从7279中读取数据

ucharreceive_byte(void)

{

unsignedchari,in_byte;

SET_DATA;//settoinputmode

long_delay();

for(i=0;i<8;i++)

{

SET_CLK;

short_delay();

in_byte=in_byte<<1;

DATA_IN;//把DATA脚设为输入DATA为P12

if(P1IN&BIT2)

{

in_byte=in_byte|0x01;

}

CLR_CLK;

short_delay();

}

DATA_OUT;//把data设为输出

CLR_DATA;

return(in_byte);

}

//向7279中写入带数据的指令

voidwr_data_com(ucharcom,uchardata)//先发送指令,再发送数据

{

send_byte(com);//发送指令

send_byte(data);//发送数据

}

//从7279中读取键盘数据函数

ucharrd_key()

{

send_byte(CMD_READ);//先写入读取键盘数据的指令

return(receive_byte());//返回接收到的数据,即为键值

}

//7279的初始化函数

voidhd7279_init()

{

delay_ms(50);//上电延迟

P1DIR|=BIT0+BIT1+BIT2;//单片机相关IO口设置

//P1DIR&=~BIT3;//KEY为输入

send_byte(CMD_RESET);//输入清除指令

delay_ms(50);

}

//因为当HD7279A检测到有效的按键时,KEY引脚从高电平变为低电平,并一直保持到按键结束,所以可以用下降沿出发,也可以用上升沿出发

voidinterrupt_init()

{

//在本程序中,按键按下于不按下,key的电平要么为高,要么为低,是确定的,不会有悬空浮动状态,所以下面两句内部拉电阻的设置可以不用要

//P1REN|=BIT3;//pullup内部上拉电阻使能

//////使用中断时,使能内部的上拉电阻这样当该脚悬空是,电平不会跳变,防止悬空时电平跳变不停的触发中断

//P1OUT=BIT3;//当引脚上的上拉或下拉电阻使能时,PxOUT选择是上拉还是下来

//////0:下拉,1:上拉

P1IE|=BIT3;//P1.3interruptenabledP13中断使能

P1IES|=BIT3;//P1.3Hi/loedge下降沿中断

P1IFG&=~BIT3;//P1.3IFGcleared中断标志位清零

}

voidmain(void)

{

unsignedchars1[]={"key:"};

WDTCTL=WDTPW+WDTHOLD;//停止看门狗定时器

BCSCTL1=CALBC1_12MHZ;//设定cpu时钟DCO频率为12MHz

DCOCTL=CALDCO_12MHZ;

P2DIR|=BIT5+BIT4;//液晶的两条线

init_lcd();

hd7279_init();

interrupt_init();//IO中断初始化

P1DIR|=BIT6;

P1OUT&=~BIT6;

wr_string(0,0,s1);//第一行第一个位置显示s1

_BIS_SR(LPM4_bits+GIE);//进入LPM4开中断

}

//Port1interruptserviceroutine

#pragmavector=PORT1_VECTOR

__interruptvoidPort_1(void)

{

uchari=0;

_DINT();

P1OUT|=BIT6;

key=rd_key();//读取键值

//while((P1IN&BIT3)==0);//等待按键松开

for(i=0;i<10;i++)

{

if(key==key_code[i])//利用数组进行键值转化

key=i;//转化为了对应的数字

}

wr_int(1,0,key);//显示

P1IFG&=~BIT3;//中断标志位清零

_EINT();//打开中断

}

//下面是用死循环检测按键按下,这种方法可以,但是不灵敏,并且浪费cpu资源改进是用key出发IO口中断,然后进行键盘处理

//for(;;)//用死循环检测按键按下

//{

//if((P1IN&BIT3)==0)//当HD7279A检测到有效的按键时,KEY引脚从高电平变为低电平,并一直保持到按键结束。在此期间,

////如果HD7279A接收到‘读键盘数据指令’,则输出当前按键的键盘代码;如果在收到‘读键盘指令’时没有有效按键,HD7279A将输出FFH。

//

//{

//key=rd_key();//读取键值

//while((P1IN&BIT3)==0);//等待按键松开

//}

//wr_int(2,0,key);//显示

//}

//对应键值:1-362-373-384-445-456-467-528-539-540-61*-60#-62A-39B-47C-55D-63



评论


技术专区

关闭