Sử dụng bộ sưu tập để sắp xếp ngăn nắp các trang
Lưu và phân loại nội dung dựa trên lựa chọn ưu tiên của bạn.
Camera cho phép bạn thay đổi điểm nhìn của người dùng trên bản đồ. Bạn có thể sử dụng các chế độ camera để kiểm soát hành vi của chế độ xem bản đồ trong khi đi theo chỉ dẫn.
Để đặt chế độ camera, hãy gọi một trong các phương thức sau được liên kết với camera:
Theo dõi vị trí của tôi (GoogleMap.followMyLocation) – Chế độ camera mặc định để chỉ đường. Chế độ này đặt camera vào thiết bị hoặc xe.
Trong khi bạn đi theo chỉ dẫn, camera sẽ tự động hướng về hướng di chuyển.
Ghim vào vị trí (GoogleMap.animateCamera và GoogleMap.moveCamera) – Cố định camera ở một vị trí cụ thể. Khi sử dụng chế độ này, bạn có thể đặt vị trí camera cùng với các thuộc tính khác của camera như hướng, độ nghiêng, mức thu phóng, v.v. Khi chế độ xem này được chọn và Navigator đã được khởi tạo, nút Định tâm lại sẽ xuất hiện.
Cho tôi xem thông tin tổng quan về tuyến đường (NavigationView.showRouteOverview hoặc SupportNavigationFragment.showRouteOverview) – Hiển thị thông tin tổng quan về tuyến đường còn lại (tối đa 45 phút lái xe tiếp theo), xoay và thu phóng khi cần để vừa với tuyến đường trong chế độ xem bản đồ. Khi bạn chọn chế độ xem này, nút Căn lại về chính giữa sẽ xuất hiện.
Khi bạn nhấp vào nút Lấy lại tâm, camera sẽ chuyển sang chế độ followMyLocation.
Chế độ theo dõi vị trí của tôi
Chế độ cài đặt camera phổ biến nhất là đặt camera ở chế độ thiết bị hoặc xe, cho biết vị trí hiện tại của thiết bị hoặc xe trong hành trình. Ở chế độ camera này, bạn có thể xem tuyến đường với xe luôn hướng lên trên màn hình theo góc nhìn nghiêng (CameraPerspective.TILTED), hoặc bạn có thể thấy xe di chuyển theo hướng bắc (CameraPerspective.TOP_DOWN_NORTH_UP) hoặc theo hướng đi (CameraPerspective.TOP_DOWN_HEADING_UP) luôn ở đầu màn hình.
Đoạn mã sau đây sử dụng góc nhìn TILTED:
// Set the camera to follow the device (vehicle):mNavFragment.getMapAsync(googleMap->googleMap.followMyLocation(CameraPerspective.TILTED))
Được ghim vào chế độ vị trí
Chế độ Pinned cho phép bạn kiểm soát camera một cách tối đa. Ở chế độ này, bạn đặt camera ở một vị trí cụ thể, chỉ định hướng để định hướng góc nhìn của camera, thay đổi độ nghiêng để đặt góc nhìn và đặt mức thu phóng của camera.
Đoạn mã sau đây minh hoạ một số cách phổ biến để di chuyển camera.
privatestaticfinalLatLngSYDNEY=newLatLng(-33.88,151.21);privatestaticfinalLatLngMOUNTAIN_VIEW=newLatLng(37.4,-122.1);privateGoogleMapmap;...// 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.CameraPositioncameraPosition=newCameraPosition.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 buildermap.animateCamera(CameraUpdateFactory.newCameraPosition(cameraPosition));
Hiển thị chế độ tổng quan về tuyến đường
Chế độ cài đặt camera showRouteOverview sẽ hiển thị toàn bộ hành trình.
Đối với hành trình có nhiều điểm đến, chế độ này sẽ hiển thị phần chưa đi của tuyến đường.
// Place the camera to see the remaining route:mNavFragment.showRouteOverview();
Bước tiếp theo
Hãy xem phần Tuỳ chỉnh giao diện người dùng Điều hướng để tìm hiểu cách tuỳ chỉnh cách người dùng tương tác với bản đồ bằng cách xác định thành phần nào trong số các thành phần giao diện người dùng tích hợp sẵn sẽ xuất hiện trên bản đồ.
[[["Dễ hiểu","easyToUnderstand","thumb-up"],["Giúp tôi giải quyết được vấn đề","solvedMyProblem","thumb-up"],["Khác","otherUp","thumb-up"]],[["Thiếu thông tin tôi cần","missingTheInformationINeed","thumb-down"],["Quá phức tạp/quá nhiều bước","tooComplicatedTooManySteps","thumb-down"],["Đã lỗi thời","outOfDate","thumb-down"],["Vấn đề về bản dịch","translationIssue","thumb-down"],["Vấn đề về mẫu/mã","samplesCodeIssue","thumb-down"],["Khác","otherDown","thumb-down"]],["Cập nhật lần gần đây nhất: 2025-09-04 UTC."],[[["\u003cp\u003eThe Navigation SDK offers three camera modes: \u003ccode\u003efollowMyLocation\u003c/code\u003e, \u003ccode\u003ePinned to location\u003c/code\u003e, and \u003ccode\u003eshowRouteOverview\u003c/code\u003e to control the user's viewpoint of the map during navigation.\u003c/p\u003e\n"],["\u003cp\u003e\u003ccode\u003efollowMyLocation\u003c/code\u003e mode centers the map on the user's location and automatically adjusts during navigation, while \u003ccode\u003ePinned to location\u003c/code\u003e mode fixes the camera at a specific location with customizable properties.\u003c/p\u003e\n"],["\u003cp\u003e\u003ccode\u003eshowRouteOverview\u003c/code\u003e mode displays the entire route or remaining route, adjusting the view to fit the route on the screen.\u003c/p\u003e\n"],["\u003cp\u003eYou can customize the camera's perspective, zoom level, bearing, and tilt to enhance the user experience.\u003c/p\u003e\n"],["\u003cp\u003eHigh detail setting, when enabled, displays 2-D building outlines when the zoom level is 19 or higher, which can be further customized using \u003ccode\u003eFollowMyLocationOptions\u003c/code\u003e.\u003c/p\u003e\n"]]],[],null,["# Adjust the camera\n\nThe camera allows you to change the user's viewpoint of the map. You can\nuse camera modes to control the behavior of the map view during navigation.\nTo set the camera mode, call one of the following methods associated\nwith the camera:\n\n- Follow my location (`GoogleMap.followMyLocation`) --- The default camera\n mode for navigation. This mode sets the camera to the device or vehicle.\n During navigation, the camera automatically faces the direction of travel.\n\n- Pinned to location (`GoogleMap.animateCamera` and `GoogleMap.moveCamera`)\n --- Fixes the camera at a specific location. When using this mode, you can\n set the camera location along with other camera properties like bearing, tilt,\n zoom, etc. When this view is selected and the Navigator has been initialized,\n the **Re-center** button is visible.\n\n- Show route overview (`NavigationView.showRouteOverview` or\n `SupportNavigationFragment.showRouteOverview`) --- Displays an overview\n of the remaining route (up to the next 45 minutes of driving time), panning and zooming as needed to fit the route\n into the map view. When this view is selected, the **Re-center** button\n is visible.\n\nClicking the **Re-center** button sets the camera to `followMyLocation` mode.\n\nFollow my location mode\n-----------------------\n\nThe most common camera setting is to have the camera set to the\ndevice or vehicle, showing its current position within the journey. In\nthis camera mode, you can view the route with the car always headed up\nthe screen with an angled perspective (`CameraPerspective.TILTED`), or\nyou can see the car traveling with north (`CameraPerspective.TOP_DOWN_NORTH_UP`)\nor with heading (`CameraPerspective.TOP_DOWN_HEADING_UP)` always at the top of\nthe screen.\n\nThe following code fragment uses the `TILTED` perspective: \n\n // Set the camera to follow the device (vehicle):\n mNavFragment.getMapAsync(googleMap -\u003e googleMap.followMyLocation(CameraPerspective.TILTED))\n\nPinned to location mode\n-----------------------\n\nThe `Pinned` mode provides you with the most control of the\ncamera. In this mode, you place the camera in a specific location, assign\na bearing to orient the camera view, change the tilt to set the viewing angle, and\nset the camera's zoom level.\n\nThe following code snippet demonstrates some of the common ways to move the\ncamera. \n\n private static final LatLng SYDNEY = new LatLng(-33.88, 151.21);\n private static final LatLng MOUNTAIN_VIEW = new LatLng(37.4, -122.1);\n\n private GoogleMap map;\n ... // Obtain the map from a SupportNavigationFragment or NavigationView.\n\n // Move the camera instantly to Sydney with a zoom of 15.\n map.moveCamera(CameraUpdateFactory.newLatLngZoom(SYDNEY, 15));\n\n // Zoom in, animating the camera.\n map.animateCamera(CameraUpdateFactory.zoomIn());\n\n // Zoom out to zoom level 10, animating with a duration of 2 seconds.\n map.animateCamera(CameraUpdateFactory.zoomTo(10), 2000, null);\n\n // Construct a CameraPosition focusing on Mountain View and animate the camera to that position.\n CameraPosition cameraPosition = new CameraPosition.Builder()\n .target(MOUNTAIN_VIEW) // Sets the center of the map to Mountain View\n .zoom(17) // Sets the zoom\n .bearing(90) // Sets the orientation of the camera to east\n .tilt(30) // Sets the tilt of the camera to 30 degrees\n .build(); // Creates a CameraPosition from the builder\n map.animateCamera(CameraUpdateFactory.newCameraPosition(cameraPosition));\n\nShow route overview mode\n------------------------\n\nThe `showRouteOverview` camera setting displays the entire journey.\nFor multiple-destination journeys, this mode displays the untraveled\nportion of the route. \n\n // Place the camera to see the remaining route:\n mNavFragment.showRouteOverview();\n\nNext step\n---------\n\nSee [Customize the Navigation UI](/maps/documentation/navigation/android-sdk/controls)\nto learn how to customize the way in which users interact with your map\nby determining which of the built-in UI components appear on the map."]]