2010-12-21 01:13:06 +00:00
|
|
|
.. _installation:
|
|
|
|
|
|
|
|
Installation
|
|
|
|
============
|
|
|
|
|
2012-07-08 09:36:49 +00:00
|
|
|
We try not to reinvent the wheel, but to bring something innovative to the
|
2012-10-16 09:19:01 +00:00
|
|
|
market. As a consequence, we're focused on our own code and use pre-existing,
|
2012-07-08 09:36:49 +00:00
|
|
|
high-quality third-party libraries where possible.
|
|
|
|
To support the full, rich set of features that Kivy offers, several other libraries are
|
2013-04-20 07:00:40 +00:00
|
|
|
required. If you do not use a specific feature (e.g. video playback), you
|
|
|
|
don't need the corresponding dependency.
|
2011-03-16 17:19:57 +00:00
|
|
|
That said, there is one dependency that Kivy **does** require:
|
2011-01-07 17:41:54 +00:00
|
|
|
`Cython <http://cython.org>`_.
|
2011-03-16 17:19:57 +00:00
|
|
|
|
2012-10-16 09:19:01 +00:00
|
|
|
In addition, you need a `Python <http://python.org/>`_ 2.x (2.6 <= x < 3.0)
|
2013-04-20 07:00:40 +00:00
|
|
|
interpreter. If you want to enable features like windowing (i.e. open a Window),
|
2011-03-16 19:18:07 +00:00
|
|
|
audio/video playback or spelling correction, additional dependencies must
|
|
|
|
be available. For these, we recommend `Pygame <http://pygame.org>`_, `Gst-Python
|
2010-12-21 01:13:06 +00:00
|
|
|
<http://www.gstreamer.net/modules/gst-python.html>`_ and `Enchant
|
2011-01-02 16:34:18 +00:00
|
|
|
<http://www.rfk.id.au/software/pyenchant/>`_, respectively.
|
2010-12-21 01:13:06 +00:00
|
|
|
|
2012-07-08 09:36:49 +00:00
|
|
|
Other optional libraries (mutually independent) are:
|
2011-03-16 17:19:57 +00:00
|
|
|
|
|
|
|
* `OpenCV 2.0 <http://sourceforge.net/projects/opencvlibrary/>`_ -- Camera input.
|
|
|
|
* `PIL <http://www.pythonware.com/products/pil/index.htm>`_ -- Image and text display.
|
|
|
|
* `PyCairo <http://www.cairographics.org/pycairo/>`_ -- Text display.
|
|
|
|
* `PyEnchant <http://www.rfk.id.au/software/pyenchant/>`_ -- Spelling correction.
|
|
|
|
* `PyGST <http://gstreamer.freedesktop.org/ + http://pygstdocs.berlios.de/>`_ -- Audio/video playback and camera input.
|
|
|
|
|
|
|
|
|
|
|
|
That said, **DON'T PANIC**!
|
2010-12-21 01:13:06 +00:00
|
|
|
|
2013-04-20 07:00:40 +00:00
|
|
|
We don't expect you to install all those things on your own.
|
|
|
|
Instead, we have created nice portable packages that you can use directly,
|
|
|
|
and they already contain the necessary packages for your platform.
|
|
|
|
We just want you to know that there are alternatives to the defaults and give
|
|
|
|
you an overview of the things Kivy uses internally.
|
2010-12-21 01:13:06 +00:00
|
|
|
|
|
|
|
|
2011-03-16 17:19:57 +00:00
|
|
|
Stable Version
|
2010-12-21 01:13:06 +00:00
|
|
|
--------------
|
|
|
|
|
2013-04-20 07:00:40 +00:00
|
|
|
The latest stable version can be found on Kivy's website at http://kivy.org/#download.
|
2011-03-16 17:19:57 +00:00
|
|
|
Please refer to the installation instructions for your specific platform:
|
2010-12-21 01:13:06 +00:00
|
|
|
|
2011-02-01 10:24:24 +00:00
|
|
|
.. toctree::
|
2011-03-16 19:18:07 +00:00
|
|
|
:maxdepth: 2
|
2011-02-01 10:24:24 +00:00
|
|
|
|
2011-03-16 15:07:40 +00:00
|
|
|
installation-windows
|
2011-03-16 15:04:34 +00:00
|
|
|
installation-macosx
|
2012-01-12 10:28:22 +00:00
|
|
|
installation-linux
|
2011-03-16 15:04:34 +00:00
|
|
|
installation-android
|
2011-01-30 12:43:20 +00:00
|
|
|
|
2011-03-16 19:18:07 +00:00
|
|
|
|
2012-03-23 01:22:05 +00:00
|
|
|
.. _installation_devel:
|
|
|
|
|
2011-01-30 12:43:20 +00:00
|
|
|
Development Version
|
2010-12-21 01:13:06 +00:00
|
|
|
-------------------
|
|
|
|
|
2011-01-30 12:43:20 +00:00
|
|
|
The development version is for developers and testers. Note that when
|
|
|
|
running a development version, you're running potentially broken code at
|
|
|
|
your own risk.
|
|
|
|
To use the development version, you will first need to install the
|
2013-04-20 07:00:40 +00:00
|
|
|
dependencies. Thereafter, you will need to set up Kivy on your computer
|
|
|
|
in a way that allows for easy development. For that, please see our
|
2011-01-30 12:43:20 +00:00
|
|
|
:ref:`contributing` document.
|
|
|
|
|
|
|
|
Installing Dependencies
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
To install Kivy's dependencies, follow the guide below for your platform.
|
2010-12-21 01:13:06 +00:00
|
|
|
|
|
|
|
Ubuntu
|
2011-01-30 12:43:20 +00:00
|
|
|
++++++
|
|
|
|
|
2013-04-23 07:59:09 +00:00
|
|
|
For Ubuntu 12.04, simply enter the following command that will install all
|
2013-04-20 07:00:40 +00:00
|
|
|
necessary packages::
|
2010-12-21 01:13:06 +00:00
|
|
|
|
2013-04-23 07:59:09 +00:00
|
|
|
$ sudo apt-get install python-setuptools python-pygame python-opengl \
|
|
|
|
python-gst0.10 python-enchant gstreamer0.10-plugins-good python-dev \
|
|
|
|
build-essential libgl1-mesa-dev-lts-quantal libgles2-mesa-dev-lts-quantal\
|
|
|
|
python-pip
|
|
|
|
|
|
|
|
For other versions of Ubuntu, this one should work::
|
|
|
|
|
2011-01-22 14:11:02 +00:00
|
|
|
$ sudo apt-get install python-setuptools python-pygame python-opengl \
|
2012-10-01 22:33:11 +00:00
|
|
|
python-gst0.10 python-enchant gstreamer0.10-plugins-good python-dev \
|
|
|
|
build-essential libgl1-mesa-dev libgles2-mesa-dev python-pip
|
|
|
|
|
2013-04-20 07:00:40 +00:00
|
|
|
Kivy requires a recent version of Cython, so it's better to use the last
|
|
|
|
version published on pypi::
|
2012-10-01 22:33:11 +00:00
|
|
|
|
|
|
|
$ sudo pip install --upgrade cython
|
2010-12-21 01:13:06 +00:00
|
|
|
|
2013-07-07 14:57:21 +00:00
|
|
|
Mac OS X
|
|
|
|
++++++++
|
|
|
|
|
|
|
|
You will need to install at least the following:
|
|
|
|
|
|
|
|
* PyGame - we recommend installing from a binary packaged for your version
|
|
|
|
of Mac OS X. Download it from http://www.pygame.org/download.shtml
|
|
|
|
|
|
|
|
If you run into problems, please read :ref:`troubleshooting-macosx`.
|
|
|
|
|
2011-01-30 19:16:09 +00:00
|
|
|
.. _dev-install:
|
2011-01-22 14:11:02 +00:00
|
|
|
|
2011-01-30 19:16:09 +00:00
|
|
|
Installing Kivy for Development
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2010-12-21 01:13:06 +00:00
|
|
|
|
2011-01-30 19:16:09 +00:00
|
|
|
Now that you've installed all the required dependencies, it's time to
|
|
|
|
download and compile a development version of Kivy::
|
|
|
|
|
|
|
|
$ # Download Kivy from GitHub
|
2011-12-16 09:54:33 +00:00
|
|
|
$ git clone git://github.com/kivy/kivy.git
|
2011-01-30 19:16:09 +00:00
|
|
|
$ cd kivy
|
|
|
|
|
|
|
|
$ # Compile:
|
2011-02-10 12:32:11 +00:00
|
|
|
$ python setup.py build_ext --inplace -f
|
2011-01-30 19:16:09 +00:00
|
|
|
|
|
|
|
If you have the ``make`` command available, you can also use the
|
2011-03-16 17:19:57 +00:00
|
|
|
following shortcut to compile (does the same as the last command)::
|
2011-01-30 19:16:09 +00:00
|
|
|
|
2011-03-16 17:19:57 +00:00
|
|
|
$ make
|
2011-01-30 19:16:09 +00:00
|
|
|
|
2011-10-24 07:59:35 +00:00
|
|
|
If you want to modify the Kivy code itself, set up the `PYTHONPATH environment
|
|
|
|
variable
|
|
|
|
<http://docs.python.org/tutorial/modules.html#the-module-search-path>`_ to
|
|
|
|
point at your clone.
|
2011-01-30 19:16:09 +00:00
|
|
|
This way you don't have to install (``setup.py install``) after every tiny
|
|
|
|
modification. Python will instead import Kivy from your clone.
|
|
|
|
|
2013-04-20 07:00:40 +00:00
|
|
|
Alternatively, if you don't want to make any changes to Kivy itself, you can
|
|
|
|
also run (as admin, e.g. with sudo)::
|
2011-01-30 19:16:09 +00:00
|
|
|
|
|
|
|
$ python setup.py install
|
|
|
|
|
|
|
|
If you want to contribute code (patches, new features) to the Kivy
|
2011-03-16 17:19:57 +00:00
|
|
|
code base, please read :ref:`contributing`.
|
2011-10-24 07:59:35 +00:00
|
|
|
|
2012-05-25 16:10:49 +00:00
|
|
|
Running the test suite
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
2013-04-20 07:00:40 +00:00
|
|
|
To help detect issues and behaviour changes in Kivy, a set of unittests are
|
|
|
|
provided. A good thing to do is to run them just after your Kivy installation, and
|
|
|
|
every time you intend to push a change. If you think something was broken
|
|
|
|
in Kivy, perhaps a test will show this? If not, it might be a good time to write
|
2012-05-25 16:10:49 +00:00
|
|
|
one .)
|
|
|
|
|
2013-04-20 07:00:40 +00:00
|
|
|
Kivy tests are based on nosetest, which you can install from your package
|
2012-05-25 16:10:49 +00:00
|
|
|
manager or using pip :
|
|
|
|
|
2012-08-31 02:11:24 +00:00
|
|
|
$ pip install nose
|
2012-05-25 16:10:49 +00:00
|
|
|
|
2013-04-20 07:00:40 +00:00
|
|
|
To run the test suite, do :
|
2012-05-25 16:10:49 +00:00
|
|
|
|
|
|
|
$ make test
|
|
|
|
|
2011-10-24 07:59:35 +00:00
|
|
|
Uninstalling Kivy
|
|
|
|
~~~~~~~~~~~~~~~~~
|
|
|
|
|
2012-07-08 09:36:49 +00:00
|
|
|
If you are mixing multiple Kivy installations, you might be confused about where each Kivy version is
|
2013-04-20 07:00:40 +00:00
|
|
|
located. Please note that you might need to follow these steps multiple times if you have multiple
|
|
|
|
Kivy versions installed in the Python library path.
|
2012-07-22 15:08:33 +00:00
|
|
|
To find your current installed version, you can use the command line::
|
2011-10-24 07:59:35 +00:00
|
|
|
|
2013-05-31 09:12:21 +00:00
|
|
|
$ python -c 'import kivy; print(kivy.__path__)'
|
2011-10-24 07:59:35 +00:00
|
|
|
|
|
|
|
Then, remove that directory recursively.
|
|
|
|
|
2012-07-08 09:36:49 +00:00
|
|
|
If you have installed Kivy with easy_install on linux, the directory may
|
|
|
|
contain a "egg" directory. Remove that as well::
|
2011-10-24 07:59:35 +00:00
|
|
|
|
2013-05-31 09:12:21 +00:00
|
|
|
$ python -c 'import kivy; print(kivy.__path__)'
|
2011-10-24 07:59:35 +00:00
|
|
|
['/usr/local/lib/python2.7/dist-packages/Kivy-1.0.7-py2.7-linux-x86_64.egg/kivy']
|
|
|
|
$ sudo rm -rf /usr/local/lib/python2.7/dist-packages/Kivy-1.0.7-py2.7-linux-x86_64.egg
|
|
|
|
|
|
|
|
If you have installed with apt-get, do::
|
|
|
|
|
|
|
|
$ sudo apt-get remove --purge python-kivy
|