皮皮网

【食品溯源码激光打标机】【python源码剖析 陈儒】【强庄起爆指标源码】qtimer源码

2024-11-20 00:39:19 来源:pyqt开发的源码

1.如何让 Qt 的程序使用 Sleep
2.qt5和opencv4.3.0实现打开摄像头并截屏拍照,源码再将灰度化,源码直方化,源码食品溯源码激光打标机边缘检测,源码怎么写?
3.如何让 Qt 程序 Sleep

qtimer源码

如何让 Qt 的程序使用 Sleep

       Qt 为何没有提供 Sleep

       è®ºå›ä¸Šä¸æ—¶è§åˆ°æœ‰äººé—®ï¼š

       Qt 为什么没有提供跨平台的 sleep 函数?

       ä½¿ç”¨å¹³å°ç›¸å…³çš„ Sleep 或 nanosleep 以后,界面为什么没有反应?

       QThread 中提供了protected 权限的 sleep 函数,如何用到主线程中?

       ä½¿ç”¨ QTest 中的 qSleep,在windows下如何隐藏控制台?

       è¿™äº›é—®é¢˜å…¶å®žå½’结为一点:在主线程中使用这些函数是一种错误,这会直接导致界面无法刷新,用户与程序无法交互。

       Qt不提供,是因为你不需要在主线程中使用 sleep 函数。

       å¦‚何让程序等待一段时间

       QTime

       QTime t;

       t.start();

       while(t.elapsed()<);

       è¿™ç§æ­»å¾ªçŽ¯ä¹Ÿæ˜¯ä¸€ç§å¸¸è§é”™è¯¯ç”¨æ³•ã€‚但改成正确的还是比较简单的:

       QTime t;

       t.start();

       while(t.elapsed()<)

        QCoreApplication::processEvents();

       ä¸åœåœ°å¤„理事件,以使得程序保持响应。

       QElapsedTimer

       è¿™æ˜¯Qt4.7引入的新的类,和QTime相比,它提供了更快的计算 elapsed 时间的方法。

       QElapsedTimer t;

       t.start();

       while(t.elapsed()<)

        QCoreApplication::processEvents();

       QTest::qWait

       è¿™æ˜¯QTest模块提供的等待函数

       ä¸‹é¢æ˜¯å…¶æºä»£ç ï¼ˆå’Œæˆ‘们前面的代码很像吧?):

       namespace QTest

       {

        inline static void qWait(int ms)

        {

        Q_ASSERT(QCoreApplication::instance());

        QElapsedTimer timer;

        timer.start();

        do {

        QCoreApplication::processEvents(QEventLoop::AllEvents,源码python源码剖析 陈儒 ms);

        QTest::qSleep();

        } while (timer.elapsed() < ms);

        }

       ...

       å…¶å®žæ²¡ä»€ä¹ˆé­”力,对吧?但是因为它QTest模块,所以在程序中我们不要使用它。

       QEventLoop

       é…åˆQTimer使用局部的 eventLoop 也是一个不错的选择。例子:

        QEventLoop eventloop;

        QTimer::singleShot(, &eventloop, SLOT(quit()));

        eventloop.exec();

       QTimer 和 QBasicTimer

       è¿™ä¸¤ä¸ªå’Œæœ¬æ–‡æ²¡æœ‰ä»€ä¹ˆç›´æŽ¥å…³ç³»ï¼ŒQTimer估计大家都很熟了。而QBasicTimer估计很少有人用。

       ä¸ŽQTimer相比,QBasicTimer更快速、轻量、底层。

       ä¸ŽQTimer相比,它不是QObject的派生类。

       è·¨å¹³å°çš„sleep

       å°½ç®¡ä¸€å¼€å§‹æˆ‘们就说了,不需要这个东西。但不排除某种场合下,你确实需要这个东西。如何实现一个跨平台的 sleep 呢?

       æˆ‘们一开始也提到了,QThreadç±» 和 QTest模块都提供了sleep函数,其实我们只需要看看他们的源码就够了:

       QTest 模块中的函数很简单(windows下调用Sleep,其他平台调用 nanosleep):

       void QTest::qSleep(int ms)

       {

        QTEST_ASSERT(ms > 0);

       #ifdef Q_OS_WIN

        Sleep(uint(ms));

       #else

        struct timespec ts = { ms / , (ms % ) * * };

        nanosleep(&ts, NULL);

       #endif

       }

       çœ‹QThread的源码,windows下同样直接调用Sleep,但非windows的实现比这个就复杂多了:

       [cpp] view plain copy

       /* /internal

        helper function to do thread sleeps, since usleep()/nanosleep()

        aren't reliable enough (in terms of behavior and availability)

       */

       static void thread_sleep(struct timespec *ti)

       {

        pthread_mutex_t mtx;

        pthread_cond_t cnd;

        pthread_mutex_init(&mtx, 0);

        pthread_cond_init(&cnd, 0);

        pthread_mutex_lock(&mtx);

        (void) pthread_cond_timedwait(&cnd, &mtx, ti);

        pthread_mutex_unlock(&mtx);

        pthread_cond_destroy(&cnd);

        pthread_mutex_destroy(&mtx);

       }

       void QThread::sleep(unsigned long secs)

       {

        struct timeval tv;

        gettimeofday(&tv, 0);

        struct timespec ti;

        ti.tv_sec = tv.tv_sec + secs;

        ti.tv_nsec = (tv.tv_usec * );

        thread_sleep(&ti);

       }

qt5和opencv4.3.0实现打开摄像头并截屏拍照,再将灰度化,源码强庄起爆指标源码直方化,源码边缘检测,源码怎么写?

       代码如下,源码觉得有帮助可以采纳下,源码后面有我在vscode的源码源代码,可以对照输入测试

       #include <QApplication>

       #include <QMainWindow>

       #include <QPushButton>

       #include <QVBoxLayout>

       #include <QLabel>

       #include <QPixmap>

       #include <QTimer>

       #include <opencv2/opencv.hpp>

       class MainWindow : public QMainWindow

       {

       Q_OBJECT

       public:

       MainWindow(QWidget *parent = nullptr)

       : QMainWindow(parent)

       {

       // 创建显示摄像头图像的源码标签

       imageLabel = new QLabel(this);

       imageLabel->setAlignment(Qt::AlignCenter);

       // 创建按钮

       QPushButton *captureButton = new QPushButton("拍照", this);

       connect(captureButton, &QPushButton::clicked, this, &MainWindow::captureImage);

       // 创建垂直布局并将标签和按钮添加到布局中

       QVBoxLayout *layout = new QVBoxLayout;

       layout->addWidget(imageLabel);

       layout->addWidget(captureButton);

       // 创建主窗口并设置布局

       QWidget *centralWidget = new QWidget(this);

       centralWidget->setLayout(layout);

       setCentralWidget(centralWidget);

       // 设置定时器,定时更新摄像头图像

       QTimer *timer = new QTimer(this);

       connect(timer,源码网络游戏辅助源码 &QTimer::timeout, this, &MainWindow::updateImage);

       timer->start(); // 每毫秒更新一次图像

       }

       private slots:

       void updateImage()

       {

       // 打开摄像头

       cv::VideoCapture cap(0);

       if (!cap.isOpened())

       {

       qDebug() << "无法打开摄像头!";

       return;

       }

       // 读取摄像头图像

       cv::Mat frame;

       cap.read(frame);

       cap.release();

       // 将OpenCV图像转换为Qt图像,源码并显示在标签上

       QImage qImage(frame.data,源码黑马 微信项目源码 frame.cols, frame.rows, frame.step, QImage::Format_BGR);

       QPixmap pixmap = QPixmap::fromImage(qImage);

       imageLabel->setPixmap(pixmap.scaled(imageLabel->size(), Qt::KeepAspectRatio));

       }

       void captureImage()

       {

       // 获取当前摄像头图像

       cv::VideoCapture cap(0);

       if (!cap.isOpened())

       {

       qDebug() << "无法打开摄像头!";

       return;

       }

       cv::Mat frame;

       cap.read(frame);

       cap.release();

       // 转换为灰度图像

       cv::cvtColor(frame, frame, cv::COLOR_BGR2GRAY);

       // 直方化

       cv::equalizeHist(frame, frame);

       // 边缘检测

       cv::Canny(frame, frame, , );

       // 保存图像

       cv::imwrite("captured_image.jpg", frame);

       qDebug() << "已保存为 captured_image.jpg";

       }

       private:

       QLabel *imageLabel;

       };

       int main(int argc, char *argv[])

       {

       QApplication a(argc, argv);

       MainWindow w;

       w.show();

       return a.exec();

       }

       #include "main.moc"

如何让 Qt 程序 Sleep

       ä½¿ç”¨å¹³å°ç›¸å…³çš„ Sleep 或 nanosleep 以后,界面为什么没有反应?QThread 中提供了protected 权限的 sleep 函数,如何用到主线程中?使用QTest 中的 qSleep,在windows下如何隐藏控制台?这些问题其实归结为一点:在主线程中使用这些函数是一种错误,这会直接导致界面无法刷新,用户与程序无法交互。Qt不提供,是因为你不需要在主线程中使用 sleep 函数。如何让程序等待一段时间QTimeQTime t; t.start(); while(t.elapsed()<);这种死循环也是一种常见错误用法。但改成正确的还是比较简单的:QTime t; t.start(); while(t.elapsed()<) QCoreApplication::processEvents();不停地处理事件,以使得程序保持响应。QElapsedTimer这是Qt4.7引入的新的类,和QTime相比,它提供了更快的计算 elapsed 时间的方法。QElapsedTimer t; t.start(); while(t.elapsed()<) QCoreApplication::processEvents();QTest::qWait这是QTest模块提供的等待函数下面是其源代码(和我们前面的代码很像吧?):namespace QTest { inline static void qWait(int ms) { Q_ASSERT(QCoreApplication::instance()); QElapsedTimer timer; timer.start(); do { QCoreApplication::processEvents(QEventLoop::AllEvents, ms); QTest::qSleep(); } while (timer.elapsed() < ms); } ...其实没什么魔力,对吧?但是因为它QTest模块,所以在程序中我们不要使用它。QEventLoop配合QTimer使用局部的 eventLoop 也是一个不错的选择。例子: QEventLoop eventloop; QTimer::singleShot(, &eventloop, SLOT(quit())); eventloop.exec();QTimer 和 QBasicTimer这两个和本文没有什么直接关系,QTimer估计大家都很熟了。而QBasicTimer估计很少有人用。与QTimer相比,QBasicTimer更快速、轻量、底层。与QTimer相比,它不是QObject的派生类。跨平台的sleep尽管一开始我们就说了,不需要这个东西。但不排除某种场合下,你确实需要这个东西。橹械暮��芗虻ィ╳indows下调用Sleep,其他平台调用 nanosleep):void QTest::qSleep(int ms) { QTEST_ASSERT(ms > 0); #ifdef Q_OS_WIN Sleep(uint(ms)); #else struct timespec ts = { ms / , (ms % ) * * }; nanosleep(&ts, NULL); #endif }看QThread的源码,windows下同样直接调用Sleep,但非windows的实现比这个就复杂多了:/* \internal helper function to do thread sleeps, since usleep()/nanosleep() aren't reliable enough (in terms of behavior and availability)*/staticvoidthread_sleep(structtimespec *ti){ pthread_mutex_tmtx;pthread_cond_tcnd;pthread_mutex_init(&mtx, 0);pthread_cond_init(&cnd, 0);pthread_mutex_lock(&mtx); (void) pthread_cond_timedwait(&cnd, &mtx, ti);pthread_mutex_unlock(&mtx);pthread_cond_destroy(&cnd);pthread_mutex_destroy(&mtx);}voidQThread::sleep(unsignedlongsecs){ structtimevaltv;gettimeofday(&tv, 0);structtimespecti;ti.tv_sec = tv.tv_sec + secs;ti.tv_nsec = (tv.tv_usec * );thread_sleep(&ti);}