pimoroni-pico/libraries/generic_st7789
Phil Howard 9b8d215cd3 ST7789/PicoGraphics: Update C++ libs and examples. 2022-06-13 20:11:09 +01:00
..
CMakeLists.txt ST7789: Create generic display driver for #299 2022-03-21 17:02:46 +00:00
README.md ST7789/PicoGraphics: Update C++ libs and examples. 2022-06-13 20:11:09 +01:00
generic_st7789.cmake ST7789/PicoGraphics: Refactor for init & rotation. 2022-06-13 20:11:09 +01:00
generic_st7789.cpp ST7789/PicoGraphics: Refactor for init & rotation. 2022-06-13 20:11:09 +01:00
generic_st7789.hpp ST7789/PicoGraphics: Refactor for init & rotation. 2022-06-13 20:11:09 +01:00

README.md

Genereic ST7789 - Pico Display Pack & Pico Display Pack 2.0" and 240x240 Square & Round LCD Breakouts

Our Pico Display Packs offers a vibrant 1.14" (240x135) or 2.0" (320x240) IPS LCD screen for your Raspberry Pi Pico it also includes four switches and and an RGB LED!

We've included helper functions to handle every aspect of drawing to the screen and interfacing with the buttons and LED. See the function reference for details.

Example Program

The following example sets up Pico Display, displays some basic demo text and graphics and will illuminate the RGB LED green if the A button is pressed.

#include "pico_display.hpp"
#include "generic_st7789.hpp"
#include "rgbled.hpp"
#include "button.hpp"

using namespace pimoroni;

// Swap WIDTH and HEIGHT to rotate 90 degrees
ST7789Generic pico_display(PicoDisplay::WIDTH, PicoDisplay::HEIGHT, ROTATE_0);

// RGB LED controller
RGBLED led(PicoDisplay::LED_R, PicoDisplay::LED_G, PicoDisplay::LED_B);

// Buttons
Button button_a(PicoDisplay::A);
Button button_b(PicoDisplay::B);
Button button_x(PicoDisplay::X);
Button button_y(PicoDisplay::Y);

int main() {
    // set the backlight to a value between 0 and 255
    // the backlight is driven via PWM and is gamma corrected by our
    // library to give a gorgeous linear brightness range.
    pico_display.set_backlight(100);
    
    // Create pens for the colours we want to use
    // parameters are red, green, blue all between 0 and 255
    // By default these are crushed to RGB332 so only the upper bits of each are used!
    int BG_COLOR = pico_display.create_pen(30, 40, 50);
    int BOX_COLOR = pico_display.create_pen(10, 20, 30);
    int TEXT_COLOR = pico_display.create_pen(110, 120, 130);

    while(true) {
        // detect if the A button is pressed (could be A, B, X, or Y)
        if(button_a.raw()) {
            // make the led glow green
            // parameters are red, green, blue all between 0 and 255
            // these are also gamma corrected
            led.set_rgb(0, 255, 0);
        }

        // set the colour of the pen
        pico_display.set_pen(BG_COLOR);

        // fill the screen with the current pen colour
        pico_display.clear();

        // draw a box to put some text in
        pico_display.set_pen(BOX_COLOR);
        Rect text_rect(10, 10, 150, 150);
        pico_display.rectangle(text_rect);

        // write some text inside the box with 10 pixels of margin
        // automatically word wrapping
        text_rect.deflate(10);
        pico_display.set_pen(TEXT_COLOR);
        pico_display.text("This is a message", Point(text_rect.x, text_rect.y), text_rect.w);

        // now we've done our drawing let's update the screen
        pico_display.update();
    }
}

Function Reference

PicoGraphics

The generic ST7789 driver uses our Pico Graphics library to draw graphics and text. For more information read the Pico Graphics function reference..

You will also need to use the RGBLED library to drive the RGB LED, and the Button library for the four buttons.

set_backlight

Set the display backlight from 0-255.

pico_display.set_backlight(brightness);

Uses hardware PWM to dim the display backlight, dimming values are gamma-corrected to provide smooth brightness transitions across the full range of intensity. This may result in some low values mapping as "off."

update

To display your changes on Pico Display's screen you need to call update:

pico_display.update();