include uncertainty into shared geo uri
This commit is contained in:
parent
a508a81553
commit
5d526a77e3
|
@ -856,9 +856,15 @@ public class ConversationFragment extends XmppFragment implements EditMessage.Ke
|
||||||
toggleInputMethod();
|
toggleInputMethod();
|
||||||
break;
|
break;
|
||||||
case ATTACHMENT_CHOICE_LOCATION:
|
case ATTACHMENT_CHOICE_LOCATION:
|
||||||
double latitude = data.getDoubleExtra("latitude", 0);
|
final double latitude = data.getDoubleExtra("latitude", 0);
|
||||||
double longitude = data.getDoubleExtra("longitude", 0);
|
final double longitude = data.getDoubleExtra("longitude", 0);
|
||||||
Uri geo = Uri.parse("geo:" + latitude + "," + longitude);
|
final int accuracy = data.getIntExtra("accuracy", 0);
|
||||||
|
final Uri geo;
|
||||||
|
if (accuracy > 0) {
|
||||||
|
geo = Uri.parse(String.format("geo:%s,%s;u=%s", latitude, longitude, accuracy));
|
||||||
|
} else {
|
||||||
|
geo = Uri.parse(String.format("geo:%s,%s", latitude, longitude));
|
||||||
|
}
|
||||||
mediaPreviewAdapter.addMediaPreviews(Attachment.of(getActivity(), geo, Attachment.Type.LOCATION));
|
mediaPreviewAdapter.addMediaPreviews(Attachment.of(getActivity(), geo, Attachment.Type.LOCATION));
|
||||||
toggleInputMethod();
|
toggleInputMethod();
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -13,10 +13,13 @@ import androidx.annotation.NonNull;
|
||||||
import androidx.databinding.DataBindingUtil;
|
import androidx.databinding.DataBindingUtil;
|
||||||
|
|
||||||
import com.google.android.material.snackbar.Snackbar;
|
import com.google.android.material.snackbar.Snackbar;
|
||||||
|
import com.google.common.math.DoubleMath;
|
||||||
|
|
||||||
import org.osmdroid.api.IGeoPoint;
|
import org.osmdroid.api.IGeoPoint;
|
||||||
import org.osmdroid.util.GeoPoint;
|
import org.osmdroid.util.GeoPoint;
|
||||||
|
|
||||||
|
import java.math.RoundingMode;
|
||||||
|
|
||||||
import eu.siacs.conversations.Config;
|
import eu.siacs.conversations.Config;
|
||||||
import eu.siacs.conversations.R;
|
import eu.siacs.conversations.R;
|
||||||
import eu.siacs.conversations.databinding.ActivityShareLocationBinding;
|
import eu.siacs.conversations.databinding.ActivityShareLocationBinding;
|
||||||
|
@ -76,23 +79,7 @@ public class ShareLocationActivity extends LocationActivity implements LocationL
|
||||||
});
|
});
|
||||||
ThemeHelper.fix(this.snackBar);
|
ThemeHelper.fix(this.snackBar);
|
||||||
|
|
||||||
this.binding.shareButton.setOnClickListener(view -> {
|
this.binding.shareButton.setOnClickListener(this::shareLocation);
|
||||||
final Intent result = new Intent();
|
|
||||||
|
|
||||||
if (marker_fixed_to_loc && myLoc != null) {
|
|
||||||
result.putExtra("latitude", myLoc.getLatitude());
|
|
||||||
result.putExtra("longitude", myLoc.getLongitude());
|
|
||||||
result.putExtra("altitude", myLoc.getAltitude());
|
|
||||||
result.putExtra("accuracy", (int) myLoc.getAccuracy());
|
|
||||||
} else {
|
|
||||||
final IGeoPoint markerPoint = this.binding.map.getMapCenter();
|
|
||||||
result.putExtra("latitude", markerPoint.getLatitude());
|
|
||||||
result.putExtra("longitude", markerPoint.getLongitude());
|
|
||||||
}
|
|
||||||
|
|
||||||
setResult(RESULT_OK, result);
|
|
||||||
finish();
|
|
||||||
});
|
|
||||||
|
|
||||||
this.marker_fixed_to_loc = isLocationEnabledAndAllowed();
|
this.marker_fixed_to_loc = isLocationEnabledAndAllowed();
|
||||||
|
|
||||||
|
@ -108,6 +95,22 @@ public class ShareLocationActivity extends LocationActivity implements LocationL
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void shareLocation(final View view) {
|
||||||
|
final Intent result = new Intent();
|
||||||
|
if (marker_fixed_to_loc && myLoc != null) {
|
||||||
|
result.putExtra("latitude", myLoc.getLatitude());
|
||||||
|
result.putExtra("longitude", myLoc.getLongitude());
|
||||||
|
result.putExtra("altitude", myLoc.getAltitude());
|
||||||
|
result.putExtra("accuracy", DoubleMath.roundToInt(myLoc.getAccuracy(), RoundingMode.HALF_UP));
|
||||||
|
} else {
|
||||||
|
final IGeoPoint markerPoint = this.binding.map.getMapCenter();
|
||||||
|
result.putExtra("latitude", markerPoint.getLatitude());
|
||||||
|
result.putExtra("longitude", markerPoint.getLongitude());
|
||||||
|
}
|
||||||
|
setResult(RESULT_OK, result);
|
||||||
|
finish();
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onRequestPermissionsResult(final int requestCode,
|
public void onRequestPermissionsResult(final int requestCode,
|
||||||
@NonNull final String[] permissions,
|
@NonNull final String[] permissions,
|
||||||
|
|
Loading…
Reference in a new issue