X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=text.rs;h=14b2633b8a6712910bb49b7abcb46f57bb8d0f59;hb=2b40ae7b37cf23dcce1561c33e254e6d60d03ad5;hp=bf19aa2ad273aff0eb9cd544153cac4a90bf0982;hpb=cb9417c29f520264b1d6395216e2dcf624eebd04;p=mandelwow.git diff --git a/text.rs b/text.rs index bf19aa2..14b2633 100644 --- a/text.rs +++ b/text.rs @@ -1,10 +1,42 @@ use cgmath::conv::array4x4; -use cgmath::{Matrix4, One}; +use cgmath::{Matrix4, Vector3}; use glium; use glium::{Surface, texture}; -use image; use std; +fn gamma(x: T) -> f32 +where + f32: From, + T: Copy, +{ + ((f32::from(x)) / 255.).powf(2.2) +} + +fn srgb(c: [T; 3]) -> [f32; 4] +where + f32: From, + T: Copy, +{ + [gamma(c[0]), gamma(c[1]), gamma(c[2]), 0.0] +} + +#[cfg(feature = "image")] +fn c64_font() -> (u32, u32, Vec) { + use image; + let image = + image::load_from_memory_with_format(&include_bytes!("c64-font.png")[..], image::PNG) + .unwrap() + .to_luma(); + let (w, h) = image.dimensions(); + (w, h, image.into_raw()) +} + +#[cfg(not(feature = "image"))] +fn c64_font() -> (u32, u32, Vec) { + let pixels = &include_bytes!("c64-font.gray")[..]; + (128, 128, Vec::from(pixels)) +} + #[derive(Copy, Clone)] struct Vertex { position: [f32; 2], @@ -23,13 +55,9 @@ pub struct Text<'a> { impl<'a> Text<'a> { pub fn new(display: &glium::Display) -> Text { - let image = - image::load_from_memory_with_format(&include_bytes!("c64-font.png")[..], image::PNG) - .unwrap() - .to_luma(); - let (w, h) = image.dimensions(); + let (w, h, pixels) = c64_font(); let image = glium::texture::RawImage2d { - data: std::borrow::Cow::from(image.into_raw()), + data: std::borrow::Cow::from(pixels), width: w, height: h, format: glium::texture::ClientFormat::U8, @@ -124,7 +152,7 @@ impl<'a> Text<'a> { }; Text { - model: Matrix4::one(), + model: Matrix4::from_translation(Vector3::unit_z() * (-1.0)), tex: tex, vertex_buffer: vertex_buffer, index_buffer: index_buffer, @@ -142,8 +170,8 @@ impl<'a> Text<'a> { .magnify_filter(glium::uniforms::MagnifySamplerFilter::Nearest), index: 'C' as i32, // RGB values from http://unusedino.de/ec64/technical/misc/vic656x/colors/ - bgcolor: [ 53./255., 40./255., 121./255., 0.0/255. ] as [f32; 4], - fgcolor: [ 120./255., 106./255., 255./255., 188.0/255. ] as [f32; 4], + bgcolor: srgb([ 64, 50, 133u8]), // 6 - blue + fgcolor: srgb([120, 106, 189u8]), // 14 - light blue }; frame .draw(