當前位置: 首頁>>代碼示例>>Java>>正文


Java Geo.distance方法代碼示例

本文整理匯總了Java中com.androzic.util.Geo.distance方法的典型用法代碼示例。如果您正苦於以下問題:Java Geo.distance方法的具體用法?Java Geo.distance怎麽用?Java Geo.distance使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在com.androzic.util.Geo的用法示例。


在下文中一共展示了Geo.distance方法的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: 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;
}
 
開發者ID:andreynovikov,項目名稱:Androzic,代碼行數:17,代碼來源:NavigationService.java

示例2: 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);
}
 
開發者ID:andreynovikov,項目名稱:androzic-library,代碼行數:36,代碼來源:Track.java

示例3: 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);		
}
 
開發者ID:andreynovikov,項目名稱:androzic-library,代碼行數:10,代碼來源:Route.java

示例4: 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);
}
 
開發者ID:andreynovikov,項目名稱:androzic-library,代碼行數:33,代碼來源:Route.java

示例5: 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;
}
 
開發者ID:andreynovikov,項目名稱:androzic-library,代碼行數:13,代碼來源:Route.java

示例6: 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);
}
 
開發者ID:andreynovikov,項目名稱:androzic-plugin-tracker,代碼行數:75,代碼來源:TrackerList.java


注:本文中的com.androzic.util.Geo.distance方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。