diff options
-rw-r--r-- | CMakeLists.txt | 26 | ||||
-rw-r--r-- | pico-watch.c | 74 |
2 files changed, 60 insertions, 40 deletions
diff --git a/CMakeLists.txt b/CMakeLists.txt index 52b713f..8019126 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -17,33 +17,33 @@ project(pico-watch C CXX) # Initialise the Pico SDK pico_sdk_init() -# Add executable. Default name is the project name, version 0.1 +# Add OLED library +add_library(Oled + oled/BitBang_I2C.c + oled/BitBang_I2C.h + oled/ss_oled.c + oled/ss_oled.h + ) +target_link_libraries(Oled pico_stdlib hardware_i2c) +# Main code #add_executable(pico-watch pico-watch.c ) add_executable(pico-watch pico-watch.c - BitBang_I2C.c - BitBang_I2C.h - ss_oled.c - ss_oled.h ) - pico_set_program_name(pico-watch "pico-watch") pico_set_program_version(pico-watch "0.1") - -pico_enable_stdio_uart(pico-watch 0) -pico_enable_stdio_usb(pico-watch 1) +pico_enable_stdio_uart(pico-watch 1) # Add the standard library to the build target_link_libraries(pico-watch pico_stdlib) # Add any user requested libraries target_link_libraries(pico-watch - hardware_i2c - hardware_timer - hardware_clocks + Oled + hardware_rtc +# hardware_clocks ) pico_add_extra_outputs(pico-watch) - diff --git a/pico-watch.c b/pico-watch.c index 3d39b9b..b9bc993 100644 --- a/pico-watch.c +++ b/pico-watch.c @@ -1,40 +1,60 @@ #include <stdio.h> #include "pico/stdlib.h" #include "hardware/i2c.h" -#include "hardware/timer.h" -#include "hardware/clocks.h" - -// I2C defines -// This example will use I2C0 on GPIO8 (SDA) and GPIO9 (SCL) running at 400KHz. -// Pins can be changed, see the GPIO function select table in the datasheet for information on GPIO assignments -#define I2C_PORT i2c0 -#define I2C_SDA 8 -#define I2C_SCL 9 +#include "hardware/rtc.h" +#include "pico/util/datetime.h" +#include "oled/ss_oled.h" + +// To modify the I2C port used, change the `#define I2C_PORT` in "oled/BitBang_I2C.c" +// Pin numbers are GPIO pins. +#define SDA_PIN 6 +#define SCL_PIN 7 +#define RESET_PIN -1 +SSOLED oled; +// Unused but useful for reference: +#define OLED_WIDTH 128 +#define OLED_HEIGHT 64 + + +void init_display() { + oledInit(&oled, OLED_128x64, 0x3d, 0, 0, 1, SDA_PIN, SCL_PIN, RESET_PIN, 1000000L); + oledFill(&oled, 0,1); + oledSetContrast(&oled, 127); + oledSetTextWrap(&oled, true); +} -int64_t alarm_callback(alarm_id_t id, void *user_data) { - // Put your timeout handler code in here - return 0; +void init_rtc() { + datetime_t init_date = { + .year = 2020, + .month = 06, + .day = 05, + .dotw = 5, // 0 is Sunday, so 5 is Friday + .hour = 15, + .min = 45, + .sec = 00 }; + rtc_init(); + rtc_set_datetime(&init_date); } +void show_datetime() { + char datetime_buf[256]; + char *datetime_str = &datetime_buf[0]; + datetime_t t; + rtc_get_datetime(&t); + datetime_to_str(datetime_str, sizeof(datetime_buf), &t); + oledWriteString(&oled, 0,10,3, datetime_str, FONT_12x16, 0, 1); +} int main() { stdio_init_all(); - - // I2C Initialisation. Using it at 400Khz. - i2c_init(I2C_PORT, 400*1000); - - gpio_set_function(I2C_SDA, GPIO_FUNC_I2C); - gpio_set_function(I2C_SCL, GPIO_FUNC_I2C); - gpio_pull_up(I2C_SDA); - gpio_pull_up(I2C_SCL); - - // Timer example code - This example fires off the callback after 2000ms - add_alarm_in_ms(2000, alarm_callback, NULL, false); - - - puts("Hello, world!"); - + init_display(); + init_rtc(); + oledWriteString(&oled, 0,15,0, (char *)"Test clock", FONT_8x8, 0, 1); + while (1) { + show_datetime(); + sleep_ms(500); + } return 0; } |