display info bubble
This commit is contained in:
@ -0,0 +1,93 @@
|
||||
package com.safemobile.dispatch;
|
||||
|
||||
import android.content.Context;
|
||||
import android.util.Log;
|
||||
import android.view.LayoutInflater;
|
||||
import android.view.View;
|
||||
import android.widget.ImageView;
|
||||
import android.widget.RelativeLayout;
|
||||
import android.widget.TextView;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
|
||||
import com.google.android.gms.maps.GoogleMap;
|
||||
import com.google.android.gms.maps.model.Marker;
|
||||
import com.safemobile.lib.SuperVehicle;
|
||||
|
||||
import java.text.DateFormat;
|
||||
import java.text.SimpleDateFormat;
|
||||
import java.util.Date;
|
||||
import java.util.Hashtable;
|
||||
import java.util.Locale;
|
||||
|
||||
|
||||
public class GoogleMapsInfoBubble implements GoogleMap.InfoWindowAdapter {
|
||||
private final String TAG = GoogleMapsInfoBubble.class.getName();
|
||||
|
||||
private final View mWindow;
|
||||
private final Hashtable<Long, SuperVehicle> superVehHash;
|
||||
private final Context context;
|
||||
|
||||
|
||||
public GoogleMapsInfoBubble(LayoutInflater layoutInflater, Context context, Hashtable<Long, SuperVehicle> vehicles) {
|
||||
this.context = context;
|
||||
this.superVehHash = vehicles;
|
||||
mWindow = layoutInflater.inflate(R.layout.map_marker_info_bubble, null);
|
||||
}
|
||||
|
||||
@Override
|
||||
public View getInfoWindow(@NonNull Marker marker) {
|
||||
render(marker, mWindow);
|
||||
return mWindow;
|
||||
}
|
||||
|
||||
@Override
|
||||
public View getInfoContents(@NonNull Marker marker) {
|
||||
render(marker, mWindow);
|
||||
return mWindow;
|
||||
}
|
||||
|
||||
private void render(Marker marker, View view) {
|
||||
long key = 0;
|
||||
|
||||
try {
|
||||
key = Long.parseLong(marker.getTitle());
|
||||
} catch (Exception ex) {
|
||||
Log.v(TAG, "Unable to parse Google Maps Info Bubble title");
|
||||
}
|
||||
SuperVehicle vehicle = superVehHash.get(key);
|
||||
|
||||
RelativeLayout rlMapInfoBubbleInfo = view.findViewById(R.id.rlMapInfoBubbleInfo);
|
||||
TextView tvUnitName = view.findViewById(R.id.tvUnitName);
|
||||
TextView tvGPSLocation = view.findViewById(R.id.tvGPSLocation);
|
||||
TextView tvTimeAgo = view.findViewById(R.id.tvTimeAgo);
|
||||
TextView tvSpeed = view.findViewById(R.id.tvSpeed);
|
||||
TextView tvStreetView = view.findViewById(R.id.tvStreetView);
|
||||
ImageView streetView = view.findViewById(R.id.streetView);
|
||||
rlMapInfoBubbleInfo.setVisibility(View.VISIBLE);
|
||||
|
||||
boolean isMilitaryTime = false;
|
||||
Date positionTime = new Date(vehicle.timeGMT);
|
||||
|
||||
|
||||
String timeFormat = isMilitaryTime
|
||||
? "HH:mm:ss dd.MMM.yyyy"
|
||||
: "hh:mm:ss a dd.MMM.yyy";
|
||||
|
||||
DateFormat format = new SimpleDateFormat(timeFormat, Locale.ENGLISH);
|
||||
|
||||
tvTimeAgo.setText(format.format(positionTime));
|
||||
|
||||
tvSpeed.setText(String.format(context.getResources().getString(R.string.speedMph), vehicle.speed));
|
||||
|
||||
String address = vehicle.Address != null ? vehicle.Address : "";
|
||||
|
||||
tvStreetView.setText(address);
|
||||
streetView.setVisibility(address.length() > 0 ? View.VISIBLE : View.GONE);
|
||||
tvStreetView.setVisibility(address.length() > 0 ? View.VISIBLE : View.GONE);
|
||||
tvUnitName.setText(vehicle.name);
|
||||
tvGPSLocation.setText("[" + String.format("%.4f", vehicle.lat)
|
||||
+ "," + String.format("%.4f",vehicle.lng) + "]");
|
||||
}
|
||||
}
|
||||
|
@ -32,6 +32,8 @@ import android.widget.TextView;
|
||||
import android.widget.Toast;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
import androidx.annotation.Nullable;
|
||||
import androidx.constraintlayout.widget.ConstraintLayout;
|
||||
|
||||
import com.google.android.gms.maps.CameraUpdateFactory;
|
||||
import com.google.android.gms.maps.GoogleMap;
|
||||
@ -307,7 +309,8 @@ public class LiveActivity extends AbstractLiveActivity implements OnMapReadyCall
|
||||
@Override
|
||||
public void onMapReady(@NonNull GoogleMap googleMap) {
|
||||
this.googleMap = googleMap;
|
||||
|
||||
GoogleMapsInfoBubble infoBubble = new GoogleMapsInfoBubble(getLayoutInflater(), this, getParentTab().SuperVehHash);
|
||||
this.googleMap.setInfoWindowAdapter(infoBubble);
|
||||
// Add a marker in Sydney and move the camera
|
||||
LatLng sydney = new LatLng(-34, 151);
|
||||
this.googleMap.addMarker(new MarkerOptions().position(sydney).title("Marker in Sydney"));
|
||||
@ -475,12 +478,12 @@ public class LiveActivity extends AbstractLiveActivity implements OnMapReadyCall
|
||||
|
||||
if (tmpSuper != null) {
|
||||
LatLng newLocation = new LatLng(tmpSuper.lat, tmpSuper.lng);
|
||||
MarkerOptions markerOptions = new MarkerOptions().position(newLocation).title(tmpSuper.name);
|
||||
MarkerOptions markerOptions = new MarkerOptions().position(newLocation).title(liveVehicle.get(i).imei);
|
||||
|
||||
BitmapDescriptor markerIcon = getProperBitmap(tmpSuper.getLargeIcon(), tmpSuper.name);
|
||||
markerOptions.icon(markerIcon);
|
||||
|
||||
Marker marker = this.googleMap.addMarker(markerOptions);
|
||||
Marker marker = this.googleMap.addMarker(markerOptions);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -232,4 +232,7 @@
|
||||
<item >German</item>
|
||||
<item >Romanian</item>
|
||||
</string-array>
|
||||
|
||||
<string name="speedMph">%1$d mph</string>
|
||||
|
||||
</resources>
|
@ -236,4 +236,7 @@
|
||||
<item >Spanish</item>
|
||||
<item >Russian</item>
|
||||
</string-array>
|
||||
|
||||
<string name="speedMph">%1$d mph</string>
|
||||
|
||||
</resources>
|
@ -233,4 +233,7 @@
|
||||
<item >Turca</item>
|
||||
<item >Romana</item>
|
||||
</string-array>
|
||||
|
||||
<string name="speedMph">%1$d mph</string>
|
||||
|
||||
</resources>
|
@ -232,4 +232,7 @@
|
||||
<item >German</item>
|
||||
<item >Romanian</item>
|
||||
</string-array>
|
||||
|
||||
<string name="speedMph">%1$d mph</string>
|
||||
|
||||
</resources>
|
@ -254,4 +254,8 @@
|
||||
</string-array>
|
||||
<string name="title_activity_new_live">NewLiveActivity</string>
|
||||
<string name="title_activity_google_maps">GoogleMapsActivity</string>
|
||||
|
||||
|
||||
<string name="speedMph">%1$d mph</string>
|
||||
|
||||
</resources>
|
Reference in New Issue
Block a user