Giter Site home page Giter Site logo

kimocoder / python-for-android Goto Github PK

View Code? Open in Web Editor NEW

This project forked from kivy/python-for-android

1.0 3.0 0.0 16.44 MB

Turn your Python application into an Android APK

Home Page: https://python-for-android.readthedocs.io

License: MIT License

Python 66.71% Shell 0.23% Makefile 1.16% C 3.42% Java 28.29% C++ 0.02% HTML 0.16% CMake 0.01%

python-for-android's Introduction

python-for-android

Build Status Backers on Open Collective Sponsors on Open Collective

python-for-android is a packager for Python apps on Android. You can create your own Python distribution including the modules and dependencies you want, and bundle it in an APK along with your own code.

Features include:

  • Support for building with both Python 2 and Python 3.
  • Different app backends including Kivy, PySDL2, and a WebView with Python webserver.
  • Automatic support for most pure Python modules, and built in support for many others, including popular dependencies such as numpy and sqlalchemy.
  • Multiple architecture targets, for APKs optimised on any given device.

For documentation and support, see:

Documentation

Follow the quickstart instructions to install and begin creating APKs.

Quick instructions to start would be:

pip install python-for-android

or to test the master branch:

pip install git+https://github.com/kivy/python-for-android.git

The executable is called python-for-android or p4a (both are equivalent). To test that the installation worked, try::

python-for-android recipes

This should return a list of recipes available to be built.

To build any distributions, you need to set up the Android SDK and NDK as described in the documentation linked above.

If you did this, to build an APK with SDL2 you can try e.g.:

p4a apk --requirements=kivy --private /home/asandy/devel/planewave_frozen/ --package=net.inclem.planewavessdl2 --name="planewavessdl2" --version=0.5 --bootstrap=sdl2

For full instructions and parameter options, see the documentation.

Support

If you need assistance, you can ask for help on our mailing list:

We also have #support Discord channel.

Contributing

We love pull requests and discussing novel ideas. Check out our contribution guide and feel free to improve python-for-android.

The following mailing list and IRC channel are used exclusively for discussions about developing the Kivy framework and its sister projects:

We also have #dev Discord channel.

License

python-for-android is released under the terms of the MIT License. Please refer to the LICENSE file.

History

In 2015 these tools were rewritten to provide a new, easier to use and extend interface. If you are looking for the old toolchain with distribute.sh and build.py, it is still available at https://github.com/kivy/python-for-android/tree/old_toolchain, and issues and PRs relating to this branch are still accepted. However, the new toolchain contains all the same functionality via the built in pygame bootstrap.

In the last quarter of 2018 the python recipes has been changed, the new recipe for python3 (3.7.1) has a new build system which has been applied to the ancient python recipe, allowing us to bump the python2 version number to 2.7.15. This change, unifies the build process for both python recipes, and probably solve some issues detected over the years, but unfortunately, this change breaks the pygame bootstrap (in a near future we will fix it or remove it). Also should be mentioned that the old python recipe is still usable, and has been renamed to python2legacy. This python2legacy recipe allow us to build with a minimum api lower than 21, which is not the case for the new python recipes which are limited to a minimum api of 21. All this work has been done using android ndk version r17c, and your build should success with that version...but be aware that the project is in constant development so...the ndk version will change at some time.

Those mentioned changes has been done this way to make easier the transition between python3 and python2. We will slowly phase out python2 support towards 2020...so...if you are using python2 in your projects you should consider to migrate it into python3.

Contributors

This project exists thanks to all the people who contribute. [Contribute].

Backers

Thank you to all our backers! 🙏 [Become a backer]

Sponsors

Support this project by becoming a sponsor. Your logo will show up here with a link to your website. [Become a sponsor]

python-for-android's People

Contributors

inclement avatar tito avatar andremiras avatar kived avatar brussee avatar opacam avatar akshayaurora avatar tshirtman avatar keyweeusr avatar ibobalo avatar goffi-contrib avatar clayote avatar thopiekar avatar germn avatar j-devel avatar thebrokenrail avatar mathewvermeer avatar wexi avatar optimusgreen avatar denys-duchier avatar zen-code avatar cbenhagen avatar b3b avatar dessant avatar misl6 avatar bob-the-hamster avatar trevorjamesmartin avatar alanjds avatar hottwaj avatar kollivier avatar

Stargazers

 avatar

Watchers

James Cloos avatar Christian Bremvåg avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.