X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=text.rs;h=abcd9b40f17b3235fcf230883f1e57f8c686b28e;hb=e909401ee19ae946d8888dc3aa75d269f408fb92;hp=82d4d1703a79da5bd4efed53dc5c9205f4493f2b;hpb=bcda449dea3673fecf4c0ea5c96799f4bc4e59a2;p=mandelwow.git diff --git a/text.rs b/text.rs index 82d4d17..abcd9b4 100644 --- a/text.rs +++ b/text.rs @@ -1,10 +1,26 @@ 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] +} + #[derive(Copy, Clone)] struct Vertex { position: [f32; 2], @@ -13,7 +29,7 @@ struct Vertex { implement_vertex!(Vertex, position, tex_coords); pub struct Text<'a> { - tex: texture::UnsignedTexture2d, + tex: texture::Texture2d, vertex_buffer: glium::VertexBuffer, index_buffer: glium::IndexBuffer, program: glium::Program, @@ -34,10 +50,10 @@ impl<'a> Text<'a> { height: h, format: glium::texture::ClientFormat::U8, }; - let tex = glium::texture::UnsignedTexture2d::with_format( + let tex = glium::texture::Texture2d::with_format( display, image, - glium::texture::UncompressedUintFormat::U8, + glium::texture::UncompressedFloatFormat::U8, glium::texture::MipmapsOption::NoMipmap, ).unwrap(); @@ -94,13 +110,13 @@ impl<'a> Text<'a> { // Characters are arranged in a 16x16 square. int xpos = index % 16; int ypos = index / 16; - v_tex_coords = (tex_coords) / 16.0 + vec2(xpos / 16., ypos / 16.); + v_tex_coords = (tex_coords + vec2(xpos, ypos)) / 16.; } ", fragment: " #version 140 - uniform usampler2D tex; + uniform sampler2D tex; uniform vec4 bgcolor; uniform vec4 fgcolor; @@ -124,7 +140,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 +158,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(