Skip to content
/ kivent Public
forked from kivy/kivent

KivEnt is an entity-based game engine for Kivy

Notifications You must be signed in to change notification settings

nboutin/kivent

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

KivEnt

KivEnt is a framework for building performant, dynamic real-time scenes in Kivy. At the moment it is 2d oriented. The only dependency for the kivent_core module is Kivy itself. Additional modules may have other requirements, such as kivent_cymunk module being based on Chipmunk2d and its cymunk wrapper.

An entity-component architecture is used to control game object state and the logic of processing the game objects. This means that your game objects will be made up of collections of independent components that stricly hold data; each component corresponds to a GameSystem that will perform all data processing on the components, in the update loop each frame, and as a result of user interaction or other programmaticaly generated events. All memory for the built-in components is allocated statically: if you would like learn more about memory management, read here.

KivEnt is built with a modular architecture and designed to have both a python api and a c-level cython api that allows more performant access to your game data. This makes it suitable for quickly prototyping a mechanic completely in python, and relatively trivial to then deeply cythonize that GameSystem if you find it to be performance sensitive. This process has already been done for the built-in components meaning they are ready for you to build new, performant game systems on top of them.

The entire framework is made available to you with an MIT license so that you have the freedom to build whatever you want on top of it and monetize it however you like.

##Project Website: http://www.kivent.org

##Mailing List: https://groups.google.com/forum/#!forum/kivent

##Documentation: http://www.kivent.org/docs

##Getting Started Read the introduction on the github wiki.

##Dependencies KivEnt is split into modules, the core module, 'kivent_core', is dependent only on Kivy.

Other modules may have other dependecies, listed here:

###kivent_core:

###kivent_cymunk:

##Installation first install all dependencies then:

cd .../KivEnt/modules/core or .../KivEnt/modules/cymunk

python setup.py build_ext install

##Tested On: Tested with Kivy 1.9.

Tested on Asus Transformer TF101, Droid 4, Droid RAZR M, Ubuntu 14.04, and Windows 8.1

##Windows Kivy Portable Package Installation:

Open the kivy-2.7.bat command console and type:

pip install https://github.com/tito/cymunk/archive/master.zip

Now either download and extract or git clone the KivEnt source:

git clone https://github.com/Kovak/KivEnt.git

Assuming you have KivEnt in the root folder for the portable package, in the kivy-2.7.bat console:

cd KivEnt/modules/core
python setup.py build_ext install
#check core install
cd ../../examples/2_basic_app
python main.py
cd ../../modules/cymunk
python setup.py build_ext install
#check that cymunk install
cd ../../examples/6_controlling_the_viewing_area
python main.py

##Extra detailed installation instructions:

###dependencies

you may need to do something like this sudo apt-get install git

#kivy deps
sudo apt-get install pkg-config python-setuptools python-pygame python-opengl   python-gst0.10 python-enchant gstreamer0.10-plugins-good python-dev   build-essential libgl1-mesa-dev libgles2-mesa-dev

#get pip if you don't have it
sudo easy_install pip

#get cython
sudo pip install cython

###Build and Environment Vars

first get to a folder to clone a couple of projects, replace /path/to/ with /home/myuser/whateverfolderyouwant

cd /path/to/
git clone https://github.com/kivy/kivy.git
git clone https://github.com/tito/cymunk.git
git clone https://github.com/Kovak/KivEnt.git

build kivy

cd kivy
make
cd ..

build cymunk

cd cymunk
python setup.py build_ext --inplace
cd ..

add the following lines to ~/.bashrc (or otherwise add them to your pythonpath)

export PYTHONPATH=/path/to/kivy:$PYTHONPATH 
export PYTHONPATH=/path/to/cymunk/:$PYTHONPATH 

if you have opted for .bashrc, you can either open a new term or run

source ~/.bashrc

you should now be able to build kivent

cd KivEnt/modules/core
python setup.py build_ext --inplace
cd ../../..

and kivent_cymunk (unless you really don't want physics)

cd KivEnt/modules/cymunk
ln -s ../core/kivent_core/ kivent_core
python setup.py build_ext --inplace
cd ../../..

rather than creating the softlink above, you could probably alter your pythonpath, or other method. But I'll stick with ln for now.

###Try it out

If you have got this far you should be able to run some examples - this first one without cymunk working.

cd KivEnt/examples/2_basic_app/
ln -s ../../modules/core/kivent_core/ kivent_core
python main.py

and a physics example

cd KivEnt/examples/4_adding_physics_objects/
ln -s ../../modules/core/kivent_core/ kivent_core
ln -s ../../modules/cymunk/kivent_cymunk/ kivent_cymunk
python main.py

About

KivEnt is an entity-based game engine for Kivy

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 96.8%
  • HTML 1.0%
  • CSS 1.0%
  • Makefile 0.7%
  • Shell 0.5%
  • PHP 0.0%