Hướng dẫn triển khai quy trình Đăng ký nhanh & đã xác minh

Tổng quan

web iOS API

Google Maps Platform có sẵn cho web (JS, TS), Android và iOS, đồng thời cũng cung cấp các API dịch vụ web để nhận thông tin về địa điểm, chỉ đường và khoảng cách. Các mẫu trong hướng dẫn này được viết cho một nền tảng, nhưng các đường liên kết đến tài liệu cũng được cung cấp để triển khai trên các nền tảng khác.

Xây dựng ngay!

Trình tạo nhanh trong Google Cloud Console giúp bạn tạo tính năng tự động hoàn thành biểu mẫu địa chỉ bằng một giao diện người dùng tương tác giúp tạo mã JavaScript cho bạn.

Người dùng đã quen với việc sống và vận hành trong một thế giới kỹ thuật số, trong đó sự thuận tiện, tốc độ và tính bảo mật là những kỳ vọng cơ bản. Khi đăng ký một dịch vụ như thẻ tín dụng, tài khoản ngân hàng hoặc khoản vay, họ kỳ vọng rằng quy trình này sẽ nhanh chóng và dễ dàng.

Càng phải nhập hoặc nhập dữ liệu trùng lặp nhiều người dùng, bạn càng có ít cơ hội giữ chân họ làm khách hàng. Việc tạo trải nghiệm đăng ký nhanh chóng, dễ dàng và được xác minh sẽ giúp cải thiện trải nghiệm người dùng trong khi vẫn giúp bạn giữ chân người dùng trên trang web của mình.

Nếu bạn nhập địa chỉ theo cách thủ công, số lượt chuyển đổi có thể giảm đi, dữ liệu CRM bị lỗi và lỗi phân phối tốn kém. Tính năng Đăng ký nhanh và xác minh giúp quá trình đăng ký nhanh hơn, đề xuất ngay các địa chỉ lân cận chỉ với một vài lần nhấn và hiển thị địa chỉ đã nhập để xác nhận trực quan, giúp người dùng cảm thấy tự tin rằng mình đã nhập đúng địa chỉ. Việc xác minh địa chỉ của người dùng bằng thông tin vị trí hiện tại của họ cũng giúp ngăn chặn hành vi lừa đảo và củng cố niềm tin của người dùng đối với các sản phẩm và dịch vụ của bạn. Việc xác minh cũng có thể giúp bạn tự tin hơn trong việc cung cấp ngay thẻ ngân hàng ảo và thẻ tín dụng.

Chủ đề này cung cấp hướng dẫn triển khai để xây dựng trải nghiệm Đăng ký nhanh và đã xác minh bằng Nền tảng Google Maps. Vì người dùng rất có thể sẽ đăng ký trên thiết bị di động, nên hầu hết ví dụ về cách triển khai trong chủ đề này đều tập trung vào Android. (Bạn có thể xem toàn bộ nguồn mẫu tại đây). Bạn cũng có thể sử dụng SDK iOS để thực hiện những việc tương tự.

Sơ đồ dưới đây cho thấy các API cốt lõi liên quan đến việc xây dựng giải pháp (hãy nhấp để phóng to).

Bật API

Để triển khai các đề xuất này, bạn phải bật các API sau trong Google Cloud Console:

Để biết thêm thông tin về cách thiết lập, hãy xem bài viết Bắt đầu sử dụng Nền tảng Google Maps.

Các mục phương pháp hay nhất

Sau đây là các phương pháp và cách tuỳ chỉnh mà chúng tôi sẽ đề cập trong chủ đề này.

  • Biểu tượng dấu kiểm là một phương pháp cốt lõi hay nhất.
  • Biểu tượng dấu sao là không bắt buộc nhưng bạn nên tuỳ chỉnh để cải thiện giải pháp.
Thêm tính năng tự động hoàn thành vào các trường nhập dữ liệu Tự động điền biểu mẫu địa chỉ. Thêm chức năng nhập theo thao tác để cải thiện trải nghiệm người dùng trên tất cả các nền tảng và cải thiện độ chính xác của địa chỉ với ít thao tác nhấn phím nhất có thể.
Cung cấp hình ảnh xác nhận địa chỉ Cho phép người dùng nhìn thấy địa chỉ của họ trên bản đồ dưới dạng một hình ảnh xác nhận rằng họ đã nhập đúng địa chỉ.
So sánh địa chỉ do người dùng nhập với vị trí thiết bị So sánh địa chỉ mà người dùng đã chọn hoặc đã nhập với vị trí thiết bị hiện tại của họ để giúp xác định rằng họ đang ở địa chỉ được chỉ định. (Để làm được điều này, người dùng phải có mặt ở nhà khi đăng ký.)
Các mẹo giúp tăng cường hiệu quả của quy trình Đăng ký nhanh và được xác minh Bạn có thể cải thiện mục nhập địa chỉ hơn nữa bằng các tính năng bổ sung, chẳng hạn như tuỳ chỉnh giao diện của tiện ích Tự động hoàn thành hoặc cho phép người dùng chọn tên của một doanh nghiệp hoặc mốc làm địa chỉ.

Thêm tính năng tự động hoàn thành vào trường nhập dữ liệu

Ví dụ này sử dụng: SDK Địa điểm dành cho Android Cũng áp dụng: iOS | JavaScript

Tính năng Tự động hoàn thành sẽ giúp đơn giản hoá việc nhập địa chỉ trong ứng dụng của bạn, nhờ đó mang lại tỷ lệ chuyển đổi cao hơn và mang lại trải nghiệm liền mạch cho khách hàng. Tính năng Tự động hoàn thành cung cấp một trường nhập nhanh duy nhất với nội dung gợi ý địa chỉ "nhập trước" có thể dùng để tự động điền biểu mẫu địa chỉ đăng ký. Bằng cách kết hợp tính năng Tự động hoàn thành địa điểm vào quy trình đăng ký, bạn có thể:

  • Giảm lỗi nhập địa chỉ.
  • Giảm số bước trong quy trình đăng ký.
  • Đơn giản hoá trải nghiệm nhập địa chỉ trên thiết bị di động hoặc thiết bị đeo.
  • Giảm đáng kể số lần nhấn phím và tổng thời gian cần thiết để khách hàng đăng ký.

Khi người dùng chọn hộp nhập Tự động hoàn thành và bắt đầu nhập, một danh sách các cụm từ gợi ý địa chỉ sẽ xuất hiện.

Khi người dùng chọn một địa chỉ trong danh sách gợi ý, bạn có thể sử dụng phản hồi để xác minh địa chỉ và nhận thông tin vị trí. Sau đó, ứng dụng của bạn có thể điền vào các trường chính xác của biểu mẫu nhập địa chỉ, như minh hoạ trong hình sau.

Video: Cải thiện biểu mẫu địa chỉ bằng tính năng Tự động hoàn thành địa điểm

Biểu mẫu địa chỉ

Android

iOS

Web

Nền tảng Google Maps cung cấp tiện ích Tự động hoàn thành địa điểm cho các nền tảng di động và web. Tiện ích này, minh hoạ trong các hình trước, cung cấp hộp thoại tìm kiếm có tích hợp sẵn chức năng tự động hoàn thành mà bạn thậm chí có thể tối ưu hoá cho hoạt động tìm kiếm ở phạm vi vị trí.

Phần này mô tả cách triển khai tính năng Tự động hoàn thành địa điểm cho quy trình Đăng ký nhanh và đã xác minh.

Thêm tiện ích Tự động hoàn thành địa điểm

Trong Android, bạn có thể thêm tiện ích tự động hoàn thành bằng cách sử dụng Ý định tự động hoàn thành. Tính năng này khởi chạy tính năng Tự động hoàn thành địa điểm từ trường nhập dữ liệu Dòng địa chỉ 1, nơi người dùng sẽ bắt đầu nhập địa chỉ của họ. Khi bắt đầu nhập, họ sẽ có thể chọn địa chỉ của mình trong danh sách cụm từ gợi ý của tính năng Tự động hoàn thành.

Trước tiên, hãy chuẩn bị một trình chạy hoạt động, bằng cách sử dụng ActivityResultLauncher, để lắng nghe kết quả từ hoạt động đã khởi chạy. Lệnh gọi lại kết quả sẽ chứa một đối tượng Địa điểm tương ứng với địa chỉ mà người dùng chọn trong các đề xuất của tính năng Tự động hoàn thành.

    private final ActivityResultLauncher<Intent> startAutocomplete = registerForActivityResult(
            new ActivityResultContracts.StartActivityForResult(),
            result -> {
                if (result.getResultCode() == Activity.RESULT_OK) {
                    Intent intent = result.getData();
                    if (intent != null) {
                        Place place = Autocomplete.getPlaceFromIntent(intent);

                        // Write a method to read the address components from the Place
                        // and populate the form with the address components
                        Log.d(TAG, "Place: " + place.getAddressComponents());
                        fillInAddress(place);
                    }
                } else if (result.getResultCode() == Activity.RESULT_CANCELED) {
                    // The user canceled the operation.
                    Log.i(TAG, "User canceled autocomplete");
                }
            });

Tiếp theo, hãy xác định các trường, vị trí và thuộc tính kiểu của ý định Tự động hoàn thành địa điểm, rồi tạo ý định đó bằng Autocomplete.IntentBuilder. Cuối cùng, hãy khởi chạy ý định bằng cách sử dụng ActivityResultLauncher được xác định trong mã mẫu trước đó.

    private void startAutocompleteIntent() {

        // Set the fields to specify which types of place data to
        // return after the user has made a selection.
        List<Place.Field> fields = Arrays.asList(Place.Field.ADDRESS_COMPONENTS,
                Place.Field.LAT_LNG, Place.Field.VIEWPORT);

        // Build the autocomplete intent with field, country, and type filters applied
        Intent intent = new Autocomplete.IntentBuilder(AutocompleteActivityMode.OVERLAY, fields)
                .setCountries(Arrays.asList("US"))
                .setTypesFilter(new ArrayList<String>() {{
                    add(TypeFilter.ADDRESS.toString().toLowerCase());
                }})
                .build(this);
        startAutocomplete.launch(intent);
    }

Xử lý địa chỉ do tính năng Tự động hoàn thành về địa điểm trả về

Việc xác định ActivityResultLauncher trước đó cũng sẽ xác định việc cần làm khi kết quả hoạt động được trả về trong lệnh gọi lại. Nếu người dùng chọn một cụm từ gợi ý, cụm từ đó sẽ được phân phối trong ý định nằm trong đối tượng kết quả. Vì ý định do Autocomplete.IntentBuilder tạo, nên phương thức Autocomplete.getPlaceFromIntent() có thể trích xuất đối tượng Địa điểm từ đó.

    private final ActivityResultLauncher<Intent> startAutocomplete = registerForActivityResult(
            new ActivityResultContracts.StartActivityForResult(),
            result -> {
                if (result.getResultCode() == Activity.RESULT_OK) {
                    Intent intent = result.getData();
                    if (intent != null) {
                        Place place = Autocomplete.getPlaceFromIntent(intent);

                        // Write a method to read the address components from the Place
                        // and populate the form with the address components
                        Log.d(TAG, "Place: " + place.getAddressComponents());
                        fillInAddress(place);
                    }
                } else if (result.getResultCode() == Activity.RESULT_CANCELED) {
                    // The user canceled the operation.
                    Log.i(TAG, "User canceled autocomplete");
                }
            });

Từ đó, hãy gọi Place.getAddressComponents() và so khớp từng thành phần địa chỉ với trường nhập dữ liệu tương ứng trong biểu mẫu địa chỉ, điền giá trị từ Địa điểm mà người dùng đã chọn vào trường.

Việc thu thập dữ liệu địa chỉ từ thông tin dự đoán thay vì địa chỉ được nhập theo cách thủ công giúp đảm bảo độ chính xác của địa chỉ, đảm bảo rằng địa chỉ đã biết và có thể được gửi tới, đồng thời giảm số lần nhấn phím của người dùng.

Những điều cần cân nhắc khi triển khai tính năng Tự động hoàn thành về địa điểm

Tính năng Tự động hoàn thành có một số tuỳ chọn cho phép tính năng này linh hoạt triển khai nếu bạn muốn sử dụng nhiều hơn là chỉ tiện ích. Bạn có thể sử dụng kết hợp các dịch vụ để có được chính xác những gì bạn cần để so khớp một vị trí theo đúng cách.

  • Đối với biểu mẫu ADDRESS, hãy đặt tham số loại thành address để hạn chế các kết quả trùng khớp với địa chỉ đường phố đầy đủ. Tìm hiểu thêm về các loại được hỗ trợ trong yêu cầu Tự động hoàn thành về địa điểm.

  • Đặt các hạn chế và độ thiên vị thích hợp nếu bạn không cần tìm kiếm trên toàn thế giới. Có một số tham số có thể dùng để sai lệch hoặc hạn chế bất kỳ kết quả khớp nào chỉ với các khu vực cụ thể.

    • Dùng RectangularBounds để thiết lập giới hạn hình chữ nhật để ràng buộc cho một khu vực, sử dụng setLocationRestriction() để đảm bảo chỉ các địa chỉ trong các khu vực đó mới được trả về.

    • Sử dụng setCountries() để hạn chế câu trả lời ở một nhóm quốc gia nhất định.

  • Để các trường có thể chỉnh sửa trong trường hợp một số trường bị thiếu thông tin so khớp và cho phép khách hàng cập nhật địa chỉ nếu cần. Vì hầu hết các địa chỉ mà tính năng Tự động hoàn thành bằng địa điểm trả về đều không chứa số tiền phòng, chẳng hạn như số căn hộ, số căn hộ hoặc số nhà, nên bạn có thể di chuyển tiêu điểm đến Dòng địa chỉ 2 để khuyến khích người dùng điền thông tin đó nếu cần.

Cung cấp hình ảnh xác nhận địa chỉ

Ví dụ này sử dụng: SDK Maps dành cho Android Cũng áp dụng: iOS | JavaScript

Trong quá trình nhập địa chỉ, hãy cung cấp cho người dùng xác nhận bằng hình ảnh về địa chỉ trên bản đồ. Việc này giúp người dùng đảm bảo thêm rằng địa chỉ đó là chính xác.

Hình sau đây cho thấy một bản đồ bên dưới địa chỉ có ghim tại địa chỉ đã nhập.

Ví dụ sau đây tuân theo các bước cơ bản để thêm bản đồ trong Android. Hãy tham khảo tài liệu để biết thêm chi tiết.

Đang thêm SupportMapFragment

Trước tiên, hãy thêm một mảnh SupportMapFragment vào tệp XML bố cục.

    <fragment
        android:name="com.google.android.gms.maps.SupportMapFragment"
        android:id="@+id/confirmation_map"
        android:layout_width="match_parent"
        android:layout_height="match_parent"/>

Sau đó, hãy lập trình để thêm mảnh nếu chưa có.

    private void showMap(Place place) {
        coordinates = place.getLatLng();

        // It isn't possible to set a fragment's id programmatically so we set a tag instead and
        // search for it using that.
        mapFragment = (SupportMapFragment)
                getSupportFragmentManager().findFragmentByTag(MAP_FRAGMENT_TAG);

        // We only create a fragment if it doesn't already exist.
        if (mapFragment == null) {
            mapPanel = ((ViewStub) findViewById(R.id.stub_map)).inflate();
            GoogleMapOptions mapOptions = new GoogleMapOptions();
            mapOptions.mapToolbarEnabled(false);

            // To programmatically add the map, we first create a SupportMapFragment.
            mapFragment = SupportMapFragment.newInstance(mapOptions);

            // Then we add it using a FragmentTransaction.
            getSupportFragmentManager()
                    .beginTransaction()
                    .add(R.id.confirmation_map, mapFragment, MAP_FRAGMENT_TAG)
                    .commit();
            mapFragment.getMapAsync(this);
        } else {
            updateMap(coordinates);
        }
    }

Lấy tên người dùng đối với mảnh và đăng ký lệnh gọi lại

  1. Để xử lý mảnh, hãy gọi phương thức FragmentManager.findFragmentById và truyền vào phương thức này mã nhận dạng tài nguyên của mảnh trong tệp bố cục. Nếu bạn thêm mảnh một cách linh động, hãy bỏ qua bước này vì bạn đã truy xuất tên người dùng.

  2. Gọi phương thức getMapAsync để thiết lập lệnh gọi lại trên mảnh.

Ví dụ: nếu bạn đã thêm mảnh theo cách tĩnh:

Kotlin



val mapFragment = supportFragmentManager
    .findFragmentById(R.id.map) as SupportMapFragment
mapFragment.getMapAsync(this)

      

Java


SupportMapFragment mapFragment = (SupportMapFragment) getSupportFragmentManager()
    .findFragmentById(R.id.map);
mapFragment.getMapAsync(this);

      

Tạo kiểu và thêm điểm đánh dấu vào bản đồ

Khi bản đồ đã sẵn sàng, hãy đặt kiểu, căn giữa máy ảnh và thêm một điểm đánh dấu tại toạ độ của địa chỉ đã nhập. Mã sau đây sử dụng kiểu được xác định trong đối tượng JSON hoặc bạn có thể tải mã nhận dạng bản đồ đã được xác định bằng Tạo kiểu bản đồ trên đám mây.

    @Override
    public void onMapReady(@NonNull GoogleMap googleMap) {
        map = googleMap;
        try {
            // Customise the styling of the base map using a JSON object defined
            // in a string resource.
            boolean success = map.setMapStyle(
                    MapStyleOptions.loadRawResourceStyle(this, R.raw.style_json));

            if (!success) {
                Log.e(TAG, "Style parsing failed.");
            }
        } catch (Resources.NotFoundException e) {
            Log.e(TAG, "Can't find style. Error: ", e);
        }
        map.moveCamera(CameraUpdateFactory.newLatLngZoom(coordinates, 15f));
        marker = map.addMarker(new MarkerOptions().position(coordinates));
    }

(Xem mã mẫu đầy đủ)

Tắt các chế độ điều khiển bản đồ

Để đơn giản hoá bản đồ bằng cách hiển thị vị trí mà không cần các chế độ điều khiển bổ sung trên bản đồ (chẳng hạn như la bàn, thanh công cụ hoặc các tính năng tích hợp sẵn khác), hãy cân nhắc tắt những chế độ điều khiển mà bạn không cần. Trên Android, có một tuỳ chọn khác là bật chế độ thu gọn để cung cấp khả năng tương tác hạn chế.

So sánh địa chỉ do người dùng nhập với vị trí thiết bị

Việc thu thập bằng chứng về địa chỉ (tức là tự tin rằng người dùng đang ở địa chỉ mà họ đã nhập) có thể phức tạp vì các yếu tố như vị trí của người dùng từ xa, người dùng chuyển đến địa chỉ mới hoặc doanh nghiệp kỹ thuật số (chẳng hạn như ngân hàng kỹ thuật số) không có vị trí thực tế mà người dùng có thể ghé thăm để cung cấp bằng chứng về địa chỉ kèm theo hoá đơn dịch vụ tiện ích hoặc giấy tờ khác. Việc cung cấp các phương thức kỹ thuật số để xác minh địa chỉ của người dùng giúp bạn đăng ký nhanh hơn và suôn sẻ hơn.

Bảo mật là yếu tố tối quan trọng trong quá trình kiểm tra địa chỉ, đặc biệt là với quy trình đăng ký kỹ thuật số. Phần này cung cấp hướng dẫn và các mẫu để kiểm tra xem vị trí của người dùng trong quá trình đăng ký có khớp với địa chỉ mà họ nhập như của mình hay không.

Quy trình so sánh địa chỉ đã nhập với vị trí của thiết bị bao gồm các bước sau:

  1. Chuyển đổi địa chỉ do người dùng nhập thành toạ độ địa lý.
  2. Nhắc người dùng cấp quyền truy cập vào thông tin vị trí của thiết bị của họ.
  3. Tính toán khoảng cách giữa địa chỉ đã nhập và vị trí thiết bị. Bạn có thể xác định khoảng cách tối đa được tính cho một trường hợp trùng khớp với vị trí địa chỉ.

Hình sau đây là ví dụ về cách bạn có thể nhắc người dùng so sánh địa chỉ họ đã nhập với vị trí hiện tại của họ.

Chuyển đổi địa chỉ do người dùng nhập thành toạ độ địa lý

Ví dụ này sử dụng: SDK Địa điểm dành cho Android Cũng áp dụng: iOS | JavaScript | API mã hoá địa lý

Sau khi người dùng đồng ý xác minh địa chỉ (bằng cách chạm vào "Xác minh rằng tôi đang ở đó" trong hình trước), bước đầu tiên để so sánh địa chỉ với vị trí hiện tại là chuyển đổi địa chỉ đã nhập thành toạ độ địa lý.

Nếu người dùng chọn địa chỉ bằng tính năng Tự động hoàn thành địa điểm, hãy nhớ yêu cầu Place.Field.LAT_LNG trong danh sách trường Tự động hoàn thành về địa điểm như minh hoạ trong đoạn mã Thêm tiện ích Tự động hoàn thành về địa điểm và gọi phương thức Place.getLatLng() để lấy toạ độ địa lý của địa chỉ đã chọn.

coordinates = place.getLatLng();

Nếu người dùng tự nhập địa chỉ hoặc chỉnh sửa sau khi tính năng Tự động hoàn thành địa điểm điền vào các trường, hãy sử dụng dịch vụ Bộ mã hoá địa lý của Android hoặc API mã hoá địa lý để tra cứu toạ độ tương ứng với địa chỉ đó.

Ví dụ

https://maps.googleapis.com/maps/api/geocode/json?address=1600%20Amphitheatre%2BParkway%2C%20Mountain%20View%2C%20CA%2094043&key=YOUR_API_KEY

Hãy nhớ Mã hoá URL lệnh gọi đến API mã hoá địa lý.

Tham chiếu nhanh để mã hóa URL: %20 = dấu cách, %2B = + (dấu cộng), %2C = , (dấu phẩy)

Nhắc người dùng cấp quyền truy cập thông tin vị trí thiết bị của họ

Để có được thông tin vị trí thiết bị của người dùng, bạn cần yêu cầu người dùng cho phép để bật dịch vụ vị trí. Theo hướng dẫn trong tài liệu của Android về cách xây dựng các ứng dụng nhận biết vị trí, hãy triển khai quy trình sau:

  • Yêu cầu quyền truy cập thông tin vị trí, dưới dạng quyền cấp một lần, ở cấp chính xác (ACCESS_FINE_LOCATION).

  • Nếu người dùng cấp quyền truy cập thông tin vị trí, hãy lấy thông tin vị trí của người dùng.

  • Nếu người dùng từ chối quyền truy cập thông tin vị trí, hãy xử lý từ chối một cách linh hoạt. Ví dụ: bạn có thể hiển thị loại thông báo sau (giả sử bạn không lưu trữ thông tin vị trí hiện tại của người dùng):

    "Nếu không cho ứng dụng biết vị trí chính xác của mình, bạn cần xác minh qua thư để kích hoạt tài khoản. [OK]"

Hình sau đây là ví dụ về lời nhắc người dùng cấp quyền lấy thông tin vị trí của thiết bị.

Để kiểm tra quyền truy cập thông tin vị trí, hãy chuẩn bị một trình chạy hoạt động sẽ lắng nghe kết quả từ hoạt động đã chạy bằng ActivityResultLauncher. Lệnh gọi lại kết quả sẽ chứa một Chuỗi cho biết người dùng đã cấp hay từ chối quyền được yêu cầu.

    // Register the permissions callback, which handles the user's response to the
    // system permissions dialog. Save the return value, an instance of
    // ActivityResultLauncher, as an instance variable.
    private final ActivityResultLauncher<String> requestPermissionLauncher =
            registerForActivityResult(new ActivityResultContracts.RequestPermission(), isGranted -> {
                if (isGranted) {
                    // Since ACCESS_FINE_LOCATION is the only permission in this sample,
                    // run the location comparison task once permission is granted.
                    // Otherwise, check which permission is granted.
                    getAndCompareLocations();
                } else {
                    // Fallback behavior if user denies permission
                    Log.d(TAG, "User denied permission");
                }
            });

Sau đó, hãy kiểm tra xem ứng dụng đã cấp quyền ACCESS_FINE_LOCATION hay chưa. Nếu không, hãy yêu cầu người dùng cấp quyền bằng cách khởi chạy hoạt động yêu cầu cấp quyền thông qua trình chạy được xác định ở bước trước.

    private void checkLocationPermissions() {
        if (ContextCompat.checkSelfPermission(this, ACCESS_FINE_LOCATION)
                == PackageManager.PERMISSION_GRANTED) {
            getAndCompareLocations();
        } else {
            requestPermissionLauncher.launch(
                    ACCESS_FINE_LOCATION);
        }
    }

Sau khi được cấp quyền ACCESS_FINE_LOCATION, hãy sử dụng trình cung cấp vị trí kết hợp để lấy thông tin vị trí xác định gần đây nhất của thiết bị rồi tạo một đối tượng LatLng từ đó.

        FusedLocationProviderClient fusedLocationClient =
                LocationServices.getFusedLocationProviderClient(this);

        fusedLocationClient.getLastLocation()
                .addOnSuccessListener(this, location -> {
                    // Got last known location. In some rare situations this can be null.
                    if (location == null) {
                        return;
                    }

                    deviceLocation = new LatLng(location.getLatitude(), location.getLongitude());
                    // ...
                });
    }

Tính khoảng cách giữa địa chỉ đã nhập và vị trí thiết bị

Sử dụng toán học để tính khoảng cách giữa hai toạ độ vĩ độ/kinh độ (địa chỉ đã nhập và vị trí thiết bị). SDK Maps dành cho Thư viện tiện ích Android nguồn mở có một số phương pháp thuận tiện để tính toán khoảng cách hình cầu giữa hai điểm trên Trái đất.

Trước tiên, hãy cài đặt SDK Maps dành cho Thư viện tiện ích Android bằng cách thêm phần phụ thuộc sau đây vào tệp build.gradle của ứng dụng:

dependencies {


    // Utility Library for Maps SDK for Android
    // You do not need to add a separate dependency for the Maps SDK for Android
    // since this library builds in the compatible version of the Maps SDK.
    implementation 'com.google.maps.android:android-maps-utils:3.8.0'
}

Tiếp theo, hãy quay lại tệp hoạt động sau khi xem vị trí thiết bị đã biết gần đây nhất, xác định bán kính tính bằng mét để coi hai vị trí này là "đã khớp". Bán kính phải đủ lớn để tính đến sự thay đổi về độ chính xác của GPS và kích thước của địa điểm theo địa chỉ mà người dùng đã nhập. Ví dụ:

private static final double acceptableProximity = 150;

Sau đó, hãy sử dụng phương thức thư viện tiện ích computeDistanceBetween() để tính khoảng cách giữa vị trí thiết bị và vị trí địa chỉ do người dùng nhập. Nếu khoảng cách nằm trong bán kính được xác định ở trên, hãy cân nhắc các vị trí trùng khớp.

// Use the computeDistanceBetween function in the Maps SDK for Android Utility Library
// to use spherical geometry to compute the distance between two Lat/Lng points.
double distanceInMeters = computeDistanceBetween(deviceLocation, enteredLocation);
if (distanceInMeters <= acceptedProximity) {
    Log.d(TAG, "location matched");
    // TODO: Display UI based on the locations matching
} else {
    Log.d(TAG, "location not matched");
    // TODO: Display UI based on the locations not matching
}

(Xem mã mẫu đầy đủ)

Nếu địa chỉ và vị trí trùng khớp, hãy cho thấy một thông báo xác nhận trong ứng dụng như minh hoạ trong hình sau.

Mẹo giúp tăng cường hiệu quả của tính năng Đăng ký nhanh và được xác minh

Cho phép người dùng nhập địa chỉ dựa trên tên doanh nghiệp hoặc tên địa điểm yêu thích. Dịch vụ dự đoán "nhập trước" không chỉ hoạt động với địa chỉ mà bạn còn có thể chọn cho phép người dùng nhập tên doanh nghiệp hoặc tên mốc. Để cho phép nhập cả địa chỉ và tên cơ sở, hãy xoá thuộc tính types khỏi định nghĩa Tự động hoàn thành.

Tuỳ chỉnh giao diện của hộp Tự động hoàn thành địa điểm cho phù hợp với kiểu trang web của bạn. Nếu muốn kiểm soát giao diện của tính năng Tự động hoàn thành địa điểm trong ứng dụng thay vì sử dụng tiện ích của Google, bạn có thể sử dụng tính năng Đặt tự động hoàn thành theo phương thức lập trình để hỗ trợ giao diện người dùng mà bạn tạo bằng dịch vụ Tự động hoàn thành địa điểm.