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虚拟定位,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我们网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

(0)

相关推荐

  • 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="and

  • Android Studio使用Profiler来完成内存泄漏的定位

    目标 使用Android Studio 4.1来完成内存泄漏的定位 目前网上大多数的文章都是在介绍Profile的使用,可以帮忙你检查出有内存泄漏,谁的内存泄漏.但是根据文章定位谁引起的这个泄漏,一直没有找到方法,通过几次努力,自己找到了比较容易的路径,希望对其他的朋友有帮助 引用 下面文章内使用的Demo在下面的地址 githubDemo 在页面内点击简单例子-> 内存泄漏-> 接着退回到上一个页面完成泄漏模拟 步骤 自己模拟一个内存泄漏 使用Profiler来完成内存泄漏的位置定位 模拟内

  • Mac Android Studio快捷键整理

    为了提高工作效率,特地的整理了MAC 版 Android Studio 快捷键的整理,如果后续还有,在继续补充! ⌥-> option|alt ⇧->shift ⌃->control ⌘->command ⎋->esc ↑↓←→ Code  alt+F7:Find usage alt+command+L:格式化代码 alt+control+O:优化import(去掉无用的import) command+O:Override Methods command+I:Implemen

  • Android Studio多渠道批量打包及代码混淆

    一.批量打包 1.集成了友盟统计,并在AndroidManifest.xml中添加了如下代码 <meta-data android:name="UMENG_CHANNEL" android:value="${CHANNEL_VALUE}"/> 2.在app的build.gradle的android标签下添加如下代码: productFlavors { myapp {} _360 {} appchina {} hiapk {} } productFlavo

  • Android studio 快捷键大全

    Android Studio常用快捷键.Android Studio快捷键大全 接下来这篇android studio使用教程,主要为大家介绍的是android studio快捷键,如果我们掌握了一些常用快捷键,那么在使用android studio的过程中会达到事半功倍的效果哦~ 下面我们步入正题,具体详情如下所示: Alt+回车 导入包,自动修正 Ctrl+N 查找类 Ctrl+Shift+N 查找文件 Ctrl+Alt+L 格式化代码 Ctrl+Alt+O 优化导入的类和包 Alt+Ins

  • Android studio 混淆+打包+验证是否成功

    前言: 单挑Android项目,最近即时通讯用到环信,集成sdk的时候 官方有一句 在 ProGuard 文件中加入以下 keep. -keep class com.hyphenate.** {*;} -dontwarn com.hyphenate.** 即:混淆规则. 自己没写过关于混淆打包的文章,在此补上. 下面了解Android studio环境下 项目混淆打包的操作. 一.打包: 即 将Android项目生成.apk文件,让用户去安装. 1.工具栏 Build->Generate Sig

  • 在Android Studio中使用BaiduMap SDK实时获取当地位置信息

    配置BaiduMap 环境 1.在百度API中新建自己的一个APP包名和APP名需要注意和自己Android Studio 中的包名和APP名保持一致: 2.百度地图中还需要填写一个SHA1 数字签名: a.输入keytool -list -v -keystore debug.keystore,会得到三种指纹证书,选取SHA1类型的证书(密钥口令是android),这个获取到的SHA1的值和ecplise中获取的值是一样的,是作为debug用的. b.输入keytool -list -v -ke

  • Android Studio 3.0 原生支持kotlin 例子详解

    安卓虽然已经成为了移动设备第一操作系统,且影响力也延伸到了汽车和tv端,不过对于谷歌来说,需要依靠Java来做安卓开发一直是一个心病,因为Oracle公司因为java和谷歌在安卓系统上的诉讼搞得心力憔悴. 现在好了,谷歌官方正式支持Kotlin(官方网站 https://kotlinlang.org/,居然没被墙)成为官方认可的安卓开发第一语言,而且从Android Studio 3.0开始,将直接集成Kotlin而无需安装任何的插件.这个语言是由JetBrains去年发明的,它受到欢迎,主要是

  • 详解Android studio ndk配置cmake开发native C

    Android 2.2 以后的版本对NDK的支持已经非常好了.最近把一个纯C的android项目,从eclipse ADT迁移到Android studio上.本文是参考Add C and C++ Code to Your Project官方文档(需要翻墙),经过各种尝试之后的总结. Android studio整合NDK开发,有两种模式,一种是ndk build,一种是cmake,如果是新项目官方推荐cmake.原来,ADT的时候只能用ndk build,这次切换IDE并没有选用ndk bui

  • Android Studio使用教程(三):常用快捷键

    Android Studio 1.0正式版发布啦 今天是个大日子,Android Studio 1.0 终于发布了正式版, 这对于Android开发者来说简直是喜大普奔的大消息啊,那么就果断来下载使用. 官方下载地址: http://developer.android.com/sdk/index.html 如果你之前已经使用其他版本的Studio,那么直接覆盖就好了,如果是第一次使用,那么参照Android Studio系列教程一进行安装配置. 于此同时一起更新的还有SDK Tools等,打开S

随机推荐