您的位置 首页 新闻

PyQt实现简易浏览器

本文主要学习 PyQt 的使用,所以在实现浏览器的时候将不涉及底层传输协议与页面解析等内容。那么该怎么实现浏览器呢?所幸 Qt 为开发者提供了 QtWebKit 模块。 QtWeb…

本文主要学习 PyQt 的使用,所以在实现浏览器的时候将不涉及底层传输协议与页面解析等内容。那么该怎么实现浏览器呢?所幸 Qt 为开发者提供了 QtWebKit 模块。

QtWebKit 是一个基于开源项目 WebKit 的网页内容渲染引擎,借助该引擎可以更加快捷地将万维网集成到 Qt 应用中。

通常来说一个浏览器应该要具备以下几个功能:

有一个可用来展示网页的窗口

拥有导航栏,地址栏

拥有标签,支持同时访问多个页面 接下来我们将逐一来实现以上提及的这些特性。

创建浏览器

from PyQt5.QtCore import * from PyQt5.QtWidgets import * from PyQt5.QtGui import * from PyQt5.QtWebKitWidgets import * import sys class MainWindow(QMainWindow): def __init__(self, *args, **kwargs): super().__init__(*args, **kwargs) # 设置窗口标题 self.setWindowTitle(‘My Browser’) self.setFixedSize(800,600) # 设置窗口图标 self.setWindowIcon(QIcon(‘icons/penguin.png’)) self.show() # 设置浏览器 self.browser = QWebView() url = ‘https://www.shiyanlou.com/’ # 指定打开界面的 URL self.browser.setUrl(QUrl(url)) # 添加浏览器到窗口中 self.setCentralWidget(self.browser) # 创建应用 app = QApplication(sys.argv) # 创建主窗口 window = MainWindow() # 显示窗口 window.show() # 运行应用,并监听事件 app.exec_()

添加导航栏

在这里我们要为浏览器添加导航栏,我们需要使用到 QToolBar 来创建,然后再往上边添加 QAction 创建按钮实例。

… class MainWindow(QMainWindow): def __init__(self, *args, **kwargs): … # 添加导航栏 navigation_bar = QToolBar(‘Navigation’) # 设定图标的大小 navigation_bar.setIconSize(QSize(16, 16)) self.addToolBar(navigation_bar) # 添加前进、后退、停止加载和刷新的按钮 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) …

现在我们不仅为浏览器添加了前进、后退、停止加载和刷新的按钮,同时还利用 QWebView 封装的槽实现了这些按钮的实际功能。

接下来我们再给浏览器添加地址栏。

… class MainWindow(QMainWindow): def __init__(self, *args, **kwargs): … # 添加 URL 地址栏 self.urlbar = QLineEdit() navigation_bar.addSeparator() navigation_bar.addWidget(self.urlbar) self.browser.urlChanged.connect(self.renew_urlbar) def renew_urlbar(self, q): # 将当前网页的链接更新到地址栏 self.urlbar.setText(q.toString()) self.urlbar.setCursorPosition(0) …

这时候我们不仅添加了地址栏,而且地址栏还能实时更新成当前网页的 URL 。当然现在还不支持回车访问,下面 来实现这一点。

… class MainWindow(QMainWindow): def __init__(self, *args, **kwargs): … # 添加 URL 地址栏 self.urlbar = QLineEdit() # 让地址栏能响应回车按键信号 self.urlbar.returnPressed.connect(self.navigate_to_url) navigation_bar.addSeparator() navigation_bar.addWidget(self.urlbar) self.browser.urlChanged.connect(self.renew_urlbar) # 响应回车按钮,将浏览器当前访问的 URL 设置为用户输入的 URL def navigate_to_url(self): q = QUrl(self.urlbar.text()) if q.scheme() == ”: q.setScheme(‘http’) self.browser.setUrl(q) …

添加标签页

为了添加标签页,我们对程序的 web 界面实现做较大的改动。

主要实现以下功能

使用 QTabWidget 来给浏览器添加标签栏用于展示标签页面。

为标签栏添加按钮能动态地扩展标签页面。

添加关闭功能

将标签标题自动设置为网页所提供的标题

本文来自网络,不代表Xnewv立场,转载请注明出处:https://xnewv.com/1947.html

为您推荐

联系我们

联系我们

18873343099

在线咨询: QQ交谈

邮箱: [email protected]

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

关注微博
返回顶部