ws2812b效果研究之八 pride2015

2024-08-31 21:36

本文主要是介绍ws2812b效果研究之八 pride2015,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这个代码实现了一个名为"Pride2015"的LED动画效果,主要是通过FastLED库生成不断变化的彩虹效果

/// @file    Pride2015.ino
/// @brief   Animated, ever-changing rainbows.
/// @example Pride2015.ino#include "FastLED.h"// Pride2015
// Animated, ever-changing rainbows.
// by Mark Kriegsman#if FASTLED_VERSION < 3001000
#error "Requires FastLED 3.1 or later; check github for latest code."
#endif#define DATA_PIN    2
//#define CLK_PIN   4
#define LED_TYPE    WS2812B
#define COLOR_ORDER GRB
#define NUM_LEDS    100
#define BRIGHTNESS  255CRGB leds[NUM_LEDS];void setup() {delay(3000); // 3 second delay for recovery// tell FastLED about the LED strip configurationFastLED.addLeds<LED_TYPE,DATA_PIN,COLOR_ORDER>(leds, NUM_LEDS).setCorrection(TypicalLEDStrip).setDither(BRIGHTNESS < 255);// set master brightness controlFastLED.setBrightness(BRIGHTNESS);
}void loop()
{pride();FastLED.show();  
}// This function draws rainbows with an ever-changing,
// widely-varying set of parameters.
void pride() 
{static uint16_t sPseudotime = 0;static uint16_t sLastMillis = 0;static uint16_t sHue16 = 0;uint8_t sat8 = beatsin88( 87, 220, 250);uint8_t brightdepth = beatsin88( 341, 96, 224);uint16_t brightnessthetainc16 = beatsin88( 203, (25 * 256), (40 * 256));uint8_t msmultiplier = beatsin88(147, 23, 60);uint16_t hue16 = sHue16;//gHue * 256;uint16_t hueinc16 = beatsin88(113, 1, 3000);uint16_t ms = millis();uint16_t deltams = ms - sLastMillis ;sLastMillis  = ms;sPseudotime += deltams * msmultiplier;sHue16 += deltams * beatsin88( 400, 5,9);uint16_t brightnesstheta16 = sPseudotime;for( uint16_t i = 0 ; i < NUM_LEDS; i++) {hue16 += hueinc16;uint8_t hue8 = hue16 / 256;brightnesstheta16  += brightnessthetainc16;uint16_t b16 = sin16( brightnesstheta16  ) + 32768;uint16_t bri16 = (uint32_t)((uint32_t)b16 * (uint32_t)b16) / 65536;uint8_t bri8 = (uint32_t)(((uint32_t)bri16) * brightdepth) / 65536;bri8 += (255 - brightdepth);CRGB newcolor = CHSV( hue8, sat8, bri8);uint16_t pixelnumber = i;pixelnumber = (NUM_LEDS-1) - pixelnumber;nblend( leds[pixelnumber], newcolor, 64);}
}

动画逻辑分析

状态变量的初始化和更新

sPseudotime、sLastMillis、sHue16是静态变量,用于存储动画状态,使得每次调用pride函数时,这些变量的值能够保留和更新。
ms = millis():获取当前时间(毫秒)。
deltams = ms - sLastMillis:计算自上次更新以来的时间差。
sPseudotime、sHue16根据时间差deltams进行更新,控制颜色和亮度的变化。

颜色和亮度的动态生成

sat8:饱和度,通过beatsin88函数进行动态调整,使彩虹色饱和度在220到250之间变化。
brightdepth:亮度深度,同样通过beatsin88函数,使亮度深度在96到224之间变化。
brightnessthetainc16:亮度角度增量,用于控制亮度的渐变速度。
hueinc16:颜色渐变的速度,通过beatsin88函数控制,使颜色变化更加丰富。
hue8:将hue16缩小至8位(0-255),用于生成HSV颜色。
像素亮度计算

通过sin16计算brightnesstheta16的正弦值b16,然后计算亮度bri16和bri8,以生成渐变的亮度效果。
newcolor = CHSV(hue8, sat8, bri8):使用HSV颜色模型生成新颜色newcolor。

颜色混合与应用

使用nblend函数将生成的颜色与当前LED颜色进行混合,使得颜色变化更加平滑。
pixelnumber = (NUM_LEDS - 1) - pixelnumber;:这个语句反转了LED的索引,使得彩虹效果从LED阵列的另一端开始。

总结

这个代码生成了一个动态、渐变的彩虹动画效果。通过使用FastLED库的高级功能,如beatsin88、sin16、nblend等函数,代码能够创造出复杂、多变的色彩效果。整体效果是一个不断变化的彩虹,具有丰富的色彩渐变和亮度变化,非常适合用于LED装置中的视觉效果展示。

这篇关于ws2812b效果研究之八 pride2015的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1125058

相关文章

Kotlin Compose Button 实现长按监听并实现动画效果(完整代码)

《KotlinComposeButton实现长按监听并实现动画效果(完整代码)》想要实现长按按钮开始录音,松开发送的功能,因此为了实现这些功能就需要自己写一个Button来解决问题,下面小编给大... 目录Button 实现原理1. Surface 的作用(关键)2. InteractionSource3.

使用WPF实现窗口抖动动画效果

《使用WPF实现窗口抖动动画效果》在用户界面设计中,适当的动画反馈可以提升用户体验,尤其是在错误提示、操作失败等场景下,窗口抖动作为一种常见且直观的视觉反馈方式,常用于提醒用户注意当前状态,本文将详细... 目录前言实现思路概述核心代码实现1、 获取目标窗口2、初始化基础位置值3、创建抖动动画4、动画完成后

uniapp小程序中实现无缝衔接滚动效果代码示例

《uniapp小程序中实现无缝衔接滚动效果代码示例》:本文主要介绍uniapp小程序中实现无缝衔接滚动效果的相关资料,该方法可以实现滚动内容中字的不同的颜色更改,并且可以根据需要进行艺术化更改和自... 组件滚动通知只能实现简单的滚动效果,不能实现滚动内容中的字进行不同颜色的更改,下面实现一个无缝衔接的滚动

Java实现图片淡入淡出效果

《Java实现图片淡入淡出效果》在现代图形用户界面和游戏开发中,**图片淡入淡出(FadeIn/Out)**是一种常见且实用的视觉过渡效果,它可以用于启动画面、场景切换、轮播图、提示框弹出等场景,通过... 目录1. 项目背景详细介绍2. 项目需求详细介绍2.1 功能需求2.2 非功能需求3. 相关技术详细

使用animation.css库快速实现CSS3旋转动画效果

《使用animation.css库快速实现CSS3旋转动画效果》随着Web技术的不断发展,动画效果已经成为了网页设计中不可或缺的一部分,本文将深入探讨animation.css的工作原理,如何使用以及... 目录1. css3动画技术简介2. animation.css库介绍2.1 animation.cs

Flutter实现文字镂空效果的详细步骤

《Flutter实现文字镂空效果的详细步骤》:本文主要介绍如何使用Flutter实现文字镂空效果,包括创建基础应用结构、实现自定义绘制器、构建UI界面以及实现颜色选择按钮等步骤,并详细解析了混合模... 目录引言实现原理开始实现步骤1:创建基础应用结构步骤2:创建主屏幕步骤3:实现自定义绘制器步骤4:构建U

Vue项目的甘特图组件之dhtmlx-gantt使用教程和实现效果展示(推荐)

《Vue项目的甘特图组件之dhtmlx-gantt使用教程和实现效果展示(推荐)》文章介绍了如何使用dhtmlx-gantt组件来实现公司的甘特图需求,并提供了一个简单的Vue组件示例,文章还分享了一... 目录一、首先 npm 安装插件二、创建一个vue组件三、业务页面内 引用自定义组件:四、dhtmlx

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

前端原生js实现拖拽排课效果实例

《前端原生js实现拖拽排课效果实例》:本文主要介绍如何实现一个简单的课程表拖拽功能,通过HTML、CSS和JavaScript的配合,我们实现了课程项的拖拽、放置和显示功能,文中通过实例代码介绍的... 目录1. 效果展示2. 效果分析2.1 关键点2.2 实现方法3. 代码实现3.1 html部分3.2

关于Java内存访问重排序的研究

《关于Java内存访问重排序的研究》文章主要介绍了重排序现象及其在多线程编程中的影响,包括内存可见性问题和Java内存模型中对重排序的规则... 目录什么是重排序重排序图解重排序实验as-if-serial语义内存访问重排序与内存可见性内存访问重排序与Java内存模型重排序示意表内存屏障内存屏障示意表Int