Multi-platform (Android specifically) MediaGoblin client

Dylan Jeffers 679a568673 Update app version il y a 9 ans
buildozer @ 97f9e293e0 07492c636c Add kivy and buildozer submodule il y a 9 ans
extensions 9424dc5d04 Add kivy and buildozer submodule il y a 9 ans
goblinoid a42db76124 Edit refresh animation speed and base color il y a 9 ans
images 37045ddd2c Add icons :) il y a 9 ans
kivy @ 1e8151f849 9424dc5d04 Add kivy and buildozer submodule il y a 9 ans
.gitignore 69cb2345ac Move main.py and prepend goblinoid to Builder il y a 9 ans
.gitmodules 9424dc5d04 Add kivy and buildozer submodule il y a 9 ans
LICENSE cf073d22a9 Init commit il y a 9 ans
MediaGoblin.jpg 23e03cfed8 Add note about versioning in main.py il y a 9 ans
README.md 9424dc5d04 Add kivy and buildozer submodule il y a 9 ans
buildozer.spec 83f7bde313 Merge branch 'develop' il y a 9 ans
main.py 679a568673 Update app version il y a 9 ans
mediagoblin.kv 485fd3a4f0 Add personal rv for good scrolling il y a 9 ans
requirements.txt 789eab264c Edit README now more intuitive il y a 9 ans
setup.py b11e5c8f65 Edit simplify setup.py build process il y a 9 ans

README.md

MediaGoblinApp

I. General Information

Project name: MediaGoblin 
Current devs: Dylan Jeffers, Christopher Webber
Outline: Android App for MediaGoblin using PyPump  Summer 2015
    - GSOC (Google Summer of Code) project to develop an Android client
        for MediaGoblin
    - Project is a Kivy application, which is written in Python. We chose Kivy
        as it allows us to use the MediaGoblin codebase
    - Uses 100% free software
    - GPLv3 or later license

II. Getting Started

Requirements:
    A MediaGoblin account:
        - There are many different MediaGoblin instances to choose from
            - We recommend pump.goblinrefuge.com
        - To create your own MediaGoblin instance, follow the guide at:
            https://mediagoblin.readthedocs.org/en/stable/siteadmin/deploying.html
User Installation Guide:
    Android app is available on F-Droid app store

Developer Installation Guide:
    The Plan:
        Install a combination of system-wide packages and
        virtualenv packages

    0. Clone the repo
      - cd into a dir of your choice and clone the repo:
        git clone https://notabug.org/SapienTech/MediaGoblinApp
        cd MediaGoblinApp
      - and init the submodules:
        git submodule init && git submodule update

    1. Download the following system-wide dependencies:
        sudo apt-get install -y \
        build-essential \
        mercurial \
        git \
        python2.7 \
        python-setuptools \
        python-dev \
        libsdl-image1.2-dev \
        libsdl-mixer1.2-dev \
        libsdl-ttf2.0-dev \
        libsmpeg-dev \
        libsdl1.2-dev \
        libportmidi-dev \
        libswscale-dev \
        libavformat-dev \
        libavcodec-dev \
        zlib1g-dev \
        python-pip \
        python-virtualenv

    2. Set up a virtual environment (in MediaGoblinApp dir):
        virtualenv env

       And activate it:
        source env/bin/activate

    3. Install dependencies:
        pip install -r requirements.txt

    4. Build the project:
      - In the project directory:
        python setup.py develop

      - This will allow you to run kivy from the computer, to install an android
        apk, continue to step 5.

    5. Compiling the Android apk:
        buildozer android debug

     - To run on phone after compiling:
        buildozer android deploy run logcat

III. Testing

- As compiling an apk takes time, it is recommended to first test on the computer,
  before debuging an apk.
    - Note, however that some functionality is exclusive to Android

IV. Contributing

- Contributing to this project is a great opportunity to hone mobile development skills.
As this project is small, but part of the larger MediaGoblin community,
contributers have a great opportunity to fully understand and engage with a
piece of software, while also benefiting from the structure and support of
an established free software community.

- If you feel like reaching out to contribute/learn more/just chat, feel 
free to ping SapienTech on irc.freenode.net in #mediagoblin, or connect
through email at sapientechnology@openmailbox.com

V. Licenses

GPLv3 or later

VI. Contact

Dylan Jeffers: sapientechnology@openmailbox.com