กล้องช่วยให้คุณเปลี่ยนมุมมองแผนที่ของผู้ใช้ได้ คุณใช้โหมดกล้องเพื่อควบคุมลักษณะการทำงานของมุมมองแผนที่ระหว่างการนำทางได้ หากต้องการตั้งค่าโหมดกล้อง ให้เรียกใช้เมธอดใดเมธอดหนึ่งต่อไปนี้ซึ่งเชื่อมโยงกับกล้อง
ติดตามตำแหน่งของฉัน (
GoogleMap.followMyLocation
) - โหมดกล้องเริ่มต้นสำหรับการนำทาง โหมดนี้จะตั้งค่ากล้องเป็นอุปกรณ์หรือยานพาหนะ ในระหว่างการนําทาง กล้องจะหันไปตามทิศทางการเดินทางโดยอัตโนมัติ เมื่อเปิดใช้การตั้งค่ารายละเอียดสูง (NavigationMapStyle.HIGH_DETAIL
) โครงร่างอาคาร 2 มิติจะแสดงเมื่อระดับการซูมเป็น 19 ขึ้นไปปักหมุดไว้ที่ตำแหน่ง (
GoogleMap.animateCamera
และGoogleMap.moveCamera
) — ตรึงกล้องไว้ที่ตำแหน่งหนึ่งๆ เมื่อใช้โหมดนี้ คุณสามารถตั้งค่าตำแหน่งกล้องพร้อมกับคุณสมบัติอื่นๆ ของกล้อง เช่น ทิศทาง การเอียง การซูม เป็นต้น เมื่อเลือกมุมมองนี้และเริ่มต้นใช้งาน Navigator แล้ว ปุ่มจัดกึ่งกลางใหม่จะปรากฏขึ้นแสดงภาพรวมเส้นทาง (
NavigationView.showRouteOverview
หรือSupportNavigationFragment.showRouteOverview
) — แสดงภาพรวมของเส้นทางที่เหลือ โดยเลื่อนและซูมได้ตามต้องการเพื่อให้เส้นทางพอดีกับมุมมองแผนที่ เมื่อเลือกมุมมองนี้ ปุ่มปรับมุมมองให้อยู่กึ่งกลางอีกครั้งจะปรากฏขึ้น
การคลิกปุ่มจัดกึ่งกลางใหม่จะตั้งค่ากล้องเป็นโหมด followMyLocation
โหมดติดตามตำแหน่งของฉัน
การตั้งค่ากล้องที่พบบ่อยที่สุดคือการตั้งค่ากล้องให้อุปกรณ์หรือยานพาหนะแสดงตำแหน่งปัจจุบันในการเดินทาง ในโหมดกล้องนี้ คุณสามารถดูเส้นทางโดยที่รถมุ่งหน้าขึ้นด้านบนของหน้าจอเสมอด้วยมุมมองแบบเอียง (CameraPerspective.TILTED
) หรือจะดูรถที่วิ่งไปทางทิศเหนือ (CameraPerspective.TOP_DOWN_NORTH_UP
) หรือตามทิศทาง (CameraPerspective.TOP_DOWN_HEADING_UP)
ที่ด้านบนของหน้าจอเสมอ) ก็ได้
ข้อมูลโค้ดต่อไปนี้ใช้มุมมอง TILTED
// Set the camera to follow the device (vehicle):
mNavFragment.getMapAsync(googleMap -> googleMap.followMyLocation(CameraPerspective.TILTED))
ปักหมุดไว้ที่โหมดตำแหน่ง
โหมด Pinned
ช่วยให้คุณควบคุมกล้องได้มากที่สุด ในโหมดนี้ คุณจะวางกล้องในตำแหน่งที่ต้องการ กําหนดทิศทางเพื่อปรับมุมมองของกล้อง เปลี่ยนการเอียงเพื่อตั้งค่ามุมมอง และตั้งค่าระดับการซูมของกล้อง
ข้อมูลโค้ดต่อไปนี้แสดงวิธีทั่วไปในการย้ายกล้อง
private static final LatLng SYDNEY = new LatLng(-33.88, 151.21);
private static final LatLng MOUNTAIN_VIEW = new LatLng(37.4, -122.1);
private GoogleMap map;
... // Obtain the map from a SupportNavigationFragment or NavigationView.
// Move the camera instantly to Sydney with a zoom of 15.
map.moveCamera(CameraUpdateFactory.newLatLngZoom(SYDNEY, 15));
// Zoom in, animating the camera.
map.animateCamera(CameraUpdateFactory.zoomIn());
// Zoom out to zoom level 10, animating with a duration of 2 seconds.
map.animateCamera(CameraUpdateFactory.zoomTo(10), 2000, null);
// Construct a CameraPosition focusing on Mountain View and animate the camera to that position.
CameraPosition cameraPosition = new CameraPosition.Builder()
.target(MOUNTAIN_VIEW) // Sets the center of the map to Mountain View
.zoom(17) // Sets the zoom
.bearing(90) // Sets the orientation of the camera to east
.tilt(30) // Sets the tilt of the camera to 30 degrees
.build(); // Creates a CameraPosition from the builder
map.animateCamera(CameraUpdateFactory.newCameraPosition(cameraPosition));
โหมดแสดงภาพรวมเส้นทาง
การตั้งค่ากล้อง showRouteOverview
จะแสดงเส้นทางทั้งหมด
สำหรับการเดินทางที่มีจุดหมายหลายแห่ง โหมดนี้จะแสดงส่วนของเส้นทางที่ไม่ได้เดินทาง
// Place the camera to see the remaining route:
mNavFragment.showRouteOverview();
การตั้งค่ารายละเอียดสูง
เมื่อเปิดใช้การตั้งค่ารายละเอียดสูง ขอบอาคาร 2 มิติจะแสดงขึ้นเมื่อตั้งค่าระดับการซูมของกล้องเป็น 19 ขึ้นไป คุณลบล้างระดับการซูมระหว่างการไปยังส่วนต่างๆ ได้โดยใช้ออบเจ็กต์ FollowMyLocationOptions
ซึ่งจะช่วยให้คุณซูมระดับที่เพียงพอเพื่อแสดงโครงร่างอาคาร 2 มิติได้เมื่อผู้ใช้เข้าใกล้จุดหมาย
ตัวอย่างนี้จะเปิดใช้การตั้งค่ารายละเอียดสูง
navigationView.setNavigationMapStyle(NavigationMapStyle.HIGH_DETAIL);
ตัวอย่างต่อไปนี้จะลบล้างระดับการซูมของกล้องระหว่างการนําทาง ระดับการซูมตั้งไว้ที่ 15 ซึ่งสูงพอที่จะแสดงโครงร่างอาคาร 2 มิติ
googleMap.followMyLocation(
FollowMyLocationOptions.builder(CameraPerspective.TILTED)
.setZoomLevel(15.0f)
.build());
ขั้นตอนถัดไป
ดูปรับแต่ง UI การนําทางเพื่อดูวิธีปรับแต่งวิธีที่ผู้ใช้โต้ตอบกับแผนที่ โดยเลือกคอมโพเนนต์ UI ในตัวที่จะปรากฏในแผนที่