#pico #oled #driver #created #screen #pi #rgb

pico_ssd1351_driver

为Pi Pico W创建的SSD1351 OLED 1.5英寸rgb屏幕的驱动程序

2个不稳定版本

0.2.0 2024年6月18日
0.1.0 2024年6月18日

#328硬件支持

MIT/Apache

46KB
652 代码行

为Pi Pico W创建的简单SSD1351 OLED 1.5英寸rgb屏幕的驱动程序

即将推出的关键修复

  • 当前Spi绑定是硬编码的。在迁移rp2040_hal版本时,DynPinID崩溃,尚未找到合适的修复方案。

基本用法示例


    #[global_allocator]
    static HEAP: Heap = Heap::empty();

    const FONT: FONT11X18 = FONT11X18 {
        width: 11,
        height: 18,
    };

    ...

    {
        use core::mem::MaybeUninit;
        const HEAP_SIZE: usize = 32768;
        static mut HEAP_MEM: [MaybeUninit<u8>; HEAP_SIZE] = [MaybeUninit::uninit(); HEAP_SIZE];
        unsafe { HEAP.init(HEAP_MEM.as_ptr() as usize, HEAP_SIZE) }
    }

    // Configure the clocks
    // The default is to generate a 125 MHz system clock
    let clocks = hal::clocks::init_clocks_and_plls(
        rp_pico::XOSC_CRYSTAL_FREQ,
        pac.XOSC,
        pac.CLOCKS,
        pac.PLL_SYS,
        pac.PLL_USB,
        &mut pac.RESETS,
        &mut watchdog,
    )
    .ok()
    .unwrap();

    let mut pac = pac::Peripherals::take().unwrap();

    let pins = bsp::Pins::new(
        pac.IO_BANK0,
        pac.PADS_BANK0,
        sio.gpio_bank0,
        &mut pac.RESETS,
    );

    let spi_sclk: gpio::Pin<_, gpio::FunctionSpi, gpio::PullNone> = pins.gpio2.reconfigure();
    let spi_mosi: gpio::Pin<_, gpio::FunctionSpi, gpio::PullNone> = pins.gpio3.reconfigure();

    let cs: gpio::Pin<_, gpio::FunctionSio<gpio::SioOutput>, gpio::PullDown> =
        pins.gpio6.into_push_pull_output();
    let dc: gpio::Pin<_, gpio::FunctionSio<gpio::SioOutput>, gpio::PullDown> =
        pins.gpio7.into_push_pull_output();
    let rst: gpio::Pin<_, gpio::FunctionSio<gpio::SioOutput>, gpio::PullDown> =
        pins.gpio8.into_push_pull_output();

    let spi_bindings = SPIPins { spi_sclk, spi_mosi };
    let spi_driver_bindings = SPIDriverPins { cs, dc, rst };

    let spi_display_controller = SSD1351_SPI::SPIDisplayInterface::new(
        spi_bindings,
        spi_driver_bindings,
        pac.SPI0,
        &mut pac.RESETS,
        &mut clocks.peripheral_clock.freq(),
    );

    let mut oled: SSD1351_OLED = SSD1351_OLED {
        spi_controller: spi_display_controller,
        height: 128,
        width: 128,
    };

    // Create buffer filed with "black" using a Vec<>
    let buff_oled: Vec<SSD1351_Color> = vec![
        SSD1351_Color {
            red: 0,
            green: 0,
            blue: 0
        };
        16384
    ];

    let mut fbo_oled: SSD1351_FBO = SSD1351_FBO {
        width: 128,
        height: 128,
        pixels: buff_oled,
    };

    oled.init(&mut delay, true);
    oled.clear(&mut fbo_oled);


    loop
    {
        oled.clear(&mut fbo_oled);

        fbo_oled.draw_string(Point { x: 0, y: 20 }, "OLED rockz", &FONT, &SSD1351_Color{red: 178, green: 102, blue: 255});

        fbo_oled.draw_line(Point { x: 50, y: 40 }, Point { x: 60, y: 50 }, &SSD1351_Color{red: 255, green:255, blue: 153});
        fbo_oled.draw_circle(Point { x: 64, y: 60 }, 5, &SSD1351_Color{red: 204, green: 255, blue: 204});
        fbo_oled.draw_circle_fill(Point { x: 30, y: 100 }, 8, &SSD1351_Color{red: 255, green: 128, blue: 0});

        fbo_oled.draw_rect(Point { x: 64, y: 90 }, 20, 10, &SSD1351_Color{red: 0, green: 153, blue: 76});
        fbo_oled.draw_rect_fill(Point { x: 64, y: 100 }, 30, 10, &SSD1351_Color{red: 102, green: 0, blue: 102});

        oled.update(&mut fbo_oled);
    }

依赖项

~9MB
~182K SLoC