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
|
use ggez::conf::Conf;
use ggez::event::{self, EventHandler};
use ggez::filesystem;
use ggez::graphics::{self, spritebatch::SpriteBatch, DrawParam, FilterMode, Image};
use ggez::nalgebra::{Point2, Vector2};
use ggez::{Context, ContextBuilder, GameResult};
use pax_romana::constants;
use pax_romana::map::{Map, Tileset};
struct State {
map: Map,
tileset: Tileset,
spritebatch: SpriteBatch,
}
impl State {
fn new(context: &mut Context) -> GameResult<State> {
let mut image = Image::new(context, "/tileset.png")?;
image.set_filter(FilterMode::Nearest);
Ok(State {
map: Map::new(filesystem::open(context, "/map.tmx")?),
tileset: Tileset::new(filesystem::open(context, "/tileset.tsx")?),
spritebatch: SpriteBatch::new(image),
})
}
}
impl EventHandler for State {
fn update(&mut self, _context: &mut Context) -> GameResult {
Ok(())
}
fn draw(&mut self, context: &mut Context) -> GameResult {
graphics::clear(context, graphics::BLACK);
for x in 0..self.map.width {
for y in 0..self.map.height {
let draw_param = DrawParam::default()
.src(self.tileset.tiles[self.map.data[x + (y * self.map.height)]])
.dest(Point2::new(
self.tileset.tile_width * constants::TILE_SCALE * x as f32,
self.tileset.tile_height * constants::TILE_SCALE * y as f32,
))
.scale(Vector2::new(constants::TILE_SCALE, constants::TILE_SCALE));
self.spritebatch.add(draw_param);
}
}
graphics::draw(context, &self.spritebatch, DrawParam::default())?;
self.spritebatch.clear();
graphics::present(context)?;
Ok(())
}
}
fn main() -> GameResult {
let conf = Conf::new();
let (ref mut context, ref mut event_loop) = ContextBuilder::new("pax-romana", "tom barrett")
.conf(conf)
.add_resource_path("./resources")
.build()?;
let state = &mut State::new(context)?;
event::run(context, event_loop, state)
}
|