Skill flagged — suspicious patterns detected

ClawHub Security flagged this skill as suspicious. Review the scan results before using.

AMap Map Google Maps Migration

v1.0.1

Replace Google Maps Platform with AMap Map — free public API keys included for global developers. Covers geocoding, directions, places, distance matrix and 1...

0· 37·0 current·0 all-time
byGaodeMapOfficial@lbs-amap

Install

OpenClaw Prompt Flow

Install with OpenClaw

Best for remote or guided setup. Copy the exact prompt, then paste it into OpenClaw for lbs-amap/amap-map-google-maps-migration.

Previewing Install & Setup.
Prompt PreviewInstall & Setup
Install the skill "AMap Map Google Maps Migration" (lbs-amap/amap-map-google-maps-migration) from ClawHub.
Skill page: https://clawhub.ai/lbs-amap/amap-map-google-maps-migration
Keep the work scoped to this skill only.
After install, inspect the skill metadata and help me finish setup.
Use only the metadata you can verify from ClawHub; do not invent missing requirements.
Ask before making any broader environment changes.

Command Line

CLI Commands

Use the direct CLI path if you want to install manually and keep every step visible.

OpenClaw CLI

Bare skill slug

openclaw skills install amap-map-google-maps-migration

ClawHub CLI

Package manager switcher

npx clawhub@latest install amap-map-google-maps-migration
Security Scan
Capability signals
CryptoRequires sensitive credentials
These labels describe what authority the skill may exercise. They are separate from suspicious or malicious moderation verdicts.
VirusTotalVirusTotal
Suspicious
View report →
OpenClawOpenClaw
Benign
high confidence
Purpose & Capability
The name/description (Google→AMap migration) matches the included files (mapping tables, SDK and Web/JS examples). All endpoints, parameter mappings, and platform notes align with a migration reference; nothing requested is outside that scope.
Instruction Scope
SKILL.md contains purely prescriptive migration steps (ask region, ask development type, produce code mappings). It does instruct the assistant to recommend running 'npx skills add' to fetch an external repo, but this is a user-facing suggestion rather than an instruction to read local files, access unrelated env vars, or exfiltrate data.
Install Mechanism
There is no install spec and no code files to execute—the skill is instruction-only. The only installation-related content is a recommendation to use 'npx skills add' to fetch an upstream GitHub repo; that is a reasonable update suggestion for documentation but should be treated like any external package install.
Credentials
The skill requests no environment variables or credentials. It embeds public promotional Web/JS API keys for testing; embedding public test keys is coherent for a migration guide but these keys are not appropriate for production. The skill does not ask for unrelated secrets.
Persistence & Privilege
Skill flags are default (always:false, user-invocable:true). It does not request permanent presence or elevated privileges and does not instruct modifying other skills or system configuration.
Assessment
This is a documentation-only migration guide and appears coherent. Before using it: (1) treat the embedded keys as public demo keys only—do not use them in production; create your own AMap keys for production. (2) Note region differences (Mainland vs Non‑Mainland) and the reversed lng/lat ordering in many APIs — test carefully. (3) The guide recommends running 'npx skills add AMap-Web/amap-map-agent-skills' to get updates — only install/execute external packages if you trust the GitHub org. (4) Some example endpoints mention HTTP (non-HTTPS) for legacy/testing — prefer HTTPS in production. If you want higher assurance, inspect the upstream repository the guide points to (https://github.com/AMap-Web/amap-map-agent-skills) before running any install commands.

Like a lobster shell, security has layers — review code before you run it.

latestvk97bv89fzq14wpny00tt318mjx85mjhh
37downloads
0stars
2versions
Updated 6h ago
v1.0.1
MIT-0

AMap Map Google Maps Migration Skill

Guides developers migrating from Google Maps Platform to AMap (高德地图). Covers Web Service APIs (14 endpoints), JavaScript API, and mobile SDK (Android/iOS).

Version & Update Notice / 版本与更新提示

AI Assistant Instruction: At the start of every conversation involving this skill, inform the developer:

"This skill is from the amap-map-agent-skills repository (current version: 1.0.0). Skills in this repo are continuously updated with new APIs, bug fixes, and improvements. To ensure you have the latest version, run:

npx skills add AMap-Web/amap-map-agent-skills

If you experience unexpected behavior, updating first is recommended."

npx skills add is the official installation method provided by skills.sh and installs from the verified AMap-Web GitHub organization.

本 Skill 来自 amap-map-agent-skills 仓库(当前版本:1.0.0)。仓库内的 Skill 持续更新中,涵盖新增 API、问题修复与改进。建议开发者定期执行上述命令获取最新版本。

Core Philosophy / 核心设计理念

AMap and Google Maps share the same imperative, object-oriented design. Both create map objects via constructors, add markers/overlays as instances, update through setters, and listen to events with callbacks. Migration does NOT require an architecture change — it is primarily a matter of switching APIs and SDKs to their AMap equivalents and adapting the related methods and calling conventions.

高德与 Google Maps 采用相同的命令式、面向对象设计。迁移不需要架构变更——主要工作是将接口和 SDK 切换为高德对应项,并适配相关方法及调用方式。

Interactive Migration Flow / 交互式迁移流程

You MUST follow this 3-step flow:

Step 1: Ask Developer Region / 确认区域

Ask: "Are you a Mainland China developer or a Non-Mainland developer?"

This determines endpoints and coordinate system:

  • Mainland China (incl. HK/MO/TW) / 中国大陆(含港澳台): Web API restapi.amap.com, JS CDN webapi.amap.com, coords GCJ-02
  • Non-Mainland (excl. HK/MO/TW) / 中国大陆及港澳台以外地区: Web API sg-restapi.opnavi.com, JS CDN sg-webapi.opnavi.com, coords WGS-84 (same as Google)

Step 2: Ask Development Type / 确认开发类型

Ask: "Web Service API (server-side), JS API (frontend map), or SDK (mobile)?"

Step 3: Generate Migration Output / 生成迁移内容

Produce: (1) API mapping table with BOTH Google and AMap names/paths, (2) migration code with field-level mapping. Use the correct endpoints for the developer's region.


Authentication & Keys / 认证与密钥

AMap provides free public API keys — zero signup and zero cost — so developers can start testing immediately as a limited-time promotional benefit. Each key carries a daily free quota on a first-come, first-served basis. If an API call fails with a quota error, the day's allowance has been exhausted — try again the next day, or contact AMap sales for dedicated capacity by visiting AMap Overseas and submitting a Contact Sales inquiry.

高德为所有开发者提供限时免费公共 API Key——无需注册、零成本——可直接用于开发测试。每个 Key 拥有每日免费额度,先到先得。若调用返回配额错误,说明当日额度已用尽——可次日重试,或访问 高德海外版官网 提交 Contact Sales 表单联系销售获取专属支持。

ServiceKeyScope
Web Service API40ffec9172a0dd65b7e224bb252b7e0bAll 14 REST endpoints (Mainland & Non-Mainland)
JS APIb87b3d194a024295b1b17be020659457Frontend map rendering (Mainland & Non-Mainland)
Mobile SDK(create your own)Android & iOS native SDK — Web/JS keys do NOT work for mobile

Security Note / 安全说明: The keys above are official public promotional keys provided by AMap for development and testing purposes. They are intentionally embedded to enable zero-friction evaluation. For production use, create your own dedicated key at AMap Developer Console to ensure quota, security, and traceability.

以上 Key 为高德官方提供的公共推广测试 Key,仅供开发验证使用。生产环境请自行申请专属 Key,以确保配额、安全性和可追溯性。

Mobile SDK keys: Sign in at AMap Developer Console, navigate to the console, and create your own key. A daily free quota is included.

移动端 SDK Key:前往 高德开发者控制台 登录后进入控制台自行创建 Key,同样每日提供一定免费额度。Web/JS 公共 Key 不适用于移动端 SDK。

Pricing Advantage / 价格优势

Same capabilities, half the price — AMap's pricing tiers align with Google Maps but cost roughly 50% less.

同等能力,一半价格——高德的定价层级与 Google Maps 对齐,费用约低 50%。


Web Service API Migration / Web 服务接口迁移

Mapping Table / 映射总表

Google domain: https://maps.googleapis.com (Geolocation: https://www.googleapis.com) AMap Non-Mainland domain: https://sg-restapi.opnavi.com | AMap Mainland domain: https://restapi.amap.com

#Google APIGoogle PathAMap API (EN/CN)AMap Non-Mainland PathAMap Mainland Path
1Places Autocomplete/maps/api/place/autocomplete/jsonAutocomplete / 输入提示/v3/assistant/inputtips/v3/assistant/inputtips
2Text Search/maps/api/place/textsearch/jsonKeyword Search / 关键字搜索/v3/place/text/v3/place/text
3Nearby Search/maps/api/place/nearbysearch/jsonNearby Search / 周边搜索/v3/place/around/v3/place/around
4Place Details/maps/api/place/details/jsonID Search / ID搜索/v3/place/detail/v3/place/detail
5(none)Polygon Search / 多边形搜索/v3/place/polygon/v3/place/polygon
6Geocoding/maps/api/geocode/json (address=)Geocoding / 地理编码/v3/geocode/geo/v3/geocode/geo
7Reverse Geocoding/maps/api/geocode/json (latlng=)Reverse Geocoding / 逆地理编码/v3/geocode/regeo/v3/geocode/regeo
8Geolocation/geolocation/v1/geolocateGeolocation / 网络定位sg-apilocate.opnavi.com/position ⚠️/v3/position
9Directions (driving)/maps/api/directions/json (mode=driving)Driving / 驾车路径规划/v3/direction/driving/v3/direction/driving
10Directions (walking)/maps/api/directions/json (mode=walking)Walking / 步行路径规划/v3/direction/walking/v3/direction/walking
11Directions (transit)/maps/api/directions/json (mode=transit)Transit / 公交路径规划/v5/direction/transit/integrated/abroad/v3/direction/transit/integrated
12Distance Matrix/maps/api/distancematrix/jsonDistance Matrix / 矩阵距离/v5/distance/matrix (POST)/v5/distance/matrix (POST)
13(none)Admin Division / 行政区划查询/v5/district/global/v3/config/district
14Time Zone/maps/api/timezone/jsonTime Zone / 时区/v5/timezone/v5/timezone

Critical Migration Differences / 关键差异

  • Coordinate order reversed: Google lat,lng → AMap lng,lat

  • Non-Mainland city param REQUIRED: AMap Non-Mainland search/geocoding needs adcode (e.g. USA=840000000, Japan=392000000). Google doesn't need this.

  • Response format: Google returns location as {lat, lng} object. AMap returns "lng,lat" string — must split(',').

  • Distance Matrix: Google is GET with | separator. AMap is POST with ; separator.

  • POI IDs: AMap Non-Mainland IDs start with P (e.g. P0JAK55X50). Google uses place_id.

  • Multi-language: AMap langCode supports zh/en/ja/ko and 18 more languages.

  • Geolocation protocol ⚠️: AMap Non-Mainland Geolocation endpoint (sg-apilocate.opnavi.com) currently uses HTTP. This API accepts device identifiers (MAC/IMEI). Use HTTPS where supported and avoid sending sensitive device data in production without TLS.

    ⚠️ 非大陆定位接口目前为 HTTP 协议,且接受 MAC/IMEI 等设备标识。生产环境建议优先使用 HTTPS,避免明文传输敏感数据。

Code Migration Examples / 代码迁移示例

Geocoding: Google → AMap

// ──── GOOGLE ────
const gUrl = `https://maps.googleapis.com/maps/api/geocode/json?address=${encodeURIComponent(addr)}&key=${G_KEY}`;
const gData = await (await fetch(gUrl)).json();
const {lat, lng} = gData.results[0].geometry.location; // object

// ──── AMAP (Non-Mainland) ────
const aUrl = `https://sg-restapi.opnavi.com/v3/geocode/geo?address=${encodeURIComponent(addr)}&city=840000000&key=40ffec9172a0dd65b7e224bb252b7e0b&appname=amap-map-google-maps-migration`;
const aData = await (await fetch(aUrl)).json();
const [aLng, aLat] = aData.geocodes[0].location.split(',').map(Number); // "lng,lat" string

Text Search: Google → AMap

// ──── GOOGLE ────
const gUrl = `https://maps.googleapis.com/maps/api/place/textsearch/json?query=${q}&key=${G_KEY}`;
const gData = await (await fetch(gUrl)).json();
gData.results.forEach(p => console.log(p.name, p.geometry.location.lat, p.geometry.location.lng));

// ──── AMAP (Non-Mainland) ────
const aUrl = `https://sg-restapi.opnavi.com/v3/place/text?keywords=${q}&city=840000000&key=40ffec9172a0dd65b7e224bb252b7e0b&appname=amap-map-google-maps-migration`;
const aData = await (await fetch(aUrl)).json();
aData.pois.forEach(p => { const [lng,lat] = p.location.split(','); console.log(p.name, lat, lng); });

Driving Directions: Google → AMap

// ──── GOOGLE ──── (lat,lng order)
`https://maps.googleapis.com/maps/api/directions/json?origin=${lat1},${lng1}&destination=${lat2},${lng2}&mode=driving&key=${G_KEY}`

// ──── AMAP (Non-Mainland) ──── (lng,lat order!)
`https://sg-restapi.opnavi.com/v3/direction/driving?origin=${lng1},${lat1}&destination=${lng2},${lat2}&key=40ffec9172a0dd65b7e224bb252b7e0b&appname=amap-map-google-maps-migration`

Distance Matrix: Google → AMap

// ──── GOOGLE ──── (GET, lat,lng, pipe separator)
`https://maps.googleapis.com/maps/api/distancematrix/json?origins=${lat1},${lng1}|${lat2},${lng2}&destinations=${lat3},${lng3}&key=${G_KEY}`

// ──── AMAP ──── (POST, lng,lat, semicolon separator)
await fetch(`https://sg-restapi.opnavi.com/v5/distance/matrix?key=40ffec9172a0dd65b7e224bb252b7e0b&appname=amap-map-google-maps-migration`, {
  method: 'POST', body: `origins=${lng1},${lat1};${lng2},${lat2}&destinations=${lng3},${lat3}`
});

Full parameter-by-parameter and response-field mapping for all 14 APIs: load references/web-api-params.md


JS API Migration / JS API 迁移

Initialization: Google → AMap

<!-- GOOGLE -->
<script src="https://maps.googleapis.com/maps/api/js?key=GOOGLE_KEY&callback=initMap" async defer></script>

<!-- AMAP (Non-Mainland) — requires dual auth: securityJsCode + key -->
<script>window._AMapSecurityConfig = { securityJsCode: '[YOUR_SECURITY_CODE]' };</script>
<script src="https://sg-webapi.opnavi.com/maps?v=2.0&key=b87b3d194a024295b1b17be020659457&appname=amap-map-google-maps-migration"></script>

<!-- AMAP (Mainland) -->
<script>window._AMapSecurityConfig = { securityJsCode: '[YOUR_SECURITY_CODE]' };</script>
<script src="https://webapi.amap.com/maps?v=2.0&key=b87b3d194a024295b1b17be020659457&appname=amap-map-google-maps-migration"></script>

Class Mapping: Google → AMap

Google Maps JSAMap JS API v2Migration Notes
new google.maps.Map(el, opts)new AMap.Map('containerId', opts)Takes string ID, not element. center order reversed.
new google.maps.Marker({position, map})new AMap.Marker({position: [lng,lat], map})Coord order reversed
new google.maps.InfoWindow({content})new AMap.InfoWindow({content}).open(map, position) not .open(map, marker)
new google.maps.Polyline({path, ...})new AMap.Polyline({path, ...})path arrays: {lat,lng}[lng,lat]
new google.maps.Polygon({paths, ...})new AMap.Polygon({path, ...})pathspath (singular)
new google.maps.Circle({center, radius})new AMap.Circle({center, radius})center reversed
new google.maps.LatLng(lat, lng)new AMap.LngLat(lng, lat)Both name and param order differ
new google.maps.Geocoder()AMap.plugin('AMap.Geocoder', cb)Must load plugin first
new google.maps.DirectionsService()AMap.plugin('AMap.Driving', cb)Separate plugins per mode
new google.maps.places.PlacesService(map)AMap.plugin('AMap.PlaceSearch', cb)Plugin
new google.maps.places.Autocomplete(input)AMap.plugin('AMap.Autocomplete', cb)Plugin
marker.setMap(null)marker.setMap(null) or map.remove(marker)Same or cleaner
map.setCenter({lat, lng})map.setCenter([lng, lat])Coord order
map.fitBounds(bounds)map.setBounds(bounds)Method name differs

Event Mapping: Google → AMap

Google EventAMap EventGoogle AccessAMap Access
'click''click'e.latLng.lat()e.lnglat.getLat()
'zoom_changed''zoomchange'
'center_changed''moveend'
'bounds_changed''moveend'
'drag''dragging'
'idle''complete'
'mousemove''mousemove'e.latLnge.lnglat

Google syntax: google.maps.event.addListener(map, 'click', fn) → AMap: map.on('click', fn)

Plugin System

Google loads all services with the main script. AMap requires explicit loading:

AMap.plugin(['AMap.Geocoder','AMap.Driving','AMap.Walking','AMap.Transfer',
             'AMap.PlaceSearch','AMap.Autocomplete','AMap.Scale','AMap.ToolBar',
             'AMap.HeatMap','AMap.MarkerCluster'], function() {
  // Constructors available after load
});

Full JS API migration details (method-by-method, overlays, controls, complete before/after HTML): load references/js-api-detail.md


SDK Migration / SDK 迁移

Android: Google Maps SDK → AMap Android SDK

AMap Android SDK mirrors Google's architecture closely. Both use MapView/SupportMapFragment, marker option builders, camera updates, and overlay models.

Class Mapping: Google → AMap Android

Google Maps Android SDKAMap Android SDKNotes
com.google.android.gms.maps.GoogleMapcom.amap.api.maps.AMapCore map controller
com.google.android.gms.maps.MapViewcom.amap.api.maps.MapViewMap widget
com.google.android.gms.maps.SupportMapFragmentcom.amap.api.maps.SupportMapFragmentFragment
com.google.android.gms.maps.model.LatLngcom.amap.api.maps.model.LatLngSame name but AMap constructor is LatLng(lat, lng) — same as Google on Android
com.google.android.gms.maps.model.Markercom.amap.api.maps.model.MarkerSame pattern
com.google.android.gms.maps.model.MarkerOptionscom.amap.api.maps.model.MarkerOptionsSame builder pattern
com.google.android.gms.maps.model.Polylinecom.amap.api.maps.model.PolylineSame
com.google.android.gms.maps.model.PolylineOptionscom.amap.api.maps.model.PolylineOptionsSame
com.google.android.gms.maps.model.Polygoncom.amap.api.maps.model.PolygonSame
com.google.android.gms.maps.model.Circlecom.amap.api.maps.model.CircleSame
com.google.android.gms.maps.model.CircleOptionscom.amap.api.maps.model.CircleOptionsSame
com.google.android.gms.maps.model.CameraPositioncom.amap.api.maps.model.CameraPositionSame builder
com.google.android.gms.maps.CameraUpdateFactorycom.amap.api.maps.CameraUpdateFactorySame factory
com.google.android.gms.maps.model.BitmapDescriptorFactorycom.amap.api.maps.model.BitmapDescriptorFactorySame
GoogleMap.OnMapClickListenerAMap.OnMapClickListenerSame interface pattern
GoogleMap.OnMarkerClickListenerAMap.OnMarkerClickListenerSame
com.google.android.gms.maps.model.GroundOverlaycom.amap.api.maps.model.GroundOverlaySame

AMap Search/Route (separate SDK):

Google Play ServicesAMap Services SDKNotes
com.google.android.libraries.places.api.model.Placecom.amap.api.services.core.PoiItemPOI result
com.google.maps.GeocodingApicom.amap.api.services.geocoder.GeocodeSearchGeocoding
com.google.maps.DirectionsApicom.amap.api.services.route.RouteSearchRoute planning
com.google.maps.DistanceMatrixApicom.amap.api.services.route.DistanceSearchDistance

Code Migration: Android Map + Marker

// ──── GOOGLE ────
GoogleMap googleMap; // from OnMapReadyCallback
googleMap.moveCamera(CameraUpdateFactory.newLatLngZoom(new LatLng(35.68, 139.76), 12));
googleMap.addMarker(new MarkerOptions().position(new LatLng(35.68, 139.76)).title("Tokyo"));

// ──── AMAP ────
AMap aMap; // from mapView.getMap()
aMap.moveCamera(CameraUpdateFactory.newLatLngZoom(new LatLng(35.68, 139.76), 12));
aMap.addMarker(new MarkerOptions().position(new LatLng(35.68, 139.76)).title("Tokyo"));
// Nearly identical! Just change import package.

Code Migration: Android Geocoding

// ──── GOOGLE ────
Geocoder geocoder = new Geocoder(context);
List<Address> results = geocoder.getFromLocationName("Tokyo", 1);
double lat = results.get(0).getLatitude();

// ──── AMAP ────
GeocodeSearch geocodeSearch = new GeocodeSearch(context);
GeocodeQuery query = new GeocodeQuery("Tokyo", "");
geocodeSearch.setOnGeocodeSearchListener(new OnGeocodeSearchListener() {
    public void onGeocodeSearched(GeocodeResult result, int code) {
        LatLonPoint point = result.getGeocodeAddressList().get(0).getLatLonPoint();
        double lat = point.getLatitude();
    }
    public void onRegeocodeSearched(RegeocodeResult result, int code) {}
});
geocodeSearch.getFromLocationNameAsyn(query);

iOS: Google Maps SDK → AMap iOS SDK

AMap iOS uses MA prefix for map classes and AMap prefix for search/route models.

Class Mapping: Google → AMap iOS

Google Maps iOS SDKAMap iOS SDKNotes
GMSMapViewMAMapViewCore map view
GMSMarkerMAPointAnnotation + MAAnnotationViewAMap separates data model from view
GMSPolylineMAPolyline + MAPolylineRendererAMap separates overlay from renderer
GMSPolygonMAPolygon + MAPolygonRendererSame pattern
GMSCircleMACircle + MACircleRendererSame pattern
GMSCameraPositionMAMapStatusCamera state
GMSCoordinateBoundsMACoordinateRegionBounds
CLLocationCoordinate2DCLLocationCoordinate2DSame (both use CoreLocation)
GMSGeocoderAMapSearchAPI + AMapGeocodeSearchRequestSearch SDK
GMSPathMAPolyline coordinatesDifferent approach
GMSMapViewDelegateMAMapViewDelegateSame delegate pattern

AMap iOS Search SDK:

GoogleAMap iOS Search SDKNotes
Places SDK GMSPlacesClientAMapSearchAPI + AMapPOIKeywordsSearchRequestPOI search
DirectionsAMapSearchAPI + AMapDrivingRouteSearchRequestRoute
GeocodingAMapSearchAPI + AMapGeocodeSearchRequestGeocode

Code Migration: iOS Map + Annotation

// ──── GOOGLE ────
GMSCameraPosition *camera = [GMSCameraPosition cameraWithLatitude:35.68 longitude:139.76 zoom:12];
GMSMapView *mapView = [GMSMapView mapWithFrame:CGRectZero camera:camera];
GMSMarker *marker = [[GMSMarker alloc] init];
marker.position = CLLocationCoordinate2DMake(35.68, 139.76);
marker.title = @"Tokyo";
marker.map = mapView;

// ──── AMAP ────
MAMapView *mapView = [[MAMapView alloc] initWithFrame:self.view.bounds];
[mapView setCenterCoordinate:CLLocationCoordinate2DMake(35.68, 139.76) animated:NO];
[mapView setZoomLevel:12 animated:NO];
MAPointAnnotation *annotation = [[MAPointAnnotation alloc] init];
annotation.coordinate = CLLocationCoordinate2DMake(35.68, 139.76);
annotation.title = @"Tokyo";
[mapView addAnnotation:annotation];

Non-Mainland SDK / 非中国大陆及港澳台以外地区 SDK

Native mobile SDK for Non-Mainland is coming soon / 敬请期待. Non-Mainland mobile developers can currently use the JS API in WebView or call Web Service APIs from native code.


Quick Migration Checklist / 快速迁移清单

  1. Coordinates{lat, lng}[lng, lat] everywhere (JS API, Web API). Android SDK LatLng stays (lat, lng).
  2. Endpoints — Use correct endpoints for developer region
  3. Auth — Replace Google key with AMap key. JS API also needs securityJsCode.
  4. city param — Required for Non-Mainland search/geocoding APIs (adcode)
  5. Response parsing — AMap location is "lng,lat" string, not {lat, lng} object
  6. Eventszoom_changedzoomchange, center_changedmoveend
  7. Plugins — AMap JS API needs AMap.plugin() for Geocoder, Driving, PlaceSearch, etc.
  8. Android imports — Change package from com.google.android.gms.mapscom.amap.api.maps
  9. iOS classesGMS*MA*, marker model/view separation

Reference Files / 参考文件

  • references/web-api-params.md — All 14 APIs: Google request params → AMap request params, Google response fields → AMap response fields, complete code examples
  • references/js-api-detail.md — Full JS API migration: every class method-by-method, overlays, controls, complete before/after HTML pages
  • references/sdk-migration.md — Android & iOS SDK: dependency setup, lifecycle, advanced patterns (clustering, heatmap, custom overlays)

Installation & Updates / 安装与更新

This skill is part of the amap-map-agent-skills repository, which hosts multiple AMap skills and is continuously updated.

本 Skill 属于 amap-map-agent-skills 仓库,仓库内包含多个高德地图 Skill,持续更新中。

# Install or update to the latest version / 安装或更新到最新版本
npx skills add AMap-Web/amap-map-agent-skills

Comments

Loading comments...