Полупрозрачный фон в окне PyQt5 (ЭТО НЕ ДУБЛИКАТ)

Мне нужно поместить полупрозрачный фон в окно PyQt5 (под полупрозрачным я подразумеваю, что можно увидеть, что находится за ним).

Во многих других темах я видел, что идея состоит в том, чтобы использовать цвет rgba. Например, поставив что-то вроде этого self.setStyleSheet('background-color: rgba(128, 128, 128, 120);'), где 120 соответствует альфе.

Но я попробовал это, и это не работает (см. пример ниже), и я не понимаю, почему.

Любая помощь будет принята с благодарностью!

PS: я также пытался протестировать setStyleSheet (фон: прозрачный;), и это тоже не работает...

#!/usr/bin/env python3

"""
The MIT License (MIT)
Copyright (c) 2017 fbjorn
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
"""

import sys

from PyQt5.QtCore import *

from PyQt5.QtWidgets import *



from pyqtspinner.spinner import WaitingSpinner


class Demo(QWidget):
    sb_roundness = None
    sb_opacity = None
    sb_fadeperc = None
    sb_lines = None
    sb_line_length = None
    sb_line_width = None
    sb_inner_radius = None
    sb_rev_s = None

    btn_start = None
    btn_stop = None
    btn_pick_color = None

    spinner = None

    def __init__(self):
        super().__init__()
        self.init_ui()

    def init_ui(self):
        grid = QGridLayout()
        groupbox1 = QGroupBox()
        groupbox1_layout = QHBoxLayout()
        groupbox2 = QGroupBox()
        groupbox2_layout = QGridLayout()
        button_hbox = QHBoxLayout()
        self.setLayout(grid)
        self.setWindowTitle("QtWaitingSpinner Demo")
        self.setStyleSheet('background-color: rgba(128, 128, 128, 120);')
        self.setWindowFlags(Qt.Dialog)

        # SPINNER
        self.spinner = WaitingSpinner(self)

        # Spinboxes
        self.sb_roundness = QDoubleSpinBox()
        self.sb_opacity = QDoubleSpinBox()
        self.sb_fadeperc = QDoubleSpinBox()
        self.sb_lines = QSpinBox()
        self.sb_line_length = QDoubleSpinBox()
        self.sb_line_width = QDoubleSpinBox()
        self.sb_inner_radius = QDoubleSpinBox()
        self.sb_rev_s = QDoubleSpinBox()

        # set spinbox default values
        self.sb_roundness.setValue(70)
        self.sb_roundness.setRange(0, 9999)
        self.sb_opacity.setValue(15)
        self.sb_opacity.setRange(0, 9999)
        self.sb_fadeperc.setValue(70)
        self.sb_fadeperc.setRange(0, 9999)
        self.sb_lines.setValue(12)
        self.sb_lines.setRange(1, 9999)
        self.sb_line_length.setValue(10)
        self.sb_line_length.setRange(0, 9999)
        self.sb_line_width.setValue(5)
        self.sb_line_width.setRange(0, 9999)
        self.sb_inner_radius.setValue(10)
        self.sb_inner_radius.setRange(0, 9999)
        self.sb_rev_s.setValue(1)
        self.sb_rev_s.setRange(0.1, 9999)

        # Buttons
        self.btn_start = QPushButton("Start")
        self.btn_stop = QPushButton("Stop")
        self.btn_pick_color = QPushButton("Pick Color")
        self.btn_show_init = QPushButton("Show init args")

        # Connects
        self.sb_roundness.valueChanged.connect(self.set_roundness)
        self.sb_opacity.valueChanged.connect(self.set_opacity)
        self.sb_fadeperc.valueChanged.connect(self.set_fadeperc)
        self.sb_lines.valueChanged.connect(self.set_lines)
        self.sb_line_length.valueChanged.connect(self.set_line_length)
        self.sb_line_width.valueChanged.connect(self.set_line_width)
        self.sb_inner_radius.valueChanged.connect(self.set_inner_radius)
        self.sb_rev_s.valueChanged.connect(self.set_rev_s)

        self.btn_start.clicked.connect(self.spinner_start)
        self.btn_stop.clicked.connect(self.spinner_stop)
        self.btn_pick_color.clicked.connect(self.show_color_picker)
        self.btn_show_init.clicked.connect(self.show_init_args)

        # Layout adds
        groupbox1_layout.addWidget(self.spinner)
        groupbox1.setLayout(groupbox1_layout)

        groupbox2_layout.addWidget(QLabel("Roundness:"), *(1, 1))
        groupbox2_layout.addWidget(self.sb_roundness, *(1, 2))
        groupbox2_layout.addWidget(QLabel("Opacity:"), *(2, 1))
        groupbox2_layout.addWidget(self.sb_opacity, *(2, 2))
        groupbox2_layout.addWidget(QLabel("Fade Perc:"), *(3, 1))
        groupbox2_layout.addWidget(self.sb_fadeperc, *(3, 2))
        groupbox2_layout.addWidget(QLabel("Lines:"), *(4, 1))
        groupbox2_layout.addWidget(self.sb_lines, *(4, 2))
        groupbox2_layout.addWidget(QLabel("Line Length:"), *(5, 1))
        groupbox2_layout.addWidget(self.sb_line_length, *(5, 2))
        groupbox2_layout.addWidget(QLabel("Line Width:"), *(6, 1))
        groupbox2_layout.addWidget(self.sb_line_width, *(6, 2))
        groupbox2_layout.addWidget(QLabel("Inner Radius:"), *(7, 1))
        groupbox2_layout.addWidget(self.sb_inner_radius, *(7, 2))
        groupbox2_layout.addWidget(QLabel("Rev/s:"), *(8, 1))
        groupbox2_layout.addWidget(self.sb_rev_s, *(8, 2))

        groupbox2.setLayout(groupbox2_layout)

        button_hbox.addWidget(self.btn_start)
        button_hbox.addWidget(self.btn_stop)
        button_hbox.addWidget(self.btn_pick_color)
        button_hbox.addWidget(self.btn_show_init)

        grid.addWidget(groupbox1, *(1, 1))
        grid.addWidget(groupbox2, *(1, 2))
        grid.addLayout(button_hbox, *(2, 1))

        self.spinner.start()
        self.show()

    def set_roundness(self):
        self.spinner.setRoundness(self.sb_roundness.value())

    def set_opacity(self):
        self.spinner.setMinimumTrailOpacity(self.sb_opacity.value())

    def set_fadeperc(self):
        self.spinner.setTrailFadePercentage(self.sb_fadeperc.value())

    def set_lines(self):
        self.spinner.setNumberOfLines(self.sb_lines.value())

    def set_line_length(self):
        self.spinner.setLineLength(self.sb_line_length.value())

    def set_line_width(self):
        self.spinner.setLineWidth(self.sb_line_width.value())

    def set_inner_radius(self):
        self.spinner.setInnerRadius(self.sb_inner_radius.value())

    def set_rev_s(self):
        self.spinner.setRevolutionsPerSecond(self.sb_rev_s.value())

    def spinner_start(self):
        self.spinner.start()

    def spinner_stop(self):
        self.spinner.stop()

    def show_color_picker(self):
        self.spinner.setColor(QColorDialog.getColor())

    def show_init_args(self):
        text = (
            'WaitingSpinner(\n'
            '    parent,\n'
            '    roundness={}, opacity={},\n'
            '    fade={}, radius={}, lines={},\n'
            '    line_length={}, line_width={},\n'
            '    speed={}, color={}\n'
            ')\n'
        ).format(
            self.sb_roundness.value(), self.sb_opacity.value(),
            self.sb_fadeperc.value(), self.sb_inner_radius.value(),
            self.sb_lines.value(), self.sb_line_length.value(),
            self.sb_line_width.value(), self.sb_rev_s.value(),
            self.spinner.color.getRgb()[:3]
        )

        msg_box = QMessageBox(text=text)
        msg_box.setWindowTitle('Text was copied to clipboard')
        cb = QApplication.clipboard()
        cb.clear(mode=cb.Clipboard)
        cb.setText(text, mode=cb.Clipboard)
        print(text)
        msg_box.exec_()

if __name__ == '__main__':
    app = QApplication(sys.argv)
    main = Demo()
    sys.exit(app.exec())

PS: извините, но я боюсь, что решение не предоставлено для упомянутых дубликатов и комментариев ... Пожалуйста, откройте тему снова. Привет ?


person daveturner    schedule 15.07.2020    source источник
comment
используйте 1_   -  person eyllanesc    schedule 15.07.2020
comment
Ответы — это не только код, но и объяснение, и на основе этого объяснения решение может быть реализовано на любом языке. Также я указал на другие дубликаты, написанные на питоне, поэтому, пожалуйста, прочитайте его, и если у вас есть какие-либо проблемы, используйте комментарии вместо правок.   -  person eyllanesc    schedule 15.07.2020
comment
Извините, у меня все еще есть проблема с этим ... Проблема в том, что фон (за макетами) полностью прозрачен. Как я могу получить полупрозрачный?   -  person daveturner    schedule 15.07.2020
comment
затем используйте self.setWindowOpacity(.9) вместо self.setAttribute(Qt.WA_TranslucentBackground). Пожалуйста, прочитайте ответы   -  person eyllanesc    schedule 15.07.2020
comment
Я уже пробовал этот setWindowOpacity(), и проблема в том, что он делает ВСЕ полупрозрачным (кнопки, текст, полоса...). Мне нужен только фон.   -  person daveturner    schedule 15.07.2020
comment
Мне очень жаль, но я боюсь, что для дубликатов, о которых вы упомянули, решения не предусмотрено...   -  person daveturner    schedule 15.07.2020
comment
см. stackoverflow.com/questions/ 62013500/   -  person S. Nick    schedule 16.07.2020
comment
Не пойму если поставить window.setAttribute(QtCore.Qt.WA_TranslucentBackground) фон полностью прозрачный а полупрозрачный у меня не получится.   -  person daveturner    schedule 16.07.2020
comment
Вместо того, чтобы указывать ЭТО НЕ ДУБЛИКАЦИЯ в заголовке, добавьте подробности о том, чем он отличается от каждой предложенной цели / как предложенные ответы (ошибочно) ведут себя при использовании для применения.   -  person Charles Duffy    schedule 22.07.2020
comment
Кроме того, постарайтесь убедиться, что ваш репродуктор является минимально воспроизводимым примером. Минимум является частью этого, а это означает, что это должен быть самый короткий код, который создает вашу проблему при запуске без изменений. Обратите внимание, что условия использования Stack Overflow размещают контент под определенной лицензией, в настоящее время CC BY-SA 4.0; если вы не можете легально публиковать контент под этой лицензией, вы вообще не можете публиковать его здесь.   -  person Charles Duffy    schedule 22.07.2020
comment
...просить людей изучить целое демонстрационное приложение с кучей функций, явно не связанных с прозрачностью, для вопроса, который только касается прозрачности, — это не способ получить хороший ответ. Люди, которые на самом деле не являются модераторами, не могут изменить плохую причину закрытия на хорошую — голосование за повторное открытие чего-то блокирует кого-то от голосования за закрытие по другой, более подходящей причине — так что одна причина для того, чтобы что-то оставить закрытый как дубликат - это люди, которые в противном случае могли бы голосовать за повторное открытие, думая, что его должно закрыть, поскольку он не соответствует правилам MRE.   -  person Charles Duffy    schedule 22.07.2020