mirror of
https://github.com/italicsjenga/rp-hal-boards.git
synced 2024-12-25 05:31:29 +11:00
d7177345af
* Add board waveshare-rp2040-lcd-0.96 * Update product page links in readme
161 lines
4.6 KiB
Rust
161 lines
4.6 KiB
Rust
//! Example of graphics on the LCD of the Waveshare RP2040-LCD-0.96
|
|
//!
|
|
//! Draws a red and green line with a blue rectangle.
|
|
//! After that it fills the screen line for line, at the end it starts over with
|
|
//! another colour, RED, GREEN and BLUE.
|
|
#![no_std]
|
|
#![no_main]
|
|
|
|
use cortex_m::delay::Delay;
|
|
use embedded_graphics::primitives::Line;
|
|
use fugit::RateExtU32;
|
|
use panic_halt as _;
|
|
|
|
use waveshare_rp2040_lcd_0_96::entry;
|
|
use waveshare_rp2040_lcd_0_96::{
|
|
hal::{
|
|
self,
|
|
clocks::{init_clocks_and_plls, Clock},
|
|
pac,
|
|
pio::PIOExt,
|
|
watchdog::Watchdog,
|
|
Sio,
|
|
},
|
|
Pins, XOSC_CRYSTAL_FREQ,
|
|
};
|
|
|
|
use embedded_graphics::{
|
|
pixelcolor::Rgb565,
|
|
prelude::*,
|
|
primitives::{PrimitiveStyle, PrimitiveStyleBuilder, Rectangle},
|
|
};
|
|
use st7735_lcd::{Orientation, ST7735};
|
|
|
|
const LCD_WIDTH: u32 = 160;
|
|
const LCD_HEIGHT: u32 = 80;
|
|
|
|
#[entry]
|
|
fn main() -> ! {
|
|
let mut pac = pac::Peripherals::take().unwrap();
|
|
let core = pac::CorePeripherals::take().unwrap();
|
|
|
|
let mut watchdog = Watchdog::new(pac.WATCHDOG);
|
|
|
|
let clocks = init_clocks_and_plls(
|
|
XOSC_CRYSTAL_FREQ,
|
|
pac.XOSC,
|
|
pac.CLOCKS,
|
|
pac.PLL_SYS,
|
|
pac.PLL_USB,
|
|
&mut pac.RESETS,
|
|
&mut watchdog,
|
|
)
|
|
.ok()
|
|
.unwrap();
|
|
|
|
let sio = Sio::new(pac.SIO);
|
|
let pins = Pins::new(
|
|
pac.IO_BANK0,
|
|
pac.PADS_BANK0,
|
|
sio.gpio_bank0,
|
|
&mut pac.RESETS,
|
|
);
|
|
|
|
// Set up the delay for the first core.
|
|
let sys_freq = clocks.system_clock.freq().to_Hz();
|
|
let mut delay = Delay::new(core.SYST, sys_freq);
|
|
|
|
let (mut _pio, _sm0, _, _, _) = pac.PIO0.split(&mut pac.RESETS);
|
|
|
|
// https://www.waveshare.com/wiki/RP2040-LCD-0.96
|
|
// ST7735S LCD
|
|
let lcd_dc = pins.gp8.into_push_pull_output();
|
|
let mut _lcd_cs = pins.gp9.into_mode::<hal::gpio::FunctionSpi>();
|
|
let mut _lcd_clk = pins.gp10.into_mode::<hal::gpio::FunctionSpi>();
|
|
let mut _lcd_mosi = pins.gp11.into_mode::<hal::gpio::FunctionSpi>();
|
|
let lcd_rst = pins
|
|
.gp12
|
|
.into_push_pull_output_in_state(hal::gpio::PinState::High);
|
|
let mut _lcd_bl = pins
|
|
.gp25
|
|
.into_push_pull_output_in_state(hal::gpio::PinState::High);
|
|
|
|
let spi = hal::Spi::<_, _, 8>::new(pac.SPI1);
|
|
|
|
// Exchange the uninitialised SPI driver for an initialised one
|
|
let spi = spi.init(
|
|
&mut pac.RESETS,
|
|
clocks.peripheral_clock.freq(),
|
|
10.MHz(),
|
|
&embedded_hal::spi::MODE_0,
|
|
);
|
|
|
|
// LCD is a 65K IPS LCD 160x80, color order is BGR and a offset 1,26 pixel.
|
|
// LCD controller can correct this by settings the order bit (bit 3) in MADCTL register.
|
|
// Also the colours are inverted, LCD controller can also correct this by writing to INVON register with no paramters.
|
|
// All this is handled by the ST7735 crate.
|
|
let mut display = ST7735::new(spi, lcd_dc, lcd_rst, false, true, LCD_WIDTH, LCD_HEIGHT);
|
|
|
|
display.init(&mut delay).unwrap();
|
|
display.set_orientation(&Orientation::Landscape).unwrap();
|
|
|
|
display.set_offset(1, 26);
|
|
|
|
let lcd_zero = Point::zero();
|
|
let lcd_max_corner = Point::new((LCD_WIDTH - 1) as i32, (LCD_HEIGHT - 1) as i32);
|
|
|
|
let style = PrimitiveStyleBuilder::new()
|
|
.fill_color(Rgb565::BLUE)
|
|
.build();
|
|
|
|
Rectangle::with_corners(lcd_zero, lcd_max_corner)
|
|
.into_styled(style)
|
|
.draw(&mut display)
|
|
.unwrap();
|
|
|
|
let style = PrimitiveStyleBuilder::new()
|
|
.fill_color(Rgb565::BLACK)
|
|
.build();
|
|
|
|
Rectangle::with_corners(
|
|
Point::new(1, 1),
|
|
Point::new((LCD_WIDTH - 2) as i32, (LCD_HEIGHT - 2) as i32),
|
|
)
|
|
.into_styled(style)
|
|
.draw(&mut display)
|
|
.unwrap();
|
|
|
|
Line::new(lcd_zero, lcd_max_corner)
|
|
.into_styled(PrimitiveStyle::with_stroke(Rgb565::RED, 1))
|
|
.draw(&mut display)
|
|
.unwrap();
|
|
|
|
Line::new(
|
|
Point::new(0, (LCD_HEIGHT - 1) as i32),
|
|
Point::new((LCD_WIDTH - 1) as i32, 0),
|
|
)
|
|
.into_styled(PrimitiveStyle::with_stroke(Rgb565::GREEN, 1))
|
|
.draw(&mut display)
|
|
.unwrap();
|
|
|
|
// Infinite colour wheel loop
|
|
let mut l: i32 = 0;
|
|
let mut c = Rgb565::RED;
|
|
loop {
|
|
Line::new(Point::new(0, l), Point::new((LCD_WIDTH - 1) as i32, l))
|
|
.into_styled(PrimitiveStyle::with_stroke(c, 1))
|
|
.draw(&mut display)
|
|
.unwrap();
|
|
delay.delay_ms(10);
|
|
l += 1;
|
|
if l == LCD_HEIGHT as i32 {
|
|
l = 0;
|
|
c = match c {
|
|
Rgb565::RED => Rgb565::GREEN,
|
|
Rgb565::GREEN => Rgb565::BLUE,
|
|
_ => Rgb565::RED,
|
|
}
|
|
}
|
|
}
|
|
}
|