Condivisione della tecnologia

QT regola la luminosità dello schermo

2024-07-12

한어Русский языкEnglishFrançaisIndonesianSanskrit日本語DeutschPortuguêsΕλληνικάespañolItalianoSuomalainenLatina

1. Obiettivo

Utilizzare QT per realizzare la funzione di regolazione della luminosità dello schermo: quando non è presente lo schermo o il tocco, la luminosità dello schermo viene ridotta e, se è presente il tocco, la luminosità dello schermo viene regolata al massimo.

2. Regolare il comando di luminosità

Il dispositivo di destinazione utilizza un sistema Linux incorporato e il comando per regolare la luminosità dello schermo è:

echo x > /sys/class/backlight/backlight/brightness #x范围为0~10

Non ci sono problemi nell'eseguire questo comando utilizzando il terminale. Tuttavia, quando si utilizza QProcess per eseguire questo comando, non vi è alcuna risposta o messaggio di errore.

Alla fine ho scoperto che devo usare questo comando:

/bin/sh -c "echo x > /sys/class/backlight/backlight/brightness" #x为亮度值

Il codice del programma è implementato come segue:

  1. QProcess setBright(this);// 进程函数,调用外部指令窗口
  2. setBright.start("cat /sys/class/backlight/backlight/brightness n"); #获取当前亮度值
  3. setBright.waitForFinished(); // 等待命令执行完成
  4. QString strCmd = QString("/bin/sh -c "echo %1 > /sys/class/backlight/backlight/brightness"").arg(brightness/10);
  5. //执行指令
  6. setBright.start(strCmd.toLocal8Bit().data()); //convert QString to char
  7. setBright.waitForFinished(1000);// 等待指令执行完毕
  8. QString strErrors = setBright.readAllStandardError();// 获取返回值
  9. qDebug()<<strErrors;

3. Rileva eventi tocco/mouse per riattivare lo schermo

3.1. Descrizione della funzione

Se non si fa clic sullo schermo per un periodo di tempo, lo schermo verrà oscurato o spento. Se si verifica un evento di tocco (ad esempio pressione/spostamento del mouse), svegliati e illumina lo schermo.

3.2 Metodo di implementazione quando c'è una finestra

Quando è presente una finestra, l'implementazione è relativamente semplice. Basta implementare la risposta agli eventi del mouse nella classe di controllo della finestra. Il codice di esempio è il seguente:

  1. //h
  2. protected:
  3. void mousePressEvent(QMouseEvent *event);
  4. void mouseMoveEvent(QMouseEvent *event);
  5. void mouseReleaseEvent(QMouseEvent *event);
  6. //cpp
  7. void MainWindow::mousePressEvent(QMouseEvent *event)
  8. {
  9. qDebug() << "Mouse pressed";
  10. mScreenSleep->ToWake(); //唤醒屏幕
  11. }
  12. void MainWindow::mouseMoveEvent(QMouseEvent *event)
  13. {
  14. qDebug() << "Mouse moved";
  15. mScreenSleep->ToWake(); //唤醒屏幕
  16. }
  17. void MainWindow::mouseReleaseEvent(QMouseEvent *event)
  18. {
  19. qDebug() << "Mouse released";
  20. mScreenSleep->ToWake(); //唤醒屏幕
  21. }

Nota: è possibile rispondere agli eventi del mouse solo all'interno dei controlli della finestra. È possibile utilizzare la classe QApplication per rispondere a eventi al di fuori del controllo della finestra.

Problema: quando la finestra è a schermo intero e impostata su trasparente, non è possibile accendere lo schermo dopo essere stato spento.

3.3 Metodo di implementazione quando non c'è finestra

3.3.1. Implementazione utilizzando la funzione di classe QApplication

Il codice di esempio è il seguente:

  1. //h
  2. #ifndef GLOBALAPP_H
  3. #define GLOBALAPP_H
  4. #include <QApplication>
  5. #include "screensleep.h" //屏幕亮度控制类
  6. class globalapp : public QApplication
  7. {
  8. public:
  9. globalapp(int &argc,char **argv);
  10. ~globalapp();
  11. ScreenSleep *mScreenSleep;
  12. bool notify(QObject*, QEvent *);
  13. };
  14. #endif // GLOBALAPP_H
  15. //cpp
  16. #include "globalapp.h"
  17. #include <QDebug>
  18. globalapp::globalapp(int &argc,char **argv):QApplication(argc,argv)
  19. {
  20. mScreenSleep = new ScreenSleep(this);
  21. }
  22. globalapp::~globalapp()
  23. {
  24. delete mScreenSleep;
  25. }
  26. bool globalapp::notify(QObject *obj, QEvent *e)
  27. {
  28. if(e->type() == QEvent::KeyPress || e->type() == QEvent::MouseButtonPress || e->type() == QEvent::MouseMove)
  29. {
  30. mScreenSleep->ToWake();
  31. }
  32. else if(e->type() == QEvent::SockAct) //为什么响应的是这个事件???
  33. {
  34. mScreenSleep->ToWake();
  35. }
  36. return QApplication::notify(obj,e);
  37. }
  38. //main
  39. int main(int argc, char *argv[])
  40. {
  41. globalapp a(argc, argv); //使用自建的QApplication对象
  42. return a.exec();
  43. }

3.3.2. Utilizzo della funzione filtro eventi

Il codice di esempio è il seguente:

  1. #include <QApplication>
  2. #include <QMouseEvent>
  3. #include <QDebug>
  4. class MouseHook : public QObject {
  5. bool eventFilter(QObject *obj, QEvent *event) override {
  6. if (event->type() == QEvent::MouseMove) {
  7. QMouseEvent *mouseEvent = static_cast<QMouseEvent*>(event);
  8. //放置事件处理
  9. }
  10. else if(event->type() == QEvent::SockAct)
  11. {
  12. QMouseEvent *mouseEvent = static_cast<QMouseEvent*>(event);
  13. //放置事件处理
  14. }
  15. return QObject::eventFilter(obj, event);
  16. }
  17. };
  18. int main(int argc, char *argv[])
  19. {
  20. MouseHook mouseHook;
  21. a.installEventFilter(&mouseHook);
  22. return a.exec();
  23. }

Come puoi vedere dai commenti sopra, quando non c'è nessuna finestra, il clic del mouse o l'evento tocco non è uguale all'evento del mouse definito da QT, ma un evento QEvent::SockAct!

Quanto al motivo per cui è così, il motivo non è stato ancora trovato, ma è un grosso buco!