找回密码
 立即注册
楼主: 32位8051

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

[复制链接]
  • 打卡等级:常住居民III
  • 打卡总天数:161
  • 最近打卡:2025-06-27 09:02:43

15

主题

163

回帖

1930

积分

版主

积分
1930
发表于 2025-1-21 16:58:36 | 显示全部楼层
第13集已学习,已手敲代码,测试通过

任务一:当按下外部中断INT1/P33,P01的LED改变原来的状态

截图202501211654452166.jpg

2.代码:


#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.zip (157.92 KB, 下载次数: 16)


回复 支持 反对

使用道具 举报 送花

  • 打卡等级:常住居民III
  • 打卡总天数:161
  • 最近打卡:2025-06-27 09:02:43

15

主题

163

回帖

1930

积分

版主

积分
1930
发表于 2025-1-24 11:31:16 | 显示全部楼层
第14集已学习,已手敲代码,测试通过

任务1:IO中断程序,实现LED灯的亮灭

截图202501241126295030.jpg

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



任务2:实现按下P33口显示数字1,按下P47口显示数字2

截图202501241128369274.jpg

代码
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按下
                {
                        password[0] = 1;
                        //P01 =!P01;
                }
        }
        
}

void P4_IO_Init(void)
{
        P4IM0 = 0X00;  //io中断模式设置为下降沿
        P4IM1 = 0Xff;
        
        P4INTE = 0X80; //打开中断
}

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



任务3:实现P33,P47口的I0中断 ,P47口中断优先P33口中断

截图202501241129544133.jpg

代码
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触发中断
        {
                P3INTF=0;
                if(intf & 0x80)//判断是否是P33按下
                {
                        password[0] = 2;
                        //P01 =!P01;
                }
        }
        
}


AI8051U教学视频第14集IO口中断 手敲程序.zip (169.04 KB, 下载次数: 24)





回复 支持 反对

使用道具 举报 送花

  • 打卡等级:常住居民III
  • 打卡总天数:161
  • 最近打卡:2025-06-27 09:02:43

15

主题

163

回帖

1930

积分

版主

积分
1930
发表于 2025-1-24 15:20:57 | 显示全部楼层
第15集已学习,已手敲代码,测试通过

任务一:编写定时器1计数的程序

代码:#include "time.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
{
        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);
}

任务二:编写INT1测量低压电平时间
代码
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集定时器做计数器手敲程序.zip (179.67 KB, 下载次数: 19)



回复 支持 反对

使用道具 举报 送花

  • 打卡等级:常住居民III
  • 打卡总天数:161
  • 最近打卡:2025-06-27 09:02:43

15

主题

163

回帖

1930

积分

版主

积分
1930
发表于 2025-2-6 15:23:56 | 显示全部楼层
第十六集 串口的简单应用,测试通过
截图202502141134464888.jpg
usart.h 代码

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

bit B_TX2_Busy=0;

u8 Rec_Dat[50];
u8 Rec_Num = 0;

void Uart2_Isr(void) interrupt 8
{
        if (S2CON & 0x02)        //检测串口2发送中断
        {
                S2CON &= ~0x02;
                B_TX2_Busy = 0;        //清除串口2发送中断请求位
        }
        if (S2CON & 0x01)        //检测串口2接收中断
        {
                S2CON &= ~0x01;        //清除串口2接收中断请求位
               
                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;                //8位数据,可变波特率
        AUXR |= 0x04;                //定时器时钟1T模式
        T2L = 0x8F;                        //设置定时初始值
        T2H = 0xFD;                        //设置定时初始值
        AUXR |= 0x10;                //定时器2开始计时
        IE2 |= 0x01;                //使能串口2中断
       
        Rec_Num = 0;
        B_TX2_Busy = 0;
}

void Uart2_SendStr(u8 *puts)   //串口数据发送函数
{
        for(; *puts !=0;  puts++)     //遇到停止符0结束
        {
                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'))
                        {
                         password[0]=16;
             password[1]=16;
             password[2]=16;
             password[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'))
                        {
                         password[0]=17;
             password[1]=17;
             password[2]=17;
             password[3]=17;
                         Uart2_SendStr("关闭成功!\r\n");
                        }
                        Rec_Num = 0;
                }
        }
}
AI8051教学视频 第16集串口的简单应用手敲代码.zip (201.06 KB, 下载次数: 10)






回复 支持 反对

使用道具 举报 送花

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

本版积分规则

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

GMT+8, 2025-6-30 13:36 , Processed in 0.121020 second(s), 63 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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