mirror of https://github.com/YTVanced/VancedMicroG
107 lines
3.0 KiB
Java
107 lines
3.0 KiB
Java
/*
|
|
* Copyright (c) 2014 μg Project Team
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
package com.google.android.gms.maps.model;
|
|
|
|
import android.os.Parcel;
|
|
import com.google.android.gms.common.safeparcel.SafeParcelable;
|
|
import com.google.android.gms.common.safeparcel.SafeReader;
|
|
import com.google.android.gms.common.safeparcel.SafeWriter;
|
|
import com.google.android.maps.GeoPoint;
|
|
|
|
public class LatLng implements SafeParcelable {
|
|
public static Creator<LatLng> CREATOR = new Creator<LatLng>() {
|
|
public LatLng createFromParcel(Parcel source) {
|
|
return new LatLng(source);
|
|
}
|
|
|
|
public LatLng[] newArray(int size) {
|
|
return new LatLng[size];
|
|
}
|
|
};
|
|
public double latitude;
|
|
public double longitude;
|
|
private int versionCode;
|
|
|
|
public LatLng(int versionCode, double latitude, double longitude) {
|
|
this.versionCode = versionCode;
|
|
this.latitude = Math.max(-90, Math.min(90, latitude));
|
|
if ((-180 <= longitude) && (longitude < 180)) {
|
|
this.longitude = longitude;
|
|
} else {
|
|
this.longitude = ((360 + (longitude - 180) % 360) % 360 - 180);
|
|
}
|
|
}
|
|
|
|
private LatLng(Parcel in) {
|
|
int end = SafeReader.readStart(in);
|
|
while (in.dataPosition() < end) {
|
|
int position = SafeReader.readSingleInt(in);
|
|
switch (SafeReader.halfOf(position)) {
|
|
case 1:
|
|
versionCode = SafeReader.readInt(in, position);
|
|
break;
|
|
case 2:
|
|
latitude = SafeReader.readDouble(in, position);
|
|
break;
|
|
case 3:
|
|
longitude = SafeReader.readDouble(in, position);
|
|
break;
|
|
default:
|
|
SafeReader.skip(in, position);
|
|
}
|
|
}
|
|
if (in.dataPosition() > end) {
|
|
throw new SafeReader.ReadException("Overread allowed size end=" + end, in);
|
|
}
|
|
}
|
|
|
|
public LatLng(double latitude, double longitude) {
|
|
this(1, latitude, longitude);
|
|
}
|
|
|
|
@Override
|
|
public final int hashCode() {
|
|
long lat = Double.doubleToLongBits(latitude);
|
|
int tmp = 31 + (int) (lat ^ lat >>> 32);
|
|
long lon = Double.doubleToLongBits(longitude);
|
|
return tmp * 31 + (int) (lon ^ lon >>> 32);
|
|
}
|
|
|
|
@Override
|
|
public String toString() {
|
|
return "lat/lng: (" + latitude + "," + longitude + ")";
|
|
}
|
|
|
|
@Override
|
|
public int describeContents() {
|
|
return 0;
|
|
}
|
|
|
|
@Override
|
|
public void writeToParcel(Parcel dest, int flags) {
|
|
int start = SafeWriter.writeStart(dest);
|
|
SafeWriter.write(dest, 1, versionCode);
|
|
SafeWriter.write(dest, 2, latitude);
|
|
SafeWriter.write(dest, 3, longitude);
|
|
SafeWriter.writeEnd(dest, start);
|
|
}
|
|
|
|
public GeoPoint toGeoPoint() {
|
|
return new GeoPoint((int) (latitude * 1E6F), (int) (longitude * 1E6F));
|
|
}
|
|
}
|