diff options
| author | Joursoir <chat@joursoir.net> | 2021-03-08 20:36:26 +0000 | 
|---|---|---|
| committer | Joursoir <chat@joursoir.net> | 2021-03-08 20:36:26 +0000 | 
| commit | ac3ab1206a7bddec5312bf974479853429426dfa (patch) | |
| tree | 26c0aacd3c78b8c2bd2d9db8c21af530d68459e6 /main.cpp | |
| download | ascii-road-ac3ab1206a7bddec5312bf974479853429426dfa.tar.gz ascii-road-ac3ab1206a7bddec5312bf974479853429426dfa.tar.bz2 ascii-road-ac3ab1206a7bddec5312bf974479853429426dfa.zip | |
init project
Diffstat (limited to 'main.cpp')
| -rw-r--r-- | main.cpp | 86 | 
1 files changed, 86 insertions, 0 deletions
| diff --git a/main.cpp b/main.cpp new file mode 100644 index 0000000..ca406f4 --- /dev/null +++ b/main.cpp @@ -0,0 +1,86 @@ +#include <ncurses.h> +#include <stdlib.h> +#include <time.h> + +#include "Vehicle.hpp" +#include "veh_models.hpp" + +int total_rows, total_cols; + +void draw_line(int y, char ch) +{ +	int i; +	move(y, 0); +	for(i = 0; i < total_cols; i++) +		addch(ch); +} + +/* This version is a dummy */ +void draw_background() +{ +	draw_line(total_rows-1, '_'); // road + +	mvprintw(total_rows-9, 10, "       _-_"); +	mvprintw(total_rows-8, 10, "    /~~   ~~\\"); +	mvprintw(total_rows-7, 10, " /~~         ~~\\"); +	mvprintw(total_rows-6, 10, "{               }"); +	mvprintw(total_rows-5, 10, " \\  _-     -_  /"); +	mvprintw(total_rows-4, 10, "   ~  \\\\ //  ~"); +	mvprintw(total_rows-3, 10, "       | |"); +	mvprintw(total_rows-2, 10, "       | |"); +	mvprintw(total_rows-1, 10, "______// \\\\"); + +	mvprintw(total_rows-9, 40, "       _-_"); +	mvprintw(total_rows-8, 40, "    /~~   ~~\\"); +	mvprintw(total_rows-7, 40, " /~~         ~~\\"); +	mvprintw(total_rows-6, 40, "{               }"); +	mvprintw(total_rows-5, 40, " \\  _-     -_  /"); +	mvprintw(total_rows-4, 40, "   ~  \\\\ //  ~"); +	mvprintw(total_rows-3, 40, "       | |"); +	mvprintw(total_rows-2, 40, "       | |"); +	mvprintw(total_rows-1, 40, "______// \\\\"); + +	refresh(); +} + +Vehicle *get_random_vehicle(int y, int x) +{ +	Vehicle *car; +	car = new Vehicle(rand() % veh_types_max, y, x); +	return car; +} + +int main(int argc, char *argv[]) +{ +	initscr(); +	noecho(); +	curs_set(0); +	srand(time(0)); + +	struct timespec my_timer; +	my_timer.tv_sec = 0; +	my_timer.tv_nsec = 50000000; // 100000000 +	getmaxyx(stdscr, total_rows, total_cols); + +	Vehicle *car = 0; +	for(;;) +	{ +		clear(); +		draw_background(); + +		if(!car) +			car = get_random_vehicle(total_rows, -1); + +		car->MoveRight(); +		if(!(car->Draw(total_cols))) { +			delete car; +			car = 0; +		} + +		refresh(); +		nanosleep(&my_timer, NULL); +	} +	 +	endwin(); +	return 0; +} | 
