用擎天柱配合冲哥视频学习8051U学习打卡
感谢赵经理送的擎天柱,自带流水灯程序,先来张美照。通过擎天柱配全冲哥视频学习8051U打卡第一天。视频第一二集基本介绍,环境已搭建好。
学习第二天,点亮第一颗LED。刷入
演示程序,使用USB连接,用ISP6.95E刷机,先按P31按键,再按POWER按键松开,再松开P31,系统识别,
。
打开程序文件,选择
烧录,查看效果。
P20、P21对应两个灯亮。感觉还是自带的流水灯效果好看。
学习打卡第三天,冲哥的视频真的是有手就行,讲解详细,连文件的多选都手把手教。今天学习USB不停电下载,这个功能非常好用,解放了双手,总结就是尽量用CDC,并且用查询模式可以让程序更稳定。现在官网上的库文件下载后包含了库文件和范例程序,范例程序里的文件和视频中的有调整,要把对应32位的.LIB和.h都复制到程序目录下。
紫色的真棒,注册送的? millxhcx 发表于 2025-1-22 13:03
紫色的真棒,注册送的?
是的呢 vzvutian 发表于 2025-1-22 15:12
是的呢
羡慕 学习打卡第四天,今天学习第5集C语言。之前也学过一些,所以感觉还是很好理解的,冲哥又帮我把常用的又复习了一遍{:4_174:}。第一个知识点是printf()这个函数,在调试时方便通过串口助手实时查看变量的变化,及时发现错误修改。用法是在stc32_stc8_usb.h中把//#define PRINTF_HID这句话前面的//去掉,在程序中就可以调用了。通过USB比以前串口输出简单了很多。第二个知识点是算术运算符和逻辑运算符,算术好理解,逻辑运算要仔细理解才行。 学习打卡第5天,今天学习第六集I/O输入输出。知识点是I/O有4种模式,一般用准双向口模式,工作模式在主函数一开始进行设置,PnM1=0;PnM0=0。小电流用准双向口模式,大电流必须用推挽模式,电流从引脚向外输出PnM1=0X01;PnM0=0X01。课后作业1、按一下P32按钮灯亮,按一下P33按钮灯灭。
if( P32 == 0 ) //判断P32按钮是否按下
{
Delay20ms(); //延时20ms消抖
if( P32 == 0 )
{
P20 = 0;
while( P32 == 0 ); //等待P32松开
}
}
if( P33 == 0 ) //判断P33按钮是否按下
{
Delay20ms(); //延时20ms消抖
if( P33 == 0 )
{
P20 = 1;
while( P33 == 0 ); //等待P33松开
}
}
作业2、按一下亮一颗灯,再按一下亮两颗灯,直到全亮(变量+加法和乘法)
先定义变量u8 state = 0xFF;循环里
if( P32 == 0 ) //判断P32按钮是否按下
{
Delay20ms(); //延时20ms消抖
if( P32 == 0 )
{
state<<=1;
P2 =state;
if(state==0x00)
state=0XFF;
while( P32 == 0 ); //等待P32松开
}
}
不知道这样是不是达到要求了。完成交作业 学习打卡第6天,今天学习定时器中断,直接上作业。
#include "ai8051u.h" //调用头文件
#include "stc32_stc8_usb.h" //调用头文件
#include "intrins.h" //d调用头文件
//注意:擎天柱的LED端口在P2,且没有三极管的电源控制,所以只要控制P2端口即可,按键通用,本节课程的其余内容均通用!
#define u8unsigned char //8位无符号变量(0-255)
#define u16 unsigned int //16位无符号变量(0-65535)
u8 state = 0; //初始状态
u8 Run_State = 0; //运行状态
u8 gongde=0; //功德
u8 tt=0; //判断运行是否到规定时间
char *USER_DEVICEDESC = NULL;
char *USER_PRODUCTDESC = NULL;
char *USER_STCISPCMD = "@STCISP#";
void Delay20ms(void) //@24.000MHzDelay20ms();
{
unsigned long edata i;
_nop_();
_nop_();
i = 119998UL;
while (i) i--;
}
void Timer0_2SInit(void) //2秒@12.000MHz
{
TM0PS = 0x1E; //设置定时器时钟预分频 ( 注意:并非所有系列都有此寄存器,详情请查看数据手册 )
AUXR &= 0x7F; //定时器时钟12T模式
TMOD &= 0xF0; //设置定时器模式
TL0 = 0xFC; //设置定时初始值
TH0 = 0x03; //设置定时初始值
TF0 = 0; //清除TF0标志
TR0 = 1; //定时器0开始计时
ET0 = 1; //使能定时器0中断
}
void Timer0_1SInit(void) //1秒@12.000MHz
{
TM0PS = 0x0F; //设置定时器时钟预分频 ( 注意:并非所有系列都有此寄存器,详情请查看数据手册 )
AUXR &= 0x7F; //定时器时钟12T模式
TMOD &= 0xF0; //设置定时器模式
TL0 = 0xDC; //设置定时初始值
TH0 = 0x0B; //设置定时初始值
TF0 = 0; //清除TF0标志
TR0 = 1; //定时器0开始计时
ET0 = 1; //使能定时器0中断
}
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(); //USB CDC 接口配置
IE2 |= 0x80; //使能USB中断
EA = 1; //IE |= 0X80;
P40 = 0;
while (DeviceState != DEVSTATE_CONFIGURED); //等待USB完成配置
while(1)
{
if (bUsbOutReady) //如果接收到了数据
{
//USB_SendData(UsbOutBuffer,OutNumber); //发送数据缓冲区,长度(接收数据原样返回, 用于测试)
usb_OUT_done(); //
}
if( P32 == 0 ) //判断P32按钮1是否按下
{
Delay20ms(); //延时20ms消抖
if( P32 == 0)
{
Run_State = !Run_State; //运行状态取反
if( Run_State==1 ) //运行
{printf("双倍功德时间\r\n");
}
else
{
printf("单倍功德时间\r\n");
}
while( P32 == 0 ); //等待P32松开
}
}
if( P33 == 0 ) //判断P33按钮2是否按下
{
Delay20ms(); //延时20ms消抖
if( P33== 0&& tt==0)
{
if( Run_State==1 ) //运行
{
gongde+=2;
printf("功德+2 当前功德:%d\r\n",(int)gongde);
P20 = 0;
Timer0_2SInit();
tt=1;
}
else
{
gongde+=1;
printf("功德+1 当前功德:%d\r\n",(int)gongde);
P20 = 0;
Timer0_1SInit();
tt=1;
}
while( P33 == 0 ); //等待P33松开
}
}
}
}
void Timer0_Isr(void) interrupt 1 //3秒执行一次
{
P20 = 1;
TR0 = 0; //定时器0关闭
tt=0;
}
TT的作用是防止时间没有到1秒或2秒时再次按下P33重新计时,导致亮灯时间不对。欢迎大家指正!{:4_166:} 很认真 加油!
页:
[1]
2