Skip to content

Latest commit

 

History

History
59 lines (42 loc) · 2.53 KB

README.md

File metadata and controls

59 lines (42 loc) · 2.53 KB

PA11: Final Project

Group members

Matt Johnson
Alex Novotny

Dependencies, Building, and Running

Dependency Instructions

For both of the operating systems to run this project installation of these three programs are required GLEW, GLM, and SDL2.

The project also uses ImGUI and JSON for Modern C++, both of which are already included.

This project uses OpenGL 3.3. Some computers, such as virtual machines in the ECC, can not run this version. In in order to run OpenGL 2.7 follow the instructions at Using OpenGL 2.7

This project uses ImageMagick++ for loading textures. We have found that there are various forms of ImageMagick++ that can conflict with each other. In order to be sure that ImageMagick++ is installed properly for this project, we recommend removing all other forms before installing the libmagick++-dev library. sudo apt-get remove *magick* should handle this removal.

This project uses Bullet Physics.

Ubuntu/Linux

sudo apt-get install libglew-dev libglm-dev libsdl2-dev libsdl2-mixer-dev libassimp-dev libmagick++-dev libbullet-dev   

Building and Running

CMake Instructions

The building of the project is done using CMake, installation with apt-get or brew may be necessary. Later use with CMake and Shader files will be require the copy of a directory where those files are stored (ex. shaders). To do this in the add_custom_target function place

mkdir build   
cd build   
cmake ..   
make   
./Tutorial  

Controls

esc - Close program right click - Hold and drag to rotate camera left click - Click and hold on the cue ball to power up a shot
left click - Places cue ball at start or after scratch Scroll wheel - Zoom in and out
N - To start a new game.
P - To pause the game.
O - Options menu.
WASD - Horizontal camera Movement Shift/Ctrl - Vertical camera movement.

Command Line Parameters

Command Usage

Tutorial - Will run using the default configuration of config.json.
Tutorial --help - Pull up the help menu / command usage
Tutorial <config> - Run the program with the given config file (e.g. "Tutorial config.json")