1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
|
extern crate sdl2;
mod font;
pub mod generated;
mod interpolation;
#[cfg(all(feature = "music", not(feature = "32k")))]
mod music;
mod render;
pub mod vendored;
use std::time::{Duration, SystemTime};
#[cfg(all(feature = "music", not(feature = "32k")))]
use music::{mmc2r_to_pcm, Music};
use sdl2::{event::Event, keyboard::Keycode};
#[cfg(all(not(feature = "notimeout"), not(feature = "32k")))]
const TIMEOUT_DEATH: f64 = render::JUST_DVD + 20.0;
use sdl2::audio::AudioSpecDesired;
#[cfg(all(feature = "music", not(feature = "32k")))]
use vendored::micromod::MmC2r;
pub fn main() {
let sdl_context = sdl2::init().unwrap();
#[cfg(all(feature = "music", not(feature = "32k")))]
let audio_subsystem = sdl_context.audio().unwrap();
#[cfg(all(feature = "music", not(feature = "32k")))]
let desired_spec = AudioSpecDesired {
freq: Some(48_000),
#[cfg(feature = "stereo")]
channels: Some(2),
#[cfg(not(feature = "stereo"))]
channels: Some(1),
samples: Some(8192 as u16),
};
#[cfg(all(feature = "music", not(feature = "32k")))]
let device = audio_subsystem
.open_playback(None, &desired_spec, |spec| {
// initialize the audio callback
Music {
offset: 0,
pcm: mmc2r_to_pcm(
&mut MmC2r::new(include_bytes!("../uwudhd.mod"), spec.freq as isize).unwrap(),
),
}
})
.unwrap();
// Start playback
#[cfg(all(feature = "music", not(feature = "32k")))]
device.resume();
let video_subsystem = sdl_context.video().unwrap();
let mut builder = video_subsystem.window("cosin25-invite.rs", 512, 256);
builder.position_centered();
#[cfg(feature = "resizable")]
builder.resizable();
let window = &mut builder.build().unwrap();
let mut canvas = window.clone().into_canvas().build().unwrap();
let texture_creator = canvas.texture_creator();
render::render(&mut canvas, &texture_creator, 0.001);
canvas.present();
let mut event_pump = sdl_context.event_pump().unwrap();
let start_time = SystemTime::now();
'running: loop {
let time = SystemTime::now()
.duration_since(start_time)
.expect("Time went back between frames");
let time = f64::from(time.as_millis() as u32) / 1000.0;
#[cfg(all(not(feature = "notimeout"), not(feature = "32k")))]
if time > TIMEOUT_DEATH {
break 'running;
}
render::render(&mut canvas, &texture_creator, time);
for event in event_pump.poll_iter() {
match event {
Event::Quit { .. }
| Event::KeyDown {
keycode: Some(Keycode::Escape),
..
} => break 'running,
_ => {}
}
}
// The rest of the game loop goes here...
canvas.present();
::std::thread::sleep(Duration::new(0, 1_000_000_000u32 / 12000));
}
}
|