QwebengineView в pyside6 показывает статическое наложение на динамическое содержаниеPython

Программы на Python
Ответить Пред. темаСлед. тема
Anonymous
 QwebengineView в pyside6 показывает статическое наложение на динамическое содержание

Сообщение Anonymous »

Я разрабатываю приложение Pyside6, которое интегрирует представление в Интернете с помощью Qwebengineview. Тем не менее, я сталкиваюсь с проблемой, в которой появляется статический кадр веб -сайта веб -интерфейса в дополнение к фактическому рабочему веб -сайту. Кроме того, я заметил, что, когда я нажимаю на любую клавишу, обновления кадра оверлея, чтобы показать текущее состояние веб -сайта в тот точный момент. Эта проблема возникает с любым веб -сайтом, а не только с Google Earth. /p>
рама сверху, рабочее веб -сайт под ним
< /p>
Вот фрагмент кода части, добавленную в Designer setupui: < /p>
self.stackedWidget.addWidget(self.widgets)
self.new_page = QWidget()
self.new_page.setObjectName(u"new_page")
self.verticalLayout_20 = QVBoxLayout(self.new_page)
self.verticalLayout_20.setObjectName(u"verticalLayout_20")
self.GoogleEarth = QWebEngineView(self.new_page)
self.GoogleEarth.setObjectName(u"GoogleEarth")

self.verticalLayout_20.addWidget(self.GoogleEarth)

self.GoogleEarth.setUrl(QUrl("https://earth.google.com/web/"))

self.stackedWidget.addWidget(self.new_page)

self.verticalLayout_15.addWidget(self.stackedWidget)
< /code>
Вот основное с классом Mainwindow: < /p>
class MainWindow(QMainWindow):
def __init__(self):
QMainWindow.__init__(self)

# SET AS GLOBAL WIDGETS
self.ui = Ui_MainWindow()
self.ui.setupUi(self)
# self.ui.configureWebEngine(self)
global widgets
widgets = self.ui

# USE CUSTOM TITLE BAR | USE AS "False" FOR MAC OR LINUX
Settings.ENABLE_CUSTOM_TITLE_BAR = True

# APP NAME
title = "test"
description = "test"
# APPLY TEXTS
self.setWindowTitle(title)
widgets.titleRightInfo.setText(description)

# TOGGLE MENU
widgets.toggleButton.clicked.connect(lambda: UIFunctions.toggleMenu(self, True))

# SET UI DEFINITIONS
UIFunctions.uiDefinitions(self)

# QTableWidget PARAMETERS
widgets.tableWidget.horizontalHeader().setSectionResizeMode(QHeaderView.Stretch)

# BUTTONS CLICK

# LEFT MENUS
widgets.btn_home.clicked.connect(self.buttonClick)
widgets.btn_widgets.clicked.connect(self.buttonClick)
widgets.btn_new.clicked.connect(self.buttonClick)
widgets.btn_save.clicked.connect(self.buttonClick)

# EXTRA LEFT BOX
def openCloseLeftBox():
UIFunctions.toggleLeftBox(self, True)
widgets.toggleLeftBox.clicked.connect(openCloseLeftBox)
widgets.extraCloseColumnBtn.clicked.connect(openCloseLeftBox)

# EXTRA RIGHT BOX
def openCloseRightBox():
UIFunctions.toggleRightBox(self, True)
widgets.settingsTopBtn.clicked.connect(openCloseRightBox)

# SHOW APP
self.show()

# SET HOME PAGE AND SELECT MENU
widgets.stackedWidget.setCurrentWidget(widgets.home)
widgets.btn_home.setStyleSheet(UIFunctions.selectMenu(widgets.btn_home.styleSheet()))

# BUTTONS CLICK
# Post here your functions for clicked buttons
def buttonClick(self):
# GET BUTTON CLICKED
btn = self.sender()
btnName = btn.objectName()

# SHOW HOME PAGE
if btnName == "btn_home":
widgets.stackedWidget.setCurrentWidget(widgets.home)
UIFunctions.resetStyle(self, btnName)
btn.setStyleSheet(UIFunctions.selectMenu(btn.styleSheet()))

# SHOW WIDGETS PAGE
if btnName == "btn_widgets":
widgets.stackedWidget.setCurrentWidget(widgets.widgets)
UIFunctions.resetStyle(self, btnName)
btn.setStyleSheet(UIFunctions.selectMenu(btn.styleSheet()))

# SHOW NEW PAGE
if btnName == "btn_new":
widgets.stackedWidget.setCurrentWidget(widgets.new_page) # SET PAGE
UIFunctions.resetStyle(self, btnName) # RESET ANOTHERS BUTTONS SELECTED
btn.setStyleSheet(UIFunctions.selectMenu(btn.styleSheet())) # SELECT MENU

if btnName == "btn_save":
print("Save BTN clicked!")

# PRINT BTN NAME
print(f'Button "{btnName}" pressed!')

# RESIZE EVENTS
def resizeEvent(self, event):
# Update Size Grips
UIFunctions.resize_grips(self)

# MOUSE CLICK EVENTS
def mousePressEvent(self, event):
# SET DRAG POS WINDOW
self.dragPos = event.globalPos()

# PRINT MOUSE EVENTS
if event.buttons() == Qt.LeftButton:
print('Mouse click: LEFT CLICK')
if event.buttons() == Qt.RightButton:
print('Mouse click: RIGHT CLICK')

if __name__ == "__main__":
app = QApplication(sys.argv)
app.setWindowIcon(QIcon("icon.ico"))
window = MainWindow()
window.show()
sys.exit(app.exec())
< /code>
Что я попробовал: < /p>
  • Принуждение перекрашивания и обновление: я попытался использовать repaint () и обновление ( ) Методы на QWebengineView после завершения загрузки страницы. : Я использовал Qtimer, чтобы принудительно обновлять после короткой задержки.


Подробнее здесь: https://stackoverflow.com/questions/794 ... ic-content
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «Python»