Android學習筆記之使用百度地圖實現地圖控制


PS:吾之榮耀,離別已久.

 

學習內容:

1.實現地圖控制.

2.百度地圖開發的一些細節

 

  1.實現地圖控制:

  這一篇主要寫在百度地圖上添加一些其他控制.上一篇書寫了覆蓋物的添加,地理編碼和反地理編碼,還有如何實現定位.那么這一篇主要是說一下實現地圖控制,以及一些細節.由於我也是看着牛人的博客學習的.因此可能有點雜亂無章.

  MapView.

  地圖控制主要是通過使用MapView類中的一些相關函數來實現地圖控制.這里的實現地圖控制主要是控制Map上的View視圖.在Map上添加或者移除一個View.控制縮放控件和比例尺控件,設置縮放控件和比例尺的相關位置.默認的情況下,MapView是自帶縮放控件和比例尺的.

//不顯示縮放按鈕和比例尺
mapView.showZoomControls(false);
mapView.showScaleControl(false);

  設置縮放控件和比例尺的相關位置

mapView.setZoomControlsPosition(new Point(150,60));
mapView.setScaleControlsPosition(new Point(150,60));

  這里還需要說明一點就是關於MapView的生命周期問題.MapView的生命周期和當前的Activity是緊密關聯的.因此我們需要在Activity當中去設置MapView的生命周期.同時在使用MapView控件的時候必須要使用SDKInitializer.initialize(Context)函數去提供全局的Context信息.

  MapView的內部函數其實並不是非常的多.也就這么幾種View的相應控制,以及生命周期函數的設定.例舉一下內部的相關函數.

mapView.addView(View child,LayoutParams params); //在地圖上添加子View.並設置相關的參數.
mapView.onDestory(); //生命周期函數,當Activity被銷毀的時候.地圖控件也被銷毀.
mapView.onPause(); //生命周期函數
mapView.onResume(); //生命周期函數
mapView.remove(View view);  //移除MapView上的View視圖.
mapView.onLayout(boolean changed,int l,int t,int r,int b); //個人認為是指定mapView的布局.官方API沒給出解釋.

  BaiduMap的監聽事件控制

  在地圖上我們可以設置相關的監聽函數.監聽的接口如下:

  setOnMapClickListener(OnMapClickListener)  點擊函數.

bdMap.setOnMapClickListener(new OnMapClickListener() {
            
            @Override
            public boolean onMapPoiClick(MapPoi arg0) {
                // TODO Auto-generated method stub
                return false;
            }
            
            @Override
            public void onMapClick(LatLng arg0) {
                // TODO Auto-generated method stub
                //設置地圖中心點
                msu = msuFactory.newLatLng(arg0);
                bdMap.animateMapStatus(msu);
                Toast.makeText(getApplicationContext(), "地圖中心點移動到"+arg0.toString(), Toast.LENGTH_SHORT).show();
            }
        });

  setOnMapDoubleClickListener(OnMapClickListener) 雙擊函數.

    bdMap.setOnMapDoubleClickListener(new OnMapDoubleClickListener() {
            @Override
            public void onMapDoubleClick(LatLng arg0) {

            }
    });

  setOnMapLongClickListener(OnMapClickListener) 長按函數.

 setOnMapStatusChangerListener(OnMapStatusChangerListener) 地圖狀態變化的監聽函數.

 這兩個就不列舉了.主要是BaiduMap的兩個

 void animateMapStatus(MapStatusUpdate status)

 void animateMapStatus(MapStatusUpdate update int duration)

 這兩個函數表示當地圖狀態發生變化的時候.以動畫的形式進行改變.第一個函數沒有指定動畫的時間.默認時間為300毫秒.第二個則是指定時間的動畫.傳遞的參數則是MapStatusUpdate參數.不難看出這個類的含義就是當地圖狀態發生改變時的更新狀態.需要將這個改變的狀態封裝成MapStatusUpdate對象.然后通過使用animateMapStatus()函數去完成這個變化. MapStatusUpdate是一個靜態類.因此實例化對象的方式采用MapStatusUpdateFactory工廠來完成對象的實例化. 這個類的內部函數還是非常的多的.我們可以通過使用內部的函數構造出各種各樣的MapStatusUpdate對象..

  還是傳一張圖吧.手打真傷不起..

 縮小地圖(縮小一個級別)

msu = msuFactory.zoomOut();
bdMap.animateMapStatus(msu);

 放大地圖(放大一個級別)

msu = msuFactory.zoomIn();
bdMap.animateMapStatus(msu);

 設置地圖中心點

msu = msuFactory.newLatLng(arg0);
bdMap.animateMapStatus(msu);

 其他函數就不一一列舉了.我們可以看到這個類的內部存在一個newMapStatus(MapStatus status)函數.這個函數是將MapStatus封裝成MapStatusUpdate,然后通過調用animateMapStatus(msu);同樣可以完成一個地圖的狀態更新.那么就不得不說一下MapStatus了.這個類的相關函數如下:

 這個類可以設置地圖的旋轉和俯視效果.設置了相關效果之后.將MapStatus封裝成MapStatusUpdate對象.就可以實現旋轉和俯視效果的地圖狀態更新了.實現方式:

 設置了一個旋轉效果的地圖狀態.

mapStatus = new MapStatus.Builder(bdMap.getMapStatus()).rotate(rotateAngle +=30).build();
msu = msuFactory.newMapStatus(mapStatus);
bdMap.animateMapStatus(msu);

 設置了一個俯視效果的地圖狀態.

mapStatus = new MapStatus.Builder(bdMap.getMapStatus()).overlook(overlookAngle -=10).build();
msu = msuFactory.newMapStatus(mapStatus);
bdMap.animateMapStatus(msu);

 這樣通過定義MapStatus對象也能夠實現一些地圖狀態的控制.最后再說一個關於地圖截圖的問題.個人感覺有點不是非常的使用了.現如今的手機都可以通過快捷鍵去直接實現截屏功能.這個功能就有點不怎么適用了.既然說了,那么還是要簡單的說一下.

 實現地圖的截圖需要使用以下函數.

 snapshot()函數..SnapshotReadyCallback()為其回調接口.截屏之后我們還可以對截取到的圖片進行數據的保存.

bdMap.snapshot(new SnapshotReadyCallback() {
                
                @Override
                public void onSnapshotReady(Bitmap bitmap) {
                    // TODO Auto-generated method stub
                    File file = new File("/mnt/sdcard/test.png");
                    FileOutputStream fos = null;
                    try {
                        fos = new FileOutputStream(file);
                        if(bitmap.compress(Bitmap.CompressFormat.JPEG, 100, fos)){
                            fos.flush();
                            fos.close();
                        }
                        Toast.makeText(MapControllActivity.this,"屏幕截圖成功,圖片存在: " + file.toString(),Toast.LENGTH_SHORT).show();

                    } catch (Exception e) {
                        // TODO Auto-generated catch block
                        e.printStackTrace();
                    }
                }
            });

 2.百度地圖開發的一些其他細節.

 也算是對自己昨天寫的東西進行一些相關的補充.上一篇博客寫了關於定位的功能.也就是使用LocationClient去實現客戶端定位.同時也說了一下內部的監聽函數.實現定位首先需要初始化對象.然后注冊定位監聽.然后設置相關的定位參數.最后開始定位就可以了.

 只是忘記了說另一個監聽函數:

 NotifyListener()

 注冊位置提醒監聽.位置提醒一般表示的是我們設置了某一位置,當我們快要到達這個位置的時候,開啟位置監聽.可以通過振動的方式來提示我們已經到達了這個位置的附近.因此這個監聽的注冊是否必要取決於我們的需求.

 並且設置了這些相關監聽的同時,我們需要在最后去釋放這些監聽.

 釋放的方式:重寫onDestory函數去釋放.

    @Override  
        protected void onDestroy() {  
            super.onDestroy();  
            mapview.onDestroy();  
            locationClient.unRegisterLocationListener(locationListener);  
            //取消位置提醒  
            locationClient.removeNotifyEvent(notifyListener);  
            locationClient.stop();  
        }  
class MyNotifyListener extends BDNotifyListener {
        @Override
        public void onNotify(BDLocation bdLocation, float distance) {
            super.onNotify(bdLocation, distance);
            mVibrator.vibrate(1000);//振動提醒已到設定位置附近
            Toast.makeText(LocationActivity.this, "震動提醒", Toast.LENGTH_SHORT).show();
        }
    }

 LocationOptions的相關補充.

 LocationOptions表示的是定位參數.我們在定位的時候可以通過設置相關的參數去完善定位.

 還要說一下這個定位模式的問題:

 1. 高精度定位模式:同時使用網絡定位和GPS定位,優先返回最高精度的定位結果。

 

 2. 低功耗定位模式:不使用GPS,只使用網絡定位(WiFi和基站)。

 

 3. 僅用設備定位模式: 不適用網絡定位,只使用GPS進行定位。但是此模式下不支持室內環境的定位。

 LocationOptions的一些相關函數:

LocationClientOption locOption = new LocationClientOption();
locOption.setLocationMode(LocationMode.Hight_Accuracy);// 設置定位模式
locOption.setCoorType("bd09ll");// 設置定位結果類型
locOption.setScanSpan(5000);// 設置發起定位請求的間隔時間,ms
locOption.setIsNeedAddress(true);// 返回的定位結果包含地址信息
locOption.setNeedDeviceDirect(true);// 設置返回結果包含手機的方向

 還有關於定位是否能夠成功.還是發生了失敗的原因,我們可以通過使用getLocType()這個方法獲取到,返回的值為int類型.

  通過這個值我們就可以判斷我們的定位是否成功,並且如果發生了錯誤,我們可以通過捕捉這個int數據來判斷我們在什么位置上發生了錯誤.通過這個錯誤信息我們就可以去調試.還是比較方便的.

 總體也就這么多了.最后再放上一個代碼.方便大家去研究.

 http://files.cnblogs.com/files/RGogoing/Map_1.rar

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM