Skip to main content

Pyforms terminal is a software layer, part of the Pyforms main library. This layer implements the execution of a Pyforms application in the terminal.

Project description

Important
If you find this project useful, please, do not forget to star it it.

Pyforms Terminal

Pyforms Terminal is a software layer, part of the Pyforms main library. This layer implements the execution of a Pyforms application in the terminal.

Diagram

Pyforms

Pyforms is a Python 3 cross-enviroment framework that aims the boost the development productivity. The library provides an API in Python to develop applications that can be executed in Windows GUI mode, Web mode, or in Terminal mode.

More @ Diagram

Advantages

  • With a minimal API, interfaces are easily defined using a short Python code.
  • Avoid the constant switching between the GUI designers and the Python IDE.
  • It is designed to allow the coding of advanced functionalities with a minimal effort.
  • The code is organized in modules and prepared to be reused by other applications.
  • It makes the applications maintenance easier.
  • Turn the prototyping much easier and fast.
  • Due to its simplicity it has a low learning curve.

Examples of applications developed in Pyforms Terminal

Installation

Check the documentation at pyforms.readthedocs.org and pyforms-terminal.readthedocs.org

Rationale behind the framework

The development of this library started with the necessity of allowing users with low programming skills to edit parameters from my python scripts. The idea was to transform scripts which had already been developed into GUI applications with a low effort and in a short time.

For example in my computer vision applications in the majority of the times there were variables that had to be set manually in the scripts for each video, to adjust the thresholds, blobs sizes, and other parameters to the environment light conditions... To test each set of parameters the script had to be executed. With GUI applications, users would be able to set the parameters using a GUI interface and visualize the results instantly without the need of restarting the script. That was the idea.

After looking into the several python options for GUI interfaces, PyQt was the one that seemed the best tool for a fast development with the QtDesigner, but after a while developing in Qt, switching between the designer and the python IDE was becoming too costly in terms of time because the interfaces were constantly evolving.

Being a Django developer, I did get inspiration on it for this framework. In the Django Models we just need to define the type of variables and their disposition in the form (in ModelAdmin) to generate a HTML form for data edition. For the GUIs that I wanted to build in my python scripts, I would like to have the same simplicity, so I could focus on the algorithms and not on GUIs developing.

The result was the simplicity you can see in the example below:

from pyforms.basewidget import BaseWidget
from pyforms.controls   import ControlFile
from pyforms.controls   import ControlText
from pyforms.controls   import ControlSlider
from pyforms.controls   import ControlPlayer
from pyforms.controls   import ControlButton

class ComputerVisionAlgorithm(BaseWidget):

    def __init__(self, *args, **kwargs):
        super().__init__('Computer vision algorithm example')

        #Definition of the forms fields
        self._videofile  = ControlFile('Video')
        self._outputfile = ControlText('Results output file')
        self._threshold  = ControlSlider('Threshold', default=114, minimum=0, maximum=255)
        self._blobsize   = ControlSlider('Minimum blob size', default=110, minimum=100, maximum=2000)
        self._player     = ControlPlayer('Player')
        self._runbutton  = ControlButton('Run')

        #Define the function that will be called when a file is selected
        self._videofile.changed_event     = self.__videoFileSelectionEvent
        #Define the event that will be called when the run button is processed
        self._runbutton.value       = self.__runEvent
        #Define the event called before showing the image in the player
        self._player.process_frame_event    = self.__process_frame

        #Define the organization of the Form Controls
        self._formset = [
            ('_videofile', '_outputfile'),
            '_threshold',
            ('_blobsize', '_runbutton'),
            '_player'
        ]


    def __videoFileSelectionEvent(self):
        """
        When the videofile is selected instanciate the video in the player
        """
        self._player.value = self._videofile.value

    def __process_frame(self, frame):
        """
        Do some processing to the frame and return the result frame
        """
        return frame

    def __runEvent(self):
        """
        After setting the best parameters run the full algorithm
        """
        pass


if __name__ == '__main__':

    from pyforms import start_app
    start_app(ComputerVisionAlgorithm)

Result of runnning the application in the terminal:

$> python test.py terminal_mode --help

ScreenShot

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

PyForms-Terminal-4.0.10.tar.gz (15.8 kB view details)

Uploaded Source

Built Distribution

PyForms_Terminal-4.0.10-py3-none-any.whl (27.3 kB view details)

Uploaded Python 3

File details

Details for the file PyForms-Terminal-4.0.10.tar.gz.

File metadata

  • Download URL: PyForms-Terminal-4.0.10.tar.gz
  • Upload date:
  • Size: 15.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.6.8

File hashes

Hashes for PyForms-Terminal-4.0.10.tar.gz
Algorithm Hash digest
SHA256 50fd0e44b70f5b0b6ca8224fbdf91db236dc874a135202dc3513ab4ed9ba6aa6
MD5 db2cc23a4dd9b45ce3b4af3c6e215020
BLAKE2b-256 5984294f67879d1d6b1b01f4c16c9ba9324fbe5a67186a88c933ac6bc1fb5624

See more details on using hashes here.

File details

Details for the file PyForms_Terminal-4.0.10-py3-none-any.whl.

File metadata

  • Download URL: PyForms_Terminal-4.0.10-py3-none-any.whl
  • Upload date:
  • Size: 27.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.6.8

File hashes

Hashes for PyForms_Terminal-4.0.10-py3-none-any.whl
Algorithm Hash digest
SHA256 eae4a524a0fc385829a427ef9884002023a01e7f3f6342043c21a99a35444a8c
MD5 7e439c6c64ab6a65333d384c9a440bc6
BLAKE2b-256 0f1e09d0785eb3eae83ade5917975e464b246bcdc89bd968dff74bef6d12d11b

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page