pyqt项目18-QSpinBox(微调框2-高精度)

本文介绍了如何在PyQt5中使用QDoubleSpinBox来创建一个支持高精度数值调整的GUI组件。通过设置setDecimals方法,可以改变微调框的小数位数。同时,结合QSlider实现精度值的动态更新,展示了QtDesigner生成的UI文件在Python代码中的应用。
摘要由CSDN通过智能技术生成

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

pyqt项目18-QSpinBox(微调框2-高精度)


前言

提示:这里可以添加本文要记录的大概内容:


提示:以下是本篇文章正文内容,下面案例可供参考

一、所学内容

1. QDoubleSpinBox
1.1 self.doubleSpinBox.setDecimals(value)

二、完整代码

2.1 界面逻辑

# -*- coding: utf-8 -*-

# Form implementation generated from reading ui file 'untitled.ui'
#
# Created by: PyQt5 UI code generator 5.13.1
#
# WARNING! All changes made in this file will be lost!


from PyQt5 import QtCore, QtGui, QtWidgets


class Ui_MainWindow(object):
    def setupUi(self, MainWindow):
        MainWindow.setObjectName("MainWindow")
        MainWindow.resize(800, 600)
        self.centralwidget = QtWidgets.QWidget(MainWindow)
        self.centralwidget.setObjectName("centralwidget")
        self.doubleSpinBox = QtWidgets.QDoubleSpinBox(self.centralwidget)
        self.doubleSpinBox.setGeometry(QtCore.QRect(80, 80, 191, 23))
        self.doubleSpinBox.setObjectName("doubleSpinBox")
        self.label = QtWidgets.QLabel(self.centralwidget)
        self.label.setGeometry(QtCore.QRect(80, 150, 201, 16))
        self.label.setObjectName("label")
        self.horizontalSlider = QtWidgets.QSlider(self.centralwidget)
        self.horizontalSlider.setGeometry(QtCore.QRect(80, 200, 181, 16))
        self.horizontalSlider.setMinimum(2)
        self.horizontalSlider.setMaximum(10)
        self.horizontalSlider.setOrientation(QtCore.Qt.Horizontal)
        self.horizontalSlider.setTickPosition(QtWidgets.QSlider.TicksAbove)
        self.horizontalSlider.setObjectName("horizontalSlider")
        MainWindow.setCentralWidget(self.centralwidget)
        self.menubar = QtWidgets.QMenuBar(MainWindow)
        self.menubar.setGeometry(QtCore.QRect(0, 0, 800, 19))
        self.menubar.setObjectName("menubar")
        MainWindow.setMenuBar(self.menubar)
        self.statusbar = QtWidgets.QStatusBar(MainWindow)
        self.statusbar.setObjectName("statusbar")
        MainWindow.setStatusBar(self.statusbar)

        self.retranslateUi(MainWindow)
        self.horizontalSlider.valueChanged['int'].connect(MainWindow.change_value)
        QtCore.QMetaObject.connectSlotsByName(MainWindow)

    def retranslateUi(self, MainWindow):
        _translate = QtCore.QCoreApplication.translate
        MainWindow.setWindowTitle(_translate("MainWindow", "MainWindow"))
        self.label.setText(_translate("MainWindow", "double spin box精度设置:"))

2.2 业务逻辑

import random
import sys
from PyQt5.QtWidgets import QApplication, QMainWindow, QMessageBox
from untitled import Ui_MainWindow
from PyQt5.QtCore import Qt, QBasicTimer


# ======haozh-検索画面(这里继承的类就是Qtdesigner生成出来的.py文件)=====
class My_Form(QMainWindow, Ui_MainWindow):
    def __init__(self):
        super(My_Form, self).__init__()
        self.setupUi(self)

        show_message = "double spin box精度设置:" + str(self.horizontalSlider.value())
        self.label.setText(show_message)

    def change_value(self, value):
        self.label.setText("double spin box精度设置:" + str(value))
        self.doubleSpinBox.setDecimals(value)



# ======haozh-主程序调用=====
if __name__=='__main__':
    app=QApplication(sys.argv)
    index=My_Form()
    index.show()
    sys.exit(app.exec_())


总结

提示:这里对文章进行总结:
例如:以上就是今天要讲的内容,本文仅仅简单介绍了pandas的使用,而pandas提供了大量能使我们快速便捷地处理数据的函数和方法。

在使用 PyQT 构建应用程序时,如果你想去除 QComboBox(下拉列表)的边,你可以通过修改其样式表(style sheet)来进行。这涉及到直接对控件的应用样式进行定制,以便达到特定的设计效果。 以下是具体的步骤和示例代码: ### 示例代码: ```python import sys from PyQt5.QtWidgets import QApplication, QLabel, QVBoxLayout, QWidget, QPushButton, QComboBox from PyQt5.QtGui import QColor # 定义要去除边的样式 style_sheet = """ QComboBox { border-width: 0px; } """ app = QApplication([]) window = QWidget() window.setWindowTitle('去边的下拉列表') layout = QVBoxLayout(window) label = QLabel('选择一个选项:') combo_box = QComboBox() # 应用样式 combo_box.setStyleSheet(style_sheet) # 添加项目到下拉列表 for i in range(1, 10): combo_box.addItem(str(i)) button = QPushButton('退出') button.clicked.connect(qt_app.quit) layout.addWidget(label) layout.addWidget(combo_box) layout.addWidget(button) window.show() sys.exit(app.exec_()) ``` ### 解释: 1. **定义样式**:我们首先定义了一个样式字符串 `style_sheet` ,其中包含了将 `border-width` 设置为 `0px` 来移除边的效果。 2. **应用样式**:接着,我们将该样式应用到了 `QComboBox` 控件上。这通常在初始化控件后立即进行,以确保样式能够即时生效。 3. **展示窗口**:最后,我们创建了一个窗口并将其展示出来。窗口中包含了标签、下拉列表和一个退出按钮。 ### 扩展问题: 1. **是否可以在运行时动态改变QComboBox的样式?** - 是的,可以利用定时器或者响应特定事件来动态更新样式表,从而实现在程序运行过程中改变QComboBox的外观。 2. **如何自定义QComboBox的提示文本和下拉箭头?** - 提示文本可以通过设置 `setPlaceholderText()` 方法来自定义。下拉箭头的样式可以根据以上方法进行修改,也可以考虑使用QSS中的其他属性来进一步微调外观。 3. **如果我想保持边但希望改变其颜色呢?** - 要改变边颜色而不移除边本身,只需在样式表中调整 `border-color` 属性即可。例如,设置 `border-color: #FF0000;` 则会使边变为红色。这同样适用于 `QComboBox` 的其他部分,如边样式、圆角等。 这些操作使得开发者能够通过简单的代码定制UI元素的外观,满足个性化设计需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大蠢驴小疯子

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值