android studio 使用Mocklocation虛擬定位
首先需要在 AndroidManifest.xml 文件中添加「獲取模擬定位信息」權(quán)限。
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/> <uses-permission android:name="android.permission.INTERNET"/> <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/> <uses-permission android:name="android.permission.ACCESS_MOCK_LOCATION" tools:ignore="MockLocation"/> <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAG"/>
然后需要打開android studio模擬器的開發(fā)者權(quán)限
step1:找到安卓的setting點(diǎn)開

step2:拉到最底部,點(diǎn)擊System,再拉到最底部找到關(guān)于手機(jī),手機(jī)版本連續(xù)點(diǎn)擊7次,返回上一層就有一個(gè)開發(fā)者選擇

step3:點(diǎn)擊Developer options,往下拉,找到select mock location app,點(diǎn)擊你需要模擬定位的app就行了。

具體app的代碼,我直接貼出來了
import android.location.Criteria;
import android.location.LocationProvider;
import android.os.Build;
import android.os.Bundle;
import android.os.SystemClock;
import android.provider.Settings;
import android.widget.TextView;
import android.location.Location;
import android.location.LocationListener;
import android.location.LocationManager;
import android.app.Activity;
import android.content.Context;
import android.view.View;
import android.widget.Button;
import java.util.Date;
public class MainActivity extends Activity {
private TextView tv;//用于顯示信息的TextView
private LocationManager mLocationManager;//位置管理器
private Button btn;//點(diǎn)擊按鈕訪問
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
boolean hasAddTestProvider = false;
LocationManager locationManager = (LocationManager) getSystemService(Context.LOCATION_SERVICE);
boolean canMockPosition = (Settings.Secure.getInt(getContentResolver(), Settings.Secure.ALLOW_MOCK_LOCATION, 0) != 0 || Build.VERSION.SDK_INT > 22);
if (canMockPosition && hasAddTestProvider == false)
try {
String providerStr = LocationManager.GPS_PROVIDER;
LocationProvider provider = locationManager.getProvider(providerStr);
if (provider != null) {
locationManager.addTestProvider(
provider.getName()
, provider.requiresNetwork()
, provider.requiresSatellite()
, provider.requiresCell()
, provider.hasMonetaryCost()
, provider.supportsAltitude()
, provider.supportsSpeed()
, provider.supportsBearing()
, provider.getPowerRequirement()
, provider.getAccuracy());
} else {
locationManager.addTestProvider(
providerStr
, true, true, false, false, true, true, true
, Criteria.POWER_HIGH, Criteria.ACCURACY_FINE);
}
locationManager.setTestProviderEnabled(providerStr, true);
locationManager.setTestProviderStatus(providerStr, LocationProvider.AVAILABLE, null, System.currentTimeMillis());
// 模擬位置可用
hasAddTestProvider = true;
canMockPosition = true;
} catch (SecurityException e) {
canMockPosition = false;
}
if (hasAddTestProvider == true) {
String providerStr = LocationManager.GPS_PROVIDER;
Location mockLocation = new Location(providerStr);
mockLocation.setLatitude(22); // 維度(度)
mockLocation.setLongitude(113); // 經(jīng)度(度)
mockLocation.setAltitude(30); // 高程(米)
mockLocation.setBearing(180); // 方向(度)
mockLocation.setSpeed(10); //速度(米/秒)
mockLocation.setAccuracy(0.1f); // 精度(米)
mockLocation.setTime(10); // 本地時(shí)間
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.JELLY_BEAN_MR1) {
mockLocation.setElapsedRealtimeNanos(SystemClock.elapsedRealtimeNanos());
}
locationManager.setTestProviderLocation(providerStr, mockLocation);
}
else {
System.out.println("hasAddTestProvider" + hasAddTestProvider);
}
LocationManager locMgr = (LocationManager)
getSystemService(LOCATION_SERVICE);
LocationListener lis = new LocationListener() {
public void onLocationChanged(Location location) {
//You will get the mock location
}
@Override
public void onStatusChanged(String s, int i, Bundle bundle) {
}
@Override
public void onProviderEnabled(String s) {
}
@Override
public void onProviderDisabled(String s) {
}
};
//獲取到位置管理器實(shí)例
mLocationManager = (LocationManager) getSystemService(Context.LOCATION_SERVICE);
//獲取到GPS_PROVIDER
final Location location = mLocationManager.getLastKnownLocation(LocationManager.GPS_PROVIDER);
//偵聽位置發(fā)生變化,2000毫秒更新一次,位置超過8米也更新一次
mLocationManager.requestLocationUpdates(LocationManager.GPS_PROVIDER, 2000, 8, new LocationListener() {
@Override
public void onStatusChanged(String provider, int status, Bundle extras) {
// TODO Auto-generated method stub
}
@Override
public void onProviderEnabled(String provider) {
// 當(dāng)GPS Location Provider可用時(shí),更新位置
updata(mLocationManager.getLastKnownLocation(provider));
}
@Override
public void onProviderDisabled(String provider) {
// TODO Auto-generated method stub
}
@Override
public void onLocationChanged(Location location) {
// 當(dāng)GPS定位信息發(fā)生改變時(shí),更新位置
String temp = updata(location);
//postinfotoweb(temp);
}
});
//創(chuàng)建發(fā)送http請求的按鈕
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
btn = findViewById(R.id.main_btn);//綁定ID
btn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {//監(jiān)聽按鈕
new Thread(new Runnable() {//創(chuàng)建子線程
@Override
public void run() {
//getwebinfo();//把路徑選到MainActivity中
String temp = updata(location);
System.out.println("location" + temp);
}
}).start();//啟動(dòng)子線程
}
});
//更新位置信息顯示到TextView
String temp = updata(location);
//postinfotoweb(temp);
}
private String updata(Location location){
if(location != null){
StringBuilder sb = new StringBuilder();
sb.append("實(shí)時(shí)的位置信息:\n");
sb.append("經(jīng)度:");
sb.append(location.getLongitude());
sb.append("\n緯度:");
sb.append(location.getLatitude());
sb.append("\n高度:");
sb.append(location.getAltitude());
sb.append("\n速度:");
sb.append(location.getSpeed());
sb.append("\n方向:");
sb.append(location.getBearing());
sb.append("\n當(dāng)?shù)貢r(shí)間:");
sb.append(location.getTime());
return sb.toString();
}
return null;
}
}
總結(jié)
以上所述是小編給大家介紹的android studio 使用Mocklocation虛擬定位,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
相關(guān)文章
Flutter自動(dòng)路由插件auto_route使用詳解
這篇文章主要為大家介紹了Flutter自動(dòng)路由插件auto_route的基本使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08
Android中invalidate()和postInvalidate() 的區(qū)別及使用方法
Android中實(shí)現(xiàn)view的更新有兩組方法,一組是invalidate,另一組是postInvalidate,其中前者是在UI線程自身中使用,而后者在非UI線程中使用。本文給大家介紹Android中invalidate()和postInvalidate() 的區(qū)別及使用方法,感興趣的朋友一起學(xué)習(xí)吧2016-05-05
Android仿Keep運(yùn)動(dòng)休息倒計(jì)時(shí)圓形控件
這篇文章主要為大家詳細(xì)介紹了Android仿Keep運(yùn)動(dòng)休息倒計(jì)時(shí)圓形控件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-09-09
Android解析JSON格式數(shù)據(jù)的兩種方式(JSONObject和Gson)
json數(shù)據(jù)的解析相對而言,還是比較容易的,實(shí)現(xiàn)的代碼也十分簡單,下面這篇文章主要給大家介紹了關(guān)于Android解析JSON格式數(shù)據(jù)的兩種方式,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-07-07
第1個(gè)Android應(yīng)用程序 Android制作簡單單頁導(dǎo)航
這篇文章主要為大家詳細(xì)介紹了第1個(gè)Android應(yīng)用程序PhonewordApp:Android制作簡單單頁導(dǎo)航,感興趣的小伙伴們可以參考一下2016-06-06
Android編程實(shí)現(xiàn)使用SoundPool播放音樂的方法
這篇文章主要介紹了Android編程實(shí)現(xiàn)使用SoundPool播放音樂的方法,較為詳細(xì)的分析說明了SoundPool對象的使用技巧,需要的朋友可以參考下2016-01-01
Android仿iOS側(cè)滑退出當(dāng)前界面功能
這篇文章主要為大家詳細(xì)介紹了Android仿iOS側(cè)滑退出當(dāng)前界面功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-12-12
Android實(shí)現(xiàn)阿里云oss上傳流程解析
這篇文章主要介紹了Android實(shí)現(xiàn)阿里云oss上傳流程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09

