我的项目中包含一个 HTML 文件。我用它来初始化一个WebView
显示自定义谷歌地图的。我是 OSX 应用程序的新手(我来自 iOS)所以这对我来说有点新......
我希望 HTML 文件的某些部分是“动态的”,尤其是在 javascript 函数中。
这是我获取本地文件的 URL 并加载 WebView 的方法:
-(void)awakeFromNib
{
NSString *indexPath = [[NSBundle mainBundle] pathForResource:@"index" ofType:@"html"];
[[mapView mainFrame] loadRequest:[NSURLRequest requestWithURL:[NSURL fileURLWithPath:indexPath]]];
[[[mapView mainFrame] frameView] setAllowsScrolling:NO];
[mapView setNeedsDisplay:YES];
}
这是 HTML 文件:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xmlns:v="urn:schemas-microsoft-com:vml">
<head>
<meta http-equiv="content-type" content="text/html; charset=utf-8"/>
<script src="https://maps.googleapis.com/maps/api/js?v=3.exp&sensor=false"></script>
</head>
<body style="width:100%;height:100%">
<div id="map_area" style="position: absolute; top: 0; right: 0; bottom: 0; left: 0"> </div>
<script type="text/javascript">
//map = new GMap2(document.getElementById("map_area"));
//map.setCenter(new GLatLng(37.4419, -122.1419), 13);
var myLatLng = new google.maps.LatLng(0, -180);
var mapOptions = {
zoom: 1,
center: myLatLng,
mapTypeId: google.maps.MapTypeId.TERRAIN
};
var map = new google.maps.Map(document.getElementById('map_area'), mapOptions);
var flightPlanCoordinates = [
new google.maps.LatLng(37.772323, -122.214897),
new google.maps.LatLng(21.291982, -157.821856),
new google.maps.LatLng(-18.142599, 178.431),
new google.maps.LatLng(-27.46758, 153.027892)
];
var flightPath = new google.maps.Polyline({
path: flightPlanCoordinates,
strokeColor: '#FF0000',
strokeOpacity: 1.0,
strokeWeight: 2
});
flightPath.setMap(map);
</script>
</body>
</html>
如何即时更改 javascript?我希望能够添加/删除坐标并绘制多条折线。在 iOS 中处理 HTML/XML 时,我使用了一种名为 HPPLE 的东西,它通过 HTML/XML 文件进行解析......
任何有关如何解决此问题的帮助将不胜感激……或者,如果您知道调用 javascript 函数的更好方法,请随时告诉我。