Skip to content
Open
Show file tree
Hide file tree
Changes from 47 commits
Commits
Show all changes
51 commits
Select commit Hold shift + click to select a range
14e46c2
Update .gitignore
srg74 Jun 2, 2025
bf5e5cc
Merge branch 'wled:main' into main
srg74 Jun 6, 2025
f91f5f3
Merge branch 'wled:main' into main
srg74 Jun 7, 2025
4e9978d
Merge branch 'wled:main' into main
srg74 Jun 8, 2025
e88b5fc
Merge branch 'wled:main' into main
srg74 Jun 9, 2025
101cea1
Merge branch 'wled:main' into main
srg74 Jun 13, 2025
359d5f1
Merge branch 'wled:main' into main
srg74 Jun 16, 2025
9236650
Merge branch 'wled:main' into main
srg74 Jun 20, 2025
1bc0fb0
Merge branch 'wled:main' into main
srg74 Jun 20, 2025
12dfa64
Merge branch 'wled:main' into main
srg74 Jun 25, 2025
4d803fc
Merge branch 'wled:main' into main
srg74 Jun 28, 2025
52a1468
Merge branch 'wled:main' into main
srg74 Jul 1, 2025
f242f21
Merge branch 'wled:main' into main
srg74 Jul 4, 2025
ff095c3
Merge branch 'wled:main' into main
srg74 Jul 7, 2025
5dd2332
Merge branch 'wled:main' into main
srg74 Jul 8, 2025
5d7793c
Merge branch 'wled:main' into main
srg74 Jul 9, 2025
6d3da55
Merge branch 'wled:main' into main
srg74 Jul 10, 2025
b0fe8a5
Merge branch 'wled:main' into main
srg74 Jul 12, 2025
9ed02f7
Merge branch 'wled:main' into main
srg74 Jul 25, 2025
9dc4472
Merge branch 'wled:main' into main
srg74 Jul 28, 2025
768d6c0
Merge branch 'wled:main' into main
srg74 Aug 3, 2025
5dd861b
Merge branch 'wled:main' into main
srg74 Aug 8, 2025
6f133f0
Merge branch 'wled:main' into main
srg74 Aug 9, 2025
fcf2797
Merge branch 'wled:main' into main
srg74 Aug 14, 2025
bb47ab7
Merge branch 'wled:main' into main
srg74 Aug 16, 2025
20df3d3
Merge branch 'wled:main' into main
srg74 Aug 21, 2025
35c8b02
Merge branch 'wled:main' into main
srg74 Aug 29, 2025
131728d
Merge branch 'wled:main' into main
srg74 Sep 1, 2025
7c29480
Merge branch 'wled:main' into main
srg74 Sep 1, 2025
4d469f2
Merge branch 'wled:main' into main
srg74 Sep 3, 2025
5266dbe
Merge branch 'wled:main' into main
srg74 Sep 10, 2025
f76422a
Merge branch 'wled:main' into main
srg74 Sep 16, 2025
aeea906
Merge branch 'wled:main' into main
srg74 Sep 17, 2025
c849310
Merge branch 'wled:main' into main
srg74 Sep 22, 2025
27a2f82
Merge branch 'wled:main' into main
srg74 Sep 23, 2025
6f57c60
Merge branch 'wled:main' into main
srg74 Sep 24, 2025
4946882
Merge branch 'wled:main' into main
srg74 Sep 25, 2025
b099eda
Update .gitignore
srg74 Sep 25, 2025
795e84c
Merge branch 'wled:main' into main
srg74 Sep 27, 2025
fff67c0
Merge branch 'wled:main' into main
srg74 Sep 29, 2025
bc939c9
Merge branch 'wled:main' into main
srg74 Oct 3, 2025
adbf826
Merge branch 'wled:main' into main
srg74 Oct 5, 2025
719fe49
Add GC9A01 round TFT display usermod
srg74 Oct 6, 2025
8d5a6cc
Fix palette navigation wraparound in rotary encoder ALT
srg74 Oct 6, 2025
fd0e9df
Address PR feedback: fix documentation and palette handling
srg74 Oct 6, 2025
406d281
Remove Wire library dependency from library.json
srg74 Oct 6, 2025
2d7d57f
Address PR feedback for GC9A01 usermod
srg74 Oct 6, 2025
7170b40
Address PR feedback for GC9A01 usermod
srg74 Oct 7, 2025
cafa73e
Use DEBUG_PRINTF/DEBUG_PRINTLN macros for consistency
srg74 Oct 7, 2025
dbdbcf5
Remove redundant Serial.println calls in rotary encoder usermod
srg74 Oct 7, 2025
c3bc3f0
Add null pointer checks for gc9a01Display->updateRedrawTime() calls
srg74 Oct 7, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 2 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -18,10 +18,11 @@ wled-update.sh
/build_output/
/node_modules/
/logs/

/tools/organize_firmware.py
/wled00/extLibs
/wled00/LittleFS
/wled00/my_config.h
/wled00/Release
/wled00/wled00.ino.cpp
/wled00/html_*.h
WLED.code-workspace
7 changes: 7 additions & 0 deletions usermods/usermod_v2_gc9a01_display/library.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
{
"name": "gc9a01_display",
"build": { "libArchive": false },
"dependencies": {
"bodmer/TFT_eSPI": "^2.5.43"
}
}
125 changes: 125 additions & 0 deletions usermods/usermod_v2_gc9a01_display/logo_data.h

Large diffs are not rendered by default.

115 changes: 115 additions & 0 deletions usermods/usermod_v2_gc9a01_display/readme.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,115 @@
# GC9A01 Display Usermod

A fully-featured WLED usermod providing comprehensive visual interface on GC9A01 240x240 round TFT displays with complete rotary encoder integration.

## Features

### Visual Interface

- **Circular Design**: Optimized for 240x240 round displays with blue bezel theming
- **Real-time Clock**: Large digital clock display (12/24-hour formats)
- **WiFi Signal Strength**: Visual signal strength indicator with 4-level bars (25%, 50%, 75%, 100%)
- **Power Status**: Dynamic "OFF [switch] ON" layout with contextual text
- **Brightness Arc**: Semicircular brightness visualization
- **Color Controls**: Three color buttons (FX, BG, CS) with live color preview and automatic updates
- **Effect Display**: Current effect name
- **Palette Display**: Current palette name
- **Startup Logo**: WLED logo display during initialization

### Modes

- **Sleep Mode**: Automatic display sleep after configurable timeout (5-300 seconds)
- **Clock Mode**: Alternative to sleep - shows clock instead of turning off display
- **Wake on Interaction**: Automatic wake on rotary encoder use or button press
- **Unified Timeout**: Single configurable timeout controls both sleep and clock modes
- **Backlight Control**: PWM-based brightness control (0-100%)

### Performance Features

- **State Caching**: Minimal redraws using comprehensive change detection
- **Smart Updates**: Automatic color button updates when colors change from any source (web UI, API, etc.)
- **Non-blocking Updates**: Asynchronous display updates following Four Line Display ALT pattern
- **Memory Optimized**: Efficient memory usage with proper cleanup
- **Debug Support**: Comprehensive debug logging with WLED macros

## Hardware Requirements

- ESP32 development board
- GC9A01 240x240 TFT display (round)
- Optional: Rotary encoder (usermod_v2_rotary_encoder_ui_ALT)

## Wiring

### GC9A01 Display

| GC9A01 Pin | ESP32 Pin | Function | Description |
|------------|-----------|-------------|-------------|
| VCC | 3.3V | Power | 3.3V power supply |
| GND | GND | Ground | Common ground |
| SCL/SCLK | GPIO18 | SPI Clock | SPI clock signal |
| SDA/MOSI | GPIO23 | SPI MOSI | SPI data out |
| RES/RST | GPIO17 | Reset | Display reset |
| DC | GPIO15 | Data/Command| Data/Command control |
| CS | GPIO5 | Chip Select | SPI chip select |
| BL | GPIO26 | Backlight | Backlight control |

**Note**: Pin assignments can be customized via build flags (see Configuration section).

### Basic Setup

Add to your `platformio_override.ini`:

```ini
[env:esp32_gc9a01]
extends = env:esp32dev
upload_speed = 460800
monitor_speed = 115200
custom_usermods =
usermod_v2_gc9a01_display
usermod_v2_rotary_encoder_ui_ALT
build_flags = ${common.build_flags} ${esp32_idf_V4.build_flags}
-D WLED_DEBUG
-D WLED_DISABLE_BROWNOUT_DET
-D USERMOD_GC9A01_DISPLAY
-DUSER_SETUP_LOADED=1
-DGC9A01_DRIVER=1
-DTFT_WIDTH=240
-DTFT_HEIGHT=240
-DTFT_MOSI=23
-DTFT_SCLK=18
-DTFT_CS=5
-DTFT_DC=15
-DTFT_RST=17
-DTFT_BL=26
-DTOUCH_CS=-1
-DLOAD_GLCD=1
-DLOAD_FONT2=1
-DLOAD_FONT4=1
-DLOAD_FONT6=1
-DLOAD_FONT7=1
-DLOAD_FONT8=1
-DLOAD_GFXFF=1
-DSMOOTH_FONT=1
-DSPI_FREQUENCY=27000000
# Rotary encoder settings
-D ENCODER_DT_PIN=25
-D ENCODER_CLK_PIN=32
-D ENCODER_SW_PIN=27
```

### Debug Information

Enable debug output with `-D WLED_DEBUG` to see detailed logging:

- Display initialization status and TFT_eSPI configuration
- Update timing information and redraw triggers
- State change detection (brightness, effect, colors, etc.)
- Sleep/wake events and timeout tracking
- Error conditions and recovery attempts

Debug output appears in Serial Monitor at 115200 baud.

## Change log

- **v1** (2025-10-06):
- First public release
Loading
Loading