找回密码
 立即注册
楼主: 芯势力

《8051U深度入门到32位51大型实战教学视频》学习心路历程

[复制链接]
  • 打卡等级:偶尔看看I
  • 打卡总天数:17
  • 最近打卡:2025-06-16 17:24:53

14

主题

159

回帖

1663

积分

版主

积分
1663
发表于 2025-1-23 15:12:31 | 显示全部楼层
第十三集,外部中断,手敲代码测试成功
d9f91e066e8b422b6255ab45474afa0.png
程序如下:
#include "io.h"

u8 State1=0;           //LED1初始状态
u8 State2=0;          //LED2初始状态
u8 State3=0;          //LED3初始状态

u16 Key_Vol = 0;
u8  Seg_no = 0;
u8 SEG_NUM[]=

{
    0x3F,       /*'0', 0*/
    0x06,       /*'1', 1*/
    0x5B,       /*'2', 2*/
    0x4F,       /*'3', 3*/
    0x66,       /*'4', 4*/
    0x6D,       /*'5', 5*/
    0x7D,       /*'6', 6*/
    0x07,       /*'7', 7*/
    0x7F,       /*'8', 8*/
    0x6F,       /*'9', 9*/
    0x77,       /*'A', 10*/
    0x7C,       /*'B', 11*/
    0x39,       /*'C', 12*/
    0x5E,       /*'D', 13*/
    0x79,       /*'E', 14*/
    0x71,       /*'F', 15*/
    0x40,       /*'-', 16*/
    0x00,       /*' ', 17*/
    0x80,       /*'.', 18*/
};

u8 T_NUM[8]=

{
0X01,0X02,0X04,0X08,0X10,0X20,0X40,0X80
};
void LED0_Blink(void)
{
        State1 = !State1;
        P00 = State1;
}
void LED1_Blink(void)
{
        State2 = !State2;
        P01 = State2;
}
void LED2_Blink(void)
{
        State3 = !State3;
        P02 = State3;
}

void KEY_Task(void)
{
   if(P33==0)
   {
      Key_Vol++;
          if(Key_Vol==5)
               {
//                       //按键按下的任务
//                       printf("按键单击\r\n");
                                   USB_Reset_U();
                                   IAP_CONTR = 0X60;
               }
   }
   else
   {
      Key_Vol=0;
   }
}

//#define ROW1  P06
//#define ROW2        P07
//#define COL1        P00
//#define COL2        P01
//#define COL3        P02
//#define COL4        P03

//任务1:数码管显示当前的按键号
//按键识别原理:端口默认为高电平,实时读取到引脚为低电平是表示按下。
u8 Key_num = 0xff;
void Task_1(void)
{
      
//①第一步:现将P0.0-P0.3输出低电平,P0.6-P0.7输出高电平,如果有按键按下,按下的那一行的IO就会变成低电平,就可以判断出哪一行按下了。.

        COL1 = 0;      
        COL2 = 0;               
        COL3 = 0;               
        COL4 = 0;
        ROW1 = 1;
        ROW2 = 1;
        if((ROW1==0) || (ROW2==0))                  //如果行按键有按下
        {
    if((ROW1==0)&&(ROW2==0))                //如果两行都有按键按下,不处理
    {
   
    }
    else if(((ROW1==1)&&(ROW2==0)) || ((ROW1==0)&&(ROW2==1)))  //如果有单颗按键按下
    {
                    if(ROW1==0)                                //判断哪一行,输出行开始的序号
                             Key_num=0;
                    else if(ROW2==0)
                             Key_num=4;
      
                        COL1 = 1        ;      
                        COL2 = 1;               
                        COL3 = 1;               
                        COL4 = 1;
                        ROW1 = 0;
                        ROW2 = 0;
                       
                             if(COL1 == 0)                                //判断哪一列,叠加按键的序号
               {
//                      Key_num = Key_num;
               }
               else if(COL2 == 0)
               {
                       Key_num = Key_num+1;
               }
               else if(COL3 == 0)
               {
                       Key_num = Key_num+2;                                
               }
               else if(COL4 == 0)
               {
                       Key_num = Key_num+3;                        
               }
        }
                        COL1 = 0;      
                        COL2 = 0;               
                        COL3 = 0;               
                        COL4 = 0;
                        ROW1 = 1;
                        ROW2 = 1;
        }
        else
        {
        Key_num = 0xff;
        }               
}

void Init_595(void)

{
        HC595_SER =0;
        HC595_RCK =0;
        HC595_SCK =0;
}

void Send_595(u8 dat)
{
    u8 i;
   
    for(i=0;i<8;i++)
    {
            dat<<=1;         //DAT=(DAT<<1);   //CY
            HC595_SER= CY;    //先把数据写到引脚上
            HC595_SCK = 1;    //输出上升沿的时钟信号
            HC595_SCK = 0;
    }        
}

void Display_Seg(u8 HC595_1,u8 HC595_2)
{
    Send_595(HC595_1);   //数码管段码输出  高电平点亮
    Send_595(HC595_2);   //数码管位码输出  低电平点亮
   
    HC595_RCK = 1;      //数据输出
    HC595_RCK = 0;
}

//void SEG_Task(void)

//{
//   if(Key_num==255)
//            Display_Seg(SEG_NUM[17],~T_NUM[0]);   //数码管刷新段码和位码
//   else
//            Display_Seg(SEG_NUM[Key_num],~T_NUM[0]);   //数码管刷新段码和位码
//}
u8 password[8]={16,16,16,16,16,16,16,16};

void SEG_Task(void)

{
  u8 num=0;
        if(Seg_no==0)            
        {  
      Display_Seg(SEG_NUM[password[0]],~T_NUM[0]);   
        }
        else if(Seg_no==1)         
        {  
      Display_Seg(SEG_NUM[password[1]],~T_NUM[1]);   
        }
        else if(Seg_no==2)        
        {  
      Display_Seg(SEG_NUM[password[2]],~T_NUM[2]);   
        }
        else if(Seg_no==3)        
        {  
      Display_Seg(SEG_NUM[password[3]],~T_NUM[3]);  
        }
        else if(Seg_no==4)        
        {  
      Display_Seg(SEG_NUM[password[4]],~T_NUM[4]);   
        }
        else if(Seg_no==5)        
        {  
       Display_Seg(SEG_NUM[password[5]],~T_NUM[5]);   
        }
        else if(Seg_no==6)         
        {  
      Display_Seg(SEG_NUM[password[6]],~T_NUM[6]);   
        }
        else if(Seg_no==7)         
        {  
      Display_Seg(SEG_NUM[password[7]],~T_NUM[7]);   
        }
        else
        {
      
        }
      
        Seg_no ++;
        if(Seg_no>7)
                 Seg_no=0;
}

u8  Key_Vol3 = 0;
u8  Key_no = 0;

void PV_write_Task(void)
{
   if(Key_num<0xff)
        {
       Key_Vol3++;
       if(Key_Vol3==5)
         {
            if(Key_no==0)
         {
            password[0]=16;
            password[1]=16;
            password[2]=16;
            password[3]=16;
            password[4]=16;
            password[5]=16;
            password[6]=16;
            password[7]=16;                              
         }
                                       
                        password[Key_no]=Key_num;
                        Key_no++;
                        //password[7]=17;
                        if(Key_no==8)    //密码输入到了八位
                        {
    if((password[0]==1)&&(password[1]==2)&&(password[2]==3)&&(password[3]==4)&&(password[4]==5)&&(password[5]==6)&&(password[6]==7)&&(password[7]==0))
                {
                        password[0]=17;
                        password[1]=17;
                        password[2]=17;
                        password[3]=17;
                        password[4]=17;
                        password[5]=17;
                        password[6]=17;
                        password[7]=1;                                               
                }
                else
                {
                        password[0]=16;
                        password[1]=16;
                        password[2]=16;
                        password[3]=16;
                        password[4]=16;
                        password[5]=16;
                        password[6]=16;
                        password[7]=16;                                               
                }
                        Key_no=0;
        }         
     }
  }
         else
         {
            Key_Vol3=0;
         }
}

void INT1_Init(void)
{
        IT1 = 1;        //下降沿中断
        EX1 = 1;                 //打开中断允许
//        EA = 1;                        //打开总中断
}

void INT_ISR(void) interrupt 2
{
        P01 =!P01;
}

AI8051U教学视频第13集外部中断手敲程序.zip (130.92 KB, 下载次数: 11)


回复 支持 反对

使用道具 举报 送花

  • 打卡等级:偶尔看看I
  • 打卡总天数:17
  • 最近打卡:2025-06-16 17:24:53

14

主题

159

回帖

1663

积分

版主

积分
1663
发表于 2025-1-24 11:38:49 | 显示全部楼层
第十四集  IO中断  手敲代码  测试成功
任务一 IO的中断程序
任务1.png

程序如下:

#include "io.h"

u8 State1 = 0;         //LED1初始状态
u8 State2 = 0;   //LED2初始状态
u8 State3 = 0;   //LED3初始状态

u16 Key_Vol=0;

u8 SEG_NUM[]=
{
    0x3F,       /*'0', 0*/
    0x06,       /*'1', 1*/
    0x5B,       /*'2', 2*/
    0x4F,       /*'3', 3*/
    0x66,       /*'4', 4*/
    0x6D,       /*'5', 5*/
    0x7D,       /*'6', 6*/
    0x07,       /*'7', 7*/
    0x7F,       /*'8', 8*/
    0x6F,       /*'9', 9*/
    0x77,       /*'A', 10*/
    0x7C,       /*'B', 11*/
    0x39,       /*'C', 12*/
    0x5E,       /*'D', 13*/
    0x79,       /*'E', 14*/
    0x71,       /*'F', 15*/
    0x40,       /*'-', 16*/
    0x00,       /*' ', 17*/
    0x80,       /*'.', 18*/
};

u8 T_NUM[8]=
{
        0X01,0X02,0X04,0X08,0X10,0X20,0X40,0X80
};

void LED0_Blink(void)
{
        State1 = !State1;
        P00 = State1;
}

void LED1_Blink(void)
{
        State2 = !State2;
        P01 = State2;
}

void LED2_Blink(void)
{
        State3 = !State3;
        P02 = State3;
}

void KEY_Task(void)
{
   if(P33==0)
         {
            Key_Vol++;
                  if(Key_Vol==5)
                        {
                                //按键按下的任务
//                                printf("按键单击\r\n");
                                
                                        USB_Reset_U();
                                
                                        IAP_CONTR=0X60;
                        }
         }
         else
         {
            Key_Vol=0;
         }
}

/*
                #define ROW1                P06   //端口定义
                #define ROW2                P07         
                #define COL1                P00
                #define COL2                P01
                #define COL3                P02
                #define COL4                P03
*/

u8 key_num=0xff;

//任务1:数码管显示当前的按键号
void Task_1(void)
{
         
        
    //①第一步:现将P0.0-P0.3输出低电平,P0.6-P0.7输出高电平,如果有按键按下,按下的那一行的IO就会变成低电平,就可以判断出哪一行按下了。
    COL1 = 0;
                COL2 = 0;
                COL3 = 0;
                COL4 = 0;
                ROW1 = 1;
                ROW2 = 1;
        
                if((ROW1==0) || (ROW2==0))                  //如果行按键有按下
                {
                        if((ROW1==0)&&(ROW2==0))                //如果两行都有按键按下,不处理
                        {
                        
                        }
                        else if(((ROW1==1)&&(ROW2==0)) || ((ROW1==0)&&(ROW2==1)))  //如果有单颗按键按下
                        {
                                        if(ROW1==0)                                //判断哪一行,输出行开始的序号
                                                 key_num=0;
                                        else if(ROW2==0)
                                                 key_num=4;
                                       
                                        //②第二步:现将P0.0-P0.3输出高电平,P0.6-P0.7输出低电平,如果有按键按下,按下的那一列的IO就会变成低电平,就可以判断出哪一列按下了。
                                        COL1 = 1;
                                        COL2 = 1;
                                        COL3 = 1;
                                        COL4 = 1;
                                        ROW1 = 0;
                                        ROW2 = 0;
                                
                                  if(COL1 == 0)                                //判断哪一列,叠加按键的序号
                                        {
//                                                key_num = key_num;
                                        }
                                        else if(COL2 == 0)
                                        {
                                                key_num = key_num+1;
                                        }
                                        else if(COL3 == 0)
                                        {
                                                key_num = key_num+2;                                
                                        }
                                        else if(COL4 == 0)
                                        {
                                                key_num = key_num+3;                        
                                        }
                                }
                                COL1 = 0;
                                COL2 = 0;
                                COL3 = 0;
                                COL4 = 0;
                                ROW1 = 1;
                                ROW2 = 1;                        
                        }
                else
                {
                        key_num=0xff;
                }
         
                //③第三步:行列组合一下就可以判断出是哪个按键按下了。

}

void Init_595(void)
{
        HC595_SER =0;
        HC595_RCK        =0;
        HC595_SCK        =0;
}

void Send_595(u8 dat)
{
        u8 i;
        
        for(i=0;i<8;i++)
        {
                dat <<=1;         //DAT=(DAT<<1);   //CY
                HC595_SER= CY;    //先把数据写到引脚上
                HC595_SCK = 1;    //输出上升沿的时钟信号
                HC595_SCK = 0;
        }        
}

void Display_Seg(u8 HC595_1,u8 HC595_2)
{
        Send_595(HC595_1);   //数码管段码输出  高电平点亮
        Send_595(HC595_2);   //数码管位码输出  低电平点亮
        
        HC595_RCK        = 1;      //数据输出
        HC595_RCK        = 0;
}

//void SEG_Task(void)
//{
//        if(key_num==255)
//                 Display_Seg(SEG_NUM[17],~T_NUM[0]);   //数码管刷新段码和位码
//        else
//                 Display_Seg(SEG_NUM[key_num],~T_NUM[0]);   //数码管刷新段码和位码
//}

u8 passward[8]={16,16,16,16,16,16,16,16};

u8 Seg_no=0;
void SEG_Task(void)
{
        u8 num=0;
        if(Seg_no==0)              //小时十位
        {  
      Display_Seg(SEG_NUM[passward[0]],~T_NUM[0]);   //数码管刷新段码和位码
        }
        else if(Seg_no==1)         //小时个位
        {  
      Display_Seg(SEG_NUM[passward[1]],~T_NUM[1]);   //数码管刷新段码和位码
        }
        else if(Seg_no==2)         //第一个横杠
        {  
                  Display_Seg(SEG_NUM[passward[2]],~T_NUM[2]);   //数码管刷新段码和位码
        }
        else if(Seg_no==3)         //分钟十位
        {  
      Display_Seg(SEG_NUM[passward[3]],~T_NUM[3]);   //数码管刷新段码和位码
        }
        else if(Seg_no==4)         //分钟个位
        {  
      Display_Seg(SEG_NUM[passward[4]],~T_NUM[4]);   //数码管刷新段码和位码
        }
        else if(Seg_no==5)         //第二个横杠
        {  
                  Display_Seg(SEG_NUM[passward[5]],~T_NUM[5]);   //数码管刷新段码和位码
        }
        else if(Seg_no==6)         //秒钟十位
        {  
      Display_Seg(SEG_NUM[passward[6]],~T_NUM[6]);   //数码管刷新段码和位码
        }
        else if(Seg_no==7)         //秒钟个位
        {  
      Display_Seg(SEG_NUM[passward[7]],~T_NUM[7]);   //数码管刷新段码和位码
        }
        else
        {
        
        }
        
        Seg_no ++;
        if(Seg_no>7)
                 Seg_no=0;
}

u8 Key_Vol3=0;
u8 key_no=0;

void PW_write_Task(void)
{
           if(key_num<0xff)
         {
            Key_Vol3++;
                  if(Key_Vol3==5)
                        {
                                if(key_no==0)
                                {
                                                passward[0]=16;
                                                passward[1]=16;
                                                passward[2]=16;
                                                passward[3]=16;
                                                passward[4]=16;
                                                passward[5]=16;
                                                passward[6]=16;
                                                passward[7]=16;                                
                                }
                                       
                                passward[key_no]=key_num;
                                key_no++;
//                        passward[7]=17;
                                if(key_no==8)    //密码输入到了八位
                                {
                                        if((passward[0]==6)&&(passward[1]==6)&&(passward[2]==6)&&(passward[3]==6)&&(passward[4]==6)&&(passward[5]==6)&&(passward[6]==6)&&(passward[7]==6))
                                        {
                                                passward[0]=17;
                                                passward[1]=17;
                                                passward[2]=17;
                                                passward[3]=17;
                                                passward[4]=17;
                                                passward[5]=17;
                                                passward[6]=17;
                                                passward[7]=1;                                                
                                        }
                                        else
                                        {
                                                passward[0]=16;
                                                passward[1]=16;
                                                passward[2]=16;
                                                passward[3]=16;
                                                passward[4]=16;
                                                passward[5]=16;
                                                passward[6]=16;
                                                passward[7]=16;                                                
                                        }
                                        key_no=0;
                                }         
                        }
         }
         else
         {
            Key_Vol3=0;
         }
}

//void INT1_Init(void)
//{
//   IT1=1;   //下降沿中断
//         EX1=1;   //打开中断允许
//         EA=1;    // 打开总中断
//}

//void INT_ISR(void)interrupt 2
//{
//                P01=!P01;
//}

void P3_IO_Init(void)
{
                P3IM0=0X00;  //IO中断模式设置为下降沿
                P3IM1=0X00;
        
                P3INTE=0X08;  //打开中断
}

void P3_IO_ISR(void)    interrupt 40
{
                u8 intf;
        
                intf=P3INTF;
               
                if(intf)  //判断有没有io触发中断
                {
                        P3INTF=0;
                        
                        if (intf & 0x08)  //判断是否是P33按键按下
                        {
                                        P01=!P01;
                        }
                }
}   
任务二: 中断优先级设置

io.c 程序如下:

#include "io.h"

u8 State1 = 0;         //LED1初始状态
u8 State2 = 0;   //LED2初始状态
u8 State3 = 0;   //LED3初始状态

u16 Key_Vol=0;

u8 SEG_NUM[]=
{
    0x3F,       /*'0', 0*/
    0x06,       /*'1', 1*/
    0x5B,       /*'2', 2*/
    0x4F,       /*'3', 3*/
    0x66,       /*'4', 4*/
    0x6D,       /*'5', 5*/
    0x7D,       /*'6', 6*/
    0x07,       /*'7', 7*/
    0x7F,       /*'8', 8*/
    0x6F,       /*'9', 9*/
    0x77,       /*'A', 10*/
    0x7C,       /*'B', 11*/
    0x39,       /*'C', 12*/
    0x5E,       /*'D', 13*/
    0x79,       /*'E', 14*/
    0x71,       /*'F', 15*/
    0x40,       /*'-', 16*/
    0x00,       /*' ', 17*/
    0x80,       /*'.', 18*/
};

u8 T_NUM[8]=
{
        0X01,0X02,0X04,0X08,0X10,0X20,0X40,0X80
};

void LED0_Blink(void)
{
        State1 = !State1;
        P00 = State1;
}

void LED1_Blink(void)
{
        State2 = !State2;
        P01 = State2;
}

void LED2_Blink(void)
{
        State3 = !State3;
        P02 = State3;
}

void KEY_Task(void)
{
   if(P33==0)
         {
            Key_Vol++;
                  if(Key_Vol==5)
                        {
                                //按键按下的任务
//                                printf("按键单击\r\n");
                              
                                        USB_Reset_U();
                              
                                        IAP_CONTR=0X60;
                        }
         }
         else
         {
            Key_Vol=0;
         }
}

/*
                #define ROW1                P06   //端口定义
                #define ROW2                P07         
                #define COL1                P00
                #define COL2                P01
                #define COL3                P02
                #define COL4                P03
*/

u8 key_num=0xff;

//任务1:数码管显示当前的按键号
void Task_1(void)
{
         
      
    //①第一步:现将P0.0-P0.3输出低电平,P0.6-P0.7输出高电平,如果有按键按下,按下的那一行的IO就会变成低电平,就可以判断出哪一行按下了。
    COL1 = 0;
                COL2 = 0;
                COL3 = 0;
                COL4 = 0;
                ROW1 = 1;
                ROW2 = 1;
      
                if((ROW1==0) || (ROW2==0))                  //如果行按键有按下
                {
                        if((ROW1==0)&&(ROW2==0))                //如果两行都有按键按下,不处理
                        {
                       
                        }
                        else if(((ROW1==1)&&(ROW2==0)) || ((ROW1==0)&&(ROW2==1)))  //如果有单颗按键按下
                        {
                                        if(ROW1==0)                                //判断哪一行,输出行开始的序号
                                                 key_num=0;
                                        else if(ROW2==0)
                                                 key_num=4;
                                       
                                        //②第二步:现将P0.0-P0.3输出高电平,P0.6-P0.7输出低电平,如果有按键按下,按下的那一列的IO就会变成低电平,就可以判断出哪一列按下了。
                                        COL1 = 1;
                                        COL2 = 1;
                                        COL3 = 1;
                                        COL4 = 1;
                                        ROW1 = 0;
                                        ROW2 = 0;
                              
                                  if(COL1 == 0)                                //判断哪一列,叠加按键的序号
                                        {
//                                                key_num = key_num;
                                        }
                                        else if(COL2 == 0)
                                        {
                                                key_num = key_num+1;
                                        }
                                        else if(COL3 == 0)
                                        {
                                                key_num = key_num+2;                              
                                        }
                                        else if(COL4 == 0)
                                        {
                                                key_num = key_num+3;                       
                                        }
                                }
                                COL1 = 0;
                                COL2 = 0;
                                COL3 = 0;
                                COL4 = 0;
                                ROW1 = 1;
                                ROW2 = 1;                       
                        }
                else
                {
                        key_num=0xff;
                }
         
                //③第三步:行列组合一下就可以判断出是哪个按键按下了。

}

void Init_595(void)
{
        HC595_SER =0;
        HC595_RCK        =0;
        HC595_SCK        =0;
}

void Send_595(u8 dat)
{
        u8 i;
      
        for(i=0;i<8;i++)
        {
                dat <<=1;         //DAT=(DAT<<1);   //CY
                HC595_SER= CY;    //先把数据写到引脚上
                HC595_SCK = 1;    //输出上升沿的时钟信号
                HC595_SCK = 0;
        }      
}

void Display_Seg(u8 HC595_1,u8 HC595_2)
{
        Send_595(HC595_1);   //数码管段码输出  高电平点亮
        Send_595(HC595_2);   //数码管位码输出  低电平点亮
      
        HC595_RCK        = 1;      //数据输出
        HC595_RCK        = 0;
}

//void SEG_Task(void)
//{
//        if(key_num==255)
//                 Display_Seg(SEG_NUM[17],~T_NUM[0]);   //数码管刷新段码和位码
//        else
//                 Display_Seg(SEG_NUM[key_num],~T_NUM[0]);   //数码管刷新段码和位码
//}

u8 passward[8]={17,17,17,17,17,17,17,17};

u8 Seg_no=0;
void SEG_Task(void)
{
        u8 num=0;
        if(Seg_no==0)              //小时十位
        {  
      Display_Seg(SEG_NUM[passward[0]],~T_NUM[0]);   //数码管刷新段码和位码
        }
        else if(Seg_no==1)         //小时个位
        {  
      Display_Seg(SEG_NUM[passward[1]],~T_NUM[1]);   //数码管刷新段码和位码
        }
        else if(Seg_no==2)         //第一个横杠
        {  
                  Display_Seg(SEG_NUM[passward[2]],~T_NUM[2]);   //数码管刷新段码和位码
        }
        else if(Seg_no==3)         //分钟十位
        {  
      Display_Seg(SEG_NUM[passward[3]],~T_NUM[3]);   //数码管刷新段码和位码
        }
        else if(Seg_no==4)         //分钟个位
        {  
      Display_Seg(SEG_NUM[passward[4]],~T_NUM[4]);   //数码管刷新段码和位码
        }
        else if(Seg_no==5)         //第二个横杠
        {  
                  Display_Seg(SEG_NUM[passward[5]],~T_NUM[5]);   //数码管刷新段码和位码
        }
        else if(Seg_no==6)         //秒钟十位
        {  
      Display_Seg(SEG_NUM[passward[6]],~T_NUM[6]);   //数码管刷新段码和位码
        }
        else if(Seg_no==7)         //秒钟个位
        {  
      Display_Seg(SEG_NUM[passward[7]],~T_NUM[7]);   //数码管刷新段码和位码
        }
        else
        {
      
        }
      
        Seg_no ++;
        if(Seg_no>7)
                 Seg_no=0;
}

u8 Key_Vol3=0;
u8 key_no=0;

void PW_write_Task(void)
{
           if(key_num<0xff)
         {
            Key_Vol3++;
                  if(Key_Vol3==5)
                        {
                                if(key_no==0)
                                {
                                                passward[0]=16;
                                                passward[1]=16;
                                                passward[2]=16;
                                                passward[3]=16;
                                                passward[4]=16;
                                                passward[5]=16;
                                                passward[6]=16;
                                                passward[7]=16;                              
                                }
                                       
                                passward[key_no]=key_num;
                                key_no++;
//                        passward[7]=17;
                                if(key_no==8)    //密码输入到了八位
                                {
                                        if((passward[0]==6)&&(passward[1]==6)&&(passward[2]==6)&&(passward[3]==6)&&(passward[4]==6)&&(passward[5]==6)&&(passward[6]==6)&&(passward[7]==6))
                                        {
                                                passward[0]=17;
                                                passward[1]=17;
                                                passward[2]=17;
                                                passward[3]=17;
                                                passward[4]=17;
                                                passward[5]=17;
                                                passward[6]=17;
                                                passward[7]=1;                                               
                                        }
                                        else
                                        {
                                                passward[0]=16;
                                                passward[1]=16;
                                                passward[2]=16;
                                                passward[3]=16;
                                                passward[4]=16;
                                                passward[5]=16;
                                                passward[6]=16;
                                                passward[7]=16;                                               
                                        }
                                        key_no=0;
                                }         
                        }
         }
         else
         {
            Key_Vol3=0;
         }
}

//void INT1_Init(void)
//{
//   IT1=1;   //下降沿中断
//         EX1=1;   //打开中断允许
//         EA=1;    // 打开总中断
//}

//void INT_ISR(void)interrupt 2
//{
//                P01=!P01;
//}

//数码管显示0;执行while函数   1;执行p3_IO中断  2;执行p4_IO中断

void P3_IO_Init(void)
{
                P3IM0=0X00;  //IO中断模式设置为下降沿
                P3IM1=0Xff;
      
                P3INTE=0X08;  //打开中断
}

void P3_IO_ISR(void)    interrupt 40
{
                u8 intf;
      
                intf=P3INTF;
               
                if(intf)  //判断有没有io触发中断
                {
                        P3INTF=0;
                       
                        if (intf & 0x08)  //判断是否是P33按键按下
                        {
                                                passward[0]=1;
//                                        P01=!P01;
                        }
                }
}      

void P4_IO_Init(void)
{
                P4IM0=0X00;  //IO中断模式设置为下降沿
                P4IM1=0Xff;
      
                P4INTE=0X80;  //打开中断
         
          PINIPH  |=(1<<4);   //写入最高优先级
                PINIPL  |=(1<<4);
}

void P4_IO_ISR(void)    interrupt 41
{
                u8 intf;
      
                intf=P4INTF;
               
                if(intf)  //判断有没有io触发中断
                {
                        P4INTF=0;
                       
                        if (intf & 0x80)  //判断是否是P33按键按下
                        {
                                        passward[0]=2;
                        }
                }
}         


回复 支持 反对

使用道具 举报 送花

  • 打卡等级:偶尔看看I
  • 打卡总天数:17
  • 最近打卡:2025-06-16 17:24:53

14

主题

159

回帖

1663

积分

版主

积分
1663
发表于 2025-2-14 09:39:53 | 显示全部楼层
第十五集:定时器做计数器
任务1:
62754af0652180dbc1f3060c4d251c2.png


代码如下:
#include "tim.h"
u32 Count_T1 = 0;

void TIM1_Count_Init(void)
{
        T1_CT = 1;
        T1_M1 = 0;
        T1_M0 = 0;
        T1_GATE = 0;
        
        TH1 =(65536-Count_num)>>8;
        TL1 =(65536-Count_num);
        P3PU |= 0x20;

        
        TR1 = 1;
        ET1 = 1;
}
void Timer1_Isr(void) interrupt 3        //3秒执行一次
{
Count_T1++;
}
void T1_RunTask(void)
{
        u32 count_th_tl = 0;
        count_th_tl=((u16)TH1<<8)+(u16)TL1;
        count_th_tl-=65526;
        SEG7_ShowLong(Count_T1*Count_num+count_th_tl,10);
}
任务二:定时器1测量INT1引脚低电平脉冲宽度
de157524b08526d8d61d5f5b696d906.png

代码如下:
#include "tim.h"
u32 Count_T1 = 0;

// void TIM1_Count_Init(void)
//{
//        T1_CT = 1;
//        T1_M1 = 0;
//        T1_M0 = 0;
//        T1_GATE = 0;
//        
//        TH1 =(65536-Count_num)>>8;
//        TL1 =(65536-Count_num);
//        P3PU |= 0x20;

//        
//        TR1 = 1;
//        ET1 = 1;
//}
//void Timer1_Isr(void) interrupt 3        //3秒执行一次
//{
//Count_T1++;
//}
//void T1_RunTask(void)
//{
//        u32 count_th_tl = 0;
//        count_th_tl=((u16)TH1<<8)+(u16)TL1;
//        count_th_tl-=65526;
//        SEG7_ShowLong(Count_T1*Count_num+count_th_tl,10);
//}
void Timer1_Isr(void) interrupt 3
{
        static u32 count_p33 = 0;
        
        if( P33 == 0 )                //按键按下开始计数
        {
                count_p33 ++ ;
        }
        else
        {
                if( count_p33>0 )                //表示之前按下了这个按键
                {
                        Count_T1 = count_p33;
                }
                count_p33 =0;
        }
}

void Timer1_Init(void)                //100微秒@24.000MHz
{
        AUXR &= 0xBF;                        //定时器时钟12T模式
        TMOD &= 0x0F;                        //设置定时器模式
        TL1 = 0x38;                                //设置定时初始值
        TH1 = 0xFF;                                //设置定时初始值
        TF1 = 0;                                //清除TF1标志
        TR1 = 1;                                //定时器1开始计时
        ET1 = 1;                                //使能定时器1中断
}

void T1_RunTask(void)
{
        //SEG7_ShowLong(Count_T1,10);        //显示整数
        SEG7_ShowString("%07.01f",((float)Count_T1)/10);
}
AI8051U实验箱第15集学习手敲代码定时器做count.zip (384.27 KB, 下载次数: 10)






回复 支持 反对

使用道具 举报 送花

  • 打卡等级:偶尔看看I
  • 打卡总天数:17
  • 最近打卡:2025-06-16 17:24:53

14

主题

159

回帖

1663

积分

版主

积分
1663
发表于 2025-2-20 13:51:11 | 显示全部楼层
第十六集 串口的简单应用,已手敲代码,测试通过
9652a3638ca32c45bbbb385fc46a769.png
2.代码如下:
usart.c 代码:


#include "usart.h"
#include "io.h"

u8 Rec_Dat[50];  
u8 Rec_Num = 0;
bit  B_TX2_Busy = 0;

void Uart2_Isr(void) interrupt 8
{
        if (S2CON & 0x02)         
        {
                S2CON &= ~0x02;         
                 B_TX2_Busy = 0;
        }
        if (S2CON & 0x01)         
        {
                S2CON &= ~0x01;         
               
                Rec_Dat[Rec_Num++] = S2BUF;
        }
}

void Uart2_Init(void)        //9600bps@24.000MHz
{

  P_SW2 |= 0x01;                                                //UART2/USART2: RxD2(P4.6), TxD2(P4.7)

        S2CON = 0x50;                 
        AUXR |= 0x04;                 
        T2L = 0x8F;                 
        T2H = 0xFD;                        
        AUXR |= 0x10;                 
        IE2 |= 0x01;                 
      
        Rec_Num = 0;
         B_TX2_Busy = 0;
}

void Uart2_SendStr(u8 *puts)

{

    for (; *puts != 0;  puts++)      
    {
        S2BUF = *puts;
        B_TX2_Busy = 1;
        while(B_TX2_Busy);
    }

}


void Usart2_RunTask(void)
{
    if(Rec_Num >= 6)
                {
                   if((Rec_Dat[Rec_Num-1] == '\n') && (Rec_Dat[Rec_Num-2] == '\r'))
                         {
                           if( (Rec_Dat[Rec_Num-6] == 'O') &&  (Rec_Dat[Rec_Num-5] == 'P') &&  (Rec_Dat[Rec_Num-4] == 'E') &&  (Rec_Dat[Rec_Num-3] == 'N') )
                                 {

                                     passward[0] = 16;
                                     passward[1] = 16;
                                     passward[2] = 16;
                                     passward[3] = 16;
                                                 Uart2_SendStr( "打开成功\r\n");
                                }
                                 else if( (Rec_Dat[Rec_Num-7] == 'C') &&  (Rec_Dat[Rec_Num-6] == 'L') &&  (Rec_Dat[Rec_Num-5] == 'O') &&  (Rec_Dat[Rec_Num-4] == 'S') &&  (Rec_Dat[Rec_Num-3] == 'E') )
                                 {
                               passward[0] = 17;
                                     passward[1] = 17;
                                     passward[2] = 17;
                                     passward[3] = 17;
                                 Uart2_SendStr( "关闭成功\r\n");
                                }
                    Rec_Num = 0;
                                }
                        }
}
AI8051U实验箱第16集学习手敲代码串口的简单应用.zip (203.77 KB, 下载次数: 10)

   
  


                        
                                 
                  


回复 支持 反对

使用道具 举报 送花

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|小黑屋|深圳国芯人工智能有限公司 ( 粤ICP备2022108929号-2 )

GMT+8, 2025-6-18 00:38 , Processed in 0.129781 second(s), 62 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表