android点到直线距离,Android高德地图添加点连点画线

说明:

最近碰到一个需求,需要在高德地图上选择航点,然后连线,最后形成一个路线图,把点的信息,用json文件的格式存储起来

效果图:

600c9fffe11f9765780d3555e7466955.png

1.先集成高德地图  app目录下的builder文件,直接添加高德地图的引用

dependencies {

implementation fileTree(dir: 'libs', include: ['*.jar'])

androidTestImplementation('com.android.support.test.espresso:espresso-core:2.2.2', {

exclude group: 'com.android.support', module: 'support-annotations'

})

implementation 'com.android.support:appcompat-v7:26.0.0-alpha1'

testImplementation 'junit:junit:4.12'

//3d地图 和导航

implementation 'com.amap.api:navi-3dmap:latest.integration'

//定位

implementation 'com.amap.api:location:latest.integration'

//搜索

implementation 'com.amap.api:search:latest.integration'

}

2.源码下载地址:https://github.com/wrs13634194612/MapDrawLine

3.清单文件:注意就是申请一下权限,然后添加高德的appkey,需要自己去官网申请,如何申请,请看我上篇博客,然后再添加高德的定位服务,就可以了

4.主界面:

package com.example.administrator.testz;

import android.graphics.Color;

import android.os.Bundle;

import android.support.v4.app.FragmentActivity;

import android.util.Log;

import android.view.TextureView;

import android.view.View;

import android.widget.Button;

import android.widget.Toast;

import com.amap.api.maps.CameraUpdate;

import com.amap.api.maps.CameraUpdateFactory;

import com.amap.api.maps.model.BitmapDescriptorFactory;

import com.amap.api.maps.model.MarkerOptions;

import com.amap.api.maps.AMap;

import com.amap.api.maps.AMap.OnCameraChangeListener;

import com.amap.api.maps.AMap.OnMapClickListener;

import com.amap.api.maps.AMap.OnMapLongClickListener;

import com.amap.api.maps.AMap.OnMapTouchListener;

import com.amap.api.maps.MapView;

import com.amap.api.maps.model.CameraPosition;

import com.amap.api.maps.model.LatLng;

import com.amap.api.maps.model.LatLngBounds;

import com.amap.api.maps.model.PolylineOptions;

import com.amap.api.maps.model.VisibleRegion;

import com.amap.api.maps.model.Marker;

import com.amap.api.maps.model.Polyline;

import java.util.ArrayList;

import java.util.Map;

import java.util.concurrent.ConcurrentHashMap;

/**

* Created by wrs on 22/11/2019,上午 10:59

* projectName: MapWay

* packageName: task.pdioms.ufi.com.mapway

*/

public class MainActivity extends FragmentActivity implements View.OnClickListener, OnMapClickListener {

private MapView mapView;

private AMap aMap;

private double droneLocationLat = 181, droneLocationLng = 181;

private boolean isAdd = false;

private final MapmMarkers = new ConcurrentHashMap();

private Marker droneMarker = null;

private Button locate, add, clear;

private Polyline polyline;

ArrayListlatLngList = new ArrayList();

LatLng[] latLngs_cross_minus_180 = {

new LatLng(36.777358, 117.114289, false),

new LatLng(34.859492, 113.582008, false),

new LatLng(31.990562, 117.115108, false)

};

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

mapView = (MapView) findViewById(R.id.map);

locate = (Button) findViewById(R.id.locate);

add = (Button) findViewById(R.id.add);

clear = (Button) findViewById(R.id.clear);

locate.setOnClickListener(this);

add.setOnClickListener(this);

clear.setOnClickListener(this);

mapView.onCreate(savedInstanceState);

initMapView();

//跨越180°的线

addBeyond180Polylines();

}

private void addBeyond180Polylines() {

/* latLngList.clear();

for (LatLng latLng : latLngs_cross_minus_180) {

latLngList.add(latLng);

}

aMap.addPolyline((new PolylineOptions())

.addAll(latLngList)

.width(5)

.setDottedLine(false)

.color(Color.RED)

);*/

}

private void initMapView() {

if (aMap == null) {

aMap = mapView.getMap();

aMap.setOnMapClickListener(this);// add the listener for click for amap object

}

// LatLng shenzhen = new LatLng(22.5362, 113.9454);

LatLng shenzhen = new LatLng(30.2781, 120.1238);

aMap.addMarker(new MarkerOptions().position(shenzhen).title("Marker in Shenzhen"));

aMap.moveCamera(CameraUpdateFactory.newLatLng(shenzhen));

}

@Override

public void onMapClick(final LatLng point) {

if (isAdd == true) {

Log.e("TAG", "onMapClick:" + point);

markWaypoint(point);

// latLngList.clear();

new Thread(new Runnable() {

@Override

public void run() {

try {

Thread.sleep(1000);

latLngList.add(point);

Log.e("TAG", "start_thread: " + latLngList.toString());

aMap.addPolyline((new PolylineOptions())

.addAll(latLngList)

.width(10)

.setDottedLine(false)

.color(Color.BLACK)

);

} catch (InterruptedException e) {

e.printStackTrace();

}

}

}).start();

} else {

setResultToToast("Cannot Add Waypoint");

}

}

// Update the drone location based on states from MCU.

private void updateDroneLocation() {

LatLng pos = new LatLng(droneLocationLat, droneLocationLng);

//Create MarkerOptions object

final MarkerOptions markerOptions = new MarkerOptions();

markerOptions.position(pos);

markerOptions.icon(BitmapDescriptorFactory.fromResource(R.mipmap.smile_face_check));

runOnUiThread(new Runnable() {

@Override

public void run() {

if (droneMarker != null) {

droneMarker.remove();

}

if (checkGpsCoordination(droneLocationLat, droneLocationLng)) {

droneMarker = aMap.addMarker(markerOptions);

}

}

});

}

private void cameraUpdate() {

LatLng pos = new LatLng(droneLocationLat, droneLocationLng);

float zoomlevel = (float) 18.0;

CameraUpdate cu = CameraUpdateFactory.newLatLngZoom(pos, zoomlevel);

aMap.moveCamera(cu);

}

public static boolean checkGpsCoordination(double latitude, double longitude) {

return (latitude > -90 && latitude < 90 && longitude > -180 && longitude < 180) && (latitude != 0f && longitude != 0f);

}

private void setResultToToast(final String string) {

runOnUiThread(new Runnable() {

@Override

public void run() {

Toast.makeText(MainActivity.this, string, Toast.LENGTH_SHORT).show();

}

});

}

private void markWaypoint(LatLng point) {

//Create MarkerOptions object

MarkerOptions markerOptions = new MarkerOptions();

markerOptions.position(point);

markerOptions.icon(BitmapDescriptorFactory.fromResource(R.mipmap.rb_news_normal));

//markerOptions.icon(BitmapDescriptorFactory.defaultMarker(BitmapDescriptorFactory.HUE_BLUE));

Marker marker = aMap.addMarker(markerOptions);

mMarkers.put(mMarkers.size(), marker);

}

@Override

public void onClick(View v) {

switch (v.getId()) {

case R.id.locate: {

updateDroneLocation();

cameraUpdate(); // Locate the drone's place

break;

}

case R.id.add: {

enableDisableAdd();

break;

}

case R.id.clear: {

runOnUiThread(new Runnable() {

@Override

public void run() {

aMap.clear();

latLngList.clear();

}

});

updateDroneLocation();

break;

}

}

}

private void enableDisableAdd() {

if (isAdd == false) {

isAdd = true;

add.setText("Exit");

} else {

isAdd = false;

add.setText("Add");

}

}

}

5.布局:

6.代码说明,核心代码说一下吧

6.1监听地图,点击的标记点的经纬度,设置marker

监听方法是:

implements OnMapClickListener

重写方法,具体的监听内容在如下方法:

public void onMapClick(final LatLng point) {}

然后就是对监听到的点,进行添加marker操作:

private void markWaypoint(LatLng point) {

//Create MarkerOptions object

MarkerOptions markerOptions = new MarkerOptions();

markerOptions.position(point);

markerOptions.icon(BitmapDescriptorFactory.fromResource(R.mipmap.rb_news_normal));

//markerOptions.icon(BitmapDescriptorFactory.defaultMarker(BitmapDescriptorFactory.HUE_BLUE));

Marker marker = aMap.addMarker(markerOptions);

mMarkers.put(mMarkers.size(), marker);

}

6.2 把刚才点击的点,用一个list集合存起来,然后,用线条把这些点连接起来就可以了,这里用了一个线程

new Thread(new Runnable() {

@Override

public void run() {

try {

Thread.sleep(1000);

latLngList.add(point);

Log.e("TAG", "start_thread: " + latLngList.toString());

aMap.addPolyline((new PolylineOptions())

.addAll(latLngList)

.width(10)

.setDottedLine(false)

.color(Color.BLACK)

);

} catch (InterruptedException e) {

e.printStackTrace();

}

}

}).start();

end

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android 高德地图中,计算点到线线段的最短距离可以通过以下步骤实现: 1. 获取地图上的线段。 ```java LatLng point = new LatLng(39.915168, 116.403875); LatLng start = new LatLng(39.993015, 116.474172); LatLng end = new LatLng(39.902981, 116.447901); Polyline polyline = new PolylineOptions().add(start, end).color(Color.RED).width(10f); aMap.addPolyline(polyline); ``` 2. 计算点到线段的距离。 ```java double distance = AMapUtils.calculateLineDistance(point, AMapUtils.nearestPointOnLine(point, start, end)); ``` 其中,nearestPointOnLine 方法可以计算点到线段的垂足,然后使用 calculateLineDistance 方法计算点到垂足的距离。 3. 显示距离信息。 ```java Toast.makeText(this, "点到线段的最短距离为:" + distance + "米", Toast.LENGTH_SHORT).show(); ``` 完整代码如下: ```java public class MainActivity extends AppCompatActivity implements OnMapReadyCallback { private AMap aMap; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); MapView mapView = findViewById(R.id.map_view); mapView.onCreate(savedInstanceState); mapView.getMapAsync(this); } @Override public void onMapReady(AMap aMap) { this.aMap = aMap; LatLng point = new LatLng(39.915168, 116.403875); LatLng start = new LatLng(39.993015, 116.474172); LatLng end = new LatLng(39.902981, 116.447901); Polyline polyline = new PolylineOptions().add(start, end).color(Color.RED).width(10f); aMap.addPolyline(polyline); double distance = AMapUtils.calculateLineDistance(point, AMapUtils.nearestPointOnLine(point, start, end)); Toast.makeText(this, "点到线段的最短距离为:" + distance + "米", Toast.LENGTH_SHORT).show(); } @Override protected void onResume() { super.onResume(); MapView mapView = findViewById(R.id.map_view); mapView.onResume(); } @Override protected void onPause() { super.onPause(); MapView mapView = findViewById(R.id.map_view); mapView.onPause(); } @Override protected void onDestroy() { super.onDestroy(); MapView mapView = findViewById(R.id.map_view); mapView.onDestroy(); } @Override public void onSaveInstanceState(Bundle outState) { super.onSaveInstanceState(outState); MapView mapView = findViewById(R.id.map_view); mapView.onSaveInstanceState(outState); } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值