简体   繁体   中英

Widgets cross over the tab on Pyqt5

I am trying to build a simple desktop application which can show and play all the movies in one place. This app includes several tabs, which contain different categories of movies.

The problem is the widgets i put inside the tab windows cross over the tab title. I don't know why.

This is my code:

import sys
from PyQt5.QtWidgets import *
from PyQt5.QtGui import *
from PyQt5.QtCore import *

class Filmler(QTabWidget):
    def __init__(self):
        super().__init__()

        self.setWindowTitle("Filmler")
        self.setWindowIcon(QIcon("film.jpg"))
        self.setGeometry(200,100,1000,500)

        self.tab1 = QWidget()
        self.tab2 = QWidget()
        self.tab3 = QWidget()
        self.tab4 = QWidget()

        self.tab1UI()
        self.tab2UI()
        self.tab3UI()
        self.tab4UI()

        self.addTab(self.tab1, "Hollywood")
        self.addTab(self.tab2, "Bollywood")
        self.addTab(self.tab3, "Uyghur")
        self.addTab(self.tab4, "Zumra'nin Filmleri")

        self.show()

    def tab1UI(self):
        # adding variables
        # 1st movie
        movie1_poster = QLabel()
        movie1_poster.setPixmap(QPixmap("equalizer2.jpg"))
        movie1_name = QLabel("Equalizer 2")
        movie1_name.setAlignment(Qt.AlignCenter)
        movie1_name.setFont(QFont("Times", 13))
        movie1_link = QPushButton("izle")
        vbox1 = QVBoxLayout()
        vbox1.addWidget(movie1_name)
        vbox1.addWidget(movie1_poster)
        vbox1.addWidget(movie1_link)
        vbox1.addStretch()

        hbox = QHBoxLayout()
        hbox.addLayout(vbox1)
        hbox.addStretch()

        self.setLayout(hbox)

    def tab2UI(self):
        pass



    def tab3UI(self):
        pass



    def tab4UI(self):
        pass


app = QApplication(sys.argv)
filmler = Filmler()
sys.exit(app.exec_())

This is the result.

在此处输入图片说明

Set parent self.tab1 to QHBoxLayout

import sys
from PyQt5.QtWidgets import *
from PyQt5.QtGui import *
from PyQt5.QtCore import *

class Filmler(QTabWidget):
    def __init__(self):
        super().__init__()

        self.setWindowTitle("Filmler")
        self.setWindowIcon(QIcon("film.jpg"))
        self.setGeometry(200,100,1000,500)

        self.tab1 = QWidget()
        self.tab2 = QWidget()
        self.tab3 = QWidget()
        self.tab4 = QWidget()

        self.tab1UI()
        self.tab2UI()
        self.tab3UI()
        self.tab4UI()

        self.addTab(self.tab1, "Hollywood")
        self.addTab(self.tab2, "Bollywood")
        self.addTab(self.tab3, "Uyghur")
        self.addTab(self.tab4, "Zumra'nin Filmleri")

        self.show()

    def tab1UI(self):
        # adding variables
        # 1st movie
        movie1_poster = QLabel()
        movie1_poster.setPixmap(QPixmap("lena.jpg"))
        movie1_name = QLabel("Equalizer 2")
        movie1_name.setAlignment(Qt.AlignCenter)
        movie1_name.setFont(QFont("Times", 13))
        movie1_link = QPushButton("izle")
        vbox1 = QVBoxLayout()
        vbox1.addWidget(movie1_name)
        vbox1.addWidget(movie1_poster)
        vbox1.addWidget(movie1_link)
        vbox1.addStretch()

        hbox = QHBoxLayout(self.tab1)                              # + self.tab1
        hbox.addLayout(vbox1)
        hbox.addStretch()

#        self.setLayout(hbox)                                       # ---

    def tab2UI(self):
        pass

    def tab3UI(self):
        pass

    def tab4UI(self):
        pass


app = QApplication(sys.argv)
filmler = Filmler()
sys.exit(app.exec_())

在此处输入图片说明

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM