0.2.0 • Published 8 years ago

gamevis v0.2.0

Weekly downloads
3
License
MIT
Repository
github
Last release
8 years ago

Gamevis

Gitter

Gamevis is an open-source Electron application for visualising gameplay data developed by Saul Rennison as part of his degree dissertation.

Gamevis is unopinionated and easily fits many genres of games, and includes importers for Counter-Strike: Global Offensive and Dota 2.

Screenshot

Screenshot demonstrating two layered heatmap visualisations:

Installation

1. Prerequisites

Node & npm are already expected to be installed:

brew install libpqxx
npm install -g gulp # required for building
npm install # install app dependencies
gulp # compile JavaScript and stylesheets

2. Database

A Postgres server is by default expected to be running on localhost. The config.json file can be updated at the root of the project to specify a non-default database IP/port.

By default the server is expected to have a database named gamevis with a username and password of gamevis.

Note that no tables need to be generated - the application will automatically generate.

3. Run the app

The application can be started with npm start. However, no sessions are available by default. The importers (see below) can be used to import game sessions into the database.

Visualisations

Multiple visualisations can be show on a single visualisation (as shown in the screenshot):

  • Heatmaps
  • Timeline events (e.g., round start)
  • Discontinuous points (e.g., death location)
  • Continuous points (e.g., player movement)

Importers

GamePathComments
Counter-Strike: Global Offensiveimporters/csgoRun import.js with the path to the demo file as the argument.
Dota 2: Rebornimporters/dota_rebornRun import.go with the path to the .dem replay file as the argument.

Release log

Gamevis is still a work-in-progress and is not expected to be in a production-ready state until Summer 2016. However, changes are committed frequently and any issues should be raised as bugs. Of course pull requests are welcome!

Database

Gamevis expects to connect to a Postgres database of version 9.3 or later due to JSONB querying features. This section details the structure of the database tables, that are automatically generated by the game client.

session

ColumnTypeValue
titlestring, not nullUser-friendly session title
levelstring, not nullName of the level/map/world this session was recorded from, e.g., de_dust2
gamestring, not nullShort name of the game this session is associated with, e.g., csgo. This name will be used as the subdirectory to find the level overview data.
dataJSONB(Optional) Custom data associated with this session.

event

This table represents events that occur throughout a game's session. Events are optionally associated with one or more locations within the game world, and optionally associated with one or more entities.

ColumnTypeValue
session_idforeign key→ session
tickint, not nullGame tick that this event occurred
namestring, not nullName of the event
dataJSONB, not nullEvent-specific data. The data keys for a particular event name are expected to be constant across all instances of it being fired in a particular session
locationsJSONB(Optional) All locations associated with this instance of the event. Keys should be a user-friendly string, and the value a Vector2 object, e.g., {'player': {'x': 500, 'y': 250}}
entitiesJSONB(Optional) All entities associated with this instance of the event. Keys should be a user-friendly string, and the values pointers into the entity_props table, e.g., {'grenade': 175, 'thrower': 11}

entity_props

This table represents the entity properties throughout the recorded session.

ColumnTypeValue
session_idforeign key→ session
indexint, not nullEntity index. Does not have unique across an entire session, just for this entity at this tick
tickint, not nullGame tick that this update occurred
propstring, not nullName of the property that was updated (e.g., health)
valueJSONB, not nullJSON object of the format {'value': newValue} representing the new value of the property.

License

This project is licensed under the MIT license, see LICENSE.md for the full legalese.

Acknowledgements