RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1100883
Accepted
MAXIM045
MAXIM045
Asked:2020-03-28 15:33:03 +0000 UTC2020-03-28 15:33:03 +0000 UTC 2020-03-28 15:33:03 +0000 UTC

如何创建半透明渐变?

  • 772

在主容器中main_box,我添加了一个按钮btn和一个彩色容器box。

我box添加了两个小部件:

  1. back_picture- 位于容器顶部的图像,使用BackPicture. btn绑定到remake类方法的按钮会MyWindow更改back_picture.
  2. 一个标签label,表明back_picture它不是唯一的容器小部件box。

申请窗口:

在此处输入图像描述

现在我需要覆盖back_picture具有特殊特征的渐变:

  1. 垂直的
  2. 最底点的颜色为#2A303D,不透明度为 100%
  3. 最高点的颜色为#2A303D,不透明度为 50%
  4. 很重要!渐变的中心不在中间,即 下点和上点不相等。梯度的中心向上点移动,这意味着下点占据主导地位。用红色箭头标记渐变中心的点。

在此处输入图像描述

我画了一张清楚地显示差异的图片。数字1标记了带有偏移中心的渐变(正如我需要的那样),数字2标记了没有偏移中心的渐变(因为我不需要):

在此处输入图像描述

1号渐变是我的目标

我将用颜色展示渐变如何向某个点移动以使其更清晰。在第一种情况下,梯度向底部移动,在第二种情况下 - 向顶部移动:

在此处输入图像描述

在 illustrator 中工作时,我注意到 png 会记住像素的透明度级别。这让我想到可以简单地保存渐变图像并将其定位在back_picture.

渐变图片:

在此处输入图像描述

如果您在某些图形编辑器中打开此图片,半透明像素将是真正的半透明。但是,令我非常失望的是,在应用程序窗口中,渐变显示为一个纯色正方形 #2A303D:

在此处输入图像描述

我需要以某种方式创建具有完全相同特征的渐变并将其准确定位在上方back_picture(重要的是没有接缝可见),同时保持在back_picture. 请帮助我做到这一点。

from PyQt5 import QtCore, QtWidgets, QtGui

class BackPicture(QtWidgets.QLabel):
    def __init__(self, picture, x, *args, **kwargs):
        super(BackPicture, self).__init__(*args, **kwargs)
        self.setFixedSize(x, x)
        self.x = x
        self.setPicture(picture)

    def setPicture(self, picture):
        self.setPixmap(QtGui.QPixmap(picture).scaled(self.x, self.x, QtCore.Qt.KeepAspectRatio))


class MyWindow(QtWidgets.QWidget):
    def __init__(self, parent = None):
        super().__init__(parent)
        self.index = 1

        btn = QtWidgets.QPushButton('Remake', clicked = self.remake)

        self.container = QtWidgets.QWidget()
        self.container.setStyleSheet('background: #2A303D;')
        self.container.setMinimumHeight(300)
        self.container.setFixedWidth(300)

        main_box = QtWidgets.QHBoxLayout(self)
        main_box.addWidget(btn)        
        main_box.addWidget(self.container)

        box = QtWidgets.QVBoxLayout(self.container)
        box.setContentsMargins(0, 0, 0, 0)

        self.back_picture = BackPicture('picture3.jpg', 300, self.container)
        self.back_picture.move(0, 0)

        #self.gradient = BackPicture('gradient.png', 300, self.container)
        #self.gradient.move(0, 0)   НЕ РАБОТАЕТ

        label = QtWidgets.QLabel('Text number 1')
        label.setStyleSheet(qss)
        box.addStretch(6)
        box.addWidget(label, alignment = QtCore.Qt.AlignCenter)
        box.addStretch(1)

    def remake(self):
        if self.index == 1:
            self.back_picture.setPicture('picture2.png') 
            self.index = 2
        else:
            self.back_picture.setPicture('picture3.jpg') 
            self.index = 1


qss = '''QLabel {
             color: white;
             font: bold 16px;
             background: transparent;
         }'''

if __name__ == '__main__':
    import sys
    app = QtWidgets.QApplication(sys.argv)
    window = MyWindow()
    window.setWindowTitle(' ')
    window.show()
    sys.exit(app.exec_())
python
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    MAXIM045
    2020-03-29T01:47:56Z2020-03-29T01:47:56Z

    您可以大致实现如下这样的渐变(最好在样式表中自行设置值):

    from PyQt5 import QtCore, QtWidgets, QtGui
    
    class BackPicture(QtWidgets.QLabel):
        def __init__(self, picture, x, *args, **kwargs):
            super(BackPicture, self).__init__(*args, **kwargs)
            self.setFixedSize(x, x)
            self.x = x
            self.setPicture(picture)
    
        def setPicture(self, picture):
            self.setPixmap(QtGui.QPixmap(picture).scaled(self.x, self.x, QtCore.Qt.KeepAspectRatio))
    
    
    class MyWindow(QtWidgets.QWidget):
        def __init__(self, parent = None):
            super().__init__(parent)
            self.index = 1
    
            btn = QtWidgets.QPushButton('Remake', clicked = self.remake)
    
            self.container = QtWidgets.QWidget()
            self.container.setStyleSheet('background: #2A303D;')
            self.container.setMinimumHeight(300)
            self.container.setFixedWidth(300)
    
            main_box = QtWidgets.QHBoxLayout(self)
            main_box.addWidget(btn)        
            main_box.addWidget(self.container)
    
            box = QtWidgets.QVBoxLayout(self.container)
            box.setContentsMargins(0, 0, 0, 0)
    
            self.back_picture = BackPicture('white.png', 300, self.container)
            self.back_picture.move(0, 0)
    
            gradient = QtWidgets.QLabel(self.container)
            gradient.setFixedSize(300, 300)
            gradient.setStyleSheet(gradient_qss)
            gradient.move(0, 0)
    
            label = QtWidgets.QLabel('Text')
            label.setStyleSheet(label_qss)
            box.addStretch(1)
            box.addWidget(label, alignment = QtCore.Qt.AlignCenter)
            box.addStretch(1)
    
        def remake(self):
            if self.index == 1:
                self.back_picture.setPicture('picture1.png') 
                self.index = 2
            else:
                self.back_picture.setPicture('picture3.jpg') 
                self.index = 1
    
    gradient_qss = '''QLabel {
                          background-color: qlineargradient(spread:pad,
                          x1:1, y1:1, x2:1, y2:0,
                          stop:0 rgb(42, 48, 61),
                          stop:0.05 rgb(42, 48, 61),
                          stop:0.1 rgb(42, 48, 61),
                          stop:0.15 rgba(42, 48, 61, 0.999),
                          stop:0.2 rgba(42, 48, 61, 0.998),
                          stop:0.25 rgba(42, 48, 61, 0.997),
                          stop:0.3 rgba(42, 48, 61, 0.996),
                          stop:0.35 rgba(42, 48, 61, 0.995),
                          stop:0.4 rgba(42, 48, 61, 0.99),
                          stop:0.45 rgba(42, 48, 61, 0.985),
                          stop:0.5 rgba(42, 48, 61, 0.98),
                          stop:0.55 rgba(42, 48, 61, 0.975),
                          stop:0.6 rgba(42, 48, 61, 0.97),
                          stop:0.65 rgba(42, 48, 61, 0.96),
                          stop:0.7 rgba(42, 48, 61, 0.95),
                          stop:0.75 rgba(42, 48, 61, 0.93),
                          stop:0.8 rgba(42, 48, 61, 0.9),
                          stop:0.85 rgba(42, 48, 61, 0.85),
                          stop:0.9 rgba(42, 48, 61, 0.8),
                          stop:0.95 rgba(42, 48, 61, 0.75),
                          stop:1 rgba(42, 48, 61, 0.7));
                      }'''
    
    label_qss = '''QLabel {
                       color: white;
                       font: bold 16px;
                       background: transparent;
                }'''
    
    
    if __name__ == '__main__':
        import sys
        app = QtWidgets.QApplication(sys.argv)
        window = MyWindow()
        window.setWindowTitle(' ')
        window.show()
        sys.exit(app.exec_())
    
    • 2

相关问题

  • 是否可以以某种方式自定义 QTabWidget?

  • telebot.anihelper.ApiException 错误

  • Python。检查一个数字是否是 3 的幂。输出 无

  • 解析多个响应

  • 交换两个数组的元素,以便它们的新内容也反转

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    如何从列表中打印最大元素(str 类型)的长度?

    • 2 个回答
  • Marko Smith

    如何在 PyQT5 中清除 QFrame 的内容

    • 1 个回答
  • Marko Smith

    如何将具有特定字符的字符串拆分为两个不同的列表?

    • 2 个回答
  • Marko Smith

    导航栏活动元素

    • 1 个回答
  • Marko Smith

    是否可以将文本放入数组中?[关闭]

    • 1 个回答
  • Marko Smith

    如何一次用多个分隔符拆分字符串?

    • 1 个回答
  • Marko Smith

    如何通过 ClassPath 创建 InputStream?

    • 2 个回答
  • Marko Smith

    在一个查询中连接多个表

    • 1 个回答
  • Marko Smith

    对列表列表中的所有值求和

    • 3 个回答
  • Marko Smith

    如何对齐 string.Format 中的列?

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5