RTThread_V4.0+中SignalLed软件包使用方法

12 篇文章 2 订阅
8 篇文章 2 订阅
  • env配置

在bsp的env钟开启SignalLed软件包

RT-Thread online packages
    peripheral libraries and drivers  --->
        [*] SignalLed:a signal led package for rt-thread
  • 本文背景

软件包作者在以下链接中提供了一个例子https://github.com/WKJay/SignalLed#readme,但是在这个例子中作者并没有将信号灯主心跳函数写在线程中或者定时器中。这导致了在测试过程中,如果使用这个例子,就无法在测试后自动退出例程,回到tshell界面。

  • 解决方法

自行编写测试函数,导出到msh命令列表中。下面的例子适用于潘多拉STM32L4 IoT开发板。将该例子放到Keil工程的Application分组中即可。

#include <rtthread.h>
#include <rtdevice.h>
#include <board.h>
#include "drv_gpio.h"
#include "signal_led.h"

/*
 * 程序清单:信号灯线程 signal_led_example.c
 * 
 */
//定义信号灯的硬件引脚
#define LED0_PIN              PIN_LED_R

#include "signal_led.h"
//定义信号灯对象
led led0;

/*  设置信号灯一个周期内的闪烁模式
 *  格式为 “亮、灭、亮、灭、亮、灭 …………” 长度不限
 *  注意:  该配置单位为毫秒,且必须大于 “LED_TICK_TIME” 宏,且为整数倍(不为整数倍则向下取整处理)
 *          必须以英文逗号为间隔,且以英文逗号结尾,字符串内只允许有数字及逗号,不得有其他字符出现
 */
char *led0BlinkMode = "200,200,200,200,200,1000,";

//定义开灯函数
void led0_switch_on(void)
{
    rt_pin_write(LED0_PIN, PIN_LOW);
}
//定义关灯函数
void led0_switch_off(void)
{
    rt_pin_write(LED0_PIN, PIN_HIGH);
}

/* 定时器的控制块 */
static rt_timer_t timer_led;

/* 定时器 timer_led 超时函数 */
static void timeout_led(void *parameter)
{
	//检测还剩的循环次数,当次数减到0时就停止定时器并删除它
	//uint8_t count = led0.loopTemp;
	//if(count == 0) 
	//{
		//rt_timer_stop(timer_led);
		//rt_timer_delete(timer_led);
	//}
    //每隔 LED_TICK_TIME(50) 毫秒循环调用心跳函数
    led_ticks();
}

/* 信号灯示例 */
int signal_led_sample(void)
{
	
	//初始化信号灯对象
    led_init(&led0, LED0_PIN, led0_switch_on, led0_switch_off);
    //设置信号灯工作模式,循环5次
    led_set_mode(&led0, 5, led0BlinkMode);
	
	/* 创建定时器1  周期定时器 */
    timer_led = rt_timer_create("led_timer", timeout_led,
                             RT_NULL, LED_TICK_TIME,
                             RT_TIMER_FLAG_PERIODIC);

    /* 启动定时器1 */
    if (timer_led != RT_NULL) rt_timer_start(timer_led);
	//开启信号灯
    led_start(&led0);
    return 0;
}

/* 导出到 msh 命令列表中 */
MSH_CMD_EXPORT(signal_led_sample, led start sample);

参考资料:

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用 Waitable Timer Objects 实现异步操作的一般步骤如下: 1. 创建一个定时器对象,使用 CreateWaitableTimer() 函数。 2. 使用 SetWaitableTimer() 函数设置定时器的时间间隔。 3. 创建一个事件对象,使用 CreateEvent() 函数。 4. 使用 WaitForMultipleObjects() 函数等待定时器和事件对象。 5. 在等待完成后,处理定时器到期的事件。 下面是一个简单的示例代码,演示如何使用 Waitable Timer Objects 实现异步操作: ```c++ #include <Windows.h> #include <iostream> int main() { // 创建定时器对象 HANDLE hTimer = CreateWaitableTimer(NULL, FALSE, NULL); // 设置定时器的时间间隔为 5 秒 LARGE_INTEGER liDueTime; liDueTime.QuadPart = -50000000LL; // 1 秒 = 10^7 纳秒,因此 5 秒 = 5 * 10^7 纳秒 SetWaitableTimer(hTimer, &liDueTime, 0, NULL, NULL, FALSE); // 创建事件对象 HANDLE hEvent = CreateEvent(NULL, FALSE, FALSE, NULL); // 等待定时器和事件对象 HANDLE waitObjects[2] = { hTimer, hEvent }; DWORD dwWaitResult = WaitForMultipleObjects(2, waitObjects, FALSE, INFINITE); // 处理定时器到期的事件 if (dwWaitResult == WAIT_OBJECT_0) { std::cout << "Timer expired!" << std::endl; } else if (dwWaitResult == WAIT_OBJECT_0 + 1) { std::cout << "Event signalled!" << std::endl; } // 关闭定时器和事件对象 CloseHandle(hEvent); CloseHandle(hTimer); return 0; } ``` 在这个示例,我们创建了一个定时器对象和一个事件对象。我们使用 SetWaitableTimer() 函数设置定时器的时间间隔为 5 秒。然后,我们使用 WaitForMultipleObjects() 函数等待定时器和事件对象。如果定时器到期,我们打印一条消息。如果事件对象被触发,我们也打印一条消息。最后,我们关闭定时器和事件对象。 这个示例只是一个简单的演示。实际上,使用 Waitable Timer Objects 实现异步操作需要更多的细节和考虑。但是,这个示例可以帮助你了解如何开始使用 Waitable Timer Objects。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值