Имея следующий код для рисования круга (взятый из карты Google Play Services):
PolylineOptions options = new PolylineOptions();
int radius = 5; //What is that?
int numPoints = 100;
double phase = 2 * Math.PI / numPoints;
for (int i = 0; i <= numPoints; i++) {
options.add(new LatLng(SYDNEY.latitude + radius * Math.sin(i * phase),
SYDNEY.longitude + radius * Math.cos(i * phase)));
}
int color = Color.RED;
mMap.addPolyline(options
.color(color)
.width(2));
Это то, что нарисовано в разных частях мира:
Как вы видите, круги не являются кругами, а второй - эллипсом.
Я предполагаю, что "сглаживание" круга зависит от количества точек в переменной int numPoints
.
- Что такое
int radius = 5
variable в примере кода? Я имею в виду, что это за показатель? - И главный вопрос, что было бы правильным способом рисования красивого круга с заданным радиусом в метрах? Что-то знакомое нам в api v1 с
canvas.drawCircle()
ОБНОВЛЕНИЕ --------------------
ОК после улучшения математики я смог нарисовать "правый" круг:
private void addCircle(LatLng latLng, double radius)
{
double R = 6371d; // earth mean radius in km
double d = radius/R; //radius given in km
double lat1 = Math.toRadians(latLng.latitude);
double lon1 = Math.toRadians(latLng.longitude);
PolylineOptions options = new PolylineOptions();
for (int x = 0; x <= 360; x++)
{
double brng = Math.toRadians(x);
double latitudeRad = Math.asin(Math.sin(lat1)*Math.cos(d) + Math.cos(lat1)*Math.sin(d)*Math.cos(brng));
double longitudeRad = (lon1 + Math.atan2(Math.sin(brng)*Math.sin(d)*Math.cos(lat1), Math.cos(d)-Math.sin(lat1)*Math.sin(latitudeRad)));
options.add(new LatLng(Math.toDegrees(latitudeRad), Math.toDegrees(longitudeRad)));
}
mMap.addPolyline(options.color(Color.BLACK).width(2));
}
Однако сглаживание круга, на мой взгляд, несколько не поддается контролю, а на некоторых уровнях масштабирования кружок может стать уродливым: