32位8051 发表于 2024-11-29 17:20:37

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

第3集已学习,已手敲代码,测试通过







#include "ai8051u.h"

void main(void)
{
        P0M0 = 0X00;
        P0M1 =0X00;
       
        P4M0 =0X00;
        P4M1 = 0X00;
               
        while(1)               
        {       
                P20 = 0;
                P00 = 0;
                P01 = 0;
        }
}




32位8051 发表于 2024-11-29 17:23:22

第4集已学习,已手敲代码,测试通过

main.c 代码

#include "ai8051u.h"
#include "stc32_stc8_usb.h"

char *USER_DEVICEDESC = NULL;
char *USER_PRODUCTDESC = NULL;
char *USER_STCISPCMD = "@STCISP#";

void main(void)
{
       P_SW2 |= 0x80;
        P0M1 = 0X00;   P0M0 =0X00;
        P1M1 = 0X00;   P1M0 =0X00;
        P2M1 = 0X00;   P2M0 =0X00;
        P3M1 = 0X00;   P3M0 =0X00;
        P4M1 = 0X00;   P4M0 =0X00;
        P5M1 = 0X00;   P5M0 =0X00;
        P6M1 = 0X00;   P6M0 =0X00;
        P7M1 = 0X00;   P7M0 =0X00;
       
        usb_init();
       
        IE2 |= 0x80;                                 
    EA = 1;
       
        while (DeviceState != DEVSTATE_CONFIGURED);
       
        while(1)               
        {       
                if (bUsbOutReady)
      {
            USB_SendData(UsbOutBuffer,OutNumber);   //发送数据缓冲区,长度(接收数据原样返回, 用于测试)
            
            usb_OUT_done();
      }
               
                P40 = 0;
                P00 = 0;
                P01 = 0;
        }
}

32位8051 发表于 2024-11-29 17:24:27

第5集已学习,已手敲代码,测试通过



main.c 代码


#include "ai8051u.h"
#include "stc32_stc8_usb.h"

#define u8unsigned char
#define u16 unsigned int
       
u8 X = 200;
u8 Y = 0;

char *USER_DEVICEDESC = NULL;
char *USER_PRODUCTDESC = NULL;
char *USER_STCISPCMD = "@STCISP#";

void main(void)
{
       P_SW2 |= 0x80;
        P0M1 = 0X00;   P0M0 =0X00;
        P1M1 = 0X00;   P1M0 =0X00;
        P2M1 = 0X00;   P2M0 =0X00;
        P3M1 = 0X00;   P3M0 =0X00;
        P4M1 = 0X00;   P4M0 =0X00;
        P5M1 = 0X00;   P5M0 =0X00;
        P6M1 = 0X00;   P6M0 =0X00;
        P7M1 = 0X00;   P7M0 =0X00;
       
        usb_init();
       
        IE2 |= 0x80;                                 
    EA = 1;
       
        while (DeviceState != DEVSTATE_CONFIGURED);
       
        while(1)               
        {       
                if (bUsbOutReady)
      {
            //USB_SendData(UsbOutBuffer,OutNumber);   //发送数据缓冲区,长度(接收数据原样返回, 用于测试)
                       if(X<Y)
                       {
                       printf("条件为真\r\n");
                       }
                       else
                       {
                          printf("条件为假\r\n");
                       }
                                  
                       
//            printf("X / Y = %u\r\n",(u16)(X/Y));
//                       
//                          printf("X %% Y = %u\r\n",(u16)(X%Y));
                       
            usb_OUT_done();
      }
               
//                P40 = 0;
//                P00 = 0;
//                P01 = 0;
        }
}






32位8051 发表于 2024-12-4 15:37:22

第6集已学习,已手敲代码,测试通过

main.c 代码


#include "ai8051u.h"
#include "stc32_stc8_usb.h"
#include "intrins.h"

#define u8unsigned char
#define u16 unsigned int
       
u8 state=0;

char *USER_DEVICEDESC = NULL;
char *USER_PRODUCTDESC = NULL;
char *USER_STCISPCMD = "@STCISP#";

void Delay20ms(void)        //@24.000MHz
{
        unsigned long edata i;

        _nop_();
        _nop_();
        i = 119998UL;
        while (i) i--;
}


void main(void)
{
        WTST = 0;//设置程序指令延时参数,赋值为0可将CPU执行指令的速度设置为最快
    EAXFR = 1; //扩展寄存器(XFR)访问使能
    CKCON = 0; //提高访问XRAM速度
       
        P0M1 = 0X00;   P0M0 =0X00;
        P1M1 = 0X00;   P1M0 =0X00;
        P2M1 = 0X00;   P2M0 =0X00;
        P3M1 = 0X00;   P3M0 =0X00;
        P4M1 = 0X00;   P4M0 =0X00;
        P5M1 = 0X00;   P5M0 =0X00;
        P6M1 = 0X00;   P6M0 =0X00;
        P7M1 = 0X00;   P7M0 =0X00;
       
        usb_init();
       
        IE2 |= 0x80;                                 
    EA = 1;
       
        P40 = 0;
       
        while (DeviceState != DEVSTATE_CONFIGURED);
       
        while(1)               
        {       
                if (bUsbOutReady)
                       
      {
            //USB_SendData(UsbOutBuffer,OutNumber);   //发送数据缓冲区,长度(接收数据原样返回, 用于测试)
                       
                                  
                       
//            printf("X / Y = %u\r\n",(u16)(X/Y));
//                       
//                          printf("X %% Y = %u\r\n",(u16)(X%Y));
                       
            usb_OUT_done();
      }
//                if(P32 == 0)
//                {
//                P00 =0;
//                }
//                else
//                {
//                P00 =1;
//                }
//                if(P32 == 0)
//                {
//                P00 =1;
//                }
//                else
//                {
//                P00 =0;
//                }
                if(P32 == 0)
                {
                Delay20ms();
                        if(P32 == 0)
                        {
                           state =!state;       
                           P00 =state;
                           printf("state:%d\r\n",(int)state);       
                               
                           while(P32 == 0);
                  }
                }
               

        }
}



32位8051 发表于 2024-12-4 15:49:05

第7集已学习,已手敲代码,测试通过

任务一:LED灯三秒取反一次,这期间任意时刻按下按钮,串口打印按键次数

任务二:灯按一下,点亮3秒后熄灭


任务三:救护车灯控制器

main.c代码


#include "ai8051u.h"
#include "stc32_stc8_usb.h"
#include "intrins.h"

#define u8unsigned char
#define u16 unsigned int
       
u8 state=0;
u8 Run_State=0;    //运行状态

char *USER_DEVICEDESC = NULL;
char *USER_PRODUCTDESC = NULL;
char *USER_STCISPCMD = "@STCISP#";

void Delay20ms(void)        //@24.000MHz
{
        unsigned long edata i;

        _nop_();
        _nop_();
        i = 119998UL;
        while (i) i--;
}
void Timer0_Init(void);
void main(void)
{
        int count = 1;
        WTST = 0;//设置程序指令延时参数,赋值为0可将CPU执行指令的速度设置为最快
    EAXFR = 1; //扩展寄存器(XFR)访问使能
    CKCON = 0; //提高访问XRAM速度
       
        P0M1 = 0X00;   P0M0 =0X00;
        P1M1 = 0X00;   P1M0 =0X00;
        P2M1 = 0X00;   P2M0 =0X00;
        P3M1 = 0X00;   P3M0 =0X00;
        P4M1 = 0X00;   P4M0 =0X00;
        P5M1 = 0X00;   P5M0 =0X00;
        P6M1 = 0X00;   P6M0 =0X00;
        P7M1 = 0X00;   P7M0 =0X00;
       
        usb_init();
       
        IE2 |= 0x80;   
//        Timer0_Init        ();
    EA = 1;
       
        P40 = 0;
       
        while (DeviceState != DEVSTATE_CONFIGURED);
       
        while(1)               
        {       
                if (bUsbOutReady)
                       
      {
            //USB_SendData(UsbOutBuffer,OutNumber);   //发送数据缓冲区,长度(接收数据原样返回, 用于测试)
                       
                                  
                       
//            printf("X / Y = %u\r\n",(u16)(X/Y));
//                       
//                          printf("X %% Y = %u\r\n",(u16)(X%Y));
                       
            usb_OUT_done();
      }
//任务一:
//                if(P32 == 0)
//                {
//                Delay20ms();
//                        if(P32 == 0)
//                        {
//                           state =!state;       
//                           P00 =state;
//                           printf("按键按下次数\xfd:%d次\r\n",(int)count);       
//                                count++;
//                           while(P32 == 0);
//                  }
//                }
//                任务二:
//                        if(P32 == 0)
//                {
//                Delay20ms();
//                        if(P32 == 0)
//                        {
//                           state =!state;       
//                           P00 =state;
////                           printf("按键按下次数\xfd:%d次\r\n",(int)count);       
////                                count++;
//                                P00 = 0;
//                                Timer0_Init        ();
//                           while(P32 == 0);
//                  }
//                }

//任务三:
                        if(P32 == 0)
                {
                Delay20ms();
                        if(P32 == 0)
                        {
                           state =!state;       
                           P00 =state;
                                Run_State=!Run_State;//运行状态取反
                                if(Run_State==1) //运行
                                {
                                        Timer0_Init        ();
                                }
                                else
                                {
                                TR0 =0;                          //关闭定时器
                                P00 =1;
                                P01 =1;
                                }
//                                P00 = 0;
//                                Timer0_Init        ();
                           while(P32 == 0);
                  }
                }
        }
}

//void Timer0_Init(void)                //3秒@24.000MHz
//{
//        TM0PS = 0x5B;                        //设置定时器时钟预分频 ( 注意:并非所有系列都有此寄存器,详情请查看数据手册 )
//        AUXR &= 0x7F;                        //定时器时钟12T模式
//        TMOD &= 0xF0;                        //设置定时器模式
//        TL0 = 0x3F;                                //设置定时初始值
//        TH0 = 0x01;                                //设置定时初始值
//        TF0 = 0;                                //清除TF0标志
//        TR0 = 1;                                //定时器0开始计时
//        ET0 = 1;                                //使能定时器0中断
//}
//TM0PS = 91
//12T   /12
//ET0-TL0=319

void Timer0_Init(void)                //500毫秒@24.000MHz
{
        TM0PS = 0x0F;                        //设置定时器时钟预分频 ( 注意:并非所有系列都有此寄存器,详情请查看数据手册 )
        AUXR &= 0x7F;                        //定时器时钟12T模式
        TMOD &= 0xF0;                        //设置定时器模式
        TL0 = 0xDC;                                //设置定时初始值
        TH0 = 0x0B;                                //设置定时初始值
        TF0 = 0;                                //清除TF0标志
        TR0 = 1;                                //定时器0开始计时
        ET0 = 1;                                //使能定时器0中断
}


void Timer0_Isr(void) interrupt 1
{
        state =!state;       
       P00 =state;
       P01 =!state;
       
}



32位8051 发表于 2024-12-6 14:53:12

第8集已学习,已手敲代码,测试通过



手敲代码:
io.c

#include "io.h"

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

u16 Key_Vol = 0;

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

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

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

voidKEY_Task(void)
{
      if(P32 == 0)
      {
      Key_Vol ++;
                if(Key_Vol == 5)
                {
                printf("按键单击\r\n");
                }
      }
      else
      {
      Key_Vol = 0;
      }
}














32位8051 发表于 2024-12-14 11:18:00

第9集已学习,已手敲代码,测试通过
任务一:数码管静态显示一个数字



任务二:数码管显示12345678





任务三:显示时钟


任务四:擎天柱,虚拟显示






IO.C 程序

#include "io.h"

u8 SEG_MUM[]=
{
    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_MUM=
{
      0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80
};


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

u16 Key_Vol = 0;

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

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

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

voidKEY_Task(void)
{
//      if(P32 == 0)
//      {
//      Key_Vol ++;
//                if(Key_Vol == 5)
//                {
//                printf("按键单击\r\n");
//                }
//      }
//      else
//      {
//      Key_Vol = 0;
//      }
}
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;
                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;
}

u8 Seg_no = 0;
u8 shi=0;
u8 fen=0;
u8 miao =0;

      void Seg_task(void)
      {
                u8 num = 0;
                if(Seg_no==0)
                {
                num      = shi/10;
                Display_Seg( SEG_MUM , ~T_MUM);   //数码管刷新断码和位码
                }
                else if(Seg_no==1)
                {
                num      = shi%10;
                Display_Seg( SEG_MUM , ~T_MUM);   //数码管刷新断码和位码
                }
                else if(Seg_no==2)
                {
                Display_Seg( SEG_MUM , ~T_MUM);   //数码管刷新断码和位码
                }
               
                else if(Seg_no==3)
                {
                num      = fen/10;
                Display_Seg( SEG_MUM , ~T_MUM);   //数码管刷新断码和位码
                }
                else if(Seg_no==4)
                {
                num      = fen%10;
                Display_Seg( SEG_MUM , ~T_MUM);   //数码管刷新断码和位码
                }
                else if(Seg_no==5)
                {
                Display_Seg( SEG_MUM , ~T_MUM);   //数码管刷新断码和位码
                }
               
                else if(Seg_no==6)
                {
                num      = miao/10;
                Display_Seg( SEG_MUM , ~T_MUM);   //数码管刷新断码和位码
                }
                else if(Seg_no==7)
                {
                num      = miao%10;
                Display_Seg( SEG_MUM , ~T_MUM);   //数码管刷新断码和位码
                }
                else
                {
               
                }
               
                Seg_no ++;
                if(Seg_no>7)
                        Seg_no=0;
}      
      

void TIMECOUNT_task(void)
{
      miao ++;
      if(miao>59)
      {
                miao = 0;
                fen++;
                if(fen>59)
                {
                        fen = 0;
                        shi ++;
                        if(shi>23)
                              shi = 0;
                }
      }
               
}

u8 state_now = 0;

void PLED_40(void)
{
//      u8 cod;
//      cod = 0x0f;   //开启P0-P3
//      cod = 0x01;
//      cod = 0x01;
//      cod = T_MUM;
//      cod = 0x01;
//      LED40_SendData(cod,5);
//      
//      P2 = T_MUM;
//      state_now++;
//      if(state_now>7)
//                state_now=0;
      
//      u8 cod;
//      cod = 0x0f;   //开启P0-P3
//      cod = T_MUM;
//      cod = 0x01;
//      cod = 0x01;
//      cod = 0x01;
//      LED40_SendData(cod,5);
//      
//      P0 = T_MUM;
//      state_now++;
//      if(state_now>7)
//                state_now=0;
      
}

void SEG_PC(void)
{
                u8 cod;
               
                cod= SEG_MUM;
                cod= SEG_MUM;
                cod=SEG_MUM;      //数码管刷新断码和位码
               
                cod= SEG_MUM;
                cod= SEG_MUM;
                cod=SEG_MUM;   //数码管刷新断码和位码

                cod= SEG_MUM;
                cod= SEG_MUM;
      
      SEG7_ShowCode(cod);
}





32位8051 发表于 2024-12-28 11:33:01

第10集已学习,已手敲代码,测试通过
任务1:P2口流水灯,P10闪烁

任务2:左边数码管显示P32按下次数。右边数码管显示P33按下次数

任务3:按下数字按键在数码管显示对应的按键数字!

IO.C 代码

#include "io.h"

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

u16 Key_Vol;
u16 Key_Vol_2;

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

void LED1_Blink(void)
{
State2 = !State2;
      P01 = State2;
}
//printf("按键单击\r\n");
void LED2_Blink(void)
{
State3 = !State3;
      P02 = State3;
}

u16 KEY1_COUNT = 0;//P32按钮计数
u16 KEY2_COUNT = 0;//P33按钮计数

voidKEY_Task(void)
{
      if(P32 == 0)
      {
      Key_Vol ++;
                if(Key_Vol == 5)
                {
                KEY1_COUNT++;
                }
      }
      else
      {
      Key_Vol = 0;
      }
      
                if(P33 == 0)
      {
      Key_Vol_2 ++;
                if(Key_Vol_2 == 5)
                {
                KEY2_COUNT++;
                }
      }
      else
      {
      Key_Vol_2 = 0;
      }
}



u8 P2_STATE = 0X01;

u8 P10_STATE = 0;

//P2口流水灯,P10闪烁
//---------------p2端口流水灯-------------
voidTASK_1(void)
{
      LED40_SetPort(2,~P2_STATE);   //点亮P20端口
      
      P2_STATE =(P2_STATE<<1);
      if(      P2_STATE == 0)
                P2_STATE=1;
      
//---------------p10端口闪烁-------------
      if(P10_STATE == 0)
      LED40_SetBit(1,0);
      else
      LED40_ClrBit(1,0);
      
      P10_STATE =!P10_STATE;
      
}

//---------------任务2:左边数码管显示P32按下次数。右边数码管显示P33按下次数-------------------


u32 KEY_Count = 0;

void TASK_2(void)
{
KEY_Count = KEY1_COUNT *10000 + KEY2_COUNT;
      SEG7_ShowLong(KEY_Count,10);
}


//--------------任务3:按下数字按键在数码管显示对应的按键数字!--------------
u32 REC_NUM =0;
void TASK_3(void)
{
SEG7_ShowLong(REC_NUM,10);
}




32位8051 发表于 2025-1-3 11:04:24

第11集已学习,已手敲代码,测试通过

任务1:数码管显示当前的按键号



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=

{
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(P32==0)
   {
      Key_Vol++;
          if(Key_Vol==5)
               {
                     //按键按下的任务
                     printf("按键单击\r\n");
               }
   }
   else
   {
      Key_Vol=0;
   }
}

//#define ROW1P06
//#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,~T_NUM);   //数码管刷新段码和位码
   else
            Display_Seg(SEG_NUM,~T_NUM);   //数码管刷新段码和位码
}
任务二.输入密码12345670,若最后显示1则密码正确,反之出现横杠则密码错误。



IO.C 代码


#include "io.h"

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

u16 Key_Vol = 0;
u8Seg_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=

{
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(P32==0)
   {
      Key_Vol++;
          if(Key_Vol==5)
               {
                     //按键按下的任务
                     printf("按键单击\r\n");
               }
   }
   else
   {
      Key_Vol=0;
   }
}

//#define ROW1P06
//#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,~T_NUM);   //数码管刷新段码和位码
//   else
//            Display_Seg(SEG_NUM,~T_NUM);   //数码管刷新段码和位码
//}
u8 password={16,16,16,16,16,16,16,16};

void SEG_Task(void)

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

u8Key_Vol3 = 0;
u8Key_no = 0;

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














32位8051 发表于 2025-1-14 14:28:26

第12集已学习,已手敲代码,测试通过
任务一:硬件复位:看门狗复位,按住P33,0.5s以上系统复位


2.定时器程序代码:
#include "config.h"
void Delay10ms(void)      //@24MHz
{
      unsigned long edata i;

      _nop_();
      _nop_();
      _nop_();
      i = 59998UL;
      while (i) i--;
}

void USB_Reset_U(void)
{
      P3M0 = 0x00;
      P3M1 = 0x00;
      
      P3M0 &= ~0x03;
      P3M1 |= 0x03;
      USBCON = 0X00;
      
      USBCLK = 0X00;
      IRC48MCR = 0X00;
      Delay10ms();
      
}
void Sys_init(void)
{

    WTST = 0;//设置程序指令延时参数,赋值为0可将CPU执行指令的速度设置为最快
    EAXFR = 1; //扩展寄存器(XFR)访问使能
    CKCON = 0; //提高访问XRAM速度
      
      P0M1 = 0X00;   P0M0 =0X00;
      P1M1 = 0X00;   P1M0 =0X00;
      P2M1 = 0X00;   P2M0 =0X00;
      P3M1 = 0X00;   P3M0 =0X00;
      P4M1 = 0X00;   P4M0 =0X00;
      P5M1 = 0X00;   P5M0 =0X00;
      P6M1 = 0X00;   P6M0 =0X00;
      P7M1 = 0X00;   P7M0 =0X00;
      
      USB_Reset_U();
}

void Timer0_Init(void)                //1毫秒@24.000MHz
{
      TM0PS = 0x00;                        //设置定时器时钟预分频 ( 注意:并非所有系列都有此寄存器,详情请查看数据手册 )
      AUXR &= 0x7F;                        //定时器时钟12T模式
      TMOD &= 0xF0;                        //设置定时器模式
      TL0 = 0x30;                              //设置定时初始值
      TH0 = 0xF8;                              //设置定时初始值
      TF0 = 0;                              //清除TF0标志
      TR0 = 1;               
      ET0 =1;
      //定时器0开始计时
}


任务二:软件复位:
IAP_CONTR = 0X60复位后进入下载模式 ;
IAP_CONTR = 0X20复位后从头开始运行用户程序 ;
IO.C 代码:
#include "io.h"
u8 State1=0;         //LED1初始状态
u8 State2=0;          //LED2初始状态
u8 State3=0;          //LED3初始状态

u16 Key_Vol = 0;
u8Seg_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=

{
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 ROW1P06
//#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,~T_NUM);   //数码管刷新段码和位码
//   else
//            Display_Seg(SEG_NUM,~T_NUM);   //数码管刷新段码和位码
//}
u8 password={16,16,16,16,16,16,16,16};

void SEG_Task(void)

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

u8Key_Vol3 = 0;
u8Key_no = 0;

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








页: [1] 2
查看完整版本: 《8051U深度入门到32位51大型实战教学视频》学习打卡