将标记从国家名称放入国家/地区

Put marker into country from country name

本文关键字:国家 地区      更新时间:2023-09-26

我有一个谷歌地图搜索字段。输入转到谷歌地点 API,我得到一个结果并缩放到该地点的边界。

如果用户搜索像Norway这样的国家/地区,地图将缩放并居中,如下所示:https://www.google.de/maps/place/Norwegen/@64.5783089,17.888237,5z/data=!3m1!4b1!4m2!3m1!1s0x461268458f4de5bf:0xa1b03b9db864d02b

但我需要在中心放置一个标记,以便用户看到他的搜索将他带到哪里。在挪威示例中,这将导致标记放置在屏幕中间,但在挪威之外。

是否有可能在一个国家/地区放置标记?

编辑

如果我搜索挪威,这个地方json:

{
    "address_components": [
        {
            "long_name": "Norway",
            "short_name": "NO",
            "types": [
                "country",
                "political"
            ]
        }
    ],
    "adr_address": "<span class='"country-name'">Norway</span>",
    "formatted_address": "Norway",
    "geometry": {
        "location": {
            "k": 60.47202399999999,
            "D": 8.46894599999996
        },
        "viewport": {
            "Ea": {
                "k": 57.9711417,
                "j": 71.1854762
            },
            "wa": {
                "j": 4.626684800000021,
                "k": 31.149789199999987
            }
        }
    },
    "icon": "http://maps.gstatic.com/mapfiles/place_api/icons/geocode-71.png",
    "id": "c94d4f99cf5b1f973f837eb189e0cfff6b91fab0",
    "name": "Norway",
    "place_id": "ChIJv-VNj0VoEkYRK9BkuJ07sKE",
    "reference": "CnRpAAAANAQEnqw1T_JMzZwRKpmAX1Yz7vZ83m1zIb20hhZVPnSrTHQN1nELF5mq73UIhsU5HpsvQV3KZWyIaEBu-WoCI0R10koCHxf3zV6FsWeS0d_GsY-rK9a6i4z0MKBSZVNTywLbZBKDIuoiZEIldqmMjxIQ94Ks-CUSOr9ciS0K8TLnmRoUTp5kU7pNMCjEfDZGde6GvYtDLGU",
    "scope": "GOOGLE",
    "types": [
        "country",
        "political"
    ],
    "url": "https://maps.google.com/maps/place?q=Norway&ftid=0x461268458f4de5bf:0xa1b03b9db864d02b",
    "html_attributions": []
} 

谷歌将其识别为一个国家,视口用于边界,但geometry.location在瑞典。

地点结果的几何包含 2 个属性,viewport(我想这就是你用来缩放到边界的属性)和一个location属性。这个位置属性通常是国家/地区内的一个点(当您搜索一个国家/地区时),您可以使用它来绘制标记。

查看 PlaceGeometry 对象。

这将允许您正确放置标记。例如:

var marker = new google.maps.Marker({
    map: map,
    title: place.name,
    position: place.geometry.location
});

这是我前段时间创建的一个小提琴示例:

JSFiddle 演示