update to servicepoint 0.10, improve pixel handling

This commit is contained in:
Vinzenz Schroeter 2024-11-09 19:02:18 +01:00
parent 4ddec8eef2
commit 36d0daba05
8 changed files with 29 additions and 27 deletions

4
Cargo.lock generated
View file

@ -1764,9 +1764,9 @@ dependencies = [
[[package]] [[package]]
name = "servicepoint" name = "servicepoint"
version = "0.9.1" version = "0.10.0"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "d7e803bc88f44d834cf52731e09392f68f9462eebaa68d3b4a406f26b41452b9" checksum = "25fd266845654e7e643cf32a9e69dd20ce2b62cf54557937d4d0d41bf27a050f"
dependencies = [ dependencies = [
"bitvec", "bitvec",
"bzip2", "bzip2",

View file

@ -16,7 +16,7 @@ pixels = "0.14"
pathfinder_geometry = "0.5.1" pathfinder_geometry = "0.5.1"
[dependencies.servicepoint] [dependencies.servicepoint]
version = "0.9.1" version = "0.10.0"
features = ["all_compressions"] features = ["all_compressions"]
[dependencies.winit] [dependencies.winit]

View file

@ -98,6 +98,7 @@
packages = with pkgs; [ packages = with pkgs; [
rustfmt rustfmt
cargo-expand cargo-expand
clippy
]; ];
# LD_LIBRARY_PATH = "${pkgs.lib.makeLibraryPath ( # LD_LIBRARY_PATH = "${pkgs.lib.makeLibraryPath (
# builtins.concatMap (d: d.runtimeDependencies) inputsFrom # builtins.concatMap (d: d.runtimeDependencies) inputsFrom

View file

@ -2,7 +2,7 @@ use std::sync::{RwLock, RwLockWriteGuard};
use log::{debug, error, info, trace, warn}; use log::{debug, error, info, trace, warn};
use servicepoint::{ use servicepoint::{
BrightnessGrid, Command, Cp437Grid, Grid, Origin, PixelGrid, Tiles, Bitmap, BrightnessGrid, Command, Cp437Grid, Grid, Origin, Tiles,
PIXEL_COUNT, PIXEL_WIDTH, TILE_SIZE, PIXEL_COUNT, PIXEL_WIDTH, TILE_SIZE,
}; };
@ -11,7 +11,7 @@ use crate::font::BitmapFont;
pub(crate) fn execute_command( pub(crate) fn execute_command(
command: Command, command: Command,
font: &BitmapFont, font: &BitmapFont,
display_ref: &RwLock<PixelGrid>, display_ref: &RwLock<Bitmap>,
luma_ref: &RwLock<BrightnessGrid>, luma_ref: &RwLock<BrightnessGrid>,
) -> bool { ) -> bool {
debug!("received {command:?}"); debug!("received {command:?}");
@ -120,7 +120,7 @@ fn print_cp437_data(
origin: Origin<Tiles>, origin: Origin<Tiles>,
grid: &Cp437Grid, grid: &Cp437Grid,
font: &BitmapFont, font: &BitmapFont,
display: &mut RwLockWriteGuard<PixelGrid>, display: &mut RwLockWriteGuard<Bitmap>,
) { ) {
let Origin { x, y, .. } = origin; let Origin { x, y, .. } = origin;
for char_y in 0usize..grid.height() { for char_y in 0usize..grid.height() {
@ -152,8 +152,8 @@ fn print_cp437_data(
fn print_pixel_grid( fn print_pixel_grid(
offset_x: usize, offset_x: usize,
offset_y: usize, offset_y: usize,
pixels: &PixelGrid, pixels: &Bitmap,
display: &mut RwLockWriteGuard<PixelGrid>, display: &mut RwLockWriteGuard<Bitmap>,
) -> bool { ) -> bool {
debug!( debug!(
"printing {}x{} grid at {offset_x} {offset_y}", "printing {}x{} grid at {offset_x} {offset_y}",

View file

@ -4,24 +4,24 @@ use font_kit::font::Font;
use font_kit::hinting::HintingOptions; use font_kit::hinting::HintingOptions;
use pathfinder_geometry::transform2d::Transform2F; use pathfinder_geometry::transform2d::Transform2F;
use pathfinder_geometry::vector::{vec2f, vec2i}; use pathfinder_geometry::vector::{vec2f, vec2i};
use servicepoint::{Grid, PixelGrid, TILE_SIZE}; use servicepoint::{Bitmap, Grid, TILE_SIZE};
const DEFAULT_FONT_FILE: &[u8] = include_bytes!("../Web437_IBM_BIOS.woff"); const DEFAULT_FONT_FILE: &[u8] = include_bytes!("../Web437_IBM_BIOS.woff");
const CHAR_COUNT: usize = u8::MAX as usize + 1; const CHAR_COUNT: usize = u8::MAX as usize + 1;
pub struct BitmapFont { pub struct BitmapFont {
bitmaps: [PixelGrid; CHAR_COUNT], bitmaps: [Bitmap; CHAR_COUNT],
} }
impl BitmapFont { impl BitmapFont {
pub fn new(bitmaps: [PixelGrid; CHAR_COUNT]) -> Self { pub fn new(bitmaps: [Bitmap; CHAR_COUNT]) -> Self {
Self { bitmaps } Self { bitmaps }
} }
pub fn load(font: Font, size: usize) -> BitmapFont { pub fn load(font: Font, size: usize) -> BitmapFont {
let mut bitmaps = let mut bitmaps =
core::array::from_fn(|_| PixelGrid::new(TILE_SIZE, TILE_SIZE)); core::array::from_fn(|_| Bitmap::new(TILE_SIZE, TILE_SIZE));
let mut canvas = let mut canvas =
Canvas::new(vec2i(size as i32, size as i32), Format::A8); Canvas::new(vec2i(size as i32, size as i32), Format::A8);
let size_f = size as f32; let size_f = size as f32;
@ -61,7 +61,7 @@ impl BitmapFont {
Self::new(bitmaps) Self::new(bitmaps)
} }
pub fn get_bitmap(&self, char_code: u8) -> &PixelGrid { pub fn get_bitmap(&self, char_code: u8) -> &Bitmap {
&self.bitmaps[char_code as usize] &self.bitmaps[char_code as usize]
} }
} }

View file

@ -2,10 +2,9 @@ use std::sync::mpsc::Sender;
use std::sync::RwLock; use std::sync::RwLock;
use log::{info, warn}; use log::{info, warn};
use pixels::wgpu::TextureFormat; use pixels::{Pixels, SurfaceTexture};
use pixels::{Pixels, PixelsBuilder, SurfaceTexture};
use servicepoint::{ use servicepoint::{
Brightness, BrightnessGrid, Grid, PixelGrid, PIXEL_HEIGHT, PIXEL_WIDTH, Bitmap, Brightness, BrightnessGrid, Grid, PIXEL_HEIGHT, PIXEL_WIDTH,
TILE_SIZE, TILE_SIZE,
}; };
use winit::application::ApplicationHandler; use winit::application::ApplicationHandler;
@ -18,7 +17,7 @@ use winit::window::{Window, WindowId};
use crate::Cli; use crate::Cli;
pub struct App<'t> { pub struct App<'t> {
display: &'t RwLock<PixelGrid>, display: &'t RwLock<Bitmap>,
luma: &'t RwLock<BrightnessGrid>, luma: &'t RwLock<BrightnessGrid>,
window: Option<Window>, window: Option<Window>,
pixels: Option<Pixels>, pixels: Option<Pixels>,
@ -36,7 +35,7 @@ pub enum AppEvents {
impl<'t> App<'t> { impl<'t> App<'t> {
pub fn new( pub fn new(
display: &'t RwLock<PixelGrid>, display: &'t RwLock<Bitmap>,
luma: &'t RwLock<BrightnessGrid>, luma: &'t RwLock<BrightnessGrid>,
stop_udp_tx: Sender<()>, stop_udp_tx: Sender<()>,
cli: &'t Cli, cli: &'t Cli,
@ -115,11 +114,13 @@ impl ApplicationHandler<AppEvents> for App<'_> {
let pixels = { let pixels = {
let window_size = window.inner_size(); let window_size = window.inner_size();
let surface_texture = SurfaceTexture::new(window_size.width, window_size.height, &window); let surface_texture = SurfaceTexture::new(
Pixels::new( window_size.width,
size.width as u32, window_size.height,
size.height as u32, &window,
surface_texture).unwrap() );
Pixels::new(size.width as u32, size.height as u32, surface_texture)
.unwrap()
}; };
self.pixels = Some(pixels); self.pixels = Some(pixels);

View file

@ -50,7 +50,7 @@ fn main() {
.set_nonblocking(true) .set_nonblocking(true)
.expect("could not enter non blocking mode"); .expect("could not enter non blocking mode");
let display = RwLock::new(PixelGrid::new(PIXEL_WIDTH, PIXEL_HEIGHT)); let display = RwLock::new(Bitmap::new(PIXEL_WIDTH, PIXEL_HEIGHT));
let mut luma = BrightnessGrid::new(TILE_WIDTH, TILE_HEIGHT); let mut luma = BrightnessGrid::new(TILE_WIDTH, TILE_HEIGHT);
luma.fill(Brightness::MAX); luma.fill(Brightness::MAX);
@ -60,7 +60,7 @@ fn main() {
} }
fn run( fn run(
display_ref: &RwLock<PixelGrid>, display_ref: &RwLock<Bitmap>,
luma_ref: &RwLock<BrightnessGrid>, luma_ref: &RwLock<BrightnessGrid>,
socket: UdpSocket, socket: UdpSocket,
font: BitmapFont, font: BitmapFont,

View file

@ -1,5 +1,5 @@
use crate::font::BitmapFont; use crate::font::BitmapFont;
use servicepoint::{DataRef, PixelGrid, TILE_SIZE}; use servicepoint::{Bitmap, DataRef, TILE_SIZE};
/// Font from the display firmware `cape-cccb-apd/cp437font_linear.h` /// Font from the display firmware `cape-cccb-apd/cp437font_linear.h`
pub(crate) const CP437_FONT_LINEAR: [u64; 256] = [ pub(crate) const CP437_FONT_LINEAR: [u64; 256] = [
@ -263,7 +263,7 @@ pub(crate) const CP437_FONT_LINEAR: [u64; 256] = [
pub fn load_static() -> BitmapFont { pub fn load_static() -> BitmapFont {
let mut bitmaps = let mut bitmaps =
core::array::from_fn(|_| PixelGrid::new(TILE_SIZE, TILE_SIZE)); core::array::from_fn(|_| Bitmap::new(TILE_SIZE, TILE_SIZE));
for (char_code, bitmap) in bitmaps.iter_mut().enumerate() { for (char_code, bitmap) in bitmaps.iter_mut().enumerate() {
let bits = CP437_FONT_LINEAR[char_code]; let bits = CP437_FONT_LINEAR[char_code];