Пожалуйста, запутался, как я могу нарисовать маршрут на карте Google, используя введенный адрес для начального и конечного адресов в тексте редактирования.
Таким образом, у меня есть исходный текст редактирования и целевой текст редактирования, который принимает адрес пользователя, и кнопку, которая должна преобразовать адреса в широту и долготу, это я сделал, передавая адреса в виде ArrayList в методе. после этого я вызываю MapAsync (this) внутри кнопки, но мой код не отвечает, как следует.
Я знаю, что пропускаю что-то или вещи, но я не знаю что. Я работаю над этим со вчерашнего дня, и он не отвечает.
Пожалуйста, мне нужна вся помощь, которую я могу получить. Заранее спасибо.
class MapsActivity : AppCompatActivity(), OnMapReadyCallback {
private lateinit var mMap: GoogleMap
private var editOrigin : EditText ?= null
private var editDestination: EditText ?= null
var markerPoints: ArrayList<LatLng>?= null
private var allLatLng: ArrayList<String>?= null
private var LatLongitude: List<LatLngModel>?= null
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_maps)
markerPoints = ArrayList()
allLatLng = ArrayList()
editDestination = findViewById(R.id.editDestination)
editOrigin = findViewById(R.id.editOrigin)
// Obtain the SupportMapFragment and get notified when the map is ready to be used.
val mapFragment = supportFragmentManager
.findFragmentById(R.id.map) as SupportMapFragment
mapFragment.getMapAsync(this)
findViewById<Button>(R.id.buttonSubmit).setOnClickListener {
val origin = editOrigin!!.text.toString()
val destination = editDestination!!.text.toString()
allLatLng!!.add(origin)
allLatLng!!.add(destination)
LatLongitude = getCompleteAddressString(allLatLng!!)
Log.d("TAGGY", LatLongitude.toString())
mapFragment.getMapAsync(this)
}
}
@SuppressLint("StaticFieldLeak")
inner class DownloadTask : AsyncTask<String,Int,String>() {
override fun doInBackground(vararg url: String): String {
var data = ""
try {
data = downloadUrl(url[0])
} catch (e: Exception) {
Log.d("Background Task", e.toString())
}
return data
}
override fun onPostExecute(result: String) {
super.onPostExecute(result)
val parserTask = ParserTask()
parserTask.execute(result)
}
}
inner class ParserTask : AsyncTask<String, Int, List<List<HashMap<String, String>>>>() {
override fun doInBackground(vararg p0: String?): List<List<HashMap<String, String>>>? {
val jObject: JSONObject
var routes: List<List<HashMap<String, String>>>?
try {
jObject = JSONObject(p0[0])
val parser = DirectionsJSONParser()
routes = parser.parse(jObject)
return routes!!
} catch ( e: Exception) {
}
return null
}
// Parsing the data in non-ui thread
override fun onPostExecute(result: List<List<HashMap<String, String>>>?) {
super.onPostExecute(result)
var points : ArrayList<LatLng>?= null
var lineOptions: PolylineOptions ? = null
val markerOptions = MarkerOptions()
for ( i in 0 ..result!!.size ) {
points = ArrayList()
lineOptions = PolylineOptions()
val path = result[i]
for (j in 0 .. path.size) {
val point = path[j]
val lat = java.lang.Double.parseDouble(point["lat"] as String?)
val lng = java.lang.Double.parseDouble(point["lng"] as String?)
val position = LatLng(lat, lng)
points.add(position)
}
lineOptions.addAll(points)
lineOptions.width(12f)
lineOptions.color(Color.RED)
lineOptions.geodesic(true)
}
// Drawing polyline in the Google Map for the i-th route
mMap.addPolyline(lineOptions)
}
}
@Throws(IOException::class)
private fun downloadUrl(strUrl: String): String {
var data = ""
var iStream: InputStream? = null
var urlConnection: HttpURLConnection? = null
try {
val url = URL(strUrl)
urlConnection = url.openConnection() as HttpURLConnection
urlConnection.connect()
iStream = urlConnection.inputStream
val br = BufferedReader(InputStreamReader(iStream))
val sb = StringBuffer()
while (true) {
val line = br.readLine()
if (line != null) {
sb.append(line)
} else {
Log.i("TAG", "HTTP RESPONSE" + sb.toString())
return sb.toString()
}
data = sb.toString()
br.close()
}
} catch (e: Exception) {
Log.d("Exception", e.toString())
} finally {
iStream!!.close()
urlConnection!!.disconnect()
}
return data
}
private fun getDirectionsUrl(origin: LatLng, dest: LatLng): String {
// Origin of route
val str_origin = "origin=" + origin.latitude + "," + origin.longitude
// Destination of route
val str_dest = "destination=" + dest.latitude + "," + dest.longitude
// Sensor enabled
val sensor = "sensor=false"
val mode = "mode=driving"
// Building the parameters to the web service
val parameters = "$str_origin&$str_dest&$sensor&$mode"
// Output format
val output = "json"
// Building the url to the web service
return "https://maps.googleapis.com/maps/api/directions/$output?$parameters"
}
private fun getCompleteAddressString(addressList: ArrayList<String>): List<LatLngModel> {
val strAdd = ArrayList<LatLngModel>()
val latLngModel = LatLngModel()
var lat: String? = null
var lng: String? = null
val geocoder = Geocoder(this, Locale.getDefault())
try {
for (a in addressList){
val addresses = geocoder.getFromLocationName(a, 1)
if (addresses != null && addresses.size > 0) {
val address = addresses[0]
val sb = StringBuilder()
val lat = address.latitude
val Lng = address.longitude
latLngModel.latitude = lat
latLngModel.longitude = Lng
strAdd.add(latLngModel)
sb.append(address.latitude).append("\n")
sb.append(address.longitude).append("\n")
}else {
Log.w("My Current addressList", "No Address returned!")
}
}
} catch (e: Exception) {
e.printStackTrace()
Log.w("My Current addressList", "Cannot get Address!")
}
return strAdd
}
/**
* Manipulates the map once available.
* This callback is triggered when the map is ready to be used.
* This is where we can add markers or lines, add listeners or move the camera. In this case,
* we just add a marker near Sydney, Australia.
* If Google Play services is not installed on the device, the user will be prompted to install
* it inside the SupportMapFragment. This method will only be triggered once the user has
* installed Google Play services and returned to the app.
*/
override fun onMapReady(googleMap: GoogleMap) {
mMap = googleMap
var lat1: Double
var lng1: Double
val options = MarkerOptions()
var latlng: LatLng? = null
// Add a marker in Sydney and move the camera
val sydney = LatLng(-34.0, 151.0)
mMap.addMarker(MarkerOptions().position(sydney).title("Marker in Sydney"))
mMap.moveCamera(CameraUpdateFactory.newLatLng(sydney))
try{
if (markerPoints!!.size >1){
markerPoints!!.clear()
mMap.clear()
}
if (LatLongitude != null){
for (v in LatLongitude!!){
lat1 = v.latitude
lng1 = v.longitude
latlng = LatLng(lat1,lng1)
}
markerPoints!!.add(latlng!!)
options.position(latlng)
if (markerPoints!!.size == 1){
options.icon(BitmapDescriptorFactory.defaultMarker(BitmapDescriptorFactory.HUE_GREEN))
}
else if (markerPoints!!.size == 2){
options.icon(BitmapDescriptorFactory.defaultMarker(BitmapDescriptorFactory.HUE_RED))
}
// Add new marker to the Google Map Android API V2
mMap.addMarker(options)
}
}catch (e: Exception){
Log.i("TAG", e.message)
}
// Checks, whether start and end locations are captured
if (markerPoints!!.size >= 2) {
val origin = markerPoints!![0]
val dest = markerPoints!![1]
// Getting URL to the Google Directions API
val url = getDirectionsUrl(origin, dest)
DownloadTask().execute(url)
}
}
}