使用qt编写一个小程序,实现一个包含Qlabel对象的列表,该列表可以多选,可以一次性删除多选项内容。

使用qt编写一个小程序,实现一个包含Qlabel对象的列表,该列表可以多选,可以一次性删除多选项内容。

#include <QApplication>
#include <QListWidget>
#include <QPushButton>
#include <QLabel>
#include <QHBoxLayout>
#include <QVBoxLayout>

//自定义一个类继承自QListWidgetItem
class LabelItem : public QListWidgetItem
{
public:
    LabelItem(const QString &text, QListWidget *parent = nullptr) : QListWidgetItem(parent)
    {
        //创建一个QLabel对象,并设置其文本内容为传入的参数
        label = new QLabel(text);
        //设置label的文本交互标志为可选择和可复制
        label->setTextInteractionFlags(Qt::TextSelectableByMouse | Qt::TextSelectableByKeyboard);
        //将label作为item的子部件显示在listwidget中
        parent->setItemWidget(this, label);
    }

    //获取和设置label的文本内容的方法
    QString text() const { return label->text(); }
    void setText(const QString &text) { label->setText(text); }

private:
    QLabel *label; //记录label对象的指针
};

int main(int argc, char *argv[])
{
    QApplication app(argc, argv);

    //创建一个窗口
    QWidget window;
    window.setWindowTitle("Label List Demo");

    //创建一个listwidget对象
 QListWidget *listWidget = new QListWidget(&window);

    //设置listwidget可以多选
    listWidget->setSelectionMode(QAbstractItemView::MultiSelection);

    //添加一些初始数据到listwidget中
    for (int i = 0; i < 10; i++)
    {
        QString text = QString("Label %1").arg(i + 1); //生成文本内容
        LabelItem *item = new LabelItem(text, listWidget); //创建自定义的item对象
        listWidget->addItem(item); //将item添加到listwidget中
    }

    //创建一个按钮对象用于删除列表项
    QPushButton *deleteButton = new QPushButton("删除", &window);

    //连接按钮的信号槽函数

    //当删除按钮被按下时,遍历listwidget中的所有item,如果被选中,则从listwidget中移除并删除该item
    QObject::connect(deleteButton, &QPushButton::clicked, [&]() {
        for (int i = 0; i < listWidget->count(); i++)
        {
            QListWidgetItem *item = listWidget->item(i);
            if (item->isSelected())
            {
                listWidget->takeItem(i);
                delete item;
                i--; //因为移除了一个item,所以索引要减一
            }
        }
    });
//创建一个水平布局对象用于放置按钮
    QHBoxLayout *hLayout = new QHBoxLayout();
    hLayout->addStretch(); //添加一个弹性空间,使按钮靠右对齐
    hLayout->addWidget(deleteButton);

    //创建一个垂直布局对象用于放置listwidget和按钮布局
    QVBoxLayout *vLayout = new QVBoxLayout(&window);
    vLayout->addWidget(listWidget);
    vLayout->addLayout(hLayout);

    //显示窗口
    window.show();

    return app.exec();
}

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个使用Qt编写的窗口,可以控制屏幕滚动,并设置滚动速度、透明度和显示内容三个按钮的示例代码: ```cpp #include <QtWidgets> class ScrollControlWidget : public QWidget { Q_OBJECT public: ScrollControlWidget(QWidget *parent = nullptr); private slots: void startScrolling(); void stopScrolling(); void setScrollingSpeed(); void setOpacity(); void setContent(); private: QLabel *scrollLabel; QPushButton *startButton; QPushButton *stopButton; QPushButton *speedButton; QPushButton *opacityButton; QPushButton *contentButton; QTimer *scrollTimer; int scrollSpeed; }; ScrollControlWidget::ScrollControlWidget(QWidget *parent) : QWidget(parent) { scrollLabel = new QLabel("Hello, World!", this); scrollLabel->setStyleSheet("background-color: black; color: white; font-size: 24px; padding: 10px;"); scrollLabel->setAlignment(Qt::AlignCenter); startButton = new QPushButton("Start Scrolling", this); connect(startButton, &QPushButton::clicked, this, &ScrollControlWidget::startScrolling); stopButton = new QPushButton("Stop Scrolling", this); connect(stopButton, &QPushButton::clicked, this, &ScrollControlWidget::stopScrolling); speedButton = new QPushButton("Set Scrolling Speed", this); connect(speedButton, &QPushButton::clicked, this, &ScrollControlWidget::setScrollingSpeed); opacityButton = new QPushButton("Set Opacity", this); connect(opacityButton, &QPushButton::clicked, this, &ScrollControlWidget::setOpacity); contentButton = new QPushButton("Set Content", this); connect(contentButton, &QPushButton::clicked, this, &ScrollControlWidget::setContent); QHBoxLayout *buttonLayout = new QHBoxLayout; buttonLayout->addWidget(startButton); buttonLayout->addWidget(stopButton); buttonLayout->addWidget(speedButton); buttonLayout->addWidget(opacityButton); buttonLayout->addWidget(contentButton); QVBoxLayout *mainLayout = new QVBoxLayout(this); mainLayout->addWidget(scrollLabel); mainLayout->addLayout(buttonLayout); scrollTimer = new QTimer(this); scrollSpeed = 50; } void ScrollControlWidget::startScrolling() { scrollTimer->start(scrollSpeed); } void ScrollControlWidget::stopScrolling() { scrollTimer->stop(); } void ScrollControlWidget::setScrollingSpeed() { bool ok; int speed = QInputDialog::getInt(this, "Set Scrolling Speed", "Speed (ms):", scrollSpeed, 1, 10000, 1, &ok); if (ok) { scrollSpeed = speed; scrollTimer->setInterval(scrollSpeed); } } void ScrollControlWidget::setOpacity() { bool ok; qreal opacity = QInputDialog::getDouble(this, "Set Opacity", "Opacity (0.0-1.0):", scrollLabel->windowOpacity(), 0, 1, 2, &ok); if (ok) { scrollLabel->setWindowOpacity(opacity); } } void ScrollControlWidget::setContent() { QString content = QInputDialog::getText(this, "Set Content", "Content:", QLineEdit::Normal, scrollLabel->text()); if (!content.isEmpty()) { scrollLabel->setText(content); } } int main(int argc, char *argv[]) { QApplication app(argc, argv); ScrollControlWidget widget; widget.show(); return app.exec(); } #include "main.moc" ``` 在上面的代码中,我们使用Qt提供的QLabel、QPushButton、QVBoxLayout、QHBoxLayout、QTimer、QInputDialog等控件和类。我们在窗口中添加了一个QLabel控件用于显示内容,并添加了一些控件如QPushButton和QInputDialog等用于控制屏幕滚动、设置滚动速度、透明度和显示内容。在构造函数中,我们创建了一个QTimer对象,用于实现屏幕滚动。在startScrolling()和stopScrolling()槽函数中,我们分别启动和停止QTimer对象实现屏幕滚动和停止滚动。在setScrollingSpeed()、setOpacity()和setContent()槽函数中,我们分别使用QInputDialog类和QLabel类的相关函数,实现设置滚动速度、透明度和显示内容的功能。 请注意,这只是一个示例代码,需要根据实际情况进行修改和完善。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值