Qt Location 오픈스트리트맵 플러그인

개요

이 지리적 서비스 플러그인을 사용하면 애플리케이션이 Qt Location API를 사용하여 오픈스트리트맵 위치 기반 서비스에 액세스할 수 있습니다.

데이터, 이미지 및 지도 정보는 ThunderForest, OpenStreetMap 및 기여자가 제공합니다. 데이터는 오픈 데이터베이스 라이선스에 따라 사용할 수 있습니다.

오픈스트리트맵 지리적 서비스 플러그인은 플러그인 키 "osm"을 사용하여 로드할 수 있습니다.

참고: 표준 지도 유형은 (부분적으로) 무료 데이터 제공업체에 의존합니다. 저희는 평가 및 개발 목적으로 유용하게 사용할 수 있도록 선택 항목을 유지하려고 노력하지만, 실제 제작 시 필요에 맞는 데이터 제공업체를 선택하는 것은 사용자의 책임입니다. 각 제공업체의 서비스 약관을 주의 깊게 읽고 준수할 것을 적극 권장합니다. 대체 데이터 제공업체 목록은 오픈스트리트맵 위키에서 확인할 수 있습니다. 이 플러그인에서 제공하는 사용 가능한 지도 유형은 각 유형에 대해 공개적으로 액세스할 수 있는 공급자의 실제 가용성에 따라 예고 없이 변경(또는 제거)될 수 있습니다. 이는 또한 HTTPS를 통해 타일을 제공하는 공급자가 사용될 수 있음을 의미합니다. 이는 기본적으로 SSL 지원이 Qt에 내장되어 있지 않은 Android와 같은 플랫폼에서 OSM 플러그인을 사용할 때 관련이 있습니다. 이러한 변경을 방지하려면 다른 지리 서비스 플러그인을 사용하거나 플러그인 매개 변수 osm.mapping.providersrepository.address를 사용자 지정 저장소로 설정하여 각 지도 유형에 사용되는 공급자 선택을 완전히 제어할 수 있도록 해야 합니다. Qt 5.9.6부터 지오코딩 및 장소에 사용되는 기본 nominatim 엔드포인트도 HTTPS 전용으로 변경되었습니다.

파라미터

선택적 매개변수

다음 표에는 오픈 스트리트맵 플러그인에 전달할 수 있는 선택적 매개변수가 나열되어 있습니다.

참고: Qt 5.5부터 아래의 모든 매개변수 앞에 osm 를 붙여야 합니다. 이전 버전에서는 접두사가 필요하지 않았습니다.

파라미터설명
osm.geocoding.host지오코딩 서버에 네트워크 요청을 할 때 설정하는 URL 문자열입니다. 이 매개변수는 올바른 OSM API를 사용하여 유효한 서버 URL로 설정해야 합니다. 지정하지 않으면 기본 URL이 사용됩니다.

참고: API 설명서는 프로젝트 OSM Nominatim에서 확인할 수 있습니다.

osm.geocoding.debug_query플러그인이 디버깅 목적으로 지오코딩 응답에 Nominatim에 대한 쿼리 URL을 삽입하도록 지시합니다.
osm.geocoding.include_extended_data플러그인이 반환된 위치 개체에 Nominatim 관련 정보(예: 지오메트리 및 클래스)를 포함하도록 지시하여 확장된 속성으로 노출되도록 합니다.
osm.mapping.cache.directory네트워크 디스크 캐시로 사용되는 맵 타일 캐시 디렉터리의 절대 경로입니다.

캐시의 기본 위치는 QStandardPaths::writableLocation()에서 반환된 위치의 QtLocation/osm 하위 디렉터리이며, QStandardPaths::GenericCacheLocation 를 매개 변수로 사용하여 호출됩니다. 공유 캐시 개념이 없는 시스템에서는 애플리케이션 전용 QStandardPaths::CacheLocation 이 대신 사용됩니다.

osm.mapping.cache.disk.cost_strategy디스크에 맵 타일을 캐시하는 데 사용할 비용 전략입니다. 유효한 값은 바이트 크기와 단일입니다. bytesize를 사용하면 관련 크기 매개 변수(osm.mapping.cache.disk.size)가 바이트로 해석됩니다. 유니티를 사용하면 타일 수로 해석됩니다. 이 매개 변수의 기본값은 바이트 크기입니다.
osm.mapping.cache.disk.size맵 타일의 디스크 캐시 크기입니다. 캐시의 기본 크기는 bytesize가 이 캐시의 비용 전략인 경우 50MiB이고, 단일이 비용 전략인 경우 1000타일입니다.
osm.mapping.cache.memory.cost_strategy메모리에 맵 타일을 캐시하는 데 사용할 비용 전략입니다. 유효한 값은 바이트사이즈와 유니티입니다. bytesize를 사용하면 관련 크기 매개 변수(osm.mapping.cache.memory.size)가 바이트로 해석됩니다. 유니티를 사용하면 타일 수로 해석됩니다. 이 매개 변수의 기본값은 바이트 크기입니다.
osm.mapping.cache.memory.size맵 타일의 메모리 캐시 크기입니다. 캐시의 기본 크기는 bytesize가 이 캐시의 비용 전략인 경우 3MB이고, 단일이 비용 전략인 경우 100타일입니다.
osm.mapping.cache.texture.cost_strategy압축 해제된 맵 타일을 메모리에 캐시하는 데 사용할 비용 전략입니다. 유효한 값은 바이트사이즈와 유니타리입니다. bytesize를 사용하면 관련 크기 매개변수(osm.mapping.cache.texture.size)가 바이트로 해석됩니다. 유니티를 사용하면 타일 수로 해석됩니다. 이 매개 변수의 기본값은 바이트 크기입니다.
osm.mapping.cache.texture.size맵 타일의 텍스처 캐시 크기입니다. 이 캐시의 비용 전략이 바이트 크기인 경우 캐시의 기본 크기는 6MB이며, 단일이 비용 전략인 경우 30개의 타일입니다. 텍스처 캐시에는 맵 뷰포트의 크기에 따라 달라지는 최소 크기가 있습니다(현재 디스플레이에 표시되는 타일을 표시하기에 충분한 데이터를 포함해야 함). 이 값은 최소값에 추가로 사용할 캐시 양입니다.
osm.mapping.custom.datacopyright사용자 지정 데이터 저작권 문자열은 urlprefix 매개 변수를 통해 Map::activeMapTypeMapType.CustomMap 으로 설정할 때 사용됩니다. 이 저작권은 위에서 사용자 지정 맵을 사용할 때만 사용됩니다. 비어 있으면 사용자 지정 맵에 대한 데이터 저작권이 표시되지 않습니다.
osm.mapping.custom.host사용자 지정 타일 서버의 URL 문자열입니다. 이 매개변수는 올바른 OSM API를 제공하는 유효한 서버 URL로 설정해야 합니다. URL에 "%z/%x/%y.png" 접미사가 추가됩니다. 6.5부터는 URL이 ".png"로 끝나는 경우 접미사가 추가되지 않습니다. 서버에 아피키가 필요한 경우 URL 문자열에 아피키를 추가해야 합니다. 이 서버를 사용하려면 MapMap::activeMapType 매개 변수를 지원되는 맵 유형(유형이 MapType.CustomMap 인 맵 유형)으로 설정해야 합니다. 이 맵 유형은 이 플러그인 매개변수가 설정된 경우에만 사용할 수 있으며, 이 경우 항상 Map::supportedMapTypes[supportedMapTypes.length - 1]입니다.

참고: mapping.custom.host 매개변수를 새 서버로 설정하면 이전 커스텀맵 스타일에 대한 맵 타일 캐시가 쓸모 없게 됩니다.

osm.mapping.custom.mapcopyright사용자 지정 맵 저작권 문자열은 urlprefix 매개 변수를 통해 Map::activeMapTypeMapType.CustomMap 로 설정할 때 사용됩니다. 이 저작권은 위에서 커스텀맵을 사용할 때만 사용됩니다. 비어 있으면 사용자 지정 맵에 대한 맵 저작권이 표시되지 않습니다.
osm.mapping.highdpi_tiles고해상도 타일을 요청할지 여부입니다. 유효한 값은 참과 거짓입니다. 기본값은 false입니다. 모든 맵 유형이 높은 dpi로 제공되는 것은 아닙니다. 현재 고해상도로 사용할 수 있는 지도 유형이 없는 경우 이 매개변수를 true로 설정해도 아무런 효과가 없을 수 있습니다. 고해상도 타일의 공급자 정보 파일 이름은 street-hires, satellite-hires, cycle-hires, transit-hires, night-transit-hires, terrain-hireshiking-hires 입니다. 이 파일은 낮은 dpi 타일에 사용된 것과 동일한 위치에서 가져옵니다.
osm.mapping.offline.directory오프라인 저장소로 사용되는 맵 타일이 포함된 디렉터리의 절대 경로입니다. 지정하면 네트워크 디스크 캐시와 함께 작동하지만 타일이 자동으로 삽입, 제거 또는 업데이트되지는 않습니다. 타일의 형식은 네트워크 디스크 캐시에서 사용하는 것과 동일합니다. 기본값은 없으며 이 속성을 설정하지 않으면 디렉터리가 인덱싱되지 않고 네트워크 디스크 캐시만 사용하여 네트워크 사용량을 줄이거나 현재 캐시된 타일의 오프라인 스토리지로 작동합니다.
osm.mapping.prefetching_style이 매개변수를 사용하면 엔진에서 타일 프리페칭을 수행하는 방법에 대한 힌트를 제공할 수 있습니다. 기본값인 TwoNeighbourLayers 은 엔진이 현재 타일 레이어 위와 아래 레이어의 타일을 프리페치하여 현재 줌 레벨에서 확대 또는 축소할 때 준비된 타일을 제공하도록 합니다. OneNeighbourLayer 은 현재 줌 레벨에 가장 가까운 레이어 하나만 프리페치합니다. 마지막으로 NoPrefetching 은 프리페칭을 비활성화하여 표시되는 타일만 가져올 수 있습니다. 활성 맵 유형에 따라 이 힌트가 무시될 수 있습니다.
osm.mapping.providersrepository.address오픈스트리트맵 플러그인은 원격 저장소에서 제공자의 정보를 검색합니다. 이는 기본적으로 사용할 수 없게 될 수 있는 하드코딩된 서버를 사용하지 않도록 하기 위한 것입니다. 기본적으로 이 정보는 maps-redirect.qt.io에서 가져옵니다. 이 매개 변수를 설정하면 공급자 리포지토리 주소가 사용자가 지정한 주소로 변경되며, 여기에는 street, satellite, cycle, transit, night-transit, terrainhiking 파일이 포함되어야 하며, 각 파일에는 유효한 공급자 정보가 포함되어야 합니다.
osm.mapping.providersrepository.disabled기본적으로 오픈스트리트맵 플러그인은 하드코딩된 서비스를 사용할 수 없어 서비스가 손실되는 것을 방지하기 위해 원격 저장소에서 제공자 정보를 검색합니다. 그러나 플러그인에는 공급자 저장소에 연결할 수 없게 될 경우를 대비하여 하드코딩된 공급자 데이터를 대체할 수 있는 폴백이 포함되어 있습니다. 이 매개 변수를 true로 설정하면 플러그인이 하드코딩된 URL만 사용하므로 플러그인이 원격 리포지토리에서 공급자 데이터를 가져오지 못합니다.
osm.places.debug_query이 매개 변수를 true로 설정하면 각 결과에 "requestUrl"이라는 이름의 확장 속성이 있고 쿼리에 사용된 URL이 포함됩니다. 기본값은 false입니다.
osm.places.host장소 서버에 네트워크 요청을 할 때 설정하는 URL 문자열입니다. 이 매개변수는 올바른 OSM API를 사용하여 유효한 서버 URL로 설정해야 합니다. 지정하지 않으면 기본 URL이 사용됩니다.

참고: API 설명서는 프로젝트 OSM Nominatim에서 확인할 수 있습니다.

osm.places.page_size페이지에 표시되는 결과의 양입니다. 이 값은 서버 측에서 클램핑될 수 있습니다. 표준 노미나팀 인스턴스의 일반적인 최대값은 50입니다.
osm.라우팅.apiversion(사용자 지정) OSRM 서버의 API 버전을 정의하는 문자열입니다. 유효한 값은 v4v5입니다. 기본값은 v5입니다. 이 매개 변수는 osm.routing.host 가 설정되어 있고 OSRM v4 서버인 경우에만 설정해야 합니다.
osm.라우팅.호스트라우팅 서버에 네트워크 요청을 할 때 설정하는 URL 문자열입니다. 이 매개변수는 올바른 OSRM API를 사용하는 유효한 서버 URL로 설정해야 합니다. 지정하지 않으면 기본 URL이 사용됩니다.

참고: API 문서 및 소스는 Project OSRM에서 확인할 수 있습니다.

osm.useragent네트워크 요청을 할 때 설정되는 사용자 에이전트 문자열입니다. 이 매개 변수는 애플리케이션을 고유하게 식별하는 값으로 설정해야 합니다. 공급자는 이 매개 변수를 설정하지 않는 애플리케이션을 차단하여 스톡 플러그인 사용자 에이전트(예: 지오코딩용 Nominatim )에 맡길 수 있습니다.

매개변수 사용 예

다음 예는 사용자 에이전트에 제공된 파라미터와 필요한 경우 타일 제공자에 대한 해당 저작권 정보와 사용자 지정 서버 URL을 사용하여 OSM 플러그인 인스턴스를 만드는 방법을 보여줍니다. 또한 공개 OSRM이 아닌 다른 라우팅 서버를 선택할 수도 있습니다.

QML

Plugin {
    name: "osm"
    PluginParameter { name: "osm.useragent"; value: "My great Qt OSM application" }
    PluginParameter { name: "osm.mapping.host"; value: "http://osm.tile.server.address/" }
    PluginParameter { name: "osm.mapping.copyright"; value: "All mine" }
    PluginParameter { name: "osm.routing.host"; value: "http://osrm.server.address/viaroute" }
    PluginParameter { name: "osm.geocoding.host"; value: "http://geocoding.server.address" }
}

기타 플러그인 관련 정보

타일 캐시

타일은 QStandardPaths::writableLocation (QStandardPaths::GenericCacheLocation)의 QtLocation/osm 디렉터리에 캐시됩니다. 공유 캐시 개념이 없는 시스템에서는 애플리케이션 전용 QStandardPaths::CacheLocation 이 대신 사용됩니다.

© 2025 The Qt Company Ltd. Documentation contributions included herein are the copyrights of their respective owners. The documentation provided herein is licensed under the terms of the GNU Free Documentation License version 1.3 as published by the Free Software Foundation. Qt and respective logos are trademarks of The Qt Company Ltd. in Finland and/or other countries worldwide. All other trademarks are property of their respective owners.