python - 在窗口的顶部中心显示 QLabel

标签 python layout pyqt pyqt5 qlabel

我自己设置 PyQt 时遇到问题。我的想法是创建一个带有歌曲标题和专辑封面的音乐播放器。我已经成功创建了自己的窗口并添加了专辑封面。但我无法将标签添加到正确的位置。我希望歌曲标题位于窗口的顶部中心,如下图所示:

enter image description here

我尝试了很多方法,但没有成功。

import sys
from PyQt5.QtGui import QIcon, QPixmap, QFontDatabase, QFont
from PyQt5.QtWidgets import QApplication, QLabel, QMainWindow, QWidget, QGridLayout, QDialog
from PyQt5.QtCore import Qt, QRect

# Subclass QMainWindow to customise your application's main window
class MainWindow(QMainWindow):
    def __init__(self, *args, **kwargs):
        super(MainWindow, self).__init__(*args, **kwargs)
        self.title = 'PyQt5 simple window - pythonspot.com'
        self.left = 10
        self.top = 10
        self.width = 480
        self.height = 320
        self.initUI()

        self.setWindowTitle("My Awesome App")

    def add_font(self):
        # Load the font:
        font_db = QFontDatabase()
        font_id = font_db.addApplicationFont('American Captain.ttf')
        families = font_db.applicationFontFamilies(font_id)
        ttf_font = QFont(' '.join(families), 15)
        return ttf_font

    def initUI(self):
        ttf_font = self.add_font()
        w = QWidget()
        self.setWindowTitle(self.title)
        self.setGeometry(self.left, self.top, self.width, self.height)
        self.show()
        album_cover = QLabel(self)
        album_pic = QPixmap('resized_image.jpg')
        album_cover.setPixmap(album_pic)

        album_cover.setAlignment(Qt.AlignCenter)
        self.setCentralWidget(album_cover)


        art_alb = QLabel(self)
        art_alb.setFont(ttf_font)
        art_alb.setText("michael buble - christmas")
        art_alb.setGeometry(self.x, self.y, self.x, self.y)
        art_alb.setAlignment(Qt.AlignTop | Qt.AlignCenter )
        art_alb.show()
        self.show()



app = QApplication(sys.argv)

window = MainWindow()
window.show()

app.exec_()





最佳答案

您应该使用带有布局的中央小部件来控制子小部件在主窗口中的大小和位置。这是对 initUI 方法的重写,它应该执行您想要的操作:

class MainWindow(QMainWindow):
    ...

    def initUI(self):
        self.setWindowTitle(self.title)
        self.setGeometry(self.left, self.top, self.width, self.height)

        widget = QWidget()
        layout = QGridLayout(widget)

        art_alb = QLabel(self)
        ttf_font = self.add_font()
        art_alb.setFont(ttf_font)
        art_alb.setText("michael buble - christmas")

        layout.addWidget(art_alb, 0, 0, Qt.AlignTop | Qt.AlignHCenter)

        album_cover = QLabel(self)
        album_pic = QPixmap('image.jpg')
        album_cover.setPixmap(album_pic)

        layout.addWidget(album_cover, 1, 0, Qt.AlignHCenter)
        layout.setRowStretch(1, 1)

        self.setCentralWidget(widget)

请注意,无需继续调用 show(),因为这一切都是由布局自动处理的。欲了解更多信息,请参阅Layout Management Qt 文档中的文章。

关于python - 在窗口的顶部中心显示 QLabel,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58892935/

相关文章:

Javascript - 上传文件内容类型验证

python - reduceByKey 在 Spark 中有两列

android - setClickable() 不适用于按钮

python - 按下 "Enter"后 PyQt QItemDelegate setFocus 到 QTableWidget

python-3.x - 新型信号和插槽支持,PyQt

python - 无法抓取《华尔街日报》页面上 "div"类中的数据

python - np.loadtxt 用于包含多个矩阵的文件

html - CSS - 在不改变 HTML 的情况下将图像对齐到右上角和左上角

css - 将自定义字体与 CSS 结合使用时布局更改直到文件加载

python - Matplotlib.savefig 忽略轴并在图像周围绘制黑色边框