本文整理匯總了Java中com.androzic.util.Geo類的典型用法代碼示例。如果您正苦於以下問題:Java Geo類的具體用法?Java Geo怎麽用?Java Geo使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
Geo類屬於com.androzic.util包,在下文中一共展示了Geo類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: sort
import com.androzic.util.Geo; //導入依賴的package包/類
public void sort(final int type)
{
Collections.sort(application.getWaypoints(), new Comparator<Waypoint>() {
@Override
public int compare(Waypoint o1, Waypoint o2)
{
if (type == 1)
{
// TODO cache distances
double dist1 = Geo.distance(loc[0], loc[1], o1.latitude, o1.longitude);
double dist2 = Geo.distance(loc[0], loc[1], o2.latitude, o2.longitude);
return (Double.compare(dist1, dist2));
}
else
{
return (o1.name.compareToIgnoreCase(o2.name));
}
}
});
notifyDataSetChanged();
}
示例2: navigateTo
import com.androzic.util.Geo; //導入依賴的package包/類
private void navigateTo(final Route route, final int direction)
{
clearNavigation();
connect();
startForeground(NOTIFICATION_ID, getNotification());
vmgav = new float[] { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 };
navRoute = route;
navDirection = direction;
navCurrentRoutePoint = navDirection == 1 ? 1 : navRoute.length()-2;
navWaypoint = navRoute.getWaypoint(navCurrentRoutePoint);
prevWaypoint = navRoute.getWaypoint(navCurrentRoutePoint - navDirection);
navProximity = navWaypoint.proximity > 0 ? navWaypoint.proximity : routeProximity;
navRouteDistance = -1;
navCourse = Geo.bearing(prevWaypoint.latitude, prevWaypoint.longitude, navWaypoint.latitude, navWaypoint.longitude);
updateNavigationState(STATE_STARTED);
if (lastKnownLocation != null)
calculateNavigationStatus(lastKnownLocation, 0, 0);
}
示例3: navRouteWaypointETE
import com.androzic.util.Geo; //導入依賴的package包/類
public int navRouteWaypointETE(int index)
{
if (index == 0)
return 0;
int ete = Integer.MAX_VALUE;
if (avvmg > 0)
{
int i = navDirection == DIRECTION_FORWARD ? index : navRoute.length() - index - 1;
int j = i - navDirection;
MapObject w1 = navRoute.getWaypoint(i);
MapObject w2 = navRoute.getWaypoint(j);
double distance = Geo.distance(w1.latitude, w1.longitude, w2.latitude, w2.longitude);
ete = (int) Math.round(distance / avvmg / 60);
}
return ete;
}
示例4: addPoint
import com.androzic.util.Geo; //導入依賴的package包/類
public void addPoint(boolean continous, double lat, double lon, double elev, double speed, double bearing, double accuracy, long time)
{
if (lastTrackPoint != null)
{
distance += Geo.distance(lastTrackPoint.latitude, lastTrackPoint.longitude, lat, lon);
}
lastTrackPoint = new TrackPoint(continous, lat, lon, elev, speed, bearing, accuracy, time);
boolean needNewSegment = false;
synchronized (lastSegment)
{
needNewSegment = !continous || lastSegment.trackpoints.size() > SEGMENT_CAPACITY;
}
if (needNewSegment)
{
synchronized (this)
{
lastSegment = new TrackSegment();
lastSegment.independent = !continous;
segments.add(lastSegment);
}
}
synchronized (lastSegment)
{
if (maxPoints > 0 && lastSegment.trackpoints.size() > maxPoints)
{
// TODO add correct cleaning if preferences changed
TrackPoint fp = lastSegment.trackpoints.get(0);
TrackPoint sp = lastSegment.trackpoints.get(1);
distance -= Geo.distance(fp.latitude, fp.longitude, sp.latitude, sp.longitude);
lastSegment.trackpoints.remove(0);
}
lastSegment.trackpoints.add(lastTrackPoint);
}
lastSegment.bounds.extend(lastTrackPoint.latitude, lastTrackPoint.longitude);
}
示例5: addWaypoint
import com.androzic.util.Geo; //導入依賴的package包/類
public void addWaypoint(Waypoint waypoint)
{
if (lastWaypoint != null)
{
distance += Geo.distance(lastWaypoint.latitude, lastWaypoint.longitude, waypoint.latitude, waypoint.longitude);
}
lastWaypoint = waypoint;
waypoints.add(lastWaypoint);
}
示例6: insertWaypoint
import com.androzic.util.Geo; //導入依賴的package包/類
public void insertWaypoint(Waypoint waypoint)
{
if (waypoints.size() < 2)
{
addWaypoint(waypoint);
return;
}
int after = waypoints.size() - 1;
double xtk = Double.MAX_VALUE;
synchronized (waypoints)
{
for (int i = 0; i < waypoints.size()-1; i++)
{
double distance = Geo.distance(waypoint.latitude, waypoint.longitude, waypoints.get(i+1).latitude, waypoints.get(i+1).longitude);
double bearing1 = Geo.bearing(waypoint.latitude, waypoint.longitude, waypoints.get(i+1).latitude, waypoints.get(i+1).longitude);
double dtk1 = Geo.bearing(waypoints.get(i).latitude, waypoints.get(i).longitude, waypoints.get(i+1).latitude, waypoints.get(i+1).longitude);
double cxtk1 = Math.abs(Geo.xtk(distance, dtk1, bearing1));
double bearing2 = Geo.bearing(waypoint.latitude, waypoint.longitude, waypoints.get(i).latitude, waypoints.get(i).longitude);
double dtk2 = Geo.bearing(waypoints.get(i+1).latitude, waypoints.get(i+1).longitude, waypoints.get(i).latitude, waypoints.get(i).longitude);
double cxtk2 = Math.abs(Geo.xtk(distance, dtk2, bearing2));
if (cxtk2 != Double.POSITIVE_INFINITY && cxtk1 < xtk)
{
xtk = cxtk1;
after = i;
}
}
}
waypoints.add(after+1, waypoint);
lastWaypoint = waypoints.get(waypoints.size()-1);
distance = distanceBetween(0, waypoints.size()-1);
}
示例7: distanceBetween
import com.androzic.util.Geo; //導入依賴的package包/類
public double distanceBetween(int first, int last)
{
double dist = 0.0;
synchronized (waypoints)
{
for (int i = first; i < last; i++)
{
dist += Geo.distance(waypoints.get(i).latitude, waypoints.get(i).longitude, waypoints.get(i+1).latitude, waypoints.get(i+1).longitude);
}
}
return dist;
}
示例8: course
import com.androzic.util.Geo; //導入依賴的package包/類
public double course(int prev, int next)
{
synchronized (waypoints)
{
return Geo.bearing(waypoints.get(prev).latitude, waypoints.get(prev).longitude, waypoints.get(next).latitude, waypoints.get(next).longitude);
}
}
示例9: setRouteWaypoint
import com.androzic.util.Geo; //導入依賴的package包/類
public void setRouteWaypoint(int waypoint)
{
navCurrentRoutePoint = waypoint;
navWaypoint = navRoute.getWaypoint(navCurrentRoutePoint);
int prev = navCurrentRoutePoint - navDirection;
if (prev >= 0 && prev < navRoute.length())
prevWaypoint = navRoute.getWaypoint(prev);
else
prevWaypoint = null;
navProximity = navWaypoint.proximity > 0 ? navWaypoint.proximity : routeProximity;
navRouteDistance = -1;
navCourse = prevWaypoint == null ? 0.0 : Geo.bearing(prevWaypoint.latitude, prevWaypoint.longitude, navWaypoint.latitude, navWaypoint.longitude);
updateNavigationState(STATE_NEXTWPT);
}
示例10: nextRouteWaypoint
import com.androzic.util.Geo; //導入依賴的package包/類
public void nextRouteWaypoint() throws IndexOutOfBoundsException
{
navCurrentRoutePoint += navDirection;
navWaypoint = navRoute.getWaypoint(navCurrentRoutePoint);
prevWaypoint = navRoute.getWaypoint(navCurrentRoutePoint - navDirection);
navProximity = navWaypoint.proximity > 0 ? navWaypoint.proximity : routeProximity;
navRouteDistance = -1;
navCourse = Geo.bearing(prevWaypoint.latitude, prevWaypoint.longitude, navWaypoint.latitude, navWaypoint.longitude);
updateNavigationState(STATE_NEXTWPT);
}
示例11: prevRouteWaypoint
import com.androzic.util.Geo; //導入依賴的package包/類
public void prevRouteWaypoint() throws IndexOutOfBoundsException
{
navCurrentRoutePoint -= navDirection;
navWaypoint = navRoute.getWaypoint(navCurrentRoutePoint);
int prev = navCurrentRoutePoint - navDirection;
if (prev >= 0 && prev < navRoute.length())
prevWaypoint = navRoute.getWaypoint(prev);
else
prevWaypoint = null;
navProximity = navWaypoint.proximity > 0 ? navWaypoint.proximity : routeProximity;
navRouteDistance = -1;
navCourse = prevWaypoint == null ? 0.0 : Geo.bearing(prevWaypoint.latitude, prevWaypoint.longitude, navWaypoint.latitude, navWaypoint.longitude);
updateNavigationState(STATE_NEXTWPT);
}
示例12: setAccuracy
import com.androzic.util.Geo; //導入依賴的package包/類
public void setAccuracy(float accuracy)
{
if (accuracy > 0 && this.accuracy != accuracy)
{
this.accuracy = accuracy;
double[] loc = application.getLocation();
double[] prx = Geo.projection(loc[0], loc[1], accuracy/2, 90);
int[] cxy = application.getXYbyLatLon(loc[0], loc[1]);
int[] pxy = application.getXYbyLatLon(prx[0], prx[1]);
radius = (int) Math.hypot((pxy[0]-cxy[0]), (pxy[1]-cxy[1]));
}
enabled = accuracy > 0;
}
示例13: onPrepareBuffer
import com.androzic.util.Geo; //導入依賴的package包/類
@Override
public void onPrepareBuffer(final Viewport viewport, final Canvas c)
{
if (ancor == null)
return;
final double[] loc = viewport.mapCenter;
final int[] cxy = viewport.mapCenterXY;
int sx = ancorXY[0] - cxy[0] + viewport.width / 2;
int sy = ancorXY[1] - cxy[1] + viewport.height / 2;
if (ancorXY[0] != cxy[0] || ancorXY[1] != cxy[1])
{
if (sx >= 0 && sy >= 0 && sx <= viewport.width && sy <= viewport.height)
{
c.drawLine(0, 0, ancorXY[0]-cxy[0], ancorXY[1]-cxy[1], linePaint);
c.drawCircle(ancorXY[0]-cxy[0], ancorXY[1]-cxy[1], linePaint.getStrokeWidth(), circlePaint);
}
else
{
double bearing = Geo.bearing(loc[0], loc[1], ancor[0], ancor[1]);
c.save();
c.rotate((float) bearing, 0, 0);
c.drawLine(0, 0, 0, - viewport.height / 2 - viewport.width / 2, linePaint);
c.restore();
}
}
}
示例14: onClick
import com.androzic.util.Geo; //導入依賴的package包/類
public void onClick(View v)
{
try
{
Androzic application = Androzic.getApplication();
Waypoint waypoint = new Waypoint();
View view = getView();
waypoint.name = ((TextView) view.findViewById(R.id.name_text)).getText().toString();
double distance = Integer.parseInt(((TextView) view.findViewById(R.id.distance_text)).getText().toString());
double bearing = Double.parseDouble(((TextView) view.findViewById(R.id.bearing_text)).getText().toString());
int src = ((Spinner) view.findViewById(R.id.source_spinner)).getSelectedItemPosition();
int df = ((Spinner) view.findViewById(R.id.distance_spinner)).getSelectedItemPosition();
int bf = ((Spinner) view.findViewById(R.id.bearing_spinner)).getSelectedItemPosition();
double[] loc;
if (src > 0)
{
loc = new double[2];
loc[0] = waypoints.get(src-1).latitude;
loc[1] = waypoints.get(src-1).longitude;
}
else
{
loc = application.getLocation();
}
if (df == 0)
{
distance = distance / StringFormatter.distanceFactor * 1000;
}
else
{
distance = distance / StringFormatter.distanceShortFactor;
}
bearing = bearing * StringFormatter.angleFactor;
if (bf == 1)
{
GeomagneticField mag = new GeomagneticField((float) loc[0], (float) loc[1], 0.0f, System.currentTimeMillis());
bearing += mag.getDeclination();
if (bearing > 360d)
bearing -= 360d;
}
double[] prj = Geo.projection(loc[0], loc[1], distance, bearing);
waypoint.latitude = prj[0];
waypoint.longitude = prj[1];
waypoint.date = Calendar.getInstance().getTime();
application.addWaypoint(waypoint);
getTargetFragment().onActivityResult(getTargetRequestCode(), Activity.RESULT_OK, null);
dismiss();
}
catch (Exception e)
{
Toast.makeText(getActivity(), "Invalid input", Toast.LENGTH_LONG).show();
e.printStackTrace();
}
}
示例15: bindView
import com.androzic.util.Geo; //導入依賴的package包/類
@Override
public void bindView(View view, Context context, Cursor cursor)
{
Log.w(TAG, ">>>> bindView");
Tracker tracker = dataAccess.getFullInfoTracker(cursor);
TextView t = (TextView) view.findViewById(R.id.name);
t.setText(tracker.name);
Application application = Application.getApplication();
Bitmap b = application.getMarker(tracker.marker);
if (b != null)
{
Drawable drawable = new BitmapDrawable(getResources(), b);
drawable.setBounds(0, 0, b.getWidth(), b.getHeight());
t.setCompoundDrawables(drawable, null, null, null);
t.setCompoundDrawablePadding(b.getWidth() / 3);
}
else
{
t.setCompoundDrawables(null, null, null, null);
}
t = (TextView) view.findViewById(R.id.sender);
t.setText(tracker.sender);
t = (TextView) view.findViewById(R.id.imei);
t.setText(tracker.imei);
String coordinates = StringFormatter.coordinates(coordinatesFormat, " ", tracker.latitude, tracker.longitude);
t = (TextView) view.findViewById(R.id.coordinates);
t.setText(coordinates);
String speed = String.valueOf(Math.round(tracker.speed * speedFactor)) + " " + speedAbbr;
t = (TextView) view.findViewById(R.id.speed);
t.setText(speed);
String distance = "";
synchronized (currentLocation)
{
if (!"fake".equals(currentLocation.getProvider()))
{
double dist = Geo.distance(tracker.latitude, tracker.longitude, currentLocation.getLatitude(), currentLocation.getLongitude());
double bearing = Geo.bearing(currentLocation.getLatitude(), currentLocation.getLongitude(), tracker.latitude, tracker.longitude);
distance = StringFormatter.distanceH(dist) + " " + StringFormatter.bearingSimpleH(bearing);
}
}
t = (TextView) view.findViewById(R.id.distance);
t.setText(distance);
String battery = "";
if (tracker.battery == Integer.MAX_VALUE)
battery = getString(R.string.full);
if (tracker.battery == Integer.MIN_VALUE)
battery = getString(R.string.low);
if (tracker.battery >= 0 && tracker.battery <= 100)
battery = String.valueOf(tracker.battery) + "%";
t = (TextView) view.findViewById(R.id.battery);
if (! "".equals(battery))
t.setText(String.format("%s: %s", getString(R.string.battery), battery));
else
t.setText("");
String signal = "";
if (tracker.signal == Integer.MAX_VALUE)
signal = getString(R.string.full);
if (tracker.signal == Integer.MIN_VALUE)
signal = getString(R.string.low);
if (tracker.signal >= 0 && tracker.signal <= 100)
signal = String.valueOf(tracker.signal) + "%";
t = (TextView) view.findViewById(R.id.signal);
if (! "".equals(signal))
t.setText(String.format("%s: %s", getString(R.string.signal), signal));
else
t.setText("");
Calendar calendar = Calendar.getInstance();
calendar.setTimeInMillis(tracker.time);
Date date = calendar.getTime();
String modified = DateFormat.getDateFormat(TrackerList.this).format(date) + " " + DateFormat.getTimeFormat(TrackerList.this).format(date);
t = (TextView) view.findViewById(R.id.modified);
t.setText(modified);
}