2016-11-16 122 views
1

我想,以显示与QWebView的单张地图(从here启发)。我的文件夹的结构如下所示:PyQt5 QWebView:加载HTML文件加载.js文件

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

当我从map.html,其中包括map.js所有内容运行map.py,然后代码工作。

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.htmlQtCore.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_() 

有谁请告诉我如何显示PyQt5 .html文件的内容时,我从外部.html文件中加载JavaScript文件?

这里是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