PIC测试配置位的使用

发布者:心怀梦想最新更新时间:2017-12-06 来源: eefocus关键字:PIC  测试配置位 手机看文章 扫描二维码
随时随地手机看文章

//K程序主要是测试配置位的使用要调用87X.H杳看
//定时中断
//原来4的程序是可能为没有按键放开的程序
//程序5修正按键松开的程序
//biao是指示是否有按键按下如果没有的话就指示为显示4个8
#include IC.h>
#include
#define PORTDIT(add,bit) ((unsigned)(&add)*8+(bit))

#define PORTBIT(add,bit) ((unsigned)(&add)*8+(bit))
//__IDLOC(1233) ;
//__CONFIG (XT&PWRTEN) ;
static  bit  PORT_0 @  PORTDIT(PORTD,0);   /*定义PORTD 0位*/
static  bit  PORT_1 @  PORTDIT(PORTD,1);   /*定义PORTD 1位*/
static  bit  PORT_2 @  PORTDIT(PORTD,2);   /*定义PORTD 2位*/
static  bit  PORT_3 @  PORTDIT(PORTD,3);   /*定义PORTD 3位*/
static  bit  PORT_4 @  PORTDIT(PORTD,4);   /*定义PORTD 4位*/
static  bit  PORT_5 @  PORTDIT(PORTD,5);   /*定义PORTD 5位*/
static  bit  PORT_6 @  PORTDIT(PORTD,6);   /*定义PORTD 6位*/
static  bit  PORT_7 @  PORTDIT(PORTD,7);   /*定义PORTD 7位*/
//-------------------------------------------------
static  bit  PORTD_0 @  PORTBIT(PORTB,0);   /*定义PORTB 0位*/
static  bit  PORTD_1 @  PORTBIT(PORTB,1);   /*定义PORTB 1位*/
static  bit  PORTD_2 @  PORTBIT(PORTB,2);   /*定义PORTB 2位*/
static  bit  PORTD_3 @  PORTBIT(PORTB,3);   /*定义PORTB 3位*/
static  bit  PORTD_4 @  PORTBIT(PORTB,4);   /*定义PORTB 4位*/
static  bit  PORTD_5 @  PORTBIT(PORTB,5);   /*定义PORTB 5位*/
static  bit  PORTD_6 @  PORTBIT(PORTB,6);   /*定义PORTB 6位*/
static  bit  PORTD_7 @  PORTBIT(PORTB,7);   /*定义PORTB 7位*/
//const char table[]={0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F,0x7C};
unsigned char s;                    /*每0.125S累加1*/
unsigned char ss,fan;                  /*每1秒累加1*/
int i=0,tt;


unsigned char LEDadr,biao;
static unsigned char k,led1,led2,led2,led3,led4;
static unsigned char adrshow,count,show1,show2,show3,show4;//显示位控制
const char  table[]={0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F,0x77,0x7C,0x39}; //A~F
/*0,1,2,3,4,5,6,7,8,9,A,b,C,c,d,E,*/
void keysCAN();
void delay10ms(unsigned char time);
void Dispaly(unsigned char k);
unsigned char key,temp;
void tmint(void)
{   T0CS=0;
PSA=0;
PS2=0;
PS1=1;
PS0=1;
T0IF=0;
T0IE=1;
}
void interrupt clkint(void)   //定时器中断函数
{  if(T0IF=1)  //增加是定时中断时进入
  {
    TMR0=0x5b;
    T0IF=0;
    lEDAdr=ledadr+1;
    if(biao==0)

   { if (ledadr>count)
     {ledadr=0;}
      }
    if ((ledadr==1)&(show1==1||biao==1))
        {if(biao==1)
         {PORTC=0XFF;
          PORTA=0;
           RA0=1;}
         else {PORTC=led1;
         PORTA=0; 
         RA0=1;}
          }
       if ((ledadr==2)&(show2==1||biao==1))
     {   PORTA=0;
          if(biao==1)
          {PORTC=0XFF;
            PORTA=0;
            RA1=1;}
          else {
          PORTA=0;
          PORTC=led2;
          RA1=1;}
             }
      if ((ledadr==3)&(show3==1||biao==1))
          {PORTA=0;
           if (biao==1)
          {PORTC=0xff;
           PORTA=0;
            RA2=1;}
           else {
           PORTA=0;
           PORTC=led3;
            RA2=1;}
                 }
     if ((ledadr==4)&(show4==1||biao==1))
           {PORTA=0;
            if (biao==1)
            {PORTC=0XFF;
            PORTA=0;
            RA3=1;
            ledadr=0;}
                else{ 
           PORTC=led4;
           PORTA=0;
            RA3=1;
            ledadr=0;}
              }
    if(s++>8){                 s=0;
         if(ss++>05)/*每分钟清0*/
             ss=0;  
              } 
   /*  RC3=(bit)(s>4);//可改变占空比1秒闪一次
     RC1=(bit)(!ss);//1分闪一次
     RC2=(bit)(s==0 || s==2 || s== 4 || s== 6);//0.25秒闪一次*/
  }
}
main(void)
{   
    TRISD=0x0F;//低四位是输入,高四位为输出
    TRISC=0;
   // PORTD=0X55;
    TRISB=0x00;
    TRISC=0x00;
    PORTB=0X00;
    PORTC=0x00;
    RB0=1;RB2=0;//接两个LED,开始为全灭
    PCFG3=0;
    PCFG2=1;
    PCFG1=1;
    PCFG0=1;
    TRISA=0;
    PORTA=0;
    //RTC=0xff;
    T0CS=0;
    RA4=0;
    ledadr=0;
    tmint();              //调用定时器初始化程序    
    GIE=1;
    ledadr=0;
     count=0;
    // show1=1;biao=0;
     // ledadr=2;
     //if ((ledadr==2)&(show1==1||biao==1))
     // {asm("nop");}
     
     //show=0;//显示清零
     s=0 ;
     ss=0;
     adrshow=1;
     TMR0=0x06;    //装入定时器初始值
       biao=1;led1=led2=led3=led4=0xff;
       show1=show2=show3=show4=0;
     while(1)
  { 
  // ledadr=0;  
    keyscan();
    if(key!=0)
      {  if (count<=4)
          { count=count+1;
            if (count==1)
             { led1=table[key];
               key=0;
              show1=1;show2=0;show3=0;show4=0;biao=0;}
            if(count==2)
              { led2=table[key]; 
               key=0;
               show2=1;show1=1;show3=0;show4=0;biao=0; }
            if(count==3)
              { led3=table[key];
             key=0;
               show1=1;show2=1;show3=1;show4=0;biao=0;}
            if(count==4)
               {led4=table[key];
                key=0;
               show1=1;show2=1;show3=1;show4=1;biao=0;}
                  }
          else  count=0;
         
       }
   }
}
   /*    RC3=(bit)(s>4);//可改变占空比1秒闪一次
     RC1=(bit)(!ss);//1分闪一次
     RC2=(bit)(s==0 || s==2 || s== 4 || s== 6);//0.25秒闪一次 */    
  
void keyscan() //按键扫描子程序
{
PORTD=0xFF;
RD7=0; //低四位的第四位为0(输出)
temp=PORTD;
temp&=0x0F;//屏蔽掉高四位
if(temp !=0x0F) //如果有按键按下的话
{
  delay10ms(1);
  temp=PORTD;
  temp&=0x0F;
  if(temp !=0x0F) ;//如果确认有按键按下
    {
    temp=PORTD;
     temp&=0x0F;//屏蔽高位位
     asm("nop");
   switch(temp)
   {
   case 0x0E: //1110000b  b4有按下
    key=4;break;
   case 0x0D:
    key=8;break;// 10110000b d
   case 0x0B:
    key=12;break; //11010000b
   }
   Dispaly(key);
   asm("nop");
  }
}

PORTD=0xFF;
RD6=0;//低四位的第三位
temp=PORTD;
temp&=0x0F;
if(temp !=0x0F)
{
  delay10ms(1);
  temp=PORTD;
  temp&=0x0F;
  if(temp !=0x0F)
  {
   temp=PORTD;
   temp&=0x0F;

   switch(temp)
   {
   case 0x0E:  //1110000b  b4有按下
    key=3;break;
   case 0x0D:// 10110000b d
    key=7;break;
   case 0x0B: //11010000b
    key=11;break;
   }
   Dispaly(key);
  }
}

PORTD=0xFF;
RD5=0;//第二位为0
temp=PORTD;
temp&=0x0F;
if(temp !=0x0F)
{
  delay10ms(1);
  temp=PORTD;
  temp&=0x0F;
  if(temp !=0x0F)
  {
   temp=PORTD;
   temp&=0x0F;

   switch(temp)
   {
   case 0x0E:
    key=2;break;
   case 0x0D:
    key=6;break;
   case 0x0B:
    key=10;break;
   }
   Dispaly(key);
  }
}

PORTD=0xFF;
RD4=0;//第1位为0
temp=PORTD;
temp&=0x0F;
if(temp !=0x0F)
{
  delay10ms(1);
  temp=PORTD;
  temp&=0x0F;
  if(temp !=0x0F)
  {
   temp=PORTD;
   temp&=0x0F;

   switch(temp)
   {
   case 0x0E:
    key=1;break;
   case 0x0D:
    key=5;break;
   case 0x0B:
    key=9;break;
   }
   Dispaly(key);
  }
}
}

//延时程序
void delay10ms(unsigned char time)
{
unsigned char a,b,c;
for(a=0;a  for(b=0;b<10;b++)
   for(c=0;c<120;c++)
   ;
}

void Dispaly(unsigned char k) //按键放开子程序

unsigned  char  keytemp,temp;
while (1)
{
delay10ms(1);
//keytemp=(PORTD&0x0f);
  
  keytemp=0x0f;
  temp=(PORTD&0x0f);
if (keytemp==temp)
  {break;}
}
}


关键字:PIC  测试配置位 引用地址:PIC测试配置位的使用

上一篇:PIC16F877A在CAN通信中的应用程序
下一篇:PIC单片机12864编程程序

推荐阅读最新更新时间:2024-03-16 15:48

PIC16F87x单片机I/O口
单片机的I/O口(以16f87x为例) 1、默认情况下A口跟E口是模拟信号输入口,若要做数字输入输出口必须设置ADCON1寄存器(地址为9FH)的值为06H或者07H,之所以默认情况下以上端口会处于这些状态,是因为上电复位后ADCON1的值为0,而此种组合下,正好A口跟E口的每一位都做模拟输入口使用。 2、RA4由于在结构上是开漏极,所以使用时必须外接上拉电阻,否则得到不到想的高电平。 Mplab相关知识: 一、项目的建立和保存:在mplab里建立的项目文件名不能用中文(据说5.x版本的可以)且必须为西文半角格式;保存时路径不能太深,以
[单片机]
pic16f877a的B口的详解
下面是节选的关于B口的介绍: 我们在写程序的时候要注意中断是对中断的判断、读与写的区别.
[单片机]
<font color='red'>pic</font>16f877a的B口的详解
PIC单片机对9346EEPROM数据的读写
实验目的:熟悉SPI总线以及9346EEPROM的读写 ;RBO键按下时把DATA和DATA2写入到EEPROM中以EE—ADDR为地址的单元内, ;完成后,单个数码观显示“9”做为完成标志 ;RB1键按下时,读取EEPROM中以EE—ADDR为地址的单元,并送数码管显示 ;硬件要求:S3、S5、S6拨码管置ON,S1第7、8位置ON。 LIST P=16F877A, R=DEC include “P16F877A.inc” ;包含头文件 __CONFIG _DEBUG_OFF&_CP_ALL&_WRT_HALF&_CPD_ON&_LVP_OFF&_BODEN_OFF&_PWR TE _ON&_WDT_OFF&_HS_OSC
[单片机]
<font color='red'>PIC</font>单片机对9346EEPROM数据的读写
PIC单片机音乐播放程序
以下程序要用二个定时器资源,凡是有二个定时器的PIC 单片机 均可实现,该范例需要的MCU是MICROChip PIC16C62 INCLUDE D:\PIC\P16XX.EQU ;该文件在MICROCHIP光盘中可找到 ;************************************************** #define BeepOut RC,4 ;************************************************** W_TEMP EQU 0X20 ;(0XA0) STATUS_TEMP EQU 0X21 BeepCnt equ 30h TmrBak equ 31h
[单片机]
PIC单片机入门教程(一)—— 准备工作
1、电脑一台(推荐运行Windows 7 旗舰版 64位系统) 2、选择合适的烧录/调试工具 2.1 “Device Support.html”文件列举了所有器件能支持哪些烧录/调试工具,文件官方版本说明包里 下载链接:http://ww1.microchip.com/downloads/en/DeviceDoc/mplabx-ide-v4.15-release-notes-00.zip 2.2 解压后,打开目录,如下所示 2.3 “G”绿色表示完整的生产测试支持。“Y”黄色表示初步测试支持,未经生产测试。“R”红色表示不支持此设备。 PK4=PICkit 4;PK3=PICkit 3 后缀D=Debu
[单片机]
<font color='red'>PIC</font>单片机入门教程(一)—— 准备工作
基于PIC单片机和AD7705的高精度信号采集系统设计
在工业现场测试过程中,由于生产中的各种参数的测试数据对生产过程具有重要的意义,因此对各种测试数据精度要求较高。而对于传统的传感器,比如压阻式、应变桥式、热电偶、热电阻、电容式以及压电式传感器,输出的一般是毫伏级的微弱模拟信号,温度特性差,而且在传输过程中信噪比明显降低。因此需要设计高精度稳定性强的信号采集系统进行采集。然而采用以往的积分型和逐次比较型A/D实现高 精度信号采集的难度较大且成本很高。近年来兴起的∑-△A/D转换技术却能以较低的成本获取极高的分辨率。AD7705便是一款比较典型的高性能16位∑-△A/D转换芯片。 本设计采用AD7705为A/D转换器,配合8位高性能PIC单片机PIC18F458组成高精度信号采集系
[单片机]
基于<font color='red'>PIC</font>单片机和AD7705的高精度信号采集系统设计
PIC16F877A的50HZ正弦波
1 #include pic.h //包含单片机内部资源预定义 2 #include math.h 3 4 unsigned char const sin_32 ={104,109,114,119,124,128,133,137,142,146,150,154,157,161,164,//15 5 167,169,172,174,176,177,178,179,180,180,180,180,179,178,176,175,173,171,168,165,//20 6 162,159,156,152,148,144,140,135,131,126,121,116,111,106,101,96,91,86,81,76,72
[单片机]
PIC单片机“跑马灯”实验程序代码
;实验目的:本程序主要实现一个简单的流水灯程序 ;即轮流点亮C口的8个灯(先点亮RC0,再熄灭RCO点亮RC1。。。。) ;硬件要求:拨码开关S11全部置ON。 #include p16f877A.inc ;调用头文件 __CONFIG _DEBUG_OFF&_CP_ALL&_WRT_HALF&_CPD_ON&_LVP_OFF&_BODEN_OFF&_PWRTE_ON&_WDT_OFF&_HS_OSC ;**********************用户寄存器定义******************** count equ 20h ;移位次数寄存器 del_va1 equ 0ffh
[单片机]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved