Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/yjg30737/pyqt-slideshow
PyQt widget for slide show
https://github.com/yjg30737/pyqt-slideshow
carousel gui-slideshow pyqt pyqt-examples pyqt-gui pyqt5 pyqt5-examples pyqt5-gui qbuttongroup qgraphicsview qt qt5 qtimer qwidget slideshow
Last synced: about 1 month ago
JSON representation
PyQt widget for slide show
- Host: GitHub
- URL: https://github.com/yjg30737/pyqt-slideshow
- Owner: yjg30737
- License: mit
- Created: 2022-05-27T02:00:47.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2023-02-19T05:16:52.000Z (almost 2 years ago)
- Last Synced: 2024-12-20T17:11:54.700Z (about 1 month ago)
- Topics: carousel, gui-slideshow, pyqt, pyqt-examples, pyqt-gui, pyqt5, pyqt5-examples, pyqt5-gui, qbuttongroup, qgraphicsview, qt, qt5, qtimer, qwidget, slideshow
- Language: Python
- Homepage:
- Size: 6.76 MB
- Stars: 17
- Watchers: 1
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# pyqt-slideshow
PyQt widget for slide show## Requirements
* PyQt5 >= 5.8## Setup
`python -m pip install pyqt-slideshow`## Detailed Description
![image](https://user-images.githubusercontent.com/55078043/170638847-1816f292-f731-49bc-bbb3-d7180e7ec779.png)
This widget mainly consists of three child widget.
* View
* Navigation button widget - buttons on the both sides of the view
* Bottom button widget - buttons at the bottomYou can set the image files to show with `setFilenames`.
You can watch previous/next image by clicking the navigation button or nth image file by clicking the buttons at the bottom.
Image is automatically changed by internal timer(QTimer). Interval is set to 5000 milliseconds by default.
## Method Overview
* `setFilenames(filenames: list)` - give the image files. You have to call this one time only so far.
* `setTimerEnabled(f: bool)` - set the image change timer
* `setInterval(milliseconds: int)` - set the image change interval
* `setNavigationButtonVisible(f: bool)` - set the navigation button's visibility(which also decides that you use it or not)
* `setBottomButtonVisible(f: bool)` - set the bottom button's visibility(which also decides that you use it or not)
* `setGradientEnabled(f: bool)` - Cover the dark gradient over the imageFor example
* `getButtonGroup()` - get the button group(QButtonGroup) which has the every button. You can get them by `btnGrp.buttons()`
* `getBtnWidget()` - get the btn widget to set the spacing between the bottom button or other customization of button widget
* `getPrevBtn()` - get the prev button
* `getNextBtn()` - get the next button## Example
### Code Sample 1 (Including navigation/bottom button)
```python
from PyQt5.QtWidgets import QApplication
from pyqt_slideshow import SlideShowif __name__ == "__main__":
import sysapp = QApplication(sys.argv)
s = SlideShow()
s.setFilenames(['bioshock.jpg', 'dragon_age.jpg', 'ride_to_hell_retribution.jpg'])
s.show()
app.exec_()
```### Result
https://user-images.githubusercontent.com/55078043/170615616-932fb93d-3311-4f97-8ad7-10943e0d2308.mp4
### Code Sample 2 (Not including navigation/bottom button)
```python
from PyQt5.QtWidgets import QApplication
from pyqt_slideshow import SlideShowif __name__ == "__main__":
import sysapp = QApplication(sys.argv)
s = SlideShow()
s.setFilenames(['bioshock.jpg', 'dragon_age.jpg', 'ride_to_hell_retribution.jpg'])
s.setNavigationButtonVisible(False) # to not show the navigation button
s.setBottomButtonVisible(False) # to not show the bottom button
s.show()
app.exec_()
```### Result
https://user-images.githubusercontent.com/55078043/170641896-336308b5-6f5c-4099-8b03-029a1f81337e.mp4
## TODO list
* Give the option to go back to first page by user when pressing the next button in the last page
* Transition effect
* Default screen when there is no image (thumbnail?)
* Add more styles with QML