我的小程序有麻烦了。
我想在androidstudio中获得反向地理编码的地址位置。
但我的代码只是在模拟器中工作。当我把我真正的dvice和app连接起来,想要得到地址时,它给了我一个错误,app崩溃了。错误:grpc失败。
我将代码放在try-and-catch方法中,但错误仍然存在。
这是我的小应用程序:
梅尼菲斯特:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.my_test_app">
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/>
<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:roundIcon="@mipmap/ic_launcher_round"
android:supportsRtl="true"
android:theme="@style/AppTheme">
<activity android:name=".MainActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<meta-data
android:name="com.google.android.gms.version"
android:value="@integer/google_play_services_version" />
<meta-data
android:name="com.google.android.geo.API_KEY"
android:value="AIzaSyCutiOvAqZiLvka-kW9B12K.........." />
</application>
</manifest>
xml布局:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@android:color/white"
>
<TextView
android:id="@+id/textview1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="50dp"
android:text="text1"
android:textSize="20sp"
android:layout_centerHorizontal="true"
/>
<TextView
android:id="@+id/textview2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="text2"
android:layout_marginTop="10dp"
android:textSize="20sp"
android:layout_centerHorizontal="true"
android:layout_below="@+id/textview1"
/>
<Button
android:id="@+id/button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/textview2"
android:layout_centerHorizontal="true"
android:layout_marginTop="20dp"
android:text="button"
android:textSize="25sp"
/>
</RelativeLayou
主要活动:
package com.example.my_test_app
import android.Manifest
import android.content.Context
import android.content.pm.PackageManager
import android.location.Address
import android.location.Geocoder
import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import android.widget.Button
import android.widget.TextView
import android.widget.Toast
import androidx.core.app.ActivityCompat
import androidx.loader.content.AsyncTaskLoader
import com.google.android.gms.location.FusedLocationProviderClient
import com.google.android.gms.location.LocationServices
import com.google.android.gms.tasks.OnSuccessListener
import kotlinx.android.synthetic.main.activity_main.*
import java.util.*
class MainActivity : AppCompatActivity() {
lateinit var fusedLocationProviderClient: FusedLocationProviderClient
private val requestcode = 1
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
val button = findViewById<Button>(R.id.button)
fusedLocationProviderClient = LocationServices.getFusedLocationProviderClient(this)
button.setOnClickListener {
if (ActivityCompat.checkSelfPermission(
this,
Manifest.permission.ACCESS_FINE_LOCATION
) == PackageManager.PERMISSION_GRANTED && ActivityCompat.checkSelfPermission(
this,
Manifest.permission.ACCESS_COARSE_LOCATION
) == PackageManager.PERMISSION_GRANTED
) {
getlocation()
} else {
ActivityCompat.requestPermissions(
this,
arrayOf(
Manifest.permission.ACCESS_FINE_LOCATION,
Manifest.permission.ACCESS_COARSE_LOCATION
),
requestcode
)
return@setOnClickListener
}
}
}
private fun getlocation() {
fusedLocationProviderClient.lastLocation.addOnSuccessListener(this) { location ->
if (location != null) {
val lat = location.latitude
val long = location.longitude
val geocoder = Geocoder(this, Locale.getDefault())
try {
val address: List<Address> = geocoder.getFromLocation(lat, long, 1)
textview1.text = address[0].maxAddressLineIndex.toString()
textview2.text = address[0].getAddressLine(0).toString()
} catch (e: Exception) {
Toast.makeText(this, e.message.toString(), Toast.LENGTH_LONG).show()
}
} else {
Toast.makeText(this, "موقعیت پیدا نشد ", Toast.LENGTH_LONG).show()
}
}
}
}
那么,我的代码怎么了?grpc错误是什么意思?
如果我把地理代码放在后线程的问题会解决还是没有?
有人能帮忙吗?
我使用debug api键不释放。
谢谢你的帮助。
1条答案
按热度按时间mo49yndu1#
需要在应用程序的主线程之外调用geocoder。
地理编码器是同步的,可能需要很长时间才能完成它的工作,所以
should not call it from the main user interface (UI) thread
你的应用程序。尝试
AsyncTask
..还要检查你是否有良好的互联网和不使用代理。。