Skip to content

Latest commit

 

History

History

03 QVBoxLayout PyQt5

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 

QVBoxLayout PyQt5

Layouts let you position GUI elements next to each other. QVBoxLayout for instance arranges items vertically:

QVBoxLayout PyQt5

The source code for this example is not much more complex than for our Hello World app. First, we import PyQt5:

from PyQt5.QtWidgets import *

Then, we create the required QApplication:

app = QApplication([])

This time, we create a top-level window first. This will act as the container for the two buttons you see in the screenshot:

window = QWidget()

QWidget is the most basic kind of widget. It would simply be empty if we didn't add any contents to it. (Kind of like a <div> element in HTML.).

To tell Qt to arrange our buttons vertically, we create a QVBoxLayout:

layout = QVBoxLayout()

Then, we add the two buttons to it:

layout.addWidget(QPushButton('Top'))
layout.addWidget(QPushButton('Bottom'))

Finally, we add the layout - and thus its contents - to the window we created above:

window.setLayout(layout)

We conclude by showing the window and (as is required) handing control over to Qt:

window.show()
app.exec_()

For instructions how you can run this example yourself, please see here.

The related QHBoxLayout positions items horizontally. For an even more powerful approach, see QGridLayout.