RBG渐变圆形读条

RBG渐变圆形读条

教程地址原文地址(YouTube)

B站教程原文转载(bilibili)

两个视频的内容相同,第二个为转载

效果图

在这里插入图片描述

代码区

html

<div class="outer">	</div>
<div class="inner">
  <span>0%</span>
</div>

CSS

html, body {
  display: flex; /* 弹性盒模型 */
  align-items: center; /* 交叉轴对齐方式 */
  justify-content: center; /* 主轴对齐方式 */
  height: 100vh; /* 高度 */
  font-family: sans-serif; /* 字体 */
  background: #240f52; /* 背景颜色 */
  overflow: hidden; /* 超出隐藏 */
}

.outer {
  height: 300px; /* 高度 */
  width: 300px; /* 宽度 */
  background: linear-gradient(135deg,#FEED07 0%,#FE6A50 5%,#ED00AA 15%,#2FE3FE 50%,#8900FF 100%); /* 背景-渐变 */
  border-radius: 50%; /* 边框圆角 */
}

.inner {
  position: absolute; /* 绝对定位 */
  width: 275px;
  height: 275px;
  text-align: center; /* 字体居中 */
  line-height: 275px; /* 行高 */
  background: #240f52;
  border-radius: 50%;
  cursor: default; /* 光标默认样式 */
}

.inner span {
  font-size: 60px; /* 字体大小 */
  font-weight: 800; /* 字体维度 */
  background: linear-gradient(135deg,#FEED07 0%,#FE6A50 5%,#ED00AA 15%,#2FE3FE 50%,#8900FF 100%);
  color: transparent; /* 透明 */
  -webkit-background-clip: text; /* 背景按照文字裁剪 */
  background-size: 300%; /* 背景大小 */
  user-select: none; /* 用户无法选中 */
}
/* 默认添加的旋转0-100% */
.outer.active-loader {
  animation: rotate 2s ease infinite; /* 动画名称,动画时间,播放速率,重复播放 */
}

@keyframes rotate {
  to {
    transform: rotate(360deg); /* 通过修改旋转实现 */
  }
}
/* 100之后的一次动画 */
.outer.active-loader-2 {
  animation: rotate2 3s ease;
}

@keyframes rotate2 {
  to {
    transform: rotate(360deg);
  }
}

JS

// 获取3个元素
let outer = document.querySelector('.outer')
let inner = document.querySelector('.inner')
let percent = document.querySelector('span')
let count = 0;
// 添加点击事件
inner.addEventListener('click', function() {
  // 添加调用的周期间隔(func, time)
  let loading = setInterval(animate, 200);
  function animate() {
    if(count == 100) {
      // 清除(停止)周期间隔
      clearInterval()
      // 删除、添加类
      outer.classList.remove('active-loader')
      outer.classList.add('active-loader-2')
    }else {
      count = count + 1;
      // 文字更改显示
      percent.textContent = count + '%'
      outer.classList.add('active-loader')
    }
  }
})

教程地址原文地址(YouTube)

B站教程原文转载(bilibili)

### 使用 ESP32 控制 S3 RGB #### 示例代码 以下是基于 MicroPython 的示例代码,用于通过 ESP32-S3 控制 WS2812 类型的 RGB: ```python from machine import Pin from neopixel import NeoPixel import time # 定义参数 pin = 27 # 连接到 GPIO27 num_pixels = 5 # 灯上的像素数量 # 初始化 Neopixel 对象 np = NeoPixel(Pin(pin, Pin.OUT), num_pixels) def set_color(r, g, b): """设置整个灯的颜色""" for i in range(num_pixels): np[i] = (r, g, b) np.write() if __name__ == "__main__": try: while True: r = int(input("请输入红色亮度值 R(0-255): ")) g = int(input("请输入绿色亮度值 G(0-255): ")) b = int(input("请输入蓝色亮度值 B(0-255): ")) set_color(r, g, b) time.sleep_ms(10) except KeyboardInterrupt: pass ``` 上述代码实现了用户输入指定颜色值的功能,并将其应用到连接在 GPIO27 上的 WS2812 灯上[^3]。 --- #### 教程说明 为了更好地理解如何使用 ESP32 控制 RGB,可以按照以下方式操作: 1. **硬件准备** - 准备一块支持 ESP32-S3 的开发板。 - 购买一 WS2812 或兼容类型的 RGB。 - 将灯的数据线连接至 ESP32-S3 的某个 GPIO 引脚(如 GPIO27),并确保电源供电充足[^1]。 2. **软件环境配置** - 下载并安装最新版本的 MicroPython 固件到 ESP32-S3 开发板。 - 配置好串口通信工具以便上传代码和调试。 3. **运行效果** - 当执行以上代码时,可以通过终端依次输入红、绿、蓝三种颜色分量的数值来改变灯的整体颜色。 4. **高级功能扩展** 如果希望实现更复杂的灯光效果(如呼吸灯、渐变等),可参考 ws2812_control 组件中的预设函数[^2]。例如,在 IDF 框架下可以直接调用这些内置方法来自定义动态显示模式。 --- #### 注意事项 - 确保所选 GPIO 引脚能够驱动 WS2812 器件;某些特殊引脚可能不适用于此用途。 - 提供足够的电流给外部电路以防止电压降影响正常工作状态。 - 测试前建议先验证单颗 LED 是否能被成功点亮再逐步增加负载数目。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值