zoukankan      html  css  js  c++  java
  • arcgis android 图上记录gps轨迹

    原文  arcgis android 图上记录gps轨迹

    public class MainActivity extends Activity {
    
        MapView mMapView;
        LocationDisplayManager lDisplayManager = null;
        GraphicsLayer gpsGraphicsLayer;
        Polyline mPolyline;
        int pointCount = 0;
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
            // after the content of this activity is set
            // the map can be accessed from the layout
            mMapView = (MapView) findViewById(R.id.map);
            ArcGISTiledMapServiceLayer tile = new ArcGISTiledMapServiceLayer("http://map.geoq.cn/ArcGIS/rest/services/ChinaOnlineCommunity_Mobile/MapServer");
            mMapView.addLayer(tile);
            gpsGraphicsLayer = new GraphicsLayer();
            mMapView.addLayer(gpsGraphicsLayer);
            mPolyline = new Polyline();
            mMapView.setOnStatusChangedListener(new OnStatusChangedListener() {
                @Override
                public void onStatusChanged(Object source, STATUS status) {
                    if (source == mMapView && status == STATUS.INITIALIZED) {
                        lDisplayManager = mMapView.getLocationDisplayManager();//获取LocationDisplayManager
                        lDisplayManager.setAutoPanMode(LocationDisplayManager.AutoPanMode.OFF);
                        lDisplayManager.setShowLocation(false);//不显示当前位置,坐标系不一致坐标偏移严重
                        lDisplayManager.setShowPings(false);
                        lDisplayManager.setAccuracyCircleOn(false);
                        lDisplayManager.setAllowNetworkLocation(true);
                        lDisplayManager.setLocationListener(new LocationListener() {
                            @Override
                            public void onLocationChanged(Location loc) {
                                //火星坐标转换
                                double[] gcj = CoordinateConvert.wgs2GCJ(loc.getLatitude(), loc.getLongitude());
    
                                Point wgspoint = new Point(gcj[1], gcj[0]);
                                Point p = (Point) GeometryEngine.project(wgspoint,
                                        SpatialReference.create(SpatialReference.WKID_WGS84),
                                        mMapView.getSpatialReference());
                                SimpleMarkerSymbol ptSym = new SimpleMarkerSymbol(Color.BLUE, 15,
                                        SimpleMarkerSymbol.STYLE.CIRCLE);
                                Graphic graphic = new Graphic(p, ptSym, null);
                                if (pointCount == 0) {
                                    mPolyline.startPath(p.getX(), p.getY());
                                    mMapView.zoomTo(p, 17);
                                } else {
                                    mPolyline.lineTo(p.getX(), p.getY());//点画线
                                    mMapView.centerAt(p, true);
                                }
                                gpsGraphicsLayer.removeAll();
                                SimpleLineSymbol lineSym = new SimpleLineSymbol(Color.RED, 10);
                                Graphic g = new Graphic(mPolyline, lineSym);
                                gpsGraphicsLayer.addGraphic(g);
                                pointCount++;
    
                                gpsGraphicsLayer.addGraphic(graphic);
                            }
    
                            @Override
                            public void onProviderDisabled(String arg0) {
                            }
    
                            @Override
                            public void onProviderEnabled(String arg0) {
                            }
    
                            @Override
                            public void onStatusChanged(String arg0, int arg1,
                                                        Bundle arg2) {
    
                            }
                        });  // Actionlistener
    
                        lDisplayManager.start();
                    }
                }
            });
    
    
        }
    
    }
  • 相关阅读:
    数据库中Schema和Database有什么区别
    VS2015智能提示由英文改为中文
    分配数据库角色权限
    【转载】使用局部标准差实现图像的局部对比度增强算法
    RS485的常用电路设计
    c++对txt文件的读取与写入 【转载】
    OpencV使用fitEllipse拟合椭圆后,获取椭圆参数 【转载】
    C++指定编译代码语句(模块)
    C++自动创建文件夹
    vs2015中复制C++ DLL 和.pdb文件到C#工程中bin目录的设置方法
  • 原文地址:https://www.cnblogs.com/arxive/p/6243776.html
Copyright © 2011-2022 走看看