diff --git a/.github/workflows/support.yml b/.github/workflows/support.yml new file mode 100644 index 000000000..944addf4c --- /dev/null +++ b/.github/workflows/support.yml @@ -0,0 +1,27 @@ +name: 'Support Requests' + +on: + issues: + types: [labeled, unlabeled, reopened] + +permissions: + issues: write + +jobs: + action: + runs-on: ubuntu-latest + steps: + - uses: dessant/support-requests@v4 + with: + github-token: ${{ github.token }} + support-label: 'support' + issue-comment: > + πŸ‘‹ We use the issue tracker exclusively for bug reports and feature requests. + However, this issue appears to be a support request. Please use our + [support channels](https://github.com/kivy/plyer/blob/master/CONTACT.md) + to get help with the project. + + Let us know if this comment was made in error, and we'll be happy + to reopen the issue. + close-issue: true + lock-issue: false diff --git a/CODE_OF_CONDUCT.md b/CODE_OF_CONDUCT.md new file mode 100644 index 000000000..29d18faa2 --- /dev/null +++ b/CODE_OF_CONDUCT.md @@ -0,0 +1,8 @@ +In the interest of fostering an open and welcoming community, we as +contributors and maintainers need to ensure participation in our project and +our sister projects is a harassment-free and positive experience for everyone. +It is vital that all interaction is conducted in a manner conveying respect, +open-mindedness and gratitude. + +Please consult the [latest Kivy Code of Conduct](https://github.com/kivy/kivy/blob/master/CODE_OF_CONDUCT.md). + diff --git a/CONTACT.md b/CONTACT.md new file mode 100644 index 000000000..a98bb331a --- /dev/null +++ b/CONTACT.md @@ -0,0 +1,8 @@ +.. _contact: + +Contact Us +========== + +If you are looking to contact the Kivy Team (who are responsible for managing the +Plyer project), including looking for support, please see our +`latest contact details `_. \ No newline at end of file diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md new file mode 100644 index 000000000..eccdf08d0 --- /dev/null +++ b/CONTRIBUTING.md @@ -0,0 +1,10 @@ +# Contribution Guidelines + +Plyer is part of the [Kivy](https://kivy.org) ecosystem - a large group of +products used by many thousands of developers for free, but it +is built entirely by the contributions of volunteers. We welcome (and rely on) +users who want to give back to the community by contributing to the project. + +Contributions can come in many forms. See the latest +[Contribution Guidelines](https://github.com/kivy/kivy/blob/master/CONTRIBUTING.md) +for how you can help us. diff --git a/FAQ.md b/FAQ.md new file mode 100644 index 000000000..8d6ee2edc --- /dev/null +++ b/FAQ.md @@ -0,0 +1,13 @@ +# FAQ for Plyer + +## Introduction + +Plyer is a platform-independent Python API for accessing hardware features +of various platforms (Android, iOS, macOS, Linux and Windows). + +Plyer is managed by the [Kivy Team](https://kivy.org/about.html). It is suitable for +use with Kivy apps, but can be used independently. + +## No questions yet + +No Frequently Asked Questions have been identified yet. Please contribute some. diff --git a/LICENSE b/LICENSE index d5d6b13c8..4e3506010 100644 --- a/LICENSE +++ b/LICENSE @@ -1,4 +1,6 @@ -Copyright (c) 2010-2017 Kivy Team and other contributors +MIT License + +Copyright (c) 2010-2023 Kivy Team and other contributors Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal diff --git a/README.md b/README.md index 3a106753c..0afa8a518 100644 --- a/README.md +++ b/README.md @@ -1,134 +1,171 @@ # Plyer -Plyer is a platform-independent api to use features commonly found on various -platforms, notably mobile ones, in Python. +Plyer is a platform-independent Python API for accessing hardware features +of various platforms (Android, iOS, macOS, Linux and Windows). + +Plyer is managed by the [Kivy Team](https://kivy.org/about.html). It is suitable for +use with Kivy apps, but can be used independently. -[![coverage](https://coveralls.io/repos/kivy/plyer/badge.svg?branch=master)](https://coveralls.io/r/kivy/plyer?branch=master) [![Backers on Open Collective](https://opencollective.com/kivy/backers/badge.svg)](#backers) [![Sponsors on Open Collective](https://opencollective.com/kivy/sponsors/badge.svg)](#sponsors) -![Continuous Integration with Ubuntu](https://github.com/kivy/plyer/workflows/Continuous%20Integration%20with%20Ubuntu/badge.svg) +[![GitHub contributors](https://img.shields.io/github/contributors-anon/kivy/plyer)](https://github.com/kivy/plyer/graphs/contributors) +[![Contributor Covenant](https://img.shields.io/badge/Contributor%20Covenant-2.1-4baaaa.svg)](code_of_conduct.md) + + +![PyPI - Version](https://img.shields.io/pypi/v/plyer) +![PyPI - Python Version](https://img.shields.io/pypi/pyversions/plyer) + + +[![coverage](https://coveralls.io/repos/kivy/plyer/badge.svg?branch=master)](https://coveralls.io/r/kivy/plyer?branch=master) +![Continuous Integration with Ubuntu](https://github.com/kivy/plyer/workflows/Continuous%20Integration%20with%20Ubuntu/badge.svg) ![Continuous Integration with OSX](https://github.com/kivy/plyer/workflows/Continuous%20Integration%20with%20OSX/badge.svg) ![Continuous Integration with Windows](https://github.com/kivy/plyer/workflows/Continuous%20Integration%20with%20Windows/badge.svg) ![Deploy to PyPI](https://github.com/kivy/plyer/workflows/Deploy%20to%20PyPI/badge.svg) - ## How plyer works? -Plyer tries not to reinvent the wheel, and will call for external libraries to -implement the api in the easiest way, depending on the current platform. +Plyer tries not to reinvent the wheel, and will call external libraries to +implement the API in the easiest way, depending on the current platform. -- On Android(python-for-android), pyjnius is used -- On iOS(kivy-ios), pyobjus is used -- On windows/mac/linux, commonly found libraries and programs will be used +- On Android ([python-for-android](https://python-for-android.readthedocs.io/)), [PyJNIus](https://pypi.org/project/pyjnius/) is used. +- On iOS ([kivy-ios](https://pypi.org/project/kivy-ios/)) and macOS, + [pyobjus](https://pypi.org/project/pyobjus/) is used. +- On Windows, macOS and Linux, other commonly found libraries and programs + are used. ## Supported APIs -| Platform | Android | iOS | Windows | OS X | Linux | -| ------------------------------ | ------- | --- | ------- | ---- | ----- | -| Accelerometer | βœ” | βœ” | | βœ” | βœ” | -| Audio recording | βœ” | | βœ” | βœ” | | -| Barometer | βœ” | βœ” | | | | -| Battery | βœ” | βœ” | βœ” | βœ” | βœ” | -| Bluetooth | βœ” | | | βœ” | | -| Brightness | βœ” | βœ” | | | βœ” | -| Call | βœ” | βœ” | | | | -| Camera (taking picture) | βœ” | βœ” | | | | -| Compass | βœ” | βœ” | | | | -| CPU count | | | βœ” | βœ” | βœ” | -| Devicename | βœ” | | βœ” | βœ” | βœ” | -| Email (open mail client) | βœ” | βœ” | βœ” | βœ” | βœ” | -| Flash | βœ” | βœ” | | | | -| GPS | βœ” | βœ” | | | | -| Gravity | βœ” | βœ” | | | | -| Gyroscope | βœ” | βœ” | | | | -| Humidity | βœ” | | | | | -| IR Blaster | βœ” | | | | | -| Keystore | βœ” | βœ” | βœ” | βœ” | βœ” | -| Light | βœ” | | | | | -| Maps | | βœ” | | βœ” | | -| Native file chooser | βœ” | βœ” | βœ” | βœ” | βœ” | -| Notifications | βœ” | | βœ” | βœ” | βœ” | -| Orientation | βœ” | | | | βœ” | -| Proximity | βœ” | | | | | -| Screenshot | | | βœ” | βœ” | βœ” | -| SMS (send messages) | βœ” | βœ” | | βœ” | | -| Spatial Orientation | βœ” | βœ” | | | | -| Speech to text | βœ” | | | | | -| Storage Path | βœ” | βœ” | βœ” | βœ” | βœ” | -| Temperature | βœ” | | | | | -| Text to speech | βœ” | βœ” | βœ” | βœ” | βœ” | -| Unique ID | βœ” | βœ” | βœ” | βœ” | βœ” | -| Vibrator | βœ” | βœ” | | | | -| Wifi | | | βœ” | βœ” | βœ” | - +| Platform | Android | iOS | Windows | macOS | Linux | +| ------------------------------ |:-------:|:---:|:-------:|:-----:|:-----:| +| Accelerometer | βœ” | βœ” | | βœ” | βœ” | +| Audio recording | βœ” | | βœ” | βœ” | | +| Barometer | βœ” | βœ” | | | | +| Battery | βœ” | βœ” | βœ” | βœ” | βœ” | +| Bluetooth | βœ” | | | βœ” | | +| Brightness | βœ” | βœ” | | | βœ” | +| Call | βœ” | βœ” | | | | +| Camera (taking picture) | βœ” | βœ” | | | | +| Compass | βœ” | βœ” | | | | +| CPU count | | | βœ” | βœ” | βœ” | +| Devicename | βœ” | | βœ” | βœ” | βœ” | +| Email (open mail client) | βœ” | βœ” | βœ” | βœ” | βœ” | +| Flash | βœ” | βœ” | | | | +| GPS | βœ” | βœ” | | | | +| Gravity | βœ” | βœ” | | | | +| Gyroscope | βœ” | βœ” | | | | +| Humidity | βœ” | | | | | +| IR Blaster | βœ” | | | | | +| Keystore | βœ” | βœ” | βœ” | βœ” | βœ” | +| Light | βœ” | | | | | +| Maps | | βœ” | | βœ” | | +| Native file chooser | βœ” | βœ” | βœ” | βœ” | βœ” | +| Notifications | βœ” | | βœ” | βœ” | βœ” | +| Orientation | βœ” | | | | βœ” | +| Proximity | βœ” | | | | | +| Screenshot | | | βœ” | βœ” | βœ” | +| SMS (send messages) | βœ” | βœ” | | βœ” | | +| Spatial Orientation | βœ” | βœ” | | | | +| Speech to text | βœ” | | | | | +| Storage Path | βœ” | βœ” | βœ” | βœ” | βœ” | +| Temperature | βœ” | | | | | +| Text to speech | βœ” | βœ” | βœ” | βœ” | βœ” | +| Unique ID | βœ” | βœ” | βœ” | βœ” | βœ” | +| Vibrator | βœ” | βœ” | | | | +| Wifi | | | βœ” | βœ” | βœ” | + +## Documentation + +Full documentation, including details about the API, is available +[online](https://plyer.readthedocs.io/en/latest/). If you are not using the +latest version of Plyer, earlier versions of the documentations are linked +from there. ## Installation To use on desktop: `pip install plyer` -To use in python-for-android/kivy-ios: add `plyer` to your requirements if needed. - -## Support +To use in python-for-android and Kivy for iOS, add `plyer` to your requirements +if needed. -If you need assistance, you can ask for help on our mailing list: +## License -* User Group : https://groups.google.com/group/kivy-users -* Email : kivy-users@googlegroups.com +Plyer is [MIT licensed](LICENSE), actively developed by a great +community and is supported by many projects managed by the +[Kivy Organization](https://www.kivy.org/about.html). -Discord channel: +## Support -* Server : https://chat.kivy.org -* Channel : #dev +Are you having trouble using Plyer or any of its related projects in the Kivy +ecosystem? +Is there an error you don’t understand? Are you trying to figure out how to use +it? We have volunteers who can help! +The best channels to contact us for support are listed in the latest +[Contact Us](https://github.com/kivy/plyer/blob/master/CONTACT.md) document. ## Contributing -We love pull requests and discussing novel ideas. Check out our -[contribution guide](http://kivy.org/docs/contribute.html) and -feel free to improve Plyer. - -The following mailing list and IRC channel are used exclusively for -discussions about developing the Kivy framework and its sister projects: +Plyer is part of the [Kivy](https://kivy.org) ecosystem - a large group of +products used by many thousands of developers for free, but it +is built entirely by the contributions of volunteers. We welcome (and rely on) +users who want to give back to the community by contributing to the project. -* Dev Group : https://groups.google.com/group/kivy-dev -* Email : kivy-dev@googlegroups.com +Contributions can come in many forms. See the latest +[Contribution Guidelines](https://github.com/kivy/plyer/blob/master/CONTRIBUTING.md) +for how you can help us. -IRC channel: +## Code of Conduct -* Server : irc.freenode.net -* Port : 6667, 6697 (SSL only) -* Channel : #kivy-dev - - -## License +In the interest of fostering an open and welcoming community, we as +contributors and maintainers need to ensure participation in our project and +our sister projects is a harassment-free and positive experience for everyone. +It is vital that all interaction is conducted in a manner conveying respect, +open-mindedness and gratitude. -Plyer is released under the terms of the MIT License. Please refer to the -LICENSE file. +Please consult the [latest Code of Conduct](https://github.com/kivy/plyer/blob/master/CODE_OF_CONDUCT.md). ## Contributors -This project exists thanks to all the people who contribute. [[Contribute](http://kivy.org/docs/contribute.html)]. +This project exists thanks to +[all the people who contribute](https://github.com/kivy/plyer/graphs/contributors). +[[Become a contributor](CONTRIBUTING.md)]. - + ## Backers -Thank you to all our backers! πŸ™ [[Become a backer](https://opencollective.com/kivy#backer)] - - +Thank you to [all of our backers](https://opencollective.com/kivy)! +πŸ™ [[Become a backer](https://opencollective.com/kivy#backer)] + ## Sponsors -Support this project by becoming a sponsor. Your logo will show up here with a link to your website. [[Become a sponsor](https://opencollective.com/kivy#sponsor)] +Special thanks to +[all of our sponsors, past and present](https://opencollective.com/kivy). +Support this project by +[[becoming a sponsor](https://opencollective.com/kivy#sponsor)]. + +Here are our top current sponsors. Please click through to see their websites, +and support them as they support us. + + + + + + + + + + diff --git a/docs/source/api.rst b/docs/source/api.rst new file mode 100644 index 000000000..7be16c4fe --- /dev/null +++ b/docs/source/api.rst @@ -0,0 +1,11 @@ + +.. _api: + +API +=== + +.. automodule:: plyer + :members: + +.. automodule:: plyer.facades + :members: diff --git a/docs/source/conf.py b/docs/source/conf.py index e08f9fe20..68248b87e 100644 --- a/docs/source/conf.py +++ b/docs/source/conf.py @@ -43,7 +43,7 @@ # General information about the project. project = u'Plyer' -copyright = u'2013, Mathieu Virbel, Akshay Aurora, Gabriel Petier, Ben Rousch' +copyright = u'2013-2023, Kivy Team and other contributors' # The version info for the project you're documenting, acts as replacement for # |version| and |release|, also used in various other places throughout the @@ -189,7 +189,7 @@ # (source start file, target name, title, author, documentclass [howto/manual]) latex_documents = [( 'index', 'Plyer.tex', u'Plyer Documentation', - u'Mathieu Virbel, Akshay Aurora, Gabriel Petier, Ben Rousch', 'manual' + u'Kivy Team and other contributors', 'manual' ), ] # The name of an image file (relative to this directory) to place at the top of @@ -219,7 +219,7 @@ # (source start file, name, description, authors, manual section). man_pages = [ ('index', 'plyer', u'Plyer Documentation', - [u'Mathieu Virbel, Akshay Aurora, Gabriel Petier, Ben Rousch'], 1) + [u'Kivy Team and other contributors'], 1) ] # If true, show URL addresses after external links. @@ -233,8 +233,11 @@ # dir menu entry, description, category) texinfo_documents = [( 'index', 'Plyer', u'Plyer Documentation', - u'Mathieu Virbel, Akshay Aurora, Gabriel Petier, Ben Rousch', - 'Plyer', 'One line description of project.', 'Miscellaneous' + u'Kivy Team and other contributors', + 'Plyer', + 'Plyer is a platform-independent Python API for accessing hardware ' + 'features of various platforms (Android, iOS, macOS, Linux and Windows).', + 'Miscellaneous' ), ] # Documents to append as an appendix to all manuals. diff --git a/docs/source/contact.rst b/docs/source/contact.rst new file mode 100644 index 000000000..d57f1ebea --- /dev/null +++ b/docs/source/contact.rst @@ -0,0 +1,8 @@ +.. _contact: + +Contact Us +========== + +If you are looking to contact the Kivy Team (who are responsible for managing the +Plyer project), including looking for support, please see our +`latest contact details `_. \ No newline at end of file diff --git a/docs/source/contribute.rst b/docs/source/contribute.rst new file mode 100644 index 000000000..651b6a7ea --- /dev/null +++ b/docs/source/contribute.rst @@ -0,0 +1,14 @@ +.. _contribute: + +Contribution Guidelines +======================= + + +Plyer is part of the `Kivy `_ ecosystem - a large group of +products used by many thousands of developers for free, but it +is built entirely by the contributions of volunteers. We welcome (and rely on) +users who want to give back to the community by contributing to the project. + +Contributions can come in many forms. See the latest +[Contribution Guidelines](https://github.com/kivy/plyer/blob/master/CONTRIBUTING.md) +for general guidelines of how you can help us. \ No newline at end of file diff --git a/docs/source/faq.rst b/docs/source/faq.rst new file mode 100644 index 000000000..55ec8476e --- /dev/null +++ b/docs/source/faq.rst @@ -0,0 +1,7 @@ +.. _faq: + +FAQ +=== + +Plyer has an `online FAQ `_. It contains the answers to +questions that repeatedly come up. diff --git a/docs/source/index.rst b/docs/source/index.rst index 20ae9d6f9..57893003e 100644 --- a/docs/source/index.rst +++ b/docs/source/index.rst @@ -1,18 +1,23 @@ -.. Plyer documentation master file, created by - sphinx-quickstart on Wed Jul 3 15:18:02 2013. - You can adapt this file completely to your liking, but it should at least - contain the root `toctree` directive. - Welcome to Plyer ================ -Plyer is a Python library for accessing features of your hardware / platforms. +Plyer is a platform-independent Python API for accessing hardware features +of various platforms (Android, iOS, macOS, Linux and Windows). + +Plyer is managed by the `Kivy Team ` +and is suitable for use with Kivy apps. + +Plyer is released and distributed under the terms of the MIT license. Our +`latest license `_ +is available. -.. automodule:: plyer - :members: +.. toctree:: + :maxdepth: 2 -.. automodule:: plyer.facades - :members: + api + contact + contribute + faq Indices and tables ================== diff --git a/examples/accelerometer/using_graph/libs/garden/garden.graph/__init__.py b/examples/accelerometer/using_graph/libs/garden/garden.graph/__init__.py index 841e83536..28a28e0a9 100644 --- a/examples/accelerometer/using_graph/libs/garden/garden.graph/__init__.py +++ b/examples/accelerometer/using_graph/libs/garden/garden.graph/__init__.py @@ -47,20 +47,28 @@ __all__ = ('Graph', 'Plot', 'MeshLinePlot', 'MeshStemPlot') from math import radians -from kivy.uix.widget import Widget -from kivy.uix.label import Label -from kivy.uix.stencilview import StencilView -from kivy.properties import NumericProperty, BooleanProperty,\ - BoundedNumericProperty, StringProperty, ListProperty, ObjectProperty,\ - DictProperty, AliasProperty +from math import log10, floor, ceil +from decimal import Decimal + +from kivy import metrics from kivy.clock import Clock +from kivy.event import EventDispatcher from kivy.graphics import Mesh, Color from kivy.graphics.transformation import Matrix -from kivy.event import EventDispatcher from kivy.lang import Builder -from kivy import metrics -from math import log10, floor, ceil -from decimal import Decimal +from kivy.properties import ( + NumericProperty, + BooleanProperty, + BoundedNumericProperty, + StringProperty, + ListProperty, + ObjectProperty, + DictProperty, + AliasProperty, +) +from kivy.uix.label import Label +from kivy.uix.stencilview import StencilView +from kivy.uix.widget import Widget Builder.load_string(''' #:kivy 1.1.0 diff --git a/examples/compass/main.py b/examples/compass/main.py index 6a4de0c87..a2bdaa59b 100644 --- a/examples/compass/main.py +++ b/examples/compass/main.py @@ -101,7 +101,7 @@ def get_field(self, dt): def get_field_uncalib(self, dt): if self.facade.field_uncalib != (None, None, None, None, None, None): - self.x_field, self.y_field, self.z_field, self.x_iron,\ + self.x_field, self.y_field, self.z_field, self.x_iron, \ self.y_iron, self.z_iron = self.facade.field_uncalib diff --git a/examples/gyroscope/main.py b/examples/gyroscope/main.py index 636457303..31d2d5bf2 100644 --- a/examples/gyroscope/main.py +++ b/examples/gyroscope/main.py @@ -98,7 +98,7 @@ def get_rotation_uncalib(self, dt): empty = tuple([None for i in range(6)]) if self.facade.rotation_uncalib != empty: - self.x_speed, self.y_speed, self.z_speed, self.x_drift,\ + self.x_speed, self.y_speed, self.z_speed, self.x_drift, \ self.y_drift, self.z_drift = self.facade.rotation_uncalib diff --git a/setup.py b/setup.py index 1467e9245..80f65af73 100644 --- a/setup.py +++ b/setup.py @@ -56,7 +56,8 @@ setup( name='plyer', version=plyer.__version__, - description='Platform-independent wrapper for platform-dependent APIs', + description='A platform-independent Python API for accessing hardware' + 'features of various platforms (Android, iOS, macOS, Linux and Windows).', long_description=README + u"\n\n" + CHANGELOG + u"\n\n", long_description_content_type='text/markdown', author='Kivy team', @@ -69,7 +70,7 @@ license='MIT', zip_safe=False, classifiers=[ - 'Development Status :: 4 - Beta', + 'Development Status :: 5 - Production/Stable', 'Intended Audience :: Developers', 'Natural Language :: English', 'License :: OSI Approved :: MIT License', @@ -81,5 +82,10 @@ 'Programming Language :: Python :: 3.10', 'Programming Language :: Python :: 3.11', ], + project_urls={ + 'Documentation': "https://plyer.readthedocs.io", + 'Source': "https://github.com/kivy/plyer", + 'Bug Reports': "https://github.com/kivy/plyer/issues", + }, **EXTRA_OPTIONS )