initial demo

This commit is contained in:
sigil-03 2025-08-16 21:40:39 -06:00
parent 1a714bd907
commit e3235b34a4
8 changed files with 167 additions and 51 deletions

View file

@ -1,9 +1,10 @@
use ch32_hal::timer::Channel;
use crate::insert_coin::services::{TickServiceData, TickService};
use crate::insert_coin::services::{Service, TickService, TickServiceData};
pub struct LedService {
service_data: core::cell::RefCell<TickServiceData>,
// need_service: core::cell::RefCell<bool>,
need_service: bool,
pub channel: Channel,
pub amplitude: u8,
}
@ -11,7 +12,8 @@ pub struct LedService {
impl LedService {
pub fn new(channel: Channel, service_data: TickServiceData) -> Self {
Self {
service_data: core::cell::RefCell::new(service_data),
// service_data: core::cell::RefCell::new(service_data),
need_service: false,
channel,
amplitude: 0,
}
@ -19,23 +21,19 @@ impl LedService {
pub fn set_amplitude(&mut self, amplitude: u8) {
self.amplitude = amplitude;
self.need_service = true;
}
}
impl TickService for LedService {
fn tick(&self) {
let mut tc = self.service_data.borrow_mut();
tc.ticks_remaining = tc.ticks_remaining.saturating_sub(1);
}
impl Service for LedService {
fn need_service(&self) -> bool {
self.service_data.borrow().ticks_remaining == 0
self.need_service
}
fn service(&self) {
let mut tc = self.service_data.borrow_mut();
tc.ticks_remaining = tc.ticks_per_service;
fn service(&mut self) {
self.need_service = false;
}
}