Skip to main content

Simplify Your Tax Calculations with GST Calculator 2024: The Ultimate Tool for Businesses and Individuals

How to fetch Latitude, Longitude from address and vice-versa(address from Latitude, Longitude) using Google Geo coder SDK in android| Kotlin

 In this Android development related article, you will get a simple solution that, how to get address using Latitude, Longitude and vice-versa. i.e latitude, longitude from an address text. It is very easy and simple. Read full article and carefully follow all the steps.



Here we use google Geocoder SDK.

Okay, first we create an android project in kotlin and create an Activity say MainActivity.kt. Use the below code-

Function get Latitude, Longitude from Address-

     fun getLatLngFromAddress(context: Context, mAddress: String): String {

        val coder = Geocoder(context)
        lateinit var address: List<Address>


        try {
            address = coder.getFromLocationName(mAddress, 5)
            if (address == null) {
                return "Fail to find Lat,Lng"
            }
            val location = address[0]



            return " Latitude: ${location.latitude}\n Longitude: ${location.longitude}"
        } catch (e: Exception) {
            return "Fail to find Lat,Lng"

        }
    }


Function get Address from Latitude, Longitude-

    fun getAddressFromLatLng(context: Context, latitude: String, longitude: String): String {
        val addresses: List<Address>
        val geocoder = Geocoder(context, Locale.getDefault())

        try {
            addresses = geocoder.getFromLocation(
                latitude.toDouble(),
                longitude.toDouble(),
                5
            )


            return if (addresses.isNotEmpty()) {
                val address =
                    addresses[0].getAddressLine(0)

                val city = addresses[0].locality
                val state = addresses[0].adminArea
                val country = addresses[0].countryName
                val postalCode = addresses[0].postalCode
                address
            } else {
                "No Address found"
            }


        } catch (e: Exception) {

            e.printStackTrace()
            return "Fail to search Address"
        }


    }


Full Source Code

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <TextView
        android:id="@+id/tvText1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="35dp"
        android:text="@string/address_from_latitude_longitude"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <EditText
        android:id="@+id/etLatitude"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginStart="15dp"
        android:layout_marginTop="15dp"
        android:layout_marginEnd="15dp"
        android:digits="0123456789.-"
        android:hint="@string/enter_latitude"
        android:imeOptions="actionNext"
        android:inputType="numberDecimal"
        android:maxLength="25"
        app:layout_constraintTop_toBottomOf="@id/tvText1" />

    <EditText
        android:id="@+id/etLongitude"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginStart="15dp"
        android:layout_marginTop="10dp"
        android:layout_marginEnd="15dp"
        android:digits="0123456789.-"
        android:hint="@string/enter_longitude"
        android:imeOptions="actionDone"
        android:inputType="numberDecimal"
        android:maxLength="25"
        app:layout_constraintTop_toBottomOf="@id/etLatitude" />

    <Button
        android:id="@+id/btnGetAddress"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginTop="15dp"
        android:background="@color/colorPrimary"
        android:minHeight="45dp"
        android:text="@string/get_address"
        app:layout_constraintEnd_toEndOf="@id/etLatitude"
        app:layout_constraintStart_toStartOf="@id/etLatitude"
        app:layout_constraintTop_toBottomOf="@id/etLongitude" />

    <TextView
        android:id="@+id/tvText2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="35dp"
        android:text="Lat,Lng from Address"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@id/btnGetAddress" />

    <EditText
        android:id="@+id/etAddress"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginStart="15dp"
        android:layout_marginTop="15dp"
        android:layout_marginEnd="15dp"
        android:hint="@string/enter_address"
        android:maxLength="300"
        android:maxLines="5"
        app:layout_constraintTop_toBottomOf="@id/tvText2" />

    <Button
        android:id="@+id/btnGetLatLng"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginTop="15dp"
        android:background="@color/colorPrimary"
        android:minHeight="45dp"
        android:text="@string/get_lat_lng"
        android:textAllCaps="false"
        app:layout_constraintEnd_toEndOf="@id/etAddress"
        app:layout_constraintStart_toStartOf="@id/etAddress"
        app:layout_constraintTop_toBottomOf="@id/etAddress" />

</androidx.constraintlayout.widget.ConstraintLayout>


MainActivity.Kt




package com.example.location

import android.content.Context
import android.location.Address
import android.location.Geocoder
import android.os.Bundle
import android.widget.Toast
import androidx.appcompat.app.AppCompatActivity
import kotlinx.android.synthetic.main.activity_main.*
import java.util.*

class MainActivity : AppCompatActivity() {
    private val context = this
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)


        btnGetAddress.setOnClickListener {
            val mLat = etLatitude.text.toString().trim()
            val mLng = etLongitude.text.toString().trim()
            if (mLat.isNotEmpty() && mLng.isNotEmpty()) {
                Toast.makeText(
                    context,
                    getAddressFromLatLng(context, mLat, mLng),
                    Toast.LENGTH_SHORT
                )
                    .show()
            } else {
                Toast.makeText(context, "Please Enter Lat,Lng", Toast.LENGTH_SHORT).show()
            }

        }







        btnGetLatLng.setOnClickListener {
            val mmAddress = etAddress.text.toString().trim()
            if (mmAddress.isNotEmpty()) {
                Toast.makeText(
                    context,
                    getLatLngFromAddress(context, mmAddress),
                    Toast.LENGTH_SHORT
                )
                    .show()
            } else {
                Toast.makeText(context, "Please Enter Address", Toast.LENGTH_SHORT).show()
            }
        }

    }

    fun getLatLngFromAddress(context: Context, mAddress: String): String {

        val coder = Geocoder(context)
        lateinit var address: List<Address>


        try {
            address = coder.getFromLocationName(mAddress, 5)
            if (address == null) {
                return "Fail to find Lat,Lng"
            }
            val location = address[0]

            return " Latitude: ${location.latitude}\n Longitude: ${location.longitude}"
        } catch (e: Exception) {
            return "Fail to find Lat,Lng"

        }
    }

    fun getAddressFromLatLng(context: Context, latitude: String, longitude: String): String {
        val addresses: List<Address>
        val geocoder = Geocoder(context, Locale.getDefault())

        try {
            addresses = geocoder.getFromLocation(
                latitude.toDouble(),
                longitude.toDouble(),
                5
            )


            return if (addresses.isNotEmpty()) {
                val address =
                    addresses[0].getAddressLine(0)

                val city = addresses[0].locality
                val state = addresses[0].adminArea
                val country = addresses[0].countryName
                val postalCode = addresses[0].postalCode
                address
            } else {
                "No Address found"
            }


        } catch (e: Exception) {

            e.printStackTrace()
            return "Fail to search Address"
        }


    }
}












Comments

Popular posts from this blog

How to consume REST APIs in Laravel | Laravel Development | Solution

In Laravel, you can call a REST API using the HTTP client provided by the framework. Laravel's HTTP client allows you to make GET, POST, PUT, DELETE, and other HTTP requests to external APIs. Here's how you can call a REST API in Laravel: Install Laravel (if not already done): If you haven't already set up a Laravel project, you can create one using Composer by running the following command: composer create - project -- prefer - dist laravel / laravel project - name Create a Controller (optional): You can create a controller to encapsulate the API call logic, but this step is not strictly necessary. You can also make API calls directly from your routes or other parts of your application. To create a controller, run the following command: php artisan make: controller ApiController Make an API Request: You can make API requests using Laravel's HTTP client, which is a fluent, expressive interface for making HTTP requests. Here's how you can make a simple GET request t...

Create Any Recyclerview Adapter within 5 seconds, in Android | Kotlin.

 In every single android application, we need to make many number of recycler-view adapter. So every time you create a blank adapter and modify it as per your requirements. But it is very boring and as well as time taking. So here I give you a solution that you can create any recyclerview adapter within 5 seconds using file template in Android Studio. So, Lets read this full article- First we open android studio and create a project. After project creation  Open File->new->Edit File Template... Follow this below screenshot Okay, After click on "Edit File Template" a popup is open "File and Code Template", Now click on the  " + " icon and set set your template name. Now set your template name, template extension and template body. after doing everything click on "Apply" and then click on "OK" The template body I after after the screenshot Template Body Copy this code and paste it on the template body section, which I marked in scre...