Skip to content

jmsweb/conway-gol

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 

Repository files navigation

Conway Game of Life (Java)


Prerequisites

  • Operating System
    • Windows (Tested no errors or failures, can build and run jar)
    • Mac (Test failed, can build and run jar)
    • Linux (Untested)
  • Java 9
  • JavaFX
    • The package should already included in Java9 installation.
  • Maven 3.3.9
  • JavaFX SceneBuilder 9(Optional)

https://openjfx.io/openjfx-docs/

Installation

Java and Maven knowledge is needed to execute this standalone application.

SceneBuilder is not used to run this Java application but the software was helpful to visualize the layout in wireframe, quick lookups to FXML Node attributes and properties, and read/write to FXML file.

Maven will download project dependencies from repo.maven.apache.org site, compile classes and run tests, and build to package the application as executable jar all-at-once. You will see application booting up and robot performing couple of mouse click tasks. That is the test phase in Maven process. After Maven complete the install, a executable jar will be generated.

  1. Clone conway-gol repository
  2. Change in conway-gol directory
  3. Run either of the following command from a terminal:
    • mvn clean package (Windows)
    • mvn clean package -DskipTests=true (Mac OS)
  4. Execute either of the following command from a terminal:
    • mvn exec:java -Dexec.mainClass=com.cnb.conway.App
    • mvn clean javafx:run
    • java -jar target/conway-gol.jar
  5. Execute mvn test to run test cases.
    • Known issue with RobotFX behave differently on Mac that mouse is moved out of region only on Mac OS.

Building

Generate MacOS Application Structure jpackage --type app-image --main-jar card-deck-1.0.0-SNAPSHOT.jar --input card-deck/target --dest build Generate DMG File jpackage --type dmg --main-jar card-deck-1.0.0-SNAPSHOT.jar --input card-deck/target --dest build Generate PKG File jpackage --type pkg --main-jar card-deck-1.0.0-SNAPSHOT.jar --input card-deck/target --dest build

Usage

The application is simple because the UI contains 4 UI components: 3 Buttons and a Slider. It is not resizable, and exiting application can be done by clicking on exit button top-right corner of window.

Initial State

Slider, Randomize, and Start Generation are enabled. Stop Population is disabled. The scene display a white background. Nothing special.

Generation State

To view Conway Game of Life simulation, please populate scene with clicking on the Randomize button as this will determine probability of a empty cell being alive or dead for entire grid. The button can be clicked as many times to get desired initial population. After an initial population is found, Start Population button can click to start produce generations.

Slider and Stop Population are enabled. Randomize and Start Generation are disabled. Use slider to decrease or increase generation speed.

Stopped State

Slider, Randomize, and Start Generation are enabled. Stop Population is disabled. The scene show a snapshot of generation frozen in time. Randomize button will erase and re-seed initial population. Start Generation button will resume the generating process.

Future Development

If given extra time, I would include features such as Zoom, Draw Own Pattern, Sizing and Scaling, Colorize Cell, and Display Grid Line. There are more to this than meets the eye. It is interesting to view shapes and patterns of different kinds in this simulation that piqued my curiosity to contemplate ideas and features for future development.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published