1.获取当前地理位置:

Android中提供了一个LocationManager的类,用于管理地理位置。不能通过构造函数获取该类的实例,而是通过Context的getSystemService():

LocationManager lm = (LocationManager) getSystemService(Context.LOCATION_SERVICE);

该类中有几个比较常用的方法:

getLastKnownLocation(String provider)用于根据传入的provider获取一个Location对象,该对象存储了地理位置信息,包括经度、纬度、海拔、速度等。provider指明采用何种方式获取地理位置信息,在LocationManager中定义了几个字符串常量,用于指定地理位置信息的提供者:

NETWORK_PROVIDER:采用网络的方式获取

GPS_PROVIDER:采用GPS获取

PASSIVE_PROVIDER:被动定位方式,当其他应用使用定位更新了定位信息,系统会保存下来,该应用接收到消息后直接读取就可以了

注意:在使用真机测试时,一定要走到室外。因为常用的定位方式是GPS或者NETWORK,但是在室内这两个基本没起作用,我刚开始还以为是代码的问题,后来走出去测试才发现代码没有问题。

获取地理位置信息之前,最好先查看下手机支持哪些定位方式,哪些是可用的,然后再选择一个可用的来定位:

getAllProviders()返回所有的地理位置提供者的所有字符串描述

getBestProvider()根据传入的评判准则,返回一个最佳的地理位置提供者的字符串描述,第二个参数设置为true,则返回所有可用中的最佳的;若为false则返回最佳的,不管是否可用。

getProviders()返回地理位置提供者的字符串描述,参数为true,则返回所有的可用的描述,false则返回所有的。

getProviders()根据传入的评判准则,及第二个参数标识是否可用,来返回地理位置提供者的字符串描述。

 List<String> providers = lm.getProviders(true);

         for(int i=0; i<providers.size();i++){

               System.out.println(providers.get(i));

 }

当前是GPS和PASSIVE方式可用:

 List<String> providers = lm.getProviders(true);

         String lp = null;

         if(providers.contains(LocationManager.GPS_PROVIDER)){

               lp = LocationManager.GPS_PROVIDER;

         }else if(providers.contains(LocationManager.NETWORK_PROVIDER)){

               lp = LocationManager.NETWORK_PROVIDER;

         }else{

               Toast.makeText(this, "当前没有获取地理位置的方式可用,请打开GPS", Toast.LENGTH_LONG).show();

       return;

 }

 Location loc = lm.getLastKnownLocation(lp);

获取了Location实例,就可以从中获取关心的地理信息了:

getLatitude():获取纬度信息,单位度

getLongitude():获取经度信息,单位度

getAltitude():获取海拔信息,单位米

getSpeed():获取速度信息,单位米/秒

getTime():获取时间信息,返回从1970.1.1到现在的毫秒数。

如:

Toast.makeText(MainActivity.this, "纬度:"+location.getLatitude()

                              +",经度:"+location.getLongitude()+",速度:"+location.getSpeed()+"m/s,"

                              +"海拔:"+location.getAltitude()+"米", 0).show();

以上,只能获取一次地理位置信息,如何动态实时地获取地理位置信息呢?

这就要用到LocationManager的requestLocationUpdates()方法:

该方法有多重重载形式,这里只简单试用下这种重载形式,参数说明:

provider:指定获取地理位置的方式;

minTime:指定监听位置变化的时间间隔,单位毫秒;

minDistance:指定监听位置变化的最小距离间隔,单位米;

listener:指定监听器,设置不同事件的回调处理。

注意:注册了监听器之后,但应用退出时,应当将注册的监听器移除,可以选择在Activity的onDestroy()方法中,调用LocationManager的removeUpdates(listener)方法,来将requestLocationUpdates()注册的事件监听移除。

如:

 listener = new LocationListener() {

                  @Override

                  public void onStatusChanged(String provider, int status, Bundle extras) {

                       // TODO Auto-generated method stub

                       Toast.makeText(MainActivity.this, "onStatusChanged", 0).show();

                  }

                  @Override

                  public void onProviderEnabled(String provider) {

                       // TODO Auto-generated method stub

                       Toast.makeText(MainActivity.this, "onProviderEnabled", 0).show();

                  }

                  @Override

                  public void onProviderDisabled(String provider) {

                       // TODO Auto-generated method stub

                       Toast.makeText(MainActivity.this, "onProviderDisabled", 0).show();

                  }

                  @Override

                  public void onLocationChanged(Location location) {

                       // TODO Auto-generated method stub

                       tv_lat.setText(location.getLatitude()+"");

                    tv_lng.setText(location.getLongitude()+"");

                    Toast.makeText(MainActivity.this, "纬度:"+location.getLatitude()

                               +",经度:"+location.getLongitude()+",速度:"+location.getSpeed()+"m/s,"

                               +"海拔:"+location.getAltitude()+"米", 0).show();

                  }

            };

 lm.requestLocationUpdates(LocationManager.GPS_PROVIDER, 5000, 1, listener);

每隔5秒监测下位置的变化情况,一旦距离变化超过1米,就会回调onLocationChanged()方法,并将新的Location实例作为参数传入该方法。

以上,就是简单的获取地理位置的方法,帮助文档中关于LocationManager还有其他一些可能也会用到的方法,如临近警告,测距等,在用到的时候可以再查阅。

2.百度地图控制器的简单使用,设置地图的旋转,缩放,及视角变化:

跟2.x版本不同,之前在控制器中直接就可以调用各个方法进行旋转、缩放等操作,新版的控制器类名为BaiduMap,这里要用到的是它的animateMapStatus()方法:

所有要执行的旋转、缩放等动作没有直接对应的方法,而是把这些地图状态变化的动作封装到MapStatusUpdate对象中,然后传递给BaiduMap的animateMapStatus()以动画的方式执行动作。

所以,这里的关键是获取MapStatusUpdate对象,封装要执行的动作。

但是,查看帮助文档中,MapStatusUpdate类没有任何实际的帮助信息……

但是,有几个相关的类:MapStatus、MapStatus.Builder、MapStatusUpdateFactory。

首先看MapStatus:

有这么几个字段,用于存放地图状态信息,注意文档中说明zoom的取值范围为3-20,overlook的取值是-45-0。但是没有对应的设置方法,所以猜测应该在其内部类Builder中存在相关设置方法

MapStatus.Builder:

构造方法,第二个带参的构造应该会比较有用,要进行地图状态变化,肯定要有一个参照,是在当前状态基础之上进行旋转缩放等。

build()方法返回一个MapStatus对象,如同之前常用到的android中的Builder内部类一样,在进行完一连串的设置之后,最后调用该方法得到一个需要的MapStatus对象。

overlook()方法,设置地图视角,传入一个-45~0的float值

rotate()方法,设置逆时针旋转角度

target()方法,设置地图中心店

targetScreen()方法设置地图中心点在屏幕的坐标

zoom()方法,设置地图的缩放级别。

通过MapStatus.Builder就能获取一个MapStatus对象了,但是需要的却是MapStausUpdate对象。

继续看下一个类:

MapStatusUpdateFactory类:

MapStatusUpdate的工厂类,通过它可以获取到需要的MapStatusUpdate对象:

newMapStatus()方法,可以根据传入的MapStatus获取一个MapStatusUpdate对象;

zoomIn()方法:返回一个放大地图缩放级别的MapStatusUpdate对象

zoomOut()方法:返回一个缩小地图缩放级别的MapStatusUpdate对象

zoomTo()方法:返回一个到指定缩放级别的MapStatusUpdate对象

下面根据这几个类,试着进行地图的旋转、缩放、设置中心点及视角变化:

1)设置缩放级别:

修改布局文件,在MapView下方添加几个控件,用于控制地图缩放:

 <LinearLayout

         android:orientation="horizontal"

         android:layout_width="match_parent"

         android:layout_height="wrap_content"

         >

         <EditText

             android:id="@+id/et_level"

             android:layout_height="wrap_content"

             android:layout_width="0dp"

             android:layout_weight="1"

             android:inputType="number"

             android:hint="@string/et_hint"

             />

         <Button

             android:id="@+id/btn_set"

             android:layout_height="wrap_content"

             android:layout_width="0dp"

             android:layout_weight="1"

             android:onClick="zoomTo"

             android:text="@string/btn_set_text"

             />

         <Button

             android:id="@+id/btn_in"

             android:layout_height="wrap_content"

             android:layout_width="0dp"

             android:layout_weight="1"

             android:onClick="zoomIn"

             android:text="@string/btn_text_in"/>

         <Button

             android:id="@+id/btn_out"

             android:layout_height="wrap_content"

             android:layout_width="0dp"

             android:layout_weight="1"

             android:onClick="zoomOut"

             android:text="@string/btn_out_text"

             />

 </LinearLayout>

修改MainActivity.java添加按钮回调方法:

 public class MainActivity extends Activity {

   private static final String TAG = "MainActivity";

   private EditText et_level;

   private Button btn_set, btn_in, btn_out;

   private MapView mv;

   private BaiduMap map;

     @Override

     protected void onCreate(Bundle savedInstanceState) {

         super.onCreate(savedInstanceState);

         SDKInitializer.initialize(getApplicationContext());

         setContentView(R.layout.activity_main);

         mv = (MapView) findViewById(R.id.mv);

         et_level = (EditText) findViewById(R.id.et_level);

         map.setOnMapLoadedCallback(new OnMapLoadedCallback() {

              @Override

              public void onMapLoaded() {

                    mv.setScaleControlPosition(new Point(20,20));

                 mv.setZoomControlsPosition(new Point(150,50));

              }

         });

     }

     public void zoomTo(View view){

       try {

             String s_level = et_level.getText().toString();

           float level = Float.parseFloat(s_level);

              MapStatusUpdate zt = MapStatusUpdateFactory.zoomTo(level);

              map.animateMapStatus(zt);

         } catch (NumberFormatException e) {

              Toast.makeText(this, "请输入正确的缩放级别", Toast.LENGTH_SHORT).show();

         }

     }

     public void zoomIn(View view){

       MapStatusUpdate zi = MapStatusUpdateFactory.zoomIn();

       map.animateMapStatus(zi);

     }

     public void zoomOut(View view){

       MapStatusUpdate zo = MapStatusUpdateFactory.zoomOut();

       map.animateMapStatus(zo);

     }

   @Override

   protected void onResume() {

         // TODO Auto-generated method stub

         super.onResume();

         mv.onResume();

   }

   @Override

   protected void onPause() {

         // TODO Auto-generated method stub

         super.onPause();

         mv.onPause();

   }

   @Override

   protected void onDestroy() {

         // TODO Auto-generated method stub

         super.onDestroy();

         mv.onDestroy();

   }

 }

运行效果:

2)设置地图中心点:

map.animateMapStatus(MapStatusUpdateFactory.newLatLng(new LatLng(30.757, 103.9339)));

运行结果:

3)旋转地图:

修改布局文件,添加一个旋转按钮:

 <Button

             android:id="@+id/btn_rot"

             android:layout_width="0dp"

             android:layout_height="wrap_content"

             android:layout_weight="1"

             android:onClick="rotate"

             android:text="@string/btn_rot_text"

             />

修改MainActivity.java,添加旋转按钮的回调:

 public void rotate(View view){

           float r = map.getMapStatus().rotate;

           MapStatus ms = new MapStatus.Builder(map.getMapStatus()).rotate(r+30).build();

           map.animateMapStatus(MapStatusUpdateFactory.newMapStatus(ms));

 }

运行结果:

4)设置视角:

修改布局文件:

 <Button

             android:id="@+id/btn_up"

             android:layout_height="wrap_content"

             android:layout_width="0dp"

             android:layout_weight="1"

             android:onClick="overlook"

             android:text="@string/btn_up_text"/>

         <Button

             android:id="@+id/btn_down"

             android:layout_height="wrap_content"

             android:layout_width="0dp"

             android:layout_weight="1"

             android:onClick="overlook"

             android:text="@string/btn_down_text"

             />

修改MainActivity.java:添加修改视角的按钮的回调:

 public void overlook(View view){

           float f = map.getMapStatus().overlook;

           MapStatus ms = null;

           if(view.getId() == R.id.btn_up){

                ms = new MapStatus.Builder(map.getMapStatus()).overlook(f+10).build();

           }else{

                ms = new MapStatus.Builder(map.getMapStatus()).overlook(f-10).build();

           }

           map.animateMapStatus(MapStatusUpdateFactory.newMapStatus(ms));

 }

运行结果:

android菜鸟学习笔记31----Android使用百度地图API(二)获取地理位置及地图控制器的简单使用的更多相关文章

  1. android菜鸟学习笔记30----Android使用百度地图API(一)准备工作及在应用中显示地图

    1.准备工作: 百度地图API是免费开放的,但是需要申请API Key: 1)先注册一个百度开发者帐号 2)进入百度开放服务平台http://developer.baidu.com/ 3)进入LBS云 ...

  2. android菜鸟学习笔记29----Android应用向用户发送提示信息的方式总结

    常见的向用户发送提示信息的方式有3种,分别为: 1)发送Toast信息 2)弹出对话框 3)发送通知 总结如下: 方式1:发送Toast信息: 这种方式最简单,在之前的学习中多次使用过.Toast是在 ...

  3. android菜鸟学习笔记24----与服务器端交互(一)使用HttpURLConnection和HttpClient请求服务端数据

    主要是基于HTTP协议与服务端进行交互. 涉及到的类和接口有:URL.HttpURLConnection.HttpClient等 URL: 使用一个String类型的url构造一个URL对象,如: U ...

  4. android菜鸟学习笔记21----ContentProvider(一)ContentProvider的简单使用

    ContentProvider是Android四大组件之一,它用来封装数据,并通过ContentResolver接口将数据提供给其他应用.只有当需要在多个应用之间共享数据时才会用到ContentPro ...

  5. android菜鸟学习笔记7----android布局(二)

    3.FrameLayout:帧布局 如同Flash或者photoshop中图层的概念,在上面的图层遮盖下面的图层,没被遮到的地方仍然显示出来. 右击res/layout,然后在弹出的菜单中选择new, ...

  6. android菜鸟学习笔记2----关于adb

    adb : android debug bridge android调试桥 路径:adt-bundle目录/sdk/platform-tools/adb.exe 常见的adb命令: adb devic ...

  7. android菜鸟学习笔记28----Android中的Service生命周期及本地和远程服务绑定的实现

    Service是Android中长期在后台运行的没有界面的组件,使用服务的优势在于:能够提高进程的优先级,系统不容易回收掉进程,即便回收了,内存充足的时候,会把进程重新创建. 1.服务的简单使用示例: ...

  8. android菜鸟学习笔记17----Android数据存储(一)文件读写

    假如有如下需求,要求能够记录用户输入的用户名和密码,下次登录时,能直接获取之前保存的用户名密码,并在相应的EditText中显示. 要保存用户输入的数据,最先想到的应该就是文件读写了. 通过对andr ...

  9. android菜鸟学习笔记15----Android Junit测试

    Android中的Junit测试与Java Junit测试有所不同,不能简单的使用标注…… 假设写了一个MathUtils类,有两个静态方法: public class MathUtils { pub ...

随机推荐

  1. python——二进制/十进制等转换

    To 十进制 八进制: >>> int('10', 8) ->8   To 十六进制: 十进制: >>> hex(12) ->‘0xc’ 二进制: &g ...

  2. javascript入门系列演示·三种弹出对话框的用法实例

    对话框有三种 1:只是提醒,不能对脚本产生任何改变: 2:一般用于确认,返回 true 或者 false ,所以可以轻松用于 if...else...判断 3: 一个带输入的对话框,可以返回用户填入的 ...

  3. 更改字段、添加字段脚本以及sql回滚

    --修改字段名称 EXEC sp_rename '[dbo].[SysMenu].[Type]', 'Position', 'COLUMN' --添加字段 alter table [dbo].[Age ...

  4. SpringCloud系列十二:手动创建Feign

    1. 回顾 上文讲解了自定义Feign.但是在某些场景下,前文自定义Feign的方式满足不了需求,此时可使用Feign Builder API手动创建Feign. 本文围绕以下场景,为大家讲解如何手动 ...

  5. unity, iOS下画面错乱解法

    unity版本号为5.1.1f1 Personal 在ipod5,系统为iOS7.1上测试.发现下面两种出现画面错乱的问题: 一,退后台在返回前台时画面发生错乱(错乱持续一两秒,然后变为正常).   ...

  6. android studio- Gradle "xxx" project refresh failed

    Android Studio每次更新版本都会更新Gradle这个插件,但由于长城的问题每次更新都是失败,又是停止在Refreshing Gradle Project ,有时新建项目的时候报 Gradl ...

  7. nginx日志配置指令详解

    这篇文章主要介绍了nginx日志配置指令详解,nginx有一个非常灵活的日志记录模式,每个级别的配置可以有各自独立的访问日志,需要的朋友可以参考下日志对于统计排错来说非常有利的.本文总结了nginx日 ...

  8. python模块学习之os

    16.1. os-复杂的操作系统接口 Source code: Lib/os.py 该模块提供了使用操作系统相关功能的便携式方法. 如果您只想读或写一个文件,请参阅open(),如果要操作路径,请参阅 ...

  9. (html)前端如何验证token的合法性来判断用户是否登录?

    问题: (html)前端如何验证token的合法性来判断用户是否登录?描述: 1.我使用了JWT的方式,后端生成了一个token,将其返回给前端,前端获取到后每次请求接口都附带上这个token,后端来 ...

  10. 使用pycharm手动搭建python语言django开发环境(三) 使用django的apps应用 添加应用静态文件

    1)在django 工程目录中使用cmd命令行 敲入"python manage.py startapp app名称(例子为blog)" 2)在django工程目录中应该生成了bl ...