diff options
Diffstat (limited to 'python-pyforms-gui.spec')
-rw-r--r-- | python-pyforms-gui.spec | 475 |
1 files changed, 475 insertions, 0 deletions
diff --git a/python-pyforms-gui.spec b/python-pyforms-gui.spec new file mode 100644 index 0000000..637ea01 --- /dev/null +++ b/python-pyforms-gui.spec @@ -0,0 +1,475 @@ +%global _empty_manifest_terminate_build 0 +Name: python-PyForms-GUI +Version: 5 +Release: 1 +Summary: Pyforms is a Python framework to develop GUI applications based on pyqt +License: MIT +URL: https://github.com/UmSenhorQualquer/pyforms-gui +Source0: https://mirrors.nju.edu.cn/pypi/web/packages/ab/6b/ca7bb86ddbf6cb557589e42eb4cf249afe480b4af92aaf83f020a6600a51/PyForms%20GUI-5.tar.gz +BuildArch: noarch + +Requires: python3-anyqt +Requires: python3-PyQtWebEngine +Requires: python3-pyopengl +Requires: python3-visvis +Requires: python3-matplotlib +Requires: python3-dateutil +Requires: python3-numpy +Requires: python3-opencv-python +Requires: python3-confapp +Requires: python3-natsort +Requires: python3-coloredlogs +Requires: python3-pyqt5 +Requires: python3-QScintilla + +%description + +If you find this project useful, please, do not forget to  it. + + +# Pyforms GUI + +Pyforms **GUI** is a software layer, part of the Pyforms main library. This layer implements the execution of a Pyforms application as Windows GUI. + + + + + +# Pyforms + +<!-- Posicione esta tag onde você deseja que o widget apareça. --> +<div class="g-follow" data-annotation="bubble" data-height="24" data-rel="publisher"></div> + +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 @ ](https://pyforms.readthedocs.io) + + +## 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 GUI +* [Python Video Annotator](https://github.com/UmSenhorQualquer/pythonVideoAnnotator) +* [3D tracking analyser](https://github.com/UmSenhorQualquer/3D-tracking-analyser) +* [PyBpod](http://pybpod.readthedocs.io) + +## Installation + +Check the documentation at [pyforms.readthedocs.org](http://pyforms.readthedocs.org) and [pyforms-gui.readthedocs.org](http://pyforms-gui.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](https://www.djangoproject.com/) 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: + +```python +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') + + self.set_margin(10) + + #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: + +```bash + +$> python test.py +``` + + + + + + +%package -n python3-PyForms-GUI +Summary: Pyforms is a Python framework to develop GUI applications based on pyqt +Provides: python-PyForms-GUI +BuildRequires: python3-devel +BuildRequires: python3-setuptools +BuildRequires: python3-pip +%description -n python3-PyForms-GUI + +If you find this project useful, please, do not forget to  it. + + +# Pyforms GUI + +Pyforms **GUI** is a software layer, part of the Pyforms main library. This layer implements the execution of a Pyforms application as Windows GUI. + + + + + +# Pyforms + +<!-- Posicione esta tag onde você deseja que o widget apareça. --> +<div class="g-follow" data-annotation="bubble" data-height="24" data-rel="publisher"></div> + +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 @ ](https://pyforms.readthedocs.io) + + +## 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 GUI +* [Python Video Annotator](https://github.com/UmSenhorQualquer/pythonVideoAnnotator) +* [3D tracking analyser](https://github.com/UmSenhorQualquer/3D-tracking-analyser) +* [PyBpod](http://pybpod.readthedocs.io) + +## Installation + +Check the documentation at [pyforms.readthedocs.org](http://pyforms.readthedocs.org) and [pyforms-gui.readthedocs.org](http://pyforms-gui.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](https://www.djangoproject.com/) 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: + +```python +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') + + self.set_margin(10) + + #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: + +```bash + +$> python test.py +``` + + + + + + +%package help +Summary: Development documents and examples for PyForms-GUI +Provides: python3-PyForms-GUI-doc +%description help + +If you find this project useful, please, do not forget to  it. + + +# Pyforms GUI + +Pyforms **GUI** is a software layer, part of the Pyforms main library. This layer implements the execution of a Pyforms application as Windows GUI. + + + + + +# Pyforms + +<!-- Posicione esta tag onde você deseja que o widget apareça. --> +<div class="g-follow" data-annotation="bubble" data-height="24" data-rel="publisher"></div> + +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 @ ](https://pyforms.readthedocs.io) + + +## 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 GUI +* [Python Video Annotator](https://github.com/UmSenhorQualquer/pythonVideoAnnotator) +* [3D tracking analyser](https://github.com/UmSenhorQualquer/3D-tracking-analyser) +* [PyBpod](http://pybpod.readthedocs.io) + +## Installation + +Check the documentation at [pyforms.readthedocs.org](http://pyforms.readthedocs.org) and [pyforms-gui.readthedocs.org](http://pyforms-gui.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](https://www.djangoproject.com/) 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: + +```python +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') + + self.set_margin(10) + + #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: + +```bash + +$> python test.py +``` + + + + + + +%prep +%autosetup -n PyForms-GUI-5 + +%build +%py3_build + +%install +%py3_install +install -d -m755 %{buildroot}/%{_pkgdocdir} +if [ -d doc ]; then cp -arf doc %{buildroot}/%{_pkgdocdir}; fi +if [ -d docs ]; then cp -arf docs %{buildroot}/%{_pkgdocdir}; fi +if [ -d example ]; then cp -arf example %{buildroot}/%{_pkgdocdir}; fi +if [ -d examples ]; then cp -arf examples %{buildroot}/%{_pkgdocdir}; fi +pushd %{buildroot} +if [ -d usr/lib ]; then + find usr/lib -type f -printf "/%h/%f\n" >> filelist.lst +fi +if [ -d usr/lib64 ]; then + find usr/lib64 -type f -printf "/%h/%f\n" >> filelist.lst +fi +if [ -d usr/bin ]; then + find usr/bin -type f -printf "/%h/%f\n" >> filelist.lst +fi +if [ -d usr/sbin ]; then + find usr/sbin -type f -printf "/%h/%f\n" >> filelist.lst +fi +touch doclist.lst +if [ -d usr/share/man ]; then + find usr/share/man -type f -printf "/%h/%f.gz\n" >> doclist.lst +fi +popd +mv %{buildroot}/filelist.lst . +mv %{buildroot}/doclist.lst . + +%files -n python3-PyForms-GUI -f filelist.lst +%dir %{python3_sitelib}/* + +%files help -f doclist.lst +%{_docdir}/* + +%changelog +* Fri May 05 2023 Python_Bot <Python_Bot@openeuler.org> - 5-1 +- Package Spec generated |