找回密码
 立即注册
楼主: 芯的搬砖工

《8051U深度入门到32位51大型实战教学视频》学习打卡

[复制链接]
  • 打卡等级:初来乍到
  • 打卡总天数:9
  • 最近打卡:2025-04-02 14:30:31
已绑定手机

4

主题

20

回帖

156

积分

注册会员

积分
156
发表于 2025-1-21 14:58:09 | 显示全部楼层
第十三集   外部中断,代码手输测试成功
图片:
截图202501211455212818.jpg
视频:


代码:

#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;
}


AI8051教学视频第十三集外部中断.zip (164.03 KB, 下载次数: 11)





回复 支持 反对

使用道具 举报 送花

  • 打卡等级:初来乍到
  • 打卡总天数:9
  • 最近打卡:2025-04-02 14:30:31
已绑定手机

4

主题

20

回帖

156

积分

注册会员

积分
156
发表于 2025-1-23 13:48:39 | 显示全部楼层
第十四集  IO中断  手敲代码  测试成功

任务一  IO的中断程序
图片:
截图202501231341338813.jpg

视频:


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]={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;
                        }
                }
}        



任务二  中断优先级设置
图片:
截图202501231344243342.jpg

视频:


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;
                        }
                }
}      


AI8051教学视频第十四集IO中断.zip (166 KB, 下载次数: 9)   



回复 支持 反对

使用道具 举报 送花

  • 打卡等级:初来乍到
  • 打卡总天数:9
  • 最近打卡:2025-04-02 14:30:31
已绑定手机

4

主题

20

回帖

156

积分

注册会员

积分
156
发表于 2025-1-24 14:15:59 | 显示全部楼层
第十五集  定时器做计数器  代码手敲测试成功
任务一  定时器1计数程序
主程序
截图202501241412048398.jpg
视频


任务二  INT1测低电平时间
主程序
截图202501241418053000.jpg

视频


Ai8051U视频教程第十五集-定时器做计数器.rar (4.94 MB, 下载次数: 9)


回复 支持 反对

使用道具 举报 送花

  • 打卡等级:初来乍到
  • 打卡总天数:9
  • 最近打卡:2025-04-02 14:30:31
已绑定手机

4

主题

20

回帖

156

积分

注册会员

积分
156
发表于 2025-2-6 15:14:33 | 显示全部楼层
第十六集  DS18B20测温  手输代码  测温测试成功
图片:
截图202502061509134226.jpg

视频:


主程序:
  1. #include "18b20.h"
  2. u8    MinusFlag=0;      //如果等于0,正数;如果等于1,负数
  3. u32  Temp_18b20;      //最终的温度,0.0625
  4. void Delay480us(void)        //@24.000MHz
  5. {
  6.         unsigned long edata i;
  7.         _nop_();
  8.         _nop_();
  9.         _nop_();
  10.         i = 2878UL;
  11.         while (i) i--;
  12. }
  13. void Delay60us(void)        //@24.000MHz
  14. {
  15.         unsigned long edata i;
  16.         _nop_();
  17.         _nop_();
  18.         _nop_();
  19.         i = 358UL;
  20.         while (i) i--;
  21. }
  22. void Delay1us(void)        //@24.000MHz
  23. {
  24.         unsigned long edata i;
  25.         _nop_();
  26.         _nop_();
  27.         _nop_();
  28.         i = 4UL;
  29.         while (i) i--;
  30. }
  31. //复位(输出0保持480us,输出1保持60us,读取当前电平,延时420us)
  32. void DS18B20_Reset(void)
  33. {
  34.         u8 flag=1;
  35.         
  36.         while(flag)   //只要括号里的变量大于0,就会一直执行
  37.         {
  38.                 DQ = 0;
  39.                 Delay480us();
  40.                 DQ = 1;
  41.                 Delay60us();
  42.                 flag=DQ;        // 设备存在,拉低总线
  43.                 Delay480us();
  44.         }
  45. }
  46. //写逻辑0(输出0保持60us+,输出1保持1us+)
  47. void DS18B20_Write_0(void)
  48. {
  49.           DQ = 0;
  50.           Delay60us();
  51.           DQ = 1;
  52.           Delay1us();
  53.           Delay1us();
  54. }
  55. //写逻辑1(输出0保持1us+,输出1保持60us+)
  56. void DS18B20_Write_1(void)
  57. {
  58.           DQ = 0;
  59.           Delay1us();
  60.           Delay1us();
  61.           DQ = 1;
  62.           Delay60us();
  63. }
  64. //读逻辑0/1(输出0保持1us+,输出1保持1us+,读取当前电平,延时60us)
  65. bit DS18B20_Read(void)
  66. {
  67.           bit state=0;
  68.                
  69.           DQ = 0;
  70.           Delay1us();
  71.           Delay1us();
  72.           DQ = 1;
  73.           Delay1us();
  74.           Delay1us();
  75.           state=DQ;     // 暂时保存这个DQ的数值
  76.           Delay60us();
  77.         
  78.           return state;
  79. }
  80. //写1字节(先输出低位,在输出高位)
  81. void DS18B20_WriteByte (u8 dat )
  82. {
  83.         u8 i ;
  84.         for(i=0;i<8;i++)
  85.         {
  86.                 if (dat & 0x01)  // 最低位是1,发逻辑1电平
  87.                 {
  88.                         DS18B20_Write_1();
  89.                 }
  90.                 else           //否则,发逻辑0电平
  91.                 {
  92.                         DS18B20_Write_0();
  93.                 }
  94.                 dat>>=1;        //dat=(dat>>1)  ;  
  95.         }
  96. }
  97. //读1字节(先读到的是低位,后读到的是高位)
  98. u8 DS18B20_ReadByte (void)
  99. {
  100.         u8 i ;
  101.         u8 dat =0;      //数据暂存
  102.         
  103.         for(i=0;i<8;i++)   //循环读取8次
  104.         {
  105.                 dat >>=1;
  106.                 if(DS18B20_Read())   //如果读回来的是逻辑1  // 0000 0000 ->1000 0000->0100 00000
  107.                 {
  108.                    dat |=0x80;
  109.                 }
  110.                 else
  111.                 {
  112.                 }
  113.         }
  114.          return dat;
  115. }
  116. //(复位-CCH-44H-等待-复位-CCH-BEH-读取2字节温度数据-换算)
  117. void DS18B20_ReadTemp(void)
  118. {
  119.                 u8 TempH=0;
  120.                 u8 TempL=0;
  121.                 u16 Temp=0;
  122. //----------------------发送检测命令---------------------------
  123.         DS18B20_Reset();              //1.发送复位命令
  124.         DS18B20_WriteByte(0xcc);      //2.跳过ROM命令
  125.         DS18B20_WriteByte(0x44);      //3.开始转化命令
  126.         while(!DQ);                   //4.等待这个引脚变成高电平
  127.         
  128. //----------------------发送读取命令---------------------------
  129.         DS18B20_Reset();              //1.发送复位命令
  130.         DS18B20_WriteByte(0xcc);      //2.跳过ROM命令
  131.         DS18B20_WriteByte(0xBE);      //3.开始转化命令
  132.         TempL=DS18B20_ReadByte();     //4.读取低字节温度
  133.         TempH=DS18B20_ReadByte();     //4.读取高字节温度
  134.         
  135.         if(TempH & 0x80)             //如果最高位是1,这个就是负数
  136.         {
  137.                 MinusFlag=1;
  138.                 Temp=(((u16)TempH<<8) | ((u16)TempL<<0));
  139.                 Temp=(~Temp) +1;
  140.                 Temp_18b20=(u32)Temp*625;
  141.         }
  142.         else
  143.         {
  144.                 MinusFlag=0;
  145.                 Temp=(((u16)TempH<<8) | ((u16)TempL<<0));
  146.                 Temp_18b20=(u32)Temp*625;
  147.         }
  148. }
复制代码

AI8051教学视频第十六集18b20测温.zip (215.01 KB, 下载次数: 9)






回复 支持 反对

使用道具 举报 送花

  • 打卡等级:初来乍到
  • 打卡总天数:9
  • 最近打卡:2025-04-02 14:30:31
已绑定手机

4

主题

20

回帖

156

积分

注册会员

积分
156
发表于 2025-2-13 16:35:57 | 显示全部楼层
第十六集  串口的简单应用  手敲代码成功

一 截图
截图202502131634338877.jpg

二 视频


三 主程序
  1. #include "usart.h"
  2. #include "io.h"
  3. u8 Rec_Dat[50];  //接收缓冲区
  4. u8 Rec_Num=0;    //接收计数
  5. bit B_TX2_Busy=0;
  6. void Uart2_Isr(void) interrupt 8
  7. {
  8.         if (S2CON & 0x02)        //检测串口2发送中断
  9.         {
  10.                 S2CON &= ~0x02;        //清除串口2发送中断请求位
  11.                 B_TX2_Busy=0;
  12.         }
  13.         if (S2CON & 0x01)        //检测串口2接收中断
  14.         {
  15.                 S2CON &= ~0x01;        //清除串口2接收中断请求位
  16.                
  17.                 //S2BUF
  18.                 Rec_Dat[Rec_Num++]=S2BUF;
  19.         }
  20. }
  21. void Uart2_Init(void)        //9600bps@24.000MHz
  22. {
  23.        
  24.         P_SW2 |= 0x01;                                                //UART2/USART2: RxD2(P4.6), TxD2(P4.7)
  25.         S2CON = 0x50;                //8位数据,可变波特率
  26.         AUXR |= 0x04;                //定时器时钟1T模式
  27.         T2L = 0x8F;                        //设置定时初始值
  28.         T2H = 0xFD;                        //设置定时初始值
  29.         AUXR |= 0x10;                //定时器2开始计时
  30.         IE2 |= 0x01;                //使能串口2中断
  31.        
  32.         Rec_Num=0;
  33.         B_TX2_Busy=0;
  34. }
  35. void Uart2_SendStr(u8 *puts)   //串口数据发送函数
  36. {
  37.         for(; *puts !=0;  puts++)     //遇到停止符0结束
  38.         {
  39.                 S2BUF = *puts;
  40.                 B_TX2_Busy=1;
  41.                 while(B_TX2_Busy);
  42.         }
  43. }
  44. //1.发送OPEN\r\n打开数码管,数码管显示“----”
  45. //2.发送CLOSE\r\n打开数码管,数码管全部熄灭
  46. void Usart2_RunTask(void)
  47. {
  48.         if(Rec_Num>=6)   // 是否接收到了六位数据
  49.         {
  50.                 if ((Rec_Dat[Rec_Num-1]=='\n') && (Rec_Dat[Rec_Num-2]=='\r'))  //末尾判断
  51.                 {
  52.                         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'))   
  53.                         {
  54.                                 passward[0]=16;
  55.                                 passward[1]=16;
  56.                                 passward[2]=16;
  57.                                 passward[3]=16;
  58.                                 Uart2_SendStr("打开成功!\r\n");
  59.                         }
  60.                         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'))
  61.       {
  62.                                 passward[0]=17;
  63.                                 passward[1]=17;
  64.                                 passward[2]=17;
  65.                                 passward[3]=17;
  66.                                 Uart2_SendStr("关闭成功!\r\n");
  67.                         }
  68.                         Rec_Num=0;
  69.                 }
  70.         }
  71. }
复制代码
AI8051教学视频第十六集串口的简单应用.zip (210.87 KB, 下载次数: 9)
回复 支持 反对

使用道具 举报 送花

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

本版积分规则

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

GMT+8, 2025-5-4 10:30 , Processed in 0.116664 second(s), 69 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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