操作系統(tǒng):Linux Mint
編輯器:vim
編程語(yǔ)言:python3
安裝PyQt5
Qt是一個(gè)跨平臺(tái)的C++應(yīng)用程序開(kāi)發(fā)框架
sudo apt-get install python3-pyqt5
安裝完成后進(jìn)入python命令行界面測(cè)試是否安裝正確?
python3?
>>>import PyQt5
執(zhí)行命令后如果沒(méi)有任何提示,說(shuō)明安裝成功?
Qt為開(kāi)發(fā)者提供了QtWebKit模塊,QtWebKit是一個(gè)基于開(kāi)源項(xiàng)目
WebKit的網(wǎng)頁(yè)內(nèi)容渲染引擎,借助該引擎可以更加快捷地將萬(wàn)維
網(wǎng)集成到 Qt 應(yīng)用中秦踪。
瀏覽器有一個(gè)可以用于展示網(wǎng)頁(yè)的窗口
創(chuàng)建瀏覽器
Qt的程序通過(guò)創(chuàng)建QApplication類(lèi)實(shí)例來(lái)調(diào)用exec_()方法進(jìn)入事件循環(huán)摇肌,
然后程序一直循環(huán)監(jiān)聽(tīng)各種事件并把它們放入消息隊(duì)列中不傅,在適當(dāng)?shù)臅r(shí)候從隊(duì)
列中取出處理宝冕。
...
#通過(guò)創(chuàng)建QApplication類(lèi)實(shí)例來(lái)創(chuàng)建應(yīng)用
app = QApplication(sys.argv)
#運(yùn)行應(yīng)用并循環(huán)監(jiān)聽(tīng)事件
app.exec_()?
我們可以使用Qt提供的QToolBar創(chuàng)建工具欄
...
# 添加導(dǎo)航欄
navigation_bar = QToolBar('Navigation')
# 設(shè)定圖標(biāo)的大小
navigation_bar.setIconSize(QSize(16, 16))
#添加導(dǎo)航欄到窗口中
self.addToolBar(navigation_bar)
...
QAction類(lèi)提供了抽象的用戶(hù)界面action
#添加按鈕
reload_button = QAction(QIcon('icons/renew.png'), 'reload', self)
將action與實(shí)際功能綁定
reload_button.triggered.connect(self.browser.reload)
這些action可以被放置在窗口部件中
navigation_bar.addAction(reload_button)
Qt中有一個(gè)強(qiáng)大的部件類(lèi)QWidgets姓言,基于這個(gè)類(lèi)可以派生出很多其他的小部件
寻狂,比如QLineEdit是單行文本框岁经,將這個(gè)不見(jiàn)作為地址欄,為瀏覽起添加一個(gè)地址欄
#添加URL地址欄
self.urlbar = QLineEdit()
Qt中每種組件都有信號(hào)機(jī)制蛇券,可用來(lái)將信號(hào)與相應(yīng)的處理函數(shù)進(jìn)行連接綁定缀壤,比如將
地址欄的回車(chē)信號(hào)urlbar.returnPressed與navigate_to_url函數(shù)綁定,當(dāng)?shù)刂窓诘幕剀?chē)信號(hào)發(fā)出時(shí)
便會(huì)觸發(fā)函數(shù)navigate_to_url進(jìn)行處理
# 讓地址欄能響應(yīng)回車(chē)按鍵信號(hào)
self.urlbar.returnPressed.connect(self.navigate_to_url)
#navigate_to_url函數(shù)
def navigate_to_url(self):
? ? q = QUrl(self.urlbar.text())
? ? if q.scheme() == '':
? ? ? ? q.setScheme('http')
? ? self.browser.setUrl(q)
# v1.2
# created
#? by Roger
# in 2017.1.3
from PyQt5.QtCore import *
from PyQt5.QtWidgets import *
from PyQt5.QtGui import *
from PyQt5.QtWebKitWidgets import *
import sys
class MainWindow(QMainWindow):
? ? # noinspection PyUnresolvedReferences
? ? def __init__(self, *args, **kwargs):
? ? ? ? super().__init__(*args, **kwargs)
? ? ? ? # 設(shè)置窗口標(biāo)題
? ? ? ? self.setWindowTitle('My Browser')
? ? ? ? # 設(shè)置窗口圖標(biāo)
? ? ? ? self.setWindowIcon(QIcon('icons/penguin.png'))
? ? ? ? # 設(shè)置窗口大小900*600
? ? ? ? self.resize(900, 600)
? ? ? ? self.show()
? ? ? ? # 設(shè)置瀏覽器
? ? ? ? self.browser = QWebView()
? ? ? ? url = 'http://blog.csdn.net/roger_lzh'
? ? ? ? # 指定打開(kāi)界面的 URL
? ? ? ? self.browser.setUrl(QUrl(url))
? ? ? ? # 添加瀏覽器到窗口中
? ? ? ? self.setCentralWidget(self.browser)
? ? ? ? ###使用QToolBar創(chuàng)建導(dǎo)航欄怀读,并使用QAction創(chuàng)建按鈕
? ? ? ? # 添加導(dǎo)航欄
? ? ? ? navigation_bar = QToolBar('Navigation')
? ? ? ? # 設(shè)定圖標(biāo)的大小
? ? ? ? navigation_bar.setIconSize(QSize(16, 16))
? ? ? ? #添加導(dǎo)航欄到窗口中
? ? ? ? self.addToolBar(navigation_bar)
? ? ? ? #QAction類(lèi)提供了抽象的用戶(hù)界面action诉位,這些action可以被放置在窗口部件中
? ? ? ? # 添加前進(jìn)、后退菜枷、停止加載和刷新的按鈕
? ? ? ? back_button = QAction(QIcon('icons/back.png'), 'Back', self)
? ? ? ? next_button = QAction(QIcon('icons/next.png'), 'Forward', self)
? ? ? ? stop_button = QAction(QIcon('icons/cross.png'), 'stop', self)
? ? ? ? reload_button = QAction(QIcon('icons/renew.png'), 'reload', self)
? ? ? ? back_button.triggered.connect(self.browser.back)
? ? ? ? next_button.triggered.connect(self.browser.forward)
? ? ? ? stop_button.triggered.connect(self.browser.stop)
? ? ? ? reload_button.triggered.connect(self.browser.reload)
? ? ? ? # 將按鈕添加到導(dǎo)航欄上
? ? ? ? navigation_bar.addAction(back_button)
? ? ? ? navigation_bar.addAction(next_button)
? ? ? ? navigation_bar.addAction(stop_button)
? ? ? ? navigation_bar.addAction(reload_button)
? ? ? ? #添加URL地址欄
? ? ? ? self.urlbar = QLineEdit()
? ? ? ? # 讓地址欄能響應(yīng)回車(chē)按鍵信號(hào)
? ? ? ? self.urlbar.returnPressed.connect(self.navigate_to_url)
? ? ? ? navigation_bar.addSeparator()
? ? ? ? navigation_bar.addWidget(self.urlbar)
? ? ? ? #讓瀏覽器相應(yīng)url地址的變化
? ? ? ? self.browser.urlChanged.connect(self.renew_urlbar)
? ? def navigate_to_url(self):
? ? ? ? q = QUrl(self.urlbar.text())
? ? ? ? if q.scheme() == '':
? ? ? ? ? ? q.setScheme('http')
? ? ? ? self.browser.setUrl(q)
? ? def renew_urlbar(self, q):
? ? ? ? # 將當(dāng)前網(wǎng)頁(yè)的鏈接更新到地址欄
? ? ? ? self.urlbar.setText(q.toString())
? ? ? ? self.urlbar.setCursorPosition(0)
# 創(chuàng)建應(yīng)用
app = QApplication(sys.argv)
# 創(chuàng)建主窗口
window = MainWindow()
# 顯示窗口
window.show()
# 運(yùn)行應(yīng)用苍糠,并監(jiān)聽(tīng)事件
app.exec_()? ?
歡迎批評(píng)指正,大家一起相互學(xué)習(xí)啤誊!
轉(zhuǎn)自http://blog.csdn.net/roger_lzh https://blog.csdn.net/Roger_LZH/article/details/54090203