grid.rs 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. extern crate gunpowder_treason as gt;
  2. #[macro_use] extern crate itertools;
  3. const MAP: &'static [u8] =
  4. b"0000000000000000000001110000111100111100111111001111001001000111010011\
  5. 1111101110000001001111010011100111111000000100000001111111111111111100\
  6. 0111111000000000010001111110111011111110000001001110111111100111010011\
  7. 1011111110011101000100001000000111111111000010000001110100010001110000\
  8. 0111010011110111111000000100111101110010011101001111000000100111111011\
  9. 1101110010011100101111011111100010001000000111001001110111110001110110\
  10. 0010011111110111011001110111110101110111001001111101111101100111011111\
  11. 000111000000000000000000000000";
  12. fn main() {
  13. let (w, h) = (11.0, 14.0);
  14. let mut drawing = gt::svg(w, h);
  15. drawing.add(gt::rect((0.0, 0.0), (11.0, 14.0)));
  16. const N: f64 = 0.5;
  17. let rows: usize = ((w - 1.0) / N).floor() as usize;
  18. let cols: usize = ((h - 1.0) / N).floor() as usize;
  19. let x_offset = (w - (rows as f64 * N)) / 2.0;
  20. let y_offset = (h - (cols as f64 * N)) / 2.0;
  21. let get_cell = |x: usize, y: usize| {
  22. let idx = x + y * rows;
  23. MAP[idx]
  24. };
  25. for (x, y) in iproduct!(0..rows-1, 0..cols-1) {
  26. let xc = x_offset + x as f64 * N;
  27. let yc = y_offset + y as f64 * N;
  28. let d = N / 5.0;
  29. let cs = N / 10.0;
  30. if get_cell(x, y) != get_cell(x + 1, y) {
  31. drawing.add(gt::line(xc+N, yc).to(xc+N, yc+N));
  32. let xt = if get_cell(x, y) == '0' as u8 {
  33. xc + N - 0.1
  34. } else {
  35. xc + N + 0.1
  36. };
  37. for n in 0..10 {
  38. let yt = yc + cs * (n as f64 + 0.5);
  39. drawing.add(gt::line(xc+N, yt).to(xt, yt));
  40. }
  41. } else if get_cell(x, y) == '1' as u8 {
  42. for n in 1..5 {
  43. drawing.add(gt::line(xc+N, yc + d * n as f64));
  44. }
  45. }
  46. if get_cell(x, y) != get_cell(x, y+1) {
  47. drawing.add(gt::line(xc, yc+N).to(xc+N, yc+N));
  48. let yt = if get_cell(x, y) == '0' as u8 {
  49. yc + N - 0.1
  50. } else {
  51. yc + N + 0.1
  52. };
  53. for n in 0..10 {
  54. let xt = xc + cs * (n as f64 + 0.5);
  55. drawing.add(gt::line(xt, yc+N).to(xt, yt));
  56. }
  57. } else if get_cell(x, y) == '1' as u8 {
  58. for n in 1..5 {
  59. drawing.add(gt::line(xc + d * n as f64, yc+N));
  60. }
  61. }
  62. }
  63. drawing.to_stdout();
  64. }