自信地使用我们的白光LED驱动解决方案照亮每一个空间,确保提供生动、节能的照明,让任何环境都更加迷人和提升。
A
A
硬件概览
它是如何工作的?
MCP1664 Click基于四个高功率白光LED。它搭载了Microchip的MCP1664,这是一款高电压升压LED驱动器。MCP1664 Click设计在3.3V或5V电源上运行。它通过mikroBUS™线上的PWM引脚与目标板微控制器通信。点击板具有电源和PWM输入,以便将光强度设置在所需水平。MCP1664是一款紧凑、空间效率高的
固定频率非同步升压转换器,优化用于驱动多串LED,以恒定电流供电,电源可以是两节和三节碱性或NiMH/NiCd电池,也可以是一节Li-Ion或Li-Polymer电池。MCP1664具有开路保护(OLP),当LED串意外断开连接或反馈引脚短路到GND时,会关闭操作。在关机模式(EN = GND)下,该设备停止切换并消耗40
纳安的典型输入电流。这个Click板™可以通过VCC SEL跳线选择使用3.3V或5V的逻辑电压级别,这样,3.3V和5V兼容的MCU都可以正确使用通信线。此外,这个Click板™还配备了一个库,包含易于使用的功能和示例代码,可以用作进一步开发的参考。
功能概述
开发板
Flip&Click PIC32MZ 是一款紧凑型开发板,设计为一套完整的解决方案,它将 Click 板™的灵活性带给您喜爱的微控制器,使其成为实现您想法的完美入门套件。它配备了一款板载 32 位 PIC32MZ 微控制器,Microchip 的 PIC32MZ2048EFH100,四个 mikroBUS™ 插槽用于 Click 板™连接,两个 USB 连接器,LED 指示灯,按钮,调试器/程序员连接器,以及两个与 Arduino-UNO 引脚兼容的头部。得益于创
新的制造技术,它允许您快速构建具有独特功能和特性的小工具。Flip&Click PIC32MZ 开发套件的每个部分都包含了使同一板块运行最高效的必要组件。此外,还可以选择 Flip&Click PIC32MZ 的编程方式,使用 chipKIT 引导程序(Arduino 风格的开发环境)或我们的 USB HID 引导程序,使用 mikroC、mikroBasic 和 mikroPascal for PIC32。该套件包括一个通过 USB 类型-C(USB-C)连接器的干净且调
节过的电源供应模块。所有 mikroBUS™ 本身支持的 通信方法都在这块板上,包括已经建立良好的 mikroBUS™ 插槽、用户可配置的按钮和 LED 指示灯。Flip&Click PIC32MZ 开发套件允许您在几分钟内创建新的应用程序。它由 Mikroe 软件工具原生支持,得益于大量不同的 Click 板™(超过一千块板),其数量每天都在增长,它涵盖了原型制作的许多方面。
微控制器概述
MCU卡片 / MCU

建筑
PIC32
MCU 内存 (KB)
2048
硅供应商
Microchip
引脚数
100
RAM (字节)
524288
使用的MCU引脚
mikroBUS™映射器
“仔细看看!”
Click board™ 原理图

一步一步来
项目组装
软件支持
库描述
这个库包含了MCP1664 Click驱动程序的API。
关键功能:
mcp1664_pwm_start- 启动PWM模块mcp1664_pwm_stop- 停止PWM模块
开源
代码示例
完整的应用程序代码和一个现成的项目可以通过NECTO Studio包管理器直接安装到NECTO Studio。 应用程序代码也可以在MIKROE的GitHub账户中找到。
/*!
* \file
* \brief Mcp1664 Click example
*
* # Description
* This application turn on and turn off white LEDs.
*
* The demo application is composed of two sections :
*
* ## Application Init
* Enables GPIO and PWM, sets the frequency and duty cycle and enables PWM.
*
* ## Application Task
* This is a example which demonstrates the use of MCP1664 Click board.
* It shows how to enable the device and gradualy increase the duty cycle.
*
* \author MikroE Team
*
*/
// ------------------------------------------------------------------- INCLUDES
#include "board.h"
#include "log.h"
#include "mcp1664.h"
// ------------------------------------------------------------------ VARIABLES
static mcp1664_t mcp1664;
static log_t logger;
static float duty_cycle = 0.5;
// ------------------------------------------------------ APPLICATION FUNCTIONS
void application_init ( void )
{
log_cfg_t log_cfg;
mcp1664_cfg_t cfg;
/**
* Logger initialization.
* Default baud rate: 115200
* Default log level: LOG_LEVEL_DEBUG
* @note If USB_UART_RX and USB_UART_TX
* are defined as HAL_PIN_NC, you will
* need to define them manually for log to work.
* See @b LOG_MAP_USB_UART macro definition for detailed explanation.
*/
LOG_MAP_USB_UART( log_cfg );
log_init( &logger, &log_cfg );
log_info( &logger, "---- Application Init ----" );
// Click initialization.
mcp1664_cfg_setup( &cfg );
MCP1664_MAP_MIKROBUS( cfg, MIKROBUS_1 );
mcp1664_init( &mcp1664, &cfg );
mcp1664_set_duty_cycle( &mcp1664, duty_cycle );
mcp1664_pwm_start( &mcp1664 );
Delay_ms ( 1000 );
log_printf( &logger, "------------------ \r\n" );
log_printf( &logger, " MCP1664 Click \r\n" );
log_printf( &logger, "------------------ \r\n" );
Delay_ms ( 100 );
}
void application_task ( void )
{
// Task implementation.
if ( duty_cycle > 1 )
{
duty_cycle = 0.1;
}
mcp1664_set_duty_cycle ( &mcp1664, duty_cycle );
duty_cycle += 0.1;
Delay_100ms();
log_printf( &logger, " Duty cycle is : %d \r\n", duty_cycle );
}
int main ( void )
{
/* Do not remove this line or clock might not be set correctly. */
#ifdef PREINIT_SUPPORTED
preinit();
#endif
application_init( );
for ( ; ; )
{
application_task( );
}
return 0;
}
// ------------------------------------------------------------------------ END
额外支持
资源
类别:LED 驱动器
































