用PICC编译,访真运行,开始会进一次中断,请帮着看看
//按键中断处理程序
//对应端口
//RB4=K1
//RB5=K2
//RB6=K3
//RB7=K4
//使用电平中断,打开内部弱上拉。
#include <pic.h>
#include <math.h>
#include <stdio.h>
__CONFIG(0x1832);
//芯片配置字,看门狗关,上电延时开,掉电检测关,低压编程关,加密,4M晶体HS振荡
//*该程序用于通过PORTB的"电平变化中断"进行键盘的识别。*/
//*程序设置一个键值寄存器j,当按下S9键时j=1,按下S11键时 */
//*j=2,按下S10键时,j=3,按下S12键时j=4*/
unsigned char data;
unsigned int i;
unsigned char j;
const char table[20]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0XD8,0x80,0x90,0x88,0x83,0xc6,0xa1,0x86,0x8e,0x7f,0xbf,0x89,0xff};
//*B口“电平变化中断”初始化子程序*/
void PORTBINT()
{
TRISB=0XF1; //B口RB0输入7705数据准备好信号,RB4,RB5,RB6,RB7按键输入,
//RB1输出EPROM片选,RB2输出7705片选,RB3输出1269片选
INTCON=0x00; //*关闭所有中断*/
RBPU=0; //开启按键开弱上拉
RBIE=1; //*B口变位中断允许 */
//PORTB=PORTB; //*读B口的值,为变位中断创造条件*/
}
//*spi初始化子程序*/
void SPIINIT()
{
PIR1=0;
SSPCON=0x20;
SSPSTAT=0xC0;
TRISC=0xD7; //*SDO引脚为输出,SCK引脚为输出*/
}
//*系统各输入输出口初始化子程序*/
void initial()
{
TRISA=0xDF;
INTCON=0x00; //*关闭所有中断*/
data=0X00; //*待显示的寄存器赋初值*/
}
//*键服务子程序*/
void KEYSERVE()
{
if(RB4==0) j=0X01;
if(RB5==0) j=0X02;
if(RB6==0) j=0X03;
if(RB7==0) j=0X04; //*以上通过逐行逐列扫描,以确定是何键按下*/
PORTB=0XFF; //*恢复PORTB的值*/
}
//*软件延时子程序*/
void DELAY()
{
for(i = 6553; --i ;)
continue;
}
//*SPI发送子程序*/
void SPILED(int data)
{
SSPBUF=data; //*启动发送*/
do
{
;
}while(SSPIF==0);
SSPIF=0;
}
void IDEDIS()
{
KEYSERVE(); //*进行键盘的识别*/
data=table[j]; //*获得需要送出显示的段码*/
RA5=0; //*LACK信号清0,为锁存做准备*/
SPILED(data);
RA5=1; //*最后给一个锁存信号,代表显示任务完成*/
}
//*中断服务程序*/
void interrupt keyint(void)
{
DELAY(); //*软件延时*/
if ((RB7==0)||(RB6==0)||(RB5==0)||(RB4==0)) //*该语句除了能够确认按键是否为干扰外,*/
//*还可以屏蔽一次键松开时引起的中断*/
IDEDIS(); //*键识别和显示模块*/
//PORTB=PORTB; //*读B口的值,改变中断发生的条件,避免键*/
//*一直按下时,连续进行键识别*/
RBIF=0; //*键扫描时可能会产生"电平变化"而使RBIF*/
//INTF=0; //*置1,再清除一次RBIF以避免额外中断*/
}
main()
{
initial(); //*系统初始化*/
PORTBINT(); //*B口变位中断初始化*/
SPIINIT() ; //*利用SPI显示初始化*/
//INTE=1;
ei(); //*总中断允许*/
while(1)
{
;
} //*等待中断*/
}
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
-----------------------------------------------------------------------
谢谢回复,用的是PIC16F876,ei();是打开总中断,程序在运行时会进入一次中断,然后正常。
一周热门 更多>