采用PyQt5.QtWebEngineWidgets加載網頁,直接看代碼:
from PyQt5.QtCore import *
from PyQt5.QtWidgets import *
from PyQt5.QtGui import *
from PyQt5.QtWebEngineWidgets import *
import sys
class MainWindow(QMainWindow):
# noinspection PyUnresolvedReferences
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
# 設置窗口標題
self.setWindowTitle('My Browser')
# 設置窗口圖標
self.setWindowIcon(QIcon('icons/penguin.png'))
# 設置窗口大小900*600
self.resize(900, 600)
self.show()
# 設置瀏覽器
self.browser = QWebEngineView()
url = 'http://www.xxgis.com'
# 指定打開界面的 URL
self.browser.setUrl(QUrl(url))
# 添加瀏覽器到窗口中
self.setCentralWidget(self.browser)
###使用QToolBar創建導航欄,並使用QAction創建按鈕
# 添加導航欄
navigation_bar = QToolBar('Navigation')
# 設定圖標的大小
navigation_bar.setIconSize(QSize(16, 16))
#添加導航欄到窗口中
self.addToolBar(navigation_bar)
#QAction類提供了抽象的用戶界面action,這些action可以被放置在窗口部件中
# 添加前進、后退、停止加載和刷新的按鈕
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)
# 將按鈕添加到導航欄上
navigation_bar.addAction(back_button)
navigation_bar.addAction(next_button)
navigation_bar.addAction(stop_button)
navigation_bar.addAction(reload_button)
#添加URL地址欄
self.urlbar = QLineEdit()
# 讓地址欄能響應回車按鍵信號
self.urlbar.returnPressed.connect(self.navigate_to_url)
navigation_bar.addSeparator()
navigation_bar.addWidget(self.urlbar)
#讓瀏覽器相應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):
# 將當前網頁的鏈接更新到地址欄
self.urlbar.setText(q.toString())
self.urlbar.setCursorPosition(0)
# 創建應用
app = QApplication(sys.argv)
# 創建主窗口
window = MainWindow()
# 顯示窗口
window.show()
# 運行應用,並監聽事件
app.exec_()
