gpt4 book ai didi

google-maps - 在 WebKit 中打印带有多个嵌入式 Google map 的页面会产生图 block 错误

转载 作者:行者123 更新时间:2023-12-01 15:45:27 24 4
gpt4 key购买 nike

在 Mac 上的 Chrome 或 Safari(即 WebKit)中打印以下示例页面会在从第二张 map 开始的打印输出中产生错位的 map 图 block 。它适用于网页本身,打印它似乎也适用于 Firefox。不过需要它在 Chrome 或 Safari 中工作。

示例页面:http://matsch.binaervarianz.de/tmp/print_entries.html
页面的打印到 PDF 输出:http://matsch.binaervarianz.de/tmp/print_entries.pdf

(参见,例如,从第 2 页开始的 US421 道路的位移。)

看起来是只影响打印的缓存问题。但清除缓存或隐私/隐身浏览并不能解决问题。

虽然在示例中所有 map 部分都是相同的,但不同的 map 也会出现此问题(例如,尝试在示例中进行平移和缩放)。

我可以接受部分解决方案,我可以让它在我自己的浏览器中工作——也就是说,它不一定对每个人都有效,但它必须是 Webkit(Safari 或 Chrome)。不能为此使用 Firefox...

如果这对每个人都有效,可加分。

这是一些如何初始化 map 的代码。上面的示例页面中有更多信息。

// first map
var snippets = [];
snippets.push({
snippet_approx_location_lat: "",
snippet_approx_location_long: "",
snippet_location_lat: "39.9510463",
snippet_location_long: "-86.2288448"
});

var mapData_2899_1 = {
snippets: snippets,
entry_approx_location_lat: "",
entry_approx_location_long: ""
};

showMap(mapData_2899_1, "2899_1");

// second map
snippets = [];
snippets.push({
snippet_approx_location_lat: "",
snippet_approx_location_long: "",
snippet_location_lat: "39.9510639",
snippet_location_long: "-86.2287998"
});
snippets.push({
snippet_approx_location_lat: "",
snippet_approx_location_long: "",
snippet_location_lat: "39.9510739",
snippet_location_long: "-86.2288998"
});

var mapData_2899_3 = {
snippets: snippets,
entry_approx_location_lat: "",
entry_approx_location_long: ""
};

showMap(mapData_2899_3, "2899_3");

// show map function
function showMap(d, primKey) {
$( '#map-' + primKey ).addClass('map-canvas');

var mapOptions = {
center: { lat: 39.9513164, lng: -86.2274201 },
streetViewControl: false, zoom: 12,
disableDefaultUI: true
};
var map = new google.maps.Map(document.getElementById('map-' + primKey), mapOptions);

$.each(d.snippets, function( i, snippet ) {

// location when snippet was recorded
if (snippet.snippet_location_lat !== "" && snippet.snippet_location_long !== "") {
var snippetLoc = new google.maps.LatLng(
p(snippet.snippet_location_lat),
p(snippet.snippet_location_long)
);
var marker = new google.maps.Marker({ position: snippetLoc, map: map });
}

// approximate location taking into account how long ago the event reportadly took place
if (snippet.snippet_approx_location_lat !== "") {
var snippetApproxLocation = new google.maps.LatLng(
p(snippet.snippet_approx_location_lat),
p(snippet.snippet_approx_location_long)
);
var marker2 = new google.maps.Marker({
position: snippetApproxLocation,
map: map,
icon: 'https://maps.google.com/mapfiles/ms/icons/blue-dot.png'
});
}
});

// approximate location at corrected time from diary entry
if (d.entry_approx_location_lat !== "") {
var entryApproxLocation = new google.maps.LatLng(
p(d.entry_approx_location_lat),
p(d.entry_approx_location_long)
);
var marker3 = new google.maps.Marker({
position: entryApproxLocation,
map: map,
icon: 'https://maps.google.com/mapfiles/ms/icons/yellow-dot.png'
});
}
}

function p( string ) {
if (string === null)
return "";
else
return string;
}
<script src="https://maps.googleapis.com/maps/api/js?key=AIzaSyDO_bHfTaLLr2Ugghz1hQ2QIZdRaa0SKX0"></script>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js">
</script>
<style type="text/css">
.map-canvas {
width: 325px;
height: 325px;
float: right;
margin: 5px;
}
</style>

<div id="map-2899_1" class="map-canvas"></div><br><br>
<div id="map-2899_3" class="map-canvas"></div>

最佳答案

我找到了我认为是 WebKit 中错误的解决方法。由于 map block 的缓存似乎不是问题,我开始尝试使用 CSS displayposition 属性。

display:inline-block; 添加到我的 .map_canvas 似乎解决了打印输出中的问题……现在这些图 block 都是正确的。 display:inline; 单独没有同样的效果;而且我不知道为什么 inline-block 解决了这个问题。

(因为在我的特殊情况下我想要 map 到 float:right; 我必须在 .map_canvas div 周围放置一个包装器。所以,。 map_canvasdisplay:inline-block;.map-containerfloat:right;。)

因此,在 WebKit 中,对页面上多个 map 的打印支持似乎有问题,或者我没有完全理解它。

现在,这里是工作示例页面:http://matsch.binaervarianz.de/tmp/print_entries-solution.html这是该页面的打印到 PDF 输出:http://matsch.binaervarianz.de/tmp/print_entries-solution.pdf

这是工作代码(只有 HTML/CSS 发生了变化):

// first map
var snippets = [];
snippets.push({
snippet_approx_location_lat: "",
snippet_approx_location_long: "",
snippet_location_lat: "39.9510463",
snippet_location_long: "-86.2288448"
});

var mapData_2899_1 = {
snippets: snippets,
entry_approx_location_lat: "",
entry_approx_location_long: ""
};

showMap(mapData_2899_1, "2899_1");

// second map
snippets = [];
snippets.push({
snippet_approx_location_lat: "",
snippet_approx_location_long: "",
snippet_location_lat: "39.9510639",
snippet_location_long: "-86.2287998"
});
snippets.push({
snippet_approx_location_lat: "",
snippet_approx_location_long: "",
snippet_location_lat: "39.9510739",
snippet_location_long: "-86.2288998"
});

var mapData_2899_3 = {
snippets: snippets,
entry_approx_location_lat: "",
entry_approx_location_long: ""
};

showMap(mapData_2899_3, "2899_3");

// show map function
function showMap(d, primKey) {
$( '#map-' + primKey ).addClass('map-canvas');

var mapOptions = {
center: { lat: 39.9513164, lng: -86.2274201 },
streetViewControl: false, zoom: 12,
disableDefaultUI: true
};
var map = new google.maps.Map(document.getElementById('map-' + primKey), mapOptions);

$.each(d.snippets, function( i, snippet ) {

// location when snippet was recorded
if (snippet.snippet_location_lat !== "" && snippet.snippet_location_long !== "") {
var snippetLoc = new google.maps.LatLng(
p(snippet.snippet_location_lat),
p(snippet.snippet_location_long)
);
var marker = new google.maps.Marker({ position: snippetLoc, map: map });
}

// approximate location taking into account how long ago the event reportedly took place
if (snippet.snippet_approx_location_lat !== "") {
var snippetApproxLocation = new google.maps.LatLng(
p(snippet.snippet_approx_location_lat),
p(snippet.snippet_approx_location_long)
);
var marker2 = new google.maps.Marker({
position: snippetApproxLocation,
map: map,
icon: 'https://maps.google.com/mapfiles/ms/icons/blue-dot.png'
});
}
});

// approximate location at corrected time from diary entry
if (d.entry_approx_location_lat !== "") {
var entryApproxLocation = new google.maps.LatLng(
p(d.entry_approx_location_lat),
p(d.entry_approx_location_long)
);
var marker3 = new google.maps.Marker({
position: entryApproxLocation,
map: map,
icon: 'https://maps.google.com/mapfiles/ms/icons/yellow-dot.png'
});
}
}

function p( string ) {
if (string === null)
return "";
else
return string;
}
<script src="https://maps.googleapis.com/maps/api/js?key=AIzaSyDO_bHfTaLLr2Ugghz1hQ2QIZdRaa0SKX0"></script>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js">
</script>
<style type="text/css">
.map-container {
float: right;
margin-left: 5px;
}

.map-canvas {
width: 325px;
height: 325px;
display: inline-block;
}
</style>

<div class="map-container">
<div id="map-2899_1" class="map-canvas"></div>
</div>
<br><br>
<div class="map-container">
<div id="map-2899_3" class="map-canvas"></div>
</div>

关于google-maps - 在 WebKit 中打印带有多个嵌入式 Google map 的页面会产生图 block 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30470885/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com