2016-11-16 9 views
1

Я пытаюсь показать карту листовки с QWebView (вдохновленный от here). Структура моей папки выглядит следующим образом:PyQt5 QWebView: Загрузить .html файл, который загружает файл .js

webkit_leaflet/ 
├── map.html 
├── map.js 
└── map.py 

Когда я бегу map.py со всем содержимым из map.html и map.js включен, то код работает.

from PyQt5 import QtWidgets, QtWebKitWidgets 
import sys 


# Create application 
app = QtWidgets.QApplication(sys.argv) 

# Add window 
win = QtWidgets.QWidget() 
win.setWindowTitle('QWebView Map Test') 

# Add layout 
layout = QtWidgets.QVBoxLayout() 
win.setLayout(layout) 

# Create QWebView 
view = QtWebKitWidgets.QWebView() 

# include code from map.html and map.js 

view.setHtml(''' 
<!DOCTYPE html> 
<html> 
<head> 
    <link rel="stylesheet" href="http://cdn.leafletjs.com/leaflet-0.7.3/leaflet.css" /> 
    <script src="http://cdn.leafletjs.com/leaflet-0.7.3/leaflet.js"></script> 
    <style> 
     body { padding: 0; margin: 0; } 
     html, body, #map { height: 100%; } 
    </style> 
</head> 
<body> 
    <div id="map"></div> 
    <script> 
     var map = L.map('map').setView([42.35, -71.08], 13); 
     L.tileLayer('http://tiles.mapc.org/basemap/{z}/{x}/{y}.png', 
     { 
      maxZoom: 18, 
      attribution: 'Map data &copy; <a href="http://openstreetmap.org">OpenStreetMap</a> contributors, ' + 
       '<a href="http://creativecommons.org/licenses/by-sa/2.0/">CC-BY-SA</a>, ' + 
       'Imagery &copy; <a href="http://mapbox.com">Mapbox</a>', 
      id: 'examples.map-i86nkdio', 
     }).addTo(map); 
    </script> 
</body> 
</html> 

''') 

# Add QWebView to the layout 
layout.addWidget(view) 

# Show window, run app 
win.show() 
app.exec_() 

Однако, если я пытаюсь загрузить map.html с QtCore.QUrl() ничего не происходит.

from PyQt5 import QtCore, QtWidgets, QtWebKitWidgets 
import sys 


# Create application 
app = QtWidgets.QApplication(sys.argv) 

# Add window 
win = QtWidgets.QWidget() 
win.setWindowTitle('QWebView Map Test') 

# Add layout 
layout = QtWidgets.QVBoxLayout() 
win.setLayout(layout) 

# Create QWebView 
view = QtWebKitWidgets.QWebView() 

# load .html file 
view.load(QtCore.QUrl('map.html')) 

layout.addWidget(view) 

win.show() 
app.exec_() 

Может кто-нибудь пожалуйста, скажите мне, как показать содержимое .html файла в PyQt5, когда я загрузить файл JavaScript внутри внешнего файла .html?

Вот код для map.html:

<!DOCTYPE html> 
<html> 
<head> 
    <link rel="stylesheet" href="http://cdn.leafletjs.com/leaflet-0.7.3/leaflet.css" /> 
    <script src="http://cdn.leafletjs.com/leaflet-0.7.3/leaflet.js"></script> 
    <style> 
     body { padding: 0; margin: 0; } 
     html, body, #map { height: 100%; } 
    </style> 
</head> 
<body> 
    <div id="map"></div> 
    <script src="map.js"></script> 
</body> 
</html> 

А также код map.js

var map = L.map('map').setView([42.35, -71.08], 13); 
L.tileLayer('http://tiles.mapc.org/basemap/{z}/{x}/{y}.png', 
{ 
    maxZoom: 18, 
    attribution: 'Map data &copy; <a href="http://openstreetmap.org">OpenStreetMap</a> contributors, ' + 
     '<a href="http://creativecommons.org/licenses/by-sa/2.0/">CC-BY-SA</a>, ' + 
     'Imagery &copy; <a href="http://mapbox.com">Mapbox</a>', 
    id: 'examples.map-i86nkdio', 
}).addTo(map); 

ответ

1

Использование QUrl.fromLocalFile передать файл HTML. Также кажется, вам нужно передать абсолютный путь к файлу.

import os 
view.load(QtCore.QUrl.fromLocalFile(os.path.abspath('map.html'))) 
+0

Это работает для вас? Я попытался, но он все еще не работает. – dliv

+0

Да, это работает, но я просто понял, что использую абсолютный путь к 'map.html'. С помощью 'map.html' он терпит неудачу. Я уточню свой ответ – user3419537

+0

отлично, большое спасибо, теперь он работает. :) – dliv

 Смежные вопросы

  • Нет связанных вопросов^_^