当前位置: 首页 > 编程笔记 >

android studio 使用Mocklocation虚拟定位

危璞
2023-03-14
本文向大家介绍android studio 使用Mocklocation虚拟定位,包括了android studio 使用Mocklocation虚拟定位的使用技巧和注意事项,需要的朋友参考一下

首先需要在 AndroidManifest.xml 文件中添加「获取模拟定位信息」权限。

<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模拟器的开发者权限

step1:找到安卓的setting点开

step2:拉到最底部,点击System,再拉到最底部找到关于手机,手机版本连续点击7次,返回上一层就有一个开发者选择

step3:点击Developer options,往下拉,找到select mock location app,点击你需要模拟定位的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;//点击按钮访问
 @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); // 经度(度)
   mockLocation.setAltitude(30); // 高程(米)
   mockLocation.setBearing(180); // 方向(度)
   mockLocation.setSpeed(10); //速度(米/秒)
   mockLocation.setAccuracy(0.1f); // 精度(米)
   mockLocation.setTime(10); // 本地时间
   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) {
   }
  };
  //获取到位置管理器实例
  mLocationManager = (LocationManager) getSystemService(Context.LOCATION_SERVICE);
  //获取到GPS_PROVIDER
  final Location location = mLocationManager.getLastKnownLocation(LocationManager.GPS_PROVIDER);
  //侦听位置发生变化,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) {
    // 当GPS Location Provider可用时,更新位置
    updata(mLocationManager.getLastKnownLocation(provider));
   }
   @Override
   public void onProviderDisabled(String provider) {
    // TODO Auto-generated method stub
   }
   @Override
   public void onLocationChanged(Location location) {
    // 当GPS定位信息发生改变时,更新位置
    String temp = updata(location);
    //postinfotoweb(temp);
   }
  });
  //创建发送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) {//监听按钮
    new Thread(new Runnable() {//创建子线程
     @Override
     public void run() {
      //getwebinfo();//把路径选到MainActivity中
      String temp = updata(location);
      System.out.println("location" + temp);
     }
    }).start();//启动子线程
   }
  });
  //更新位置信息显示到TextView
  String temp = updata(location);
  //postinfotoweb(temp);
 }
 private String updata(Location location){
  if(location != null){
   StringBuilder sb = new StringBuilder();
   sb.append("实时的位置信息:\n");
   sb.append("经度:");
   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当地时间:");
   sb.append(location.getTime());
   return sb.toString();
  }
  return null;
 }
}

总结

以上所述是小编给大家介绍的android studio 使用Mocklocation虚拟定位,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对小牛知识库网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

 类似资料:
  • 什么是虚拟资源(Virtual Resource),我们为什么需要它们? 下面我们来看一个可能会使用虚拟资源的典型例子。 你负责管理 facesquare 和 twitstagram 两个应用程序,他们都是运行在 Apache 上的 Web 应用程序。 facesquare 的定义看起来可能像这样: class app::facesquare { package { "apache2-mpm-

  • python 的虚拟环境可以为一个 python 项目提供独立的解释环境、依赖包等资源,既能够很好的隔离不同项目使用不同 python 版本带来的冲突,而且还能方便项目的发布。 virtualenv virtualenv可用于创建独立的 Python 环境,它会创建一个包含项目所必须要的执行文件。 安装 virtualenv $ pip install virtualenv 配置 pip 安装第

  • 定义和启用虚拟服务器 FreeRADIUS默认启用了两个虚拟服务器。 它们位于FreeRADIUS配置目录的已启用站点的子目录下。 他们是: default:该名称几乎说明了虚拟服务器的功能。 此虚拟服务器处理未明确指定由virtual_server指令处理的所有缺省请求。 到目前为止,我们一直使用这个虚拟服务器。 inner-tunnel:此虚拟服务器用于某些隧道式EAP请求,如TTLS和PEA

  • In 1974 computers were oppressive devices in far-off air-conditioned places. Now you can be oppressed in your own living room. — Ted Nelson 虽然能够在云中部署虚拟机是一个创举,但若能将虚拟机运行在你自己的桌面系统中有时甚至是更方便的, 尤其对于测试来说更是如此

  • 你的网站最终可能要用多台服务器提供的服务,模拟这种环境你可以在本地项目里定义多台虚拟机。在 Vagrant 配置文件(Vagrantfile)里,可以定义多台虚拟机,每台虚拟机都有自己的名字,各自独立的配置。比如你可以单独设置每台虚拟机的 IP 地址。你也可以单独控制某台虚拟机。 下面这个配置定义了两台虚拟机,web 与 db: Vagrant.configure("2") do |config|

  • 设置如下: 请求的时候也是统一了权限的。但是经纬度就是返回5e-324这种异常的