关于51单片机LED灯的程序

51单片机关于LED灯的程序

首先是延时函数。

//========================================================================
// 函数: void SoftWare_Dealy_MS(uint16_t X_ms)
// 描述: 毫秒延时函数
// 参数: X_ms:要延时的X_ms毫秒数, 这里只支持1~65535ms. 自动适应主时钟
// 返回: none.
// 版本: VER1.0
// 日期: 2021-2-15
// 备注:
//========================================================================
void SoftWare_Dealy_MS(uint16_t X_ms)
{
    uint16_t i;
    do
    {
        i = MAIN_Fosc / 13000;
        while (--i)
            ;
    } while (--X_ms);
}

#if (MAIN_Fosc == 11059200UL)//时钟频率
//========================================================================
// 函数: void SoftWare_Dealy_US(uint16_t X_us)
// 描述: 微秒延时函数
// 参数: X_us,要延时的X_us数, 这里只支持1~65535us.
//当x=1延时4.64μs、x=2延时6.56μS、x=3延时8.48μS、x=4延时10.4μS,由此可见x=1之后每增加1则延时1.92μs
// 返回: none.
// 版本: VER1.0
// 日期: 2021-2-15
// 备注:
//========================================================================
void SoftWare_Dealy_US(uint16_t X_us)
{
    while (X_us-- != 0)
    {
        _nop_();
        _nop_();
        _nop_();
    }
}


#endif

闪烁灯函数。

void USER_Flash_Led(void)
{
    P0 = 0x00;              //P0端口所有LED灯点亮
    SoftWare_Dealy_MS(500); //延时500毫秒   商业用途不宜长软件延时
    P0 = 0XFF;              //P0端口所有LED灯熄灭
    SoftWare_Dealy_MS(500); //延时500毫秒   商业用途不宜长软件延时
}

跑马灯函数。

void USER_Running_Horse_Led(void)
{
    static uint8_t xdata i = 0XFE; //定义局部静态变量i的值为0XFE
	
    P0 = i;                        //根据变量i的值点亮P0口相应的LED灯
    i = _crol_(i, 1);              //变量i的值循环左移动一位

    //	i = _cror_(i,1);  			//变量i的值循环右移动一位

    SoftWare_Dealy_MS(500); //延时500毫秒   商业用途不宜长软件延时
}

流水灯函数。

void USER_Flowing_Water_Led(void)
{
    uint8_t xdata i = 0;    //定义局部静态变量并赋值为0
    P0 = 0XFF;              //P0赋值0XFF,即P0端口所连接的LED灯全灭!!
    SoftWare_Dealy_MS(500); //延时500毫秒   商业用途不宜长软件延时
    for (i = 0; i < 8; i++) //for循环执行8次{}内部程序
    {
        P0 = P0 << 1; //先将特殊寄存器P0数据左移动一位再重新赋值给P0
        //P0 <<= 1;                       //此写法为上一行简写,功能一样

        //P0 = P0 >> 1; //先将特殊寄存器P0数据右移动一位再重新赋值给P0

        //P0 >>= 1; //此写法为上一行简写,功能一样

        SoftWare_Dealy_MS(500); //延时500毫秒   商业用途不宜长软件延时
    }
}

花样流水灯函数。

void USER_Variety_Flowing_Water_Led(void)
{
    static uint8_t xdata i = 0; //定义局部静态变量i并赋值为0
    static uint8_t xdata LED_HuaYang[] = {0xfe, 0xfd, 0xfb, 0xf7, 0xef, 0xdf, 0xbf, 0x7f,
                                          0xfe, 0xfd, 0xfb, 0xf7, 0xef, 0xdf, 0xbf, 0x7f,
                                          0x7f, 0xbf, 0xdf, 0xef, 0xf7, 0xfb, 0xfd, 0xfe,
                                          0x7f, 0xbf, 0xdf, 0xef, 0xf7, 0xfb, 0xfd, 0xfe,
                                          0x00, 0xff, 0x00, 0xff, 0x01}; //定义局部静态数组LED_HuaYang并赋值

    if (LED_HuaYang[i] != 0x01) //判断LED花样值是否不等于0x01
    {
        P1 = LED_HuaYang[i];    //根据读取回来的花样值点亮P1口相应的LED灯
        SoftWare_Dealy_MS(500); //延时500毫秒   商业用途不宜长软件延时
        i++;                    //变量i进行自增1
    }
    else
    {
        i = 0; //变量i赋值为0
    }
}

呼吸灯函数。

void USER_Breating_Led(void)
{
    static uint16_t xdata Cycle = 1500; //定义局部静态变量Cycle并赋值为1500
    static uint16_t xdata PWM_Low = 0;  //定义局部静态变量PWM_Low并赋值为0

    P0 = 0XFF;                                    //熄灭P0口LED
    SoftWare_Dealy_MS(500);                       //延时500ms  商业用途不宜长软件延时
    for (PWM_Low = 1; PWM_Low < Cycle; PWM_Low++) //从熄灭到逐渐变亮直至最亮
    {
        P0 = 0X00;                          //点亮P0口对应的LED
        SoftWare_Dealy_US(PWM_Low);         //延时PWM_Low微秒   商业用途不宜长软件延时
        P0 = 0XFF;                          //熄灭P0口对应的LED
        SoftWare_Dealy_US(Cycle - PWM_Low); //延时(Cycle - PWM_Low)微秒   商业用途不宜长软件延时
    }
    for (PWM_Low = Cycle - 1; PWM_Low > 0; PWM_Low--) //从最亮逐渐变暗直至熄灭
    {
        P0 = 0X00;                          //点亮P0口对应的LED
        SoftWare_Dealy_US(PWM_Low);         //延时PWM_Low微秒   商业用途不宜长软件延时
        P0 = 0XFF;                          //熄灭P0口对应的LED
        SoftWare_Dealy_US(Cycle - PWM_Low); //延时(Cycle - PWM_Low)微秒   商业用途不宜长软件延时
    }
}
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值