#if 1 #include "board.h" #include "nrf_delay.h" #include "project_cfg.h" #include "sys.h" #include "version.h" #include "zble_module.h" #include "zdatachannel_service.h" #if 0 void qingfengboard_test(void) { // 测试LED debug_light_init(15); // 测试BUTTON // static uint8_t io_index[] = {ZPIN(0, 5), ZPIN(1, 9)}; // zbsp_gpio_state_monitor(1000, (uint8_t*)io_index, ZARRAY_SIZE(io_index)); // 测试睡眠唤醒 zbsp_enter_sleep(3000, 5, true); } #endif ZDATACANNEL_DEF(m_zhrs, 2 /*回调事件优先级*/, 1 /*client num*/); static const char* hex2str(const uint8_t* data, int32_t len) { static char rx[64] = {0}; memset(rx, 0, sizeof(rx)); for (int32_t i = 0; i < len; i++) { sprintf(rx + i * 2, "%02X", data[i]); } return rx; } void zdatachannel_data_handler(zdatachannel_evt_t* p_evt) { /** * @brief 接收到指令数据 */ if (p_evt->type == ZDATACANNEL_EVT_RX_DATA) { ZLOGI("rx:%s", hex2str(p_evt->params.rx_data.p_data, p_evt->params.rx_data.length)); } } void on_service_init(void) { /** * @brief 数据通道初始化 */ ZLOGI("init zdatachannel service"); zdatachannel_init_t zdatachannle_init; memset(&zdatachannle_init, 0, sizeof(zdatachannle_init)); zdatachannle_init.data_handler = zdatachannel_data_handler; ZERROR_CHECK(zdatachannel_init(&m_zhrs, &zdatachannle_init)); } int main(void) { zsys_init(); NRF_LOG_INFO("compile time :%s", __TIME__); NRF_LOG_INFO("Version :%d", VERSION); NRF_LOG_INFO("Manufacturer :%s", MANUFACTURER_NAME); static zble_module_cfg_t cfg = // { .deviceName = "iflytop", .on_service_init = on_service_init, }; zble_module_init(&cfg); zble_module_start_adv(); zsys_loop(); } #endif