整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          Qt中插入html樣式

          Qt中插入html樣式

          t中引入html調節樣式

          HTML

          • 設置行間距字體高度和顏色
          <html><head/><body><p style=\"height:16px;line-height:24px;color:#787878\"> helloWorld</p></body></html>

          技巧

          • 實現Html鏈接動態下劃線
            • 繼承QLabel并重寫進入離開事件(對Html文字鏈接中text-decoration: none;屬性進行控制). 即可實現鼠標停留時顯示下劃線, 鼠標離開時隱藏下劃線.

          、前言

          這個IP地址輸入框控件,估計寫爛了,網上隨便一搜索,保證一大堆,估計也是因為這個控件太容易了,非常適合新手練手,一般的思路都是用4個qlineedit控件拼起來,然后每個輸入框設置正則表達式過濾只能輸入3位數字,然后安裝事件過濾器識別回車自動跳到下一個輸入框。關于如何設置正則表達式過濾,這個可以搜索查到,本人也不大懂這個規則,貌似還有專門的書籍專門介紹正則表達式,可能這塊非常強大。

          開源地址:https://gitee.com/feiyangqingyun/QWidgetDemo https://github.com/feiyangqingyun/QWidgetDemo

          二、實現的功能

          • 1:可設置IP地址,自動填入框
          • 2:可清空IP地址
          • 3:支持按下小圓點自動切換
          • 4:支持退格鍵自動切換
          • 5:支持IP地址過濾
          • 6:可設置背景色/邊框顏色/邊框圓角角度

          三、效果圖

          四、頭文件代碼

          #ifndef IPADDRESS_H
          #define IPADDRESS_H
          
          /**
           * IP地址輸入框控件 作者:feiyangqingyun(QQ:517216493) 2017-8-11
           * 1:可設置IP地址,自動填入框
           * 2:可清空IP地址
           * 3:支持按下小圓點自動切換
           * 4:支持退格鍵自動切換
           * 5:支持IP地址過濾
           * 6:可設置背景色/邊框顏色/邊框圓角角度
           */
          
          #include <QWidget>
          
          class QLabel;
          class QLineEdit;
          
          #ifdef quc
          #if (QT_VERSION < QT_VERSION_CHECK(5,7,0))
          #include <QtDesigner/QDesignerExportWidget>
          #else
          #include <QtUiPlugin/QDesignerExportWidget>
          #endif
          
          class QDESIGNER_WIDGET_EXPORT IPAddress : public QWidget
          #else
          class IPAddress : public QWidget
          #endif
          
          {
              Q_OBJECT
              Q_PROPERTY(QString ip READ getIP WRITE setIP)
          
          public:
              explicit IPAddress(QWidget *parent=0);
          
          protected:
              bool eventFilter(QObject *watched, QEvent *event);
          
          private:
              QLabel *labDot1;    //第一個小圓點
              QLabel *labDot2;    //第二個小圓點
              QLabel *labDot3;    //第三個小圓點
          
              QLineEdit *txtIP1;  //IP地址網段輸入框1
              QLineEdit *txtIP2;  //IP地址網段輸入框2
              QLineEdit *txtIP3;  //IP地址網段輸入框3
              QLineEdit *txtIP4;  //IP地址網段輸入框4
          
              QString ip;         //IP地址
              QString bgColor;    //背景顏色
              QString borderColor;//邊框顏色
              int borderRadius;   //邊框圓角角度
          
          private slots:
              void textChanged(const QString &text);
          
          public:
              //獲取IP地址
              QString getIP()                 const;
          
              QSize sizeHint()                const;
              QSize minimumSizeHint()         const;
          
          public Q_SLOTS:
              //設置IP地址
              void setIP(const QString &ip);
              //清空
              void clear();
          
              //設置背景顏色
              void setBgColor(const QString &bgColor);
              //設置邊框顏色
              void setBorderColor(const QString &borderColor);
              //設置邊框圓角角度
              void setBorderRadius(int borderRadius);
          
          };
          
          #endif // IPADDRESS_H
          
          
          

          【領QT開發教程學習資料,點擊下方鏈接莬費領取↓↓,先碼住不迷路~】

          點擊這里:Qt資料領取(視頻教程+文檔+代碼+項目實戰)

          五、核心代碼

          #pragma execution_character_set("utf-8")
          
          #include "ipaddress.h"
          #include "qlabel.h"
          #include "qlineedit.h"
          #include "qboxlayout.h"
          #include "qregexp.h"
          #include "qvalidator.h"
          #include "qevent.h"
          #include "qdebug.h"
          
          IPAddress::IPAddress(QWidget *parent) : QWidget(parent)
          {
              bgColor="#FFFFFF";
              borderColor="#A6B5B8";
              borderRadius=3;
          
              //用于顯示小圓點的標簽,居中對齊
              labDot1=new QLabel;
              labDot1->setAlignment(Qt::AlignCenter);
              labDot1->setText(".");
          
              labDot2=new QLabel;
              labDot2->setAlignment(Qt::AlignCenter);
              labDot2->setText(".");
          
              labDot3=new QLabel;
              labDot3->setAlignment(Qt::AlignCenter);
              labDot3->setText(".");
          
              //用于輸入IP地址的文本框,居中對齊
              txtIP1=new QLineEdit;
              txtIP1->setObjectName("txtIP1");
              txtIP1->setAlignment(Qt::AlignCenter);
              txtIP1->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
              connect(txtIP1, SIGNAL(textChanged(QString)), this, SLOT(textChanged(QString)));
          
              txtIP2=new QLineEdit;
              txtIP2->setObjectName("txtIP2");
              txtIP2->setAlignment(Qt::AlignCenter);
              txtIP2->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
              connect(txtIP2, SIGNAL(textChanged(QString)), this, SLOT(textChanged(QString)));
          
              txtIP3=new QLineEdit;
              txtIP3->setObjectName("txtIP3");
              txtIP3->setAlignment(Qt::AlignCenter);
              txtIP3->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
              connect(txtIP3, SIGNAL(textChanged(QString)), this, SLOT(textChanged(QString)));
          
              txtIP4=new QLineEdit;
              txtIP4->setObjectName("txtIP4");
              txtIP4->setAlignment(Qt::AlignCenter);
              txtIP4->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
              connect(txtIP4, SIGNAL(textChanged(QString)), this, SLOT(textChanged(QString)));
          
              //設置IP地址校驗過濾
              QRegExp regExp("(2[0-5]{2}|2[0-4][0-9]|1?[0-9]{1,2})");
              QRegExpValidator *validator=new QRegExpValidator(regExp, this);
              txtIP1->setValidator(validator);
              txtIP2->setValidator(validator);
              txtIP3->setValidator(validator);
              txtIP4->setValidator(validator);
          
              //綁定事件過濾器,識別鍵盤按下
              txtIP1->installEventFilter(this);
              txtIP2->installEventFilter(this);
              txtIP3->installEventFilter(this);
              txtIP4->installEventFilter(this);
          
              QFrame *frame=new QFrame;
              frame->setObjectName("frameIP");
          
              QStringList qss;
              qss.append(QString("QFrame#frameIP{border:1px solid %1;border-radius:%2px;}").arg(borderColor).arg(borderRadius));
              qss.append(QString("QLabel{min-width:15px;background-color:%1;}").arg(bgColor));
              qss.append(QString("QLineEdit{background-color:%1;border:none;}").arg(bgColor));
              qss.append(QString("QLineEdit#txtIP1{border-top-left-radius:%1px;border-bottom-left-radius:%1px;}").arg(borderRadius));
              qss.append(QString("QLineEdit#txtIP4{border-top-right-radius:%1px;border-bottom-right-radius:%1px;}").arg(borderRadius));
              frame->setStyleSheet(qss.join(""));
          
              QVBoxLayout *verticalLayout=new QVBoxLayout(this);
              verticalLayout->setMargin(0);
              verticalLayout->setSpacing(0);
              verticalLayout->addWidget(frame);
          
              //將控件按照橫向布局排列
              QHBoxLayout *layout=new QHBoxLayout(frame);
              layout->setMargin(0);
              layout->setSpacing(0);
              layout->addWidget(txtIP1);
              layout->addWidget(labDot1);
              layout->addWidget(txtIP2);
              layout->addWidget(labDot2);
              layout->addWidget(txtIP3);
              layout->addWidget(labDot3);
              layout->addWidget(txtIP4);
          }
          
          bool IPAddress::eventFilter(QObject *watched, QEvent *event)
          {
              if (event->type()==QEvent::KeyPress) {
                  QLineEdit *txt=(QLineEdit *)watched;
                  if (txt==txtIP1 || txt==txtIP2 || txt==txtIP3 || txt==txtIP4) {
                      QKeyEvent *key=(QKeyEvent *)event;
          
                      //如果當前按下了小數點則移動焦點到下一個輸入框
                      if (key->text()==".") {
                          this->focusNextChild();
                      }
          
                      //如果按下了退格鍵并且當前文本框已經沒有了內容則焦點往前移
                      if (key->key()==Qt::Key_Backspace) {
                          if (txt->text().length() <=1) {
                              this->focusNextPrevChild(false);
                          }
                      }
                  }
              }
          
              return QWidget::eventFilter(watched, event);
          }
          
          void IPAddress::textChanged(const QString &text)
          {
              int len=text.length();
              int value=text.toInt();
          
              //判斷當前是否輸入完成一個網段,是的話則自動移動到下一個輸入框
              if (len==3) {
                  if (value >=100 && value <=255) {
                      this->focusNextChild();
                  }
              }
          
              //拼接成完整IP地址
              ip=QString("%1.%2.%3.%4").arg(txtIP1->text()).arg(txtIP2->text()).arg(txtIP3->text()).arg(txtIP4->text());
          }
          
          QString IPAddress::getIP() const
          {
              return this->ip;
          }
          
          QSize IPAddress::sizeHint() const
          {
              return QSize(250, 20);
          }
          
          QSize IPAddress::minimumSizeHint() const
          {
              return QSize(30, 10);
          }
          
          void IPAddress::setIP(const QString &ip)
          {
              //先檢測IP地址是否合法
              QRegExp regExp("((2[0-4]\\d|25[0-5]|[01]?\\d\\d?)\\.){3}(2[0-4]\\d|25[0-5]|[01]?\\d\\d?)");
              if (!regExp.exactMatch(ip)) {
                  return;
              }
          
              if (this->ip !=ip) {
                  this->ip=ip;
          
                  //將IP地址填入各個網段
                  QStringList list=ip.split(".");
                  txtIP1->setText(list.at(0));
                  txtIP2->setText(list.at(1));
                  txtIP3->setText(list.at(2));
                  txtIP4->setText(list.at(3));
              }
          }
          
          void IPAddress::clear()
          {
              txtIP1->clear();
              txtIP2->clear();
              txtIP3->clear();
              txtIP4->clear();
              txtIP1->setFocus();
          }
          
          void IPAddress::setBgColor(const QString &bgColor)
          {
              if (this->bgColor !=bgColor) {
                  this->bgColor=bgColor;
              }
          }
          
          void IPAddress::setBorderColor(const QString &borderColor)
          {
              if (this->borderColor !=borderColor) {
                  this->borderColor=borderColor;
              }
          }
          
          void IPAddress::setBorderRadius(int borderRadius)
          {
              if (this->borderRadius !=borderRadius) {
                  this->borderRadius=borderRadius;
              }
          }
          
          
          

          六、控件介紹

          1. 超過160個精美控件,涵蓋了各種儀表盤、進度條、進度球、指南針、曲線圖、標尺、溫度計、導航條、導航欄,flatui、高亮按鈕、滑動選擇器、農歷等。遠超qwt集成的控件數量。
          2. 每個類都可以獨立成一個單獨的控件,零耦合,每個控件一個頭文件和一個實現文件,不依賴其他文件,方便單個控件以源碼形式集成到項目中,較少代碼量。qwt的控件類環環相扣,高度耦合,想要使用其中一個控件,必須包含所有的代碼。
          3. 全部純Qt編寫,QWidget+QPainter繪制,支持Qt4.6到Qt5.13的任何Qt版本,支持mingw、msvc、gcc等編譯器,支持任意操作系統比如windows+linux+mac+嵌入式linux等,不亂碼,可直接集成到Qt Creator中,和自帶的控件一樣使用,大部分效果只要設置幾個屬性即可,極為方便。
          4. 每個控件都有一個對應的單獨的包含該控件源碼的DEMO,方便參考使用。同時還提供一個所有控件使用的集成的DEMO。
          5. 每個控件的源代碼都有詳細中文注釋,都按照統一設計規范編寫,方便學習自定義控件的編寫。
          6. 每個控件默認配色和demo對應的配色都非常精美。
          7. 超過130個可見控件,6個不可見控件。
          8. 部分控件提供多種樣式風格選擇,多種指示器樣式選擇。
          9. 所有控件自適應窗體拉伸變化。
          10. 集成自定義控件屬性設計器,支持拖曳設計,所見即所得,支持導入導出xml格式。
          11. 自帶activex控件demo,所有控件可以直接運行在ie瀏覽器中。
          12. 集成fontawesome圖形字體+阿里巴巴iconfont收藏的幾百個圖形字體,享受圖形字體帶來的樂趣。
          13. 所有控件最后生成一個動態庫文件(dll或者so等),可以直接集成到qtcreator中拖曳設計使用。
          14. 目前已經有qml版本,后期會考慮出pyqt版本,如果用戶需求量很大的話。
          15. 自定義控件插件開放動態庫使用(永久免費),無任何后門和限制,請放心使用。
          16. 目前已提供32個版本的dll,其中qt_5_7_0_mingw530_32這個版本會一直保證最新的完整的。
          17. 不定期增加控件和完善控件,不定期更新SDK,歡迎各位提出建議,謝謝!
          18. Qt入門書籍推薦霍亞飛的《Qt Creator快速入門》《Qt5編程入門》,Qt進階書籍推薦官方的《C++ GUI Qt4編程》。
          19. 強烈推薦程序員自我修養和規劃系列書《大話程序員》《程序員的成長課》《解憂程序員》,受益匪淺,受益終生!
          20. SDK地址:https://gitee.com/feiyangqingyun/QUCSDK https://github.com/feiyangqingyun/qucsdk

          原文鏈接:https://www.cnblogs.com/feiyangqingyun/p/11665022.html

          【領QT開發教程學習資料,點擊下方鏈接莬費領取↓↓,先碼住不迷路~】

          點擊這里:「鏈接」

          i,今天用一個小例子,陳述一下 Qt 里使用 TCP 通訊的流程。

          代碼鏈接:

          https://doc.qt.io/qt-5/examples-network.html

          運行效果:


          Server 端

          運行效果:

          顯示 IP + 端口,然后靜靜地的等待客戶端的連接。

          源碼文件:

          msg_server/
          ├── msg_server.pro
          ├── main.cpp
          ├── server.cpp
          └── server.h
          

          源碼分析如下。


          創建 TCP Server

          在構造函數中進行初始化:

          // server.cpp
          Server::Server(QWidget *parent)
              : QDialog(parent)
              , statusLabel(new QLabel)
          {
              // 建立 TCP Server,并監聽
              tcpServer=new QTcpServer(this);
              tcpServer->listen()
              
              // 獲取 Server 的 IP 地址,并用其初始化 UI
              [...]
          
              // 一旦有 TCP 連接,則調用 sendMsg() 發送數據給客戶端
              connect(tcpServer, &QTcpServer::newConnection, this, &Server::sendMsg);
          }
          

          要點:

          1、QTcpServer 是對 TCP-based server 的封裝。

          2、QTcpServer::listen() 用于監聽是否有客戶端發起連接。

          3、一旦有客戶端訪問,QTcpServer 會發出 newConnection() 信號,我們通過綁定槽函數 sendMsg() 以實現發送消息的功能。

          嵌入式物聯網需要學的東西真的非常多,千萬不要學錯了路線和內容,導致工資要不上去!

          無償分享大家一個資料包,差不多150多G。里面學習內容、面經、項目都比較新也比較全!某魚上買估計至少要好幾十。

          點擊這里找小助理0元領取:嵌入式物聯網學習資料(頭條)




          獲取 Server IP

          在界面上顯示服務端的 IP 信息:

          // server.cpp
          Server::Server(QWidget *parent)
              : QDialog(parent)
              , statusLabel(new QLabel)
          {
              // 創建 TCP Server
              [...]
          
              QString ipAddress;
          
              // 獲得所有的 IP 地址
              QList<QHostAddress> ipAddressesList=QNetworkInterface::allAddresses();
          
              // 解析出第一個可用的 IPv4 地址
              for (int i=0; i < ipAddressesList.size(); ++i) {
                  if (ipAddressesList.at(i) !=QHostAddress::LocalHost &&
                      ipAddressesList.at(i).toIPv4Address()) {
                      ipAddress=ipAddressesList.at(i).toString();
                      break;
                  }
              }
          
              // 初始化 UI
              [...]
          }
          

          要點:

          1、QNetworkInterface 是對網絡接口 (例如 lo、eth0...) 的封裝。

          2、QNetworkInterface::allAddresses() 會返回系統里所有的 IP 地址。

          3、QHostAddress 是對 IP 地址(IPv4、IPv6) 的封裝。

          4、QHostAddress::toIPv4Address() 會將點分式的 IPv4 地址轉換為數字式,例如 127.0.0.1 會被轉換為 0x7F000001,失敗則返回 0。


          給客戶端發送消息

          當有客戶端連接到來時,槽函數 sendMsg()會被調用 :

          // server.cpp
          void Server::sendMsg()
          {
              // Prepare message
              QByteArray block;
              QDataStream out(&block, QIODevice::WriteOnly);
              out << message[QRandomGenerator::global()->bounded(message.size())];
          
              // Get pending connection
              QTcpSocket *clientConnection=tcpServer->nextPendingConnection();
              connect(clientConnection, &QAbstractSocket::disconnected,
                      clientConnection, &QObject::deleteLater);
          
              // Send message
              clientConnection->write(block);
              clientConnection->disconnectFromHost();
          }
          

          要點:

          1、QTcpSocket 是對 TCP Socket 的封裝。

          2、為了與主機無關 (字節序等),這里選用 QByteArray 以二進制的格式來存儲數據。使用 QDataStream 可以輕松地將 Message 寫到 QByteArray 里。

          3、QDataStream 從各種 IO 設備 (QIODeice 的子類),例如 QByteArray、文件 (QFile) 等讀寫二進制數據。

          4、從 QTcpServer::nextPendingConnection() 獲得客戶端的 Socket。

          5、用 QTcpSocket::write() 將 Message 通過網絡發給客戶端。

          6、最后,通過 QTcpSocket::disconnectFromHost 斷開連接,它會等待直到數據成功被寫出去。


          Client 端

          運行效果:

          每次點擊 "Get Message" 按鈕,客戶端都會從服務端隨機獲取到一條問候信息。

          源碼文件:

          msg_client/
          ├── msg_client.pro
          ├── client.cpp
          ├── client.h
          └── main.cpp
          

          創建 TCP Socket

          // client.cpp
          Client::Client(QWidget *parent)
              : QDialog(parent)
              , hostCombo(new QComboBox)
              , portLineEdit(new QLineEdit)
              , statusLabel(new QLabel(tr("This examples requires that you run the\n Message Server example as well.")))
              , getMsgButton(new QPushButton(tr("Get Message")))
              , tcpSocket(new QTcpSocket(this))
          {
              // Init UI
              [...]
          
              // Setup QDataStream's source
              in.setDevice(tcpSocket);
              in.setVersion(QDataStream::Qt_5_10);
          
              // Setup signal & slot
              connect(getMsgButton, &QAbstractButton::clicked,
                      this, &Client::requestNewMsg);
              connect(tcpSocket, &QIODevice::readyRead, this, &Client::readMsg);
          }
          

          要點:

          1、用 QTcpSocket 創建 TCP Socket。

          2、將 QDataStream 數據流的輸入源設置為 Socket。

          3、設置信號槽:當 Socket 有數據時,調用 readMsg() 將其讀走。


          從服務端讀取消息

          當用戶點擊 "Get Message" 按鈕時,requestNewMsg() 會被調用

          // client.cpp
          void Client::requestNewMsg()
          {
              getMsgButton->setEnabled(false);
              tcpSocket->abort();
              tcpSocket->connectToHost(hostCombo->currentText(),
                                       portLineEdit->text().toInt());
          }
          

          要點:

          1、QTcpSocket::connectToHost() 向服務端發起連接。

          2、該函數沒有返回值,是因為當有錯誤發生時,socket 會發出 error() 信號,我們可以通過綁定對應的槽函數進行錯誤處理。

          3、成功連接后,服務端會隨機發送一條信息過來,客戶端接收到消息后,readMsg() 會被調用。

          // client.cpp
          void Client::readMsg()
          {
              QString ;
              in >> nextFortune;
              statusLabel->setText(nextFortune);
              getMsgButton->setEnabled(true);
          }
          

          很簡單的流操作,讀到信息后,將其顯示在界面上。


          總結

          用一張圖總結一下 Qt TCP 通訊流程:


          原文鏈接:https://mp.weixin.qq.com/s/aCyV4HBwzTUZbCrdKsLtBw

          文章轉載自:老吳嵌入式

          文章來源于:一小例子,了解 TCP 通訊流程 | Qt 示例

          原文鏈接:一小例子,了解 TCP 通訊流程 | Qt 示例

          版權聲明:本文來源于網絡,免費傳達知識,版權歸原作者所有,如涉及作品版權問題,請聯系我進行刪除


          主站蜘蛛池模板: 国产精品日韩一区二区三区| 国产一区二区三区不卡观| 国产嫖妓一区二区三区无码| 亚洲乱码国产一区三区| 乱中年女人伦av一区二区| 麻豆亚洲av熟女国产一区二| 在线观看国产区亚洲一区成人 | 成人国产精品一区二区网站公司| 国产亚洲自拍一区| 亚洲一区二区三区免费| 国产成人精品亚洲一区| 影院成人区精品一区二区婷婷丽春院影视| 内射女校花一区二区三区| 中文字幕在线观看一区二区三区| 在线视频国产一区| 日本无卡码免费一区二区三区| 亚洲综合色一区二区三区| 无码人妻精品一区二区三区在线 | 国产剧情国产精品一区| 91精品一区国产高清在线| 中文字幕日韩人妻不卡一区| 国产亚洲一区二区三区在线观看| 日本在线不卡一区| 国产电影一区二区| 国产乱码精品一区二区三区| 日韩一区二区在线免费观看| 美女视频黄a视频全免费网站一区| 国产福利在线观看一区二区| 视频一区二区三区人妻系列| 日韩人妻无码一区二区三区综合部 | 国产精品一区二区无线| 男人的天堂精品国产一区| 国产福利电影一区二区三区,亚洲国模精品一区 | 亚洲精品色播一区二区| 午夜视频在线观看一区| 一区二区三区国模大胆| 国产一区二区三区91| 中文乱码人妻系列一区二区| 国产伦精品一区二区三区视频小说| 精彩视频一区二区三区| 精品国产一区二区三区在线观看|