Compare commits

..

13 Commits

34 changed files with 3386 additions and 3603 deletions

2
.gitignore vendored
View File

@ -184,5 +184,3 @@ $RECYCLE.BIN/
/.idea/misc.xml /.idea/misc.xml
/.idea /.idea
/.idea/modules.xml /.idea/modules.xml
/.idea/gradle.xml
/.idea/misc.xml

View File

@ -2,6 +2,7 @@ package com.safemobile.activities;
import java.util.ArrayList; import java.util.ArrayList;
import com.google.android.gms.maps.GoogleMap;
import com.safemobile.lib.Vehicle; import com.safemobile.lib.Vehicle;
import android.app.Activity; import android.app.Activity;
@ -23,7 +24,7 @@ public abstract class AbstractLiveActivity extends AppCompatActivity {
public abstract void pollReceived(int position, double lat, double lng); // --> UpdatePoll public abstract void pollReceived(int position, double lat, double lng); // --> UpdatePoll
public abstract void vehicleStatusReceived(long imei, int opCode, int status); // --> UpdateOptions public abstract void vehicleStatusReceived(long imei, int opCode, int status); // --> UpdateOptions
public abstract void emergencyAlarmReceived(int position, double lat, double lng); // --> UpdateEmergencyAlarm public abstract void emergencyAlarmReceived(int position, double lat, double lng); // --> UpdateEmergencyAlarm
public abstract GoogleMap getMap(); // --> UpdateEmergencyAlarm
/** Misc */ /** Misc */
public AbstractSDParentActivity getParentTab() { public AbstractSDParentActivity getParentTab() {

View File

@ -1,9 +1,8 @@
package com.safemobile.activities; package com.safemobile.activities;
import java.util.ArrayList; import android.app.TabActivity;
import java.util.Hashtable; import android.content.BroadcastReceiver;
import com.safemobile.bluetooth.BluetoothTether;
import com.safemobile.lib.AppParams; import com.safemobile.lib.AppParams;
import com.safemobile.lib.SM; import com.safemobile.lib.SM;
import com.safemobile.lib.SuperVehicle; import com.safemobile.lib.SuperVehicle;
@ -11,43 +10,21 @@ import com.safemobile.lib.Vehicle;
import com.safemobile.services.TCPhandler; import com.safemobile.services.TCPhandler;
import com.safemobile.services.TCPmsgParser; import com.safemobile.services.TCPmsgParser;
import android.app.Activity; import java.util.ArrayList;
import android.app.NotificationManager; import java.util.Hashtable;
import android.app.TabActivity;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.os.Handler;
import android.widget.ImageView;
import android.widget.RelativeLayout;
@SuppressWarnings("deprecation") @SuppressWarnings("deprecation")
public abstract class AbstractSDParentActivity extends TabActivity { public abstract class AbstractSDParentActivity extends TabActivity {
/** UI Elements */
public RelativeLayout layoutLoading;
public ImageView imageViewLoading;
/** Misc */ /** Misc */
public Activity activity; private static final boolean SHOULD_DISPLAY_LOGCAT = true; // show logCat messages when TCP send was successful
public Context context; private String imei;
public NotificationManager mNotificationManager; private String mess;
public boolean displayLogCat = true; // show logCat messages when TCP send was successful
public String imei, mess;
public int demoPosition = 0; public int demoPosition = 0;
/** Lists */ private ArrayList<Vehicle> allVehicle = new ArrayList<>();
public ArrayList<Vehicle> allVehicle = new ArrayList<Vehicle>(); private Hashtable<Long, SuperVehicle> superVehHash = new Hashtable<>();
public Hashtable<Long, SuperVehicle> SuperVehHash = new Hashtable<Long, SuperVehicle>(); private Hashtable<Long, Vehicle> vehHashByScId = new Hashtable<>();
public Hashtable<Long, Vehicle> VehHashbySc_id = new Hashtable<Long, Vehicle>();
/** Handler */
public Handler myHandler = new Handler();
/** BlueTooth Tether */
public BluetoothTether bluetoothTether = null;
/** Broadcast Receiver */
public BroadcastReceiver mReceiver = null;
/** TCP */ /** TCP */
protected TCPhandler tcp = null; protected TCPhandler tcp = null;
@ -66,9 +43,9 @@ public abstract class AbstractSDParentActivity extends TabActivity {
public Object getTCPState() { public Object getTCPState() {
// return true if tcp connection is on, false if not connected and null // return true if tcp connection is on, false if not connected and null
if(tcp!=null && tcp.isConnectionUP) if (tcp != null && tcp.isConnectionUP)
return "true"; return "true";
else if(tcp!=null && !tcp.isConnectionUP) else if (tcp != null)
return "false"; return "false";
return null; return null;
} }
@ -84,17 +61,16 @@ public abstract class AbstractSDParentActivity extends TabActivity {
public abstract void updateDemoPosition(); public abstract void updateDemoPosition();
public abstract void updateResultsPollInUi(String type); public abstract void updateResultsPollInUi(String type);
public abstract double best_zoom(double LATMAX,double LATmin,double LNGMAX,double LNGmin); public abstract double best_zoom(double latMax,double latMin,double lngMax,double lngMin);
/* SafeDispatch Mobile functions */ /* SafeDispatch Mobile functions */
/** get Vehicles for an user id */ /** get Vehicles for an user id */
public boolean getVehicles(int userID) public boolean getVehicles(int userID) {
{ if (tcp == null)
if(tcp == null)
return false; return false;
boolean res = tcp.Write("0.0", "#21#" + AppParams.USERID + "#"); boolean res = tcp.Write("0.0", "#21#" + userID + "#");
if(res && displayLogCat) if (res && SHOULD_DISPLAY_LOGCAT)
SM.Debug("Message (getVehs) sent to app server"); SM.Debug("Message (getVehs) sent to app server");
else else
SM.Debug("Could not send message(getVehs)!!"); SM.Debug("Could not send message(getVehs)!!");
@ -103,13 +79,12 @@ public abstract class AbstractSDParentActivity extends TabActivity {
} }
/** get vehicles Last Positions for an user id */ /** get vehicles Last Positions for an user id */
public boolean getLastPositions(int userID) public boolean getLastPositions(int userID) {
{ if (tcp == null)
if(tcp == null)
return false; return false;
boolean res = tcp.Write("0.0", "#25#" + userID + "#"); boolean res = tcp.Write("0.0", "#25#" + userID + "#");
if(res && displayLogCat) if (res && SHOULD_DISPLAY_LOGCAT)
SM.Debug("Message (getLastPOS) sent to app server"); SM.Debug("Message (getLastPOS) sent to app server");
else else
SM.Debug("Could not send message(getLastSMS)!!"); SM.Debug("Could not send message(getLastSMS)!!");
@ -118,14 +93,13 @@ public abstract class AbstractSDParentActivity extends TabActivity {
} }
/** set Enable/Disable a vehicle */ /** set Enable/Disable a vehicle */
public boolean setVehicleStatus(int radioCode, int opCode, int sc_id, int enable) public boolean setVehicleStatus(int radioCode, int opCode, int sc_id, int enable) {
{ if (tcp == null)
if(tcp == null)
return false; return false;
boolean res = tcp.Write("0.0", "#"+radioCode+"#"+opCode+"#" + sc_id+"#" + enable + "#"); boolean res = tcp.Write("0.0", "#" + radioCode + "#" + opCode + "#" + sc_id + "#" + enable + "#");
if(res && displayLogCat) if (res && SHOULD_DISPLAY_LOGCAT)
SM.Debug("Message (Option4Unit) sent to app server radioCode:"+radioCode+ " opCode:"+opCode+ " sc_id:"+sc_id+ " value:" + enable); SM.Debug("Message (Option4Unit) sent to app server radioCode:" + radioCode + " opCode:" + opCode + " sc_id:" + sc_id + " value:" + enable);
else else
SM.Debug("Could not send message(Option4Unit)!!"); SM.Debug("Could not send message(Option4Unit)!!");
@ -133,13 +107,12 @@ public abstract class AbstractSDParentActivity extends TabActivity {
} }
/** get Last SMSs for an user */ /** get Last SMSs for an user */
public boolean getLastSMSs(int userID) public boolean getLastSMSs(int userID) {
{ if (tcp == null)
if(tcp == null)
return false; return false;
boolean res = tcp.Write("0.0", "#23#" + userID + "#"); boolean res = tcp.Write("0.0", "#23#" + userID + "#");
if(res && displayLogCat) if (res && SHOULD_DISPLAY_LOGCAT)
SM.Debug("#Send Request#", "Message [getLastSMSs] sent to app server"); SM.Debug("#Send Request#", "Message [getLastSMSs] sent to app server");
else else
SM.Debug("#Send Request#", "Could not send message [getLastSMSs]!!"); SM.Debug("#Send Request#", "Could not send message [getLastSMSs]!!");
@ -150,13 +123,12 @@ public abstract class AbstractSDParentActivity extends TabActivity {
/** get SMSs for an user that are recent than timeGMT /** get SMSs for an user that are recent than timeGMT
* @param sc_id the vehicle imei for which we want the SMSs * @param sc_id the vehicle imei for which we want the SMSs
* @param timeGMT the unix time for the last message in the grid or messages that are newer than this time */ * @param timeGMT the unix time for the last message in the grid or messages that are newer than this time */
public boolean getRecentSMSs(int sc_id, long timeGMT) public boolean getRecentSMSs(int sc_id, long timeGMT) {
{ if (tcp == null)
if(tcp == null)
return false; return false;
boolean res = tcp.Write("0.0", "#22#"+sc_id+"#" +timeGMT+"#"); boolean res = tcp.Write("0.0", "#22#" + sc_id + "#" + timeGMT + "#");
if(res && displayLogCat) if (res && SHOULD_DISPLAY_LOGCAT)
SM.Debug("#Send Request#", "Message [getRecentSMSs] sent to app server"); SM.Debug("#Send Request#", "Message [getRecentSMSs] sent to app server");
else else
SM.Debug("#Send Request#", "Could not send message [getRecentSMSs]!!"); SM.Debug("#Send Request#", "Could not send message [getRecentSMSs]!!");
@ -174,7 +146,7 @@ public abstract class AbstractSDParentActivity extends TabActivity {
return false; return false;
boolean res = tcp.Write(seqID, "#24#" + AppParams.USERID + "#" + sc_id + "#" + txt + "#"); boolean res = tcp.Write(seqID, "#24#" + AppParams.USERID + "#" + sc_id + "#" + txt + "#");
if(res && displayLogCat) if(res && SHOULD_DISPLAY_LOGCAT)
SM.Debug("Message [sendSMS] sent to app server sc_id:"+sc_id+ " txt:"+txt); SM.Debug("Message [sendSMS] sent to app server sc_id:"+sc_id+ " txt:"+txt);
else else
SM.Debug("Could not send message [sendSMS]!!"); SM.Debug("Could not send message [sendSMS]!!");
@ -183,16 +155,16 @@ public abstract class AbstractSDParentActivity extends TabActivity {
} }
public boolean sendAlarmAcknoledge(int alarm_id, int type) public boolean sendAlarmAcknowledge(int alarm_id, int type)
{ {
if(tcp == null) if(tcp == null)
return false; return false;
boolean res = tcp.Write("0.0", "#28#" + alarm_id + "#" + type + "#"); boolean res = tcp.Write("0.0", "#28#" + alarm_id + "#" + type + "#");
if(res) if(res)
SM.Debug("Message [sendAlarmAcknoledge] sent to app server alarm_id:" + alarm_id + " type:" + type); SM.Debug("Message [sendAlarmAcknowledge] sent to app server alarm_id:" + alarm_id + " type:" + type);
else else
SM.Debug("Could not send message [sendAlarmAcknoledge]!!"); SM.Debug("Could not send message [sendAlarmAcknowledge]!!");
return res; return res;
} }
@ -290,7 +262,7 @@ public abstract class AbstractSDParentActivity extends TabActivity {
if(tcp == null) if(tcp == null)
return false; return false;
boolean res = tcp.Write("0.0", "#27#" + userID + "#"); // = tcp.Write("0.0", "#30#99#" + gwID + "#" + rgwID + "#"); boolean res = tcp.Write("0.0", "#27#" + userID + "#");
if(res) if(res)
SM.Debug("Message [GetAlarms] sent to app server"); SM.Debug("Message [GetAlarms] sent to app server");
else else
@ -314,10 +286,44 @@ public abstract class AbstractSDParentActivity extends TabActivity {
return res; return res;
} }
//public abstract void getVehiclePosition(long imei); public String getImei() {
/* return imei;
public abstract void onResume(); }
public abstract void onStart();
public abstract void onPause(); public void setImei(String imei) {
*/ this.imei = imei;
}
public String getMess() {
return mess;
}
public void setMess(String mess) {
this.mess = mess;
}
/** Lists */
public ArrayList<Vehicle> getAllVehicle() {
return allVehicle;
}
public void setAllVehicle(ArrayList<Vehicle> allVehicle) {
this.allVehicle = allVehicle;
}
public Hashtable<Long, SuperVehicle> getSuperVehHash() {
return superVehHash;
}
public void setSuperVehHash(Hashtable<Long, SuperVehicle> superVehHash) {
this.superVehHash = superVehHash;
}
public Hashtable<Long, Vehicle> getVehHashByScId() {
return vehHashByScId;
}
public void setVehHashByScId(Hashtable<Long, Vehicle> vehHashByScId) {
this.vehHashByScId = vehHashByScId;
}
} }

View File

@ -6,7 +6,6 @@ import java.util.Calendar;
import java.util.Hashtable; import java.util.Hashtable;
import android.app.Activity; import android.app.Activity;
import android.content.Context;
import android.view.LayoutInflater; import android.view.LayoutInflater;
import android.view.View; import android.view.View;
import android.view.ViewGroup; import android.view.ViewGroup;
@ -19,20 +18,18 @@ import com.safemobile.lib.Msg;
import com.safemobile.lib.R; import com.safemobile.lib.R;
import com.safemobile.lib.SM; import com.safemobile.lib.SM;
public class ConversationGridViewAdapter extends BaseAdapter public class ConversationGridViewAdapter extends BaseAdapter {
{ private final ArrayList<Msg> listMessages;
private ArrayList<Msg> listMessages; private final Activity activity;
private Activity activity; private final ArrayList<Boolean> dispatcherPositions;
//public String time; private final ArrayList<Boolean> ackPositions;
private ArrayList<Boolean> dispatcher_positions = new ArrayList<Boolean>(); private final Hashtable<Integer, View> hash = new Hashtable<>();
private ArrayList<Boolean> ackPositions = new ArrayList<Boolean>();
private Hashtable<Integer, View> hash = new Hashtable<Integer, View>();
public ConversationGridViewAdapter(Activity activity, ArrayList<Msg> listMessages, Context context, long sc_id, int unit_type, ArrayList<Boolean> dispatcher_positions, ArrayList<Boolean> ackPositions) { public ConversationGridViewAdapter(Activity activity, ArrayList<Msg> listMessages, ArrayList<Boolean> dispatcherPositions, ArrayList<Boolean> ackPositions) {
this.activity = activity; this.activity = activity;
this.listMessages = listMessages; this.listMessages = listMessages;
this.dispatcher_positions = dispatcher_positions; this.dispatcherPositions = dispatcherPositions;
this.ackPositions = ackPositions; this.ackPositions = ackPositions;
} }
@ -51,149 +48,230 @@ public class ConversationGridViewAdapter extends BaseAdapter
return 0; return 0;
} }
public static class ViewHolder public static class ViewHolder {
{ private ImageView imgViewContact;
public ImageView imgViewContact; private TextView txtViewMsg;
public TextView txtViewMsg; private TextView txtViewDateTime;
public TextView txtViewDateTime; private ImageView imgViewReceivedContact;
public ImageView imgViewReceivedContact; private TextView txtViewReceivedMsg;
public TextView txtViewReceivedMsg; private TextView txtViewReceivedDateTime;
public TextView txtViewReceivedDateTime; private ImageView imageAck;
public ImageView imageAck; private TextView textViewNotACK;
public TextView textViewNotACK; private LinearLayout layoutSend;
public LinearLayout layoutSend; private LinearLayout layoutReceived;
public LinearLayout layoutReceived;
public ImageView getImgViewContact() {
return imgViewContact;
}
public void setImgViewContact(ImageView imgViewContact) {
this.imgViewContact = imgViewContact;
}
public TextView getTxtViewMsg() {
return txtViewMsg;
}
public void setTxtViewMsg(TextView txtViewMsg) {
this.txtViewMsg = txtViewMsg;
}
public TextView getTxtViewDateTime() {
return txtViewDateTime;
}
public void setTxtViewDateTime(TextView txtViewDateTime) {
this.txtViewDateTime = txtViewDateTime;
}
public ImageView getImgViewReceivedContact() {
return imgViewReceivedContact;
}
public void setImgViewReceivedContact(ImageView imgViewReceivedContact) {
this.imgViewReceivedContact = imgViewReceivedContact;
}
public TextView getTxtViewReceivedMsg() {
return txtViewReceivedMsg;
}
public void setTxtViewReceivedMsg(TextView txtViewReceivedMsg) {
this.txtViewReceivedMsg = txtViewReceivedMsg;
}
public TextView getTxtViewReceivedDateTime() {
return txtViewReceivedDateTime;
}
public void setTxtViewReceivedDateTime(TextView txtViewReceivedDateTime) {
this.txtViewReceivedDateTime = txtViewReceivedDateTime;
}
public ImageView getImageAck() {
return imageAck;
}
public void setImageAck(ImageView imageAck) {
this.imageAck = imageAck;
}
public TextView getTextViewNotACK() {
return textViewNotACK;
}
public void setTextViewNotACK(TextView textViewNotACK) {
this.textViewNotACK = textViewNotACK;
}
public LinearLayout getLayoutSend() {
return layoutSend;
}
public void setLayoutSend(LinearLayout layoutSend) {
this.layoutSend = layoutSend;
}
public LinearLayout getLayoutReceived() {
return layoutReceived;
}
public void setLayoutReceived(LinearLayout layoutReceived) {
this.layoutReceived = layoutReceived;
}
} }
@Override @Override
public View getView(int position, View convertView, ViewGroup parent) { public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder view; ViewHolder view;
LayoutInflater inflator = activity.getLayoutInflater(); LayoutInflater inflater = activity.getLayoutInflater();
if(convertView==null) if (convertView == null) {
{
view = new ViewHolder(); view = new ViewHolder();
convertView = inflator.inflate(R.layout.row_conversation, null); convertView = inflater.inflate(R.layout.row_conversation, null);
view.imgViewContact = (ImageView) convertView.findViewById(R.id.imageViewSenderIco); view.setImgViewContact(convertView.findViewById(R.id.imageViewSenderIco));
view.txtViewMsg = (TextView) convertView.findViewById(R.id.textViewSendMsg); view.setTxtViewMsg(convertView.findViewById(R.id.textViewSendMsg));
view.txtViewDateTime = (TextView) convertView.findViewById(R.id.textViewSendDate); view.setTxtViewDateTime(convertView.findViewById(R.id.textViewSendDate));
view.imgViewReceivedContact = (ImageView) convertView.findViewById(R.id.imageViewReceivedIco); view.setImgViewReceivedContact(convertView.findViewById(R.id.imageViewReceivedIco));
view.txtViewReceivedMsg = (TextView) convertView.findViewById(R.id.textViewReceivedMsg); view.setTxtViewReceivedMsg(convertView.findViewById(R.id.textViewReceivedMsg));
view.txtViewReceivedDateTime = (TextView) convertView.findViewById(R.id.textViewReceivedDate); view.setTxtViewReceivedDateTime(convertView.findViewById(R.id.textViewReceivedDate));
view.layoutSend = (LinearLayout) convertView.findViewById(R.id.layoutSend); view.setLayoutSend(convertView.findViewById(R.id.layoutSend));
view.layoutReceived = (LinearLayout) convertView.findViewById(R.id.layoutReceived); view.setLayoutReceived(convertView.findViewById(R.id.layoutReceived));
view.textViewNotACK = (TextView) convertView.findViewById(R.id.textViewNotACKSendMsg); view.setTextViewNotACK(convertView.findViewById(R.id.textViewNotACK));
view.imageAck = (ImageView) convertView.findViewById(R.id.imageAck); view.setImageAck(convertView.findViewById(R.id.imageAck));
convertView.setTag(view); convertView.setTag(view);
} } else {
else
{
view = (ViewHolder) convertView.getTag(); view = (ViewHolder) convertView.getTag();
} }
try try {
{
hash.put(position, convertView); hash.put(position, convertView);
SimpleDateFormat sdf = new SimpleDateFormat("HH:mm MMM-dd"); SimpleDateFormat sdf = new SimpleDateFormat("HH:mm MMM-dd");
Calendar calendar = Calendar.getInstance(); Calendar calendar = Calendar.getInstance();
calendar.set(Calendar.HOUR_OF_DAY,0); calendar.set(Calendar.HOUR_OF_DAY, 0);
calendar.set(Calendar.MINUTE, 0); calendar.set(Calendar.MINUTE, 0);
calendar.set(Calendar.SECOND, 0); calendar.set(Calendar.SECOND, 0);
calendar.set(Calendar.MILLISECOND, 0); calendar.set(Calendar.MILLISECOND, 0);
if(listMessages.get(position).received.after(calendar.getTime())) if (listMessages.get(position).received.after(calendar.getTime()))
sdf = new SimpleDateFormat("HH:mm:ss"); sdf = new SimpleDateFormat("HH:mm:ss");
else else
sdf = new SimpleDateFormat("HH:mm MMM-dd"); sdf = new SimpleDateFormat("HH:mm MMM-dd");
//view.imgViewContact.setImageResource(getIcon(listMessages.get(position).from.user_type)); view.getImgViewContact().setImageResource(R.drawable.peoplegreen_large);
view.imgViewContact.setImageResource(R.drawable.peoplegreen_large); view.getTxtViewMsg().setText(listMessages.get(position).message);
view.txtViewMsg.setText(listMessages.get(position).message); view.getTxtViewDateTime().setText(sdf.format(listMessages.get(position).received));
view.txtViewDateTime.setText(sdf.format(listMessages.get(position).received)); view.getImgViewReceivedContact().setImageResource(listMessages.get(position).from.getLargeIcon());
//view.imgViewReceivedContact.setImageResource(getIcon(listMessages.get(position).from.user_type)); view.getTxtViewReceivedMsg().setText(listMessages.get(position).message);
view.imgViewReceivedContact.setImageResource(listMessages.get(position).from.getLargeIcon()); view.getTxtViewReceivedDateTime().setText(sdf.format(listMessages.get(position).received));
view.txtViewReceivedMsg.setText(listMessages.get(position).message);
view.txtViewReceivedDateTime.setText(sdf.format(listMessages.get(position).received));
if(ackPositions.size() > 0) if (!ackPositions.isEmpty())
switch(ackPositions.get(position) ? 1: 0) { switch (Boolean.TRUE.equals(ackPositions.get(position)) ? 1 : 0) {
case 0: case 0:
// show not ack // show not ack
view.textViewNotACK.setVisibility(View.VISIBLE); view.getTextViewNotACK().setVisibility(View.VISIBLE);
view.imageAck.setVisibility(View.VISIBLE); view.getImageAck().setVisibility(View.VISIBLE);
break; break;
case 1: case 1:
// show not ack // show not ack
view.textViewNotACK.setVisibility(View.INVISIBLE); view.getTextViewNotACK().setVisibility(View.INVISIBLE);
view.imageAck.setVisibility(View.INVISIBLE); view.getImageAck().setVisibility(View.INVISIBLE);
break;
default:
throw new IllegalStateException("Unexpected value: " + (Boolean.TRUE.equals(ackPositions.get(position)) ? 1 : 0));
} }
switch(dispatcher_positions.get(position) ? 1 : 0) { switch (Boolean.TRUE.equals(dispatcherPositions.get(position)) ? 1 : 0) {
case 1: case 1:
view.layoutReceived.setVisibility(View.GONE); view.getLayoutReceived().setVisibility(View.GONE);
view.layoutSend.setVisibility(View.VISIBLE); view.getLayoutSend().setVisibility(View.VISIBLE);
break; break;
case 0: case 0:
view.layoutReceived.setVisibility(View.VISIBLE); view.getLayoutReceived().setVisibility(View.VISIBLE);
view.layoutSend.setVisibility(View.GONE); view.getLayoutSend().setVisibility(View.GONE);
break; break;
default:
throw new IllegalStateException("Unexpected value: " + (Boolean.TRUE.equals(dispatcherPositions.get(position)) ? 1 : 0));
} }
} } catch (Exception ex) {
catch(Exception ex)
{
SM.Exception(ex.toString()); SM.Exception(ex.toString());
} }
return convertView; return convertView;
} }
public void setACK(String seqID) public void setACK(String seqID) {
{ int position = -1;
int position = -1, i=0; int i = 0;
for(Msg msg: listMessages) for (Msg msg : listMessages) {
{ if (msg.seqID.equals(seqID))
if(msg.seqID.equals(seqID))
position = i; position = i;
i++; i++;
} }
if(position > -1 && position < ackPositions.size()) { if (position > -1 && position < ackPositions.size()) {
ackPositions.remove(position); ackPositions.remove(position);
ackPositions.add(position, true); ackPositions.add(position, true);
} }
} }
public void changeView(String seqID) public void changeView(String seqID) {
{ int position = -1;
int position = -1, i=0; int i = 0;
for(Msg msg: listMessages) for (Msg msg : listMessages) {
{ if (msg.seqID.equals(seqID))
if(msg.seqID.equals(seqID))
position = i; position = i;
i++; i++;
} }
if(position != -1 && hash.size() > position) if (position != -1 && hash.size() > position) {
{
SM.Debug("POSITON : " + position); SM.Debug("POSITON : " + position);
View con = hash.get(position); View con = hash.get(position);
ViewHolder view = (ViewHolder) con.getTag(); ViewHolder view = null;
if (con != null) {
view = (ViewHolder) con.getTag();
}
switch(ackPositions.get(position) ? 1 : 0) switch (Boolean.TRUE.equals(ackPositions.get(position)) ? 1 : 0) {
{
case 1: case 1:
view.imageAck.setVisibility(View.INVISIBLE); if (view != null) {
view.textViewNotACK.setVisibility(View.INVISIBLE); view.getImageAck().setVisibility(View.INVISIBLE);
view.getTextViewNotACK().setVisibility(View.INVISIBLE);
}
break; break;
case 0: case 0:
view.imageAck.setVisibility(View.VISIBLE); if (view != null) {
view.textViewNotACK.setVisibility(View.VISIBLE); view.getImageAck().setVisibility(View.VISIBLE);
view.getTextViewNotACK().setVisibility(View.VISIBLE);
}
break; break;
default:
throw new IllegalStateException("Unexpected value: " + (Boolean.TRUE.equals(ackPositions.get(position)) ? 1 : 0));
} }
} }
} }

View File

@ -5,7 +5,6 @@ import java.util.ArrayList;
import java.util.Calendar; import java.util.Calendar;
import android.app.Activity; import android.app.Activity;
import android.content.Context;
import android.view.LayoutInflater; import android.view.LayoutInflater;
import android.view.View; import android.view.View;
import android.view.ViewGroup; import android.view.ViewGroup;
@ -18,15 +17,11 @@ import com.safemobile.lib.Msg;
import com.safemobile.lib.R; import com.safemobile.lib.R;
import com.safemobile.lib.SM; import com.safemobile.lib.SM;
public class MessagesGridViewAdapter extends BaseAdapter public class MessagesGridViewAdapter extends BaseAdapter {
{ private final ArrayList<Msg> listMessages;
private ArrayList<Msg> listMessages; private final Activity activity;
private Activity activity;
//public String time;
//private int[] colors = new int[] { Color.parseColor("#FFFFFF"), Color.parseColor("#D2E4FC") };
public MessagesGridViewAdapter(Activity activity, ArrayList<Msg> listMessages) {
public MessagesGridViewAdapter(Activity activity, ArrayList<Msg> listMessages, Context context) {
super(); super();
this.activity = activity; this.activity = activity;
this.listMessages = listMessages; this.listMessages = listMessages;
@ -47,8 +42,7 @@ public class MessagesGridViewAdapter extends BaseAdapter
return 0; return 0;
} }
public static class ViewHolder public static class ViewHolder {
{
public ImageView imgViewContact; public ImageView imgViewContact;
public TextView txtViewContact; public TextView txtViewContact;
public TextView txtViewDateTime; public TextView txtViewDateTime;
@ -62,71 +56,44 @@ public class MessagesGridViewAdapter extends BaseAdapter
ViewHolder view; ViewHolder view;
LayoutInflater inflator = activity.getLayoutInflater(); LayoutInflater inflator = activity.getLayoutInflater();
if(convertView==null) if (convertView == null) {
{
view = new ViewHolder(); view = new ViewHolder();
convertView = inflator.inflate(R.layout.row_message, null); convertView = inflator.inflate(R.layout.row_message, null);
view.imgViewContact = (ImageView) convertView.findViewById(R.id.imageViewContact); view.imgViewContact = convertView.findViewById(R.id.imageViewContact);
view.txtViewContact = (TextView) convertView.findViewById(R.id.textViewContact); view.txtViewContact = convertView.findViewById(R.id.textViewContact);
view.txtViewDateTime = (TextView) convertView.findViewById(R.id.textViewLastDate); view.txtViewDateTime = convertView.findViewById(R.id.textViewLastDate);
view.txtViewLastMsg = (TextView) convertView.findViewById(R.id.textViewLastMsg); view.txtViewLastMsg = convertView.findViewById(R.id.textViewLastMsg);
view.layoutMessage = (LinearLayout) convertView.findViewById(R.id.layoutMessage); view.layoutMessage = convertView.findViewById(R.id.layoutMessage);
convertView.setTag(view); convertView.setTag(view);
} } else {
else
{
view = (ViewHolder) convertView.getTag(); view = (ViewHolder) convertView.getTag();
} }
try try {
{
view.imgViewContact.setImageResource(listMessages.get(position).from.getLargeIcon()); view.imgViewContact.setImageResource(listMessages.get(position).from.getLargeIcon());
//view.imgViewContact.setImageResource(R.drawable.peopleblue); view.txtViewContact.setText(String.format("%s :", listMessages.get(position).from.name));
view.txtViewContact.setText(listMessages.get(position).from.name+ " :"); if (listMessages.get(position).message.length() > 25)
if(listMessages.get(position).message.length() > 25) view.txtViewLastMsg.setText(String.format("%s...", listMessages.get(position).message.substring(0, 25)));
view.txtViewLastMsg.setText(listMessages.get(position).message.substring(0, 25) + "...");
else else
view.txtViewLastMsg.setText(listMessages.get(position).message); view.txtViewLastMsg.setText(listMessages.get(position).message);
SimpleDateFormat sdf = new SimpleDateFormat("HH:mm:ss"); SimpleDateFormat sdf = new SimpleDateFormat("HH:mm:ss");
Calendar calendar = Calendar.getInstance(); Calendar calendar = Calendar.getInstance();
calendar.set(Calendar.HOUR_OF_DAY,0); calendar.set(Calendar.HOUR_OF_DAY, 0);
calendar.set(Calendar.MINUTE, 0); calendar.set(Calendar.MINUTE, 0);
calendar.set(Calendar.SECOND, 0); calendar.set(Calendar.SECOND, 0);
calendar.set(Calendar.MILLISECOND, 0); calendar.set(Calendar.MILLISECOND, 0);
if(listMessages.get(position).received.after(calendar.getTime())) if (listMessages.get(position).received.after(calendar.getTime()))
sdf = new SimpleDateFormat("HH:mm:ss"); sdf = new SimpleDateFormat("HH:mm:ss");
else else
sdf = new SimpleDateFormat("MMM-dd HH:mm"); sdf = new SimpleDateFormat("MMM-dd HH:mm");
view.txtViewDateTime.setText(sdf.format(listMessages.get(position).received)); view.txtViewDateTime.setText(sdf.format(listMessages.get(position).received));
} } catch (Exception ex) {
catch(Exception ex)
{
SM.Exception(ex.toString()); SM.Exception(ex.toString());
} }
return convertView; return convertView;
} }
public int getIcon(int user_type, String username)
{
// if request was send by MessagesActivity -> Spinner
if(user_type == -1)
{
// get unit_type for selected username
for (Msg mes: listMessages)
{
// if user is selected
if(mes.from.name.equals(username))
{
user_type = (int) mes.from.driver_id; // save user_type
return mes.from.getLargeIcon();
}
}
}
return 0;
}
} }

View File

@ -1,215 +0,0 @@
package com.safemobile.adapters;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Calendar;
import java.util.Date;
import java.util.Hashtable;
import java.util.Locale;
import android.app.Activity;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.TextView;
import com.safemobile.lib.R;
import com.safemobile.lib.SM;
import com.safemobile.libpad.PadTextMessage;
public class PadConversationGridViewAdapter extends BaseAdapter
{
private ArrayList<PadTextMessage> listMessages;
private Activity activity;
//public String time;
private ArrayList<Boolean> outgoingPositions = new ArrayList<Boolean>();
private ArrayList<Boolean> ackPositions = new ArrayList<Boolean>();
private Hashtable<Integer, View> hash = new Hashtable<Integer, View>();
public PadConversationGridViewAdapter(Activity activity, ArrayList<PadTextMessage> listMessages, Context context, ArrayList<Boolean> outgoingPositions, ArrayList<Boolean> ackPositions) {
this.activity = activity;
this.listMessages = listMessages;
this.outgoingPositions = outgoingPositions;
this.ackPositions = ackPositions;
}
@Override
public int getCount() {
return listMessages.size();
}
@Override
public PadTextMessage getItem(int position) {
return listMessages.get(position);
}
@Override
public long getItemId(int position) {
return 0;
}
/** return the list of messages in the adapter
* @return an ArrayList of PadTextMessages
*/
public ArrayList<PadTextMessage> getMessages() {
return listMessages;
}
public static class ViewHolder
{
public ImageView imgViewContact;
public TextView txtViewMsg;
public TextView txtViewDateTime;
public ImageView imgViewReceivedContact;
public TextView txtViewReceivedMsg;
public TextView txtViewReceivedDateTime;
public ImageView imageAck;
public TextView textViewNotACK;
public LinearLayout layoutSend;
public LinearLayout layoutReceived;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder view;
LayoutInflater inflator = activity.getLayoutInflater();
if(convertView==null)
{
view = new ViewHolder();
convertView = inflator.inflate(R.layout.row_conversation, null);
view.imgViewContact = (ImageView) convertView.findViewById(R.id.imageViewSenderIco);
view.txtViewMsg = (TextView) convertView.findViewById(R.id.textViewSendMsg);
view.txtViewDateTime = (TextView) convertView.findViewById(R.id.textViewSendDate);
view.imgViewReceivedContact = (ImageView) convertView.findViewById(R.id.imageViewReceivedIco);
view.txtViewReceivedMsg = (TextView) convertView.findViewById(R.id.textViewReceivedMsg);
view.txtViewReceivedDateTime = (TextView) convertView.findViewById(R.id.textViewReceivedDate);
view.layoutSend = (LinearLayout) convertView.findViewById(R.id.layoutSend);
view.layoutReceived = (LinearLayout) convertView.findViewById(R.id.layoutReceived);
view.textViewNotACK = (TextView) convertView.findViewById(R.id.textViewNotACKSendMsg);
view.imageAck = (ImageView) convertView.findViewById(R.id.imageAck);
convertView.setTag(view);
}
else
{
view = (ViewHolder) convertView.getTag();
}
try
{
hash.put(position, convertView);
SimpleDateFormat sdf = new SimpleDateFormat("HH:mm MMM-dd", Locale.getDefault());
Calendar calendar = Calendar.getInstance();
calendar.set(Calendar.HOUR_OF_DAY,0);
calendar.set(Calendar.MINUTE, 0);
calendar.set(Calendar.SECOND, 0);
calendar.set(Calendar.MILLISECOND, 0);
Date date = new Date(listMessages.get(position).timeGMT * 1000);
if(date.after(calendar.getTime()))
sdf = new SimpleDateFormat("HH:mm:ss", Locale.getDefault());
else
sdf = new SimpleDateFormat("HH:mm MMM-dd", Locale.getDefault());
// set gmt time
//sdf.setTimeZone(TimeZone.getTimeZone("GMT"));
//view.imgViewContact.setImageResource(getIcon(listMessages.get(position).from.user_type));
view.imgViewContact.setImageResource(R.drawable.peoplegreen_large);
view.txtViewMsg.setText(listMessages.get(position).message);
view.txtViewDateTime.setText(sdf.format(date));
//view.imgViewReceivedContact.setImageResource(getIcon(listMessages.get(position).from.user_type));
view.imgViewReceivedContact.setImageResource(R.drawable.peopleblue_large);
view.txtViewReceivedMsg.setText(listMessages.get(position).message);
view.txtViewReceivedDateTime.setText(sdf.format(date));
if(ackPositions.size() > 0)
switch(ackPositions.get(position) ? 1: 0) {
case 0:
// show not ack
view.textViewNotACK.setVisibility(View.VISIBLE);
view.imageAck.setVisibility(View.VISIBLE);
break;
case 1:
// show not ack
view.textViewNotACK.setVisibility(View.INVISIBLE);
view.imageAck.setVisibility(View.INVISIBLE);
}
switch(outgoingPositions.get(position) ? 1 : 0) {
case 1:
view.layoutReceived.setVisibility(View.GONE);
view.layoutSend.setVisibility(View.VISIBLE);
break;
case 0:
view.layoutReceived.setVisibility(View.VISIBLE);
view.layoutSend.setVisibility(View.GONE);
break;
}
}
catch(Exception ex)
{
SM.Exception(ex.toString());
}
return convertView;
}
/*
public void setACK(String seqID)
{
int position = -1, i=0;
for(Msg msg: listMessages)
{
if(msg.seqID.equals(seqID))
position = i;
i++;
}
ackPositions.remove(position);
ackPositions.add(position, true);
}
public void changeView(String seqID)
{
int position = -1, i=0;
for(Msg msg: listMessages)
{
if(msg.seqID.equals(seqID))
position = i;
i++;
}
if(position != -1 && hash.size() > position)
{
SM.Debug("POSITON : " + position);
View con = hash.get(position);
ViewHolder view = (ViewHolder) con.getTag();
switch(ackPositions.get(position) ? 1 : 0)
{
case 1:
view.imageAck.setVisibility(View.INVISIBLE);
view.textViewNotACK.setVisibility(View.INVISIBLE);
break;
case 0:
view.imageAck.setVisibility(View.VISIBLE);
view.textViewNotACK.setVisibility(View.VISIBLE);
break;
}
}
}
*/
}

View File

@ -21,36 +21,28 @@ public class SuperVehicle extends Vehicle{
// TODO Auto-generated constructor stub // TODO Auto-generated constructor stub
} }
public void SetDataFromLastPos(Double _lat,Double _lng,long _time,int _speed,String _Address,Boolean _isON) public void SetDataFromLastPos(Double _lat,Double _lng,long _time,int _speed,String _Address,Boolean _isON) {
{ try {
try
{
lat = _lat; lat = _lat;
lng = _lng; lng = _lng;
timeGMT = _time; timeGMT = _time;
speed = _speed; speed = _speed;
Address = _Address; Address = _Address;
isON = _isON; isON = _isON;
} } catch (Exception ex) {
catch (Exception ex) Log.d("Erorr", "Contert Error: "+ ex);
{
Log.d("Erorr", "Contert Error:"+ex.toString());
} }
} }
public void SetNewPosition(Double _lat,Double _lng,long _time,int _speed) public void SetNewPosition(Double _lat,Double _lng,long _time,int _speed) {
{ try {
try
{
lat = _lat; lat = _lat;
lng = _lng; lng = _lng;
timeGMT = _time; timeGMT = _time;
speed = _speed; speed = _speed;
isON = true; isON = true;
} } catch (Exception ex) {
catch (Exception ex) Log.d("Erorr", "Contert Error: " + ex);
{
Log.d("Erorr", "Contert Error:"+ex.toString());
} }
} }

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.0 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 16 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.1 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 22 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 19 KiB

View File

@ -0,0 +1,140 @@
<?xml version="1.0" encoding="utf-8"?><!--
Copyright (C) 2012 The Android Open Source Project
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.
-->
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
xmlns:tools="http://schemas.android.com/tools"
android:background="@drawable/custom_info_bubble"
android:paddingLeft="7dp"
android:paddingRight="7dp"
android:paddingTop="9dp"
android:orientation="vertical">
<LinearLayout
android:id="@+id/containerTop"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@drawable/l_bg_gps"
android:orientation="vertical">
<TextView
android:id="@+id/tvUnitName"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:ellipsize="end"
android:fontFamily="sans-serif-smallcaps"
android:maxLines="1"
android:paddingTop="5dp"
tools:text="Linux 9910"
android:textColor="#FFFFFF"
android:textSize="18sp"
android:textStyle="bold" />
<TextView
android:id="@+id/tvGPSLocation"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:ellipsize="end"
android:fontFamily="sans-serif-smallcaps"
android:maxLines="1"
tools:text="[44.41857,26.09585]"
android:textColor="#FFFFFF"
android:textSize="10sp"
tools:ignore="SmallSp" />
</LinearLayout>
<RelativeLayout
android:layout_width="225dp"
android:layout_height="wrap_content"
android:padding="10dp"
android:id="@+id/rlMapInfoBubbleInfo">
<ImageView
android:id="@+id/time"
android:layout_width="24dp"
android:layout_height="24dp"
android:layout_marginRight="5dp"
android:adjustViewBounds="true"
android:src="@drawable/l_time"
android:layout_marginEnd="5dp" />
<TextView
android:id="@+id/tvTimeAgo"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignBottom="@+id/time"
android:layout_alignTop="@+id/time"
android:layout_gravity="center_horizontal"
android:layout_toEndOf="@+id/time"
android:layout_toRightOf="@+id/time"
android:ellipsize="end"
android:gravity="center_vertical"
android:maxLines="1"
tools:text="a year ago [01:05:01]"
android:textColor="#ff000000"
android:textSize="10sp" />
<ImageView
android:id="@+id/speed"
android:layout_width="24dp"
android:layout_height="24dp"
android:layout_below="@+id/time"
android:layout_marginRight="5dp"
android:layout_marginTop="5dp"
android:adjustViewBounds="true"
android:src="@drawable/l_speed" />
<TextView
android:id="@+id/tvSpeed"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignBottom="@+id/speed"
android:layout_alignTop="@+id/speed"
android:layout_gravity="center_horizontal"
android:layout_toRightOf="@+id/speed"
android:ellipsize="end"
android:gravity="center_vertical"
android:maxLines="1"
tools:text="24 kph"
android:textColor="#ff000000"
android:textSize="10sp" />
<ImageView
android:id="@+id/streetView"
android:layout_width="24dp"
android:layout_height="24dp"
android:layout_below="@+id/speed"
android:layout_marginTop="5dp"
android:layout_marginRight="5dp"
android:adjustViewBounds="true"
android:src="@drawable/l_street"
android:visibility="visible" />
<TextView
android:id="@+id/tvStreetView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignTop="@+id/streetView"
android:layout_gravity="center_horizontal"
android:layout_toRightOf="@+id/streetView"
android:ellipsize="end"
android:gravity="center_vertical"
android:maxLines="5"
tools:text="3601 E Algonquin Rd., Suite 800 Rolling Meadows, IL 60008"
android:textColor="#ff000000"
android:textSize="10sp"
android:visibility="visible" />
</RelativeLayout>
</LinearLayout>

View File

@ -1,5 +1,6 @@
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="fill_parent" android:layout_width="fill_parent"
android:layout_height="fill_parent" android:layout_height="fill_parent"
android:orientation="vertical" android:orientation="vertical"
@ -53,7 +54,7 @@
android:layout_width="fill_parent" android:layout_width="fill_parent"
android:layout_height="wrap_content"> android:layout_height="wrap_content">
<ImageView <ImageView
android:id="@+id/imageAckSendMsg" android:id="@+id/imageAck"
android:layout_width="wrap_content" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:adjustViewBounds="true" android:adjustViewBounds="true"
@ -61,16 +62,18 @@
android:paddingTop="2dp" android:paddingTop="2dp"
android:src="@drawable/exclamation_small" android:src="@drawable/exclamation_small"
android:layout_weight="0" android:layout_weight="0"
android:visibility="invisible"/> android:visibility="invisible"
tools:ignore="DuplicateIds" />
<TextView <TextView
android:id="@+id/textViewNotACKSendMsg" android:id="@+id/textViewNotACK"
android:layout_width="fill_parent" android:layout_width="fill_parent"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:text="@string/notAck" android:text="@string/notAck"
android:textColor="#000000" android:textColor="#000000"
android:textSize="13dp" android:textSize="13dp"
android:layout_toRightOf="@+id/imageAck" android:layout_toRightOf="@+id/imageAck"
android:visibility="invisible" /> android:visibility="invisible"
tools:ignore="DuplicateIds" />
<TextView <TextView
android:id="@+id/textViewSendDate" android:id="@+id/textViewSendDate"
android:layout_width="wrap_content" android:layout_width="wrap_content"
@ -113,7 +116,7 @@
android:layout_width="fill_parent" android:layout_width="fill_parent"
android:layout_height="wrap_content"> android:layout_height="wrap_content">
<ImageView <ImageView
android:id="@+id/imageAckReceiveMsg" android:id="@+id/imageAck"
android:layout_width="wrap_content" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:adjustViewBounds="true" android:adjustViewBounds="true"
@ -121,16 +124,18 @@
android:paddingTop="2dp" android:paddingTop="2dp"
android:src="@drawable/exclamation_small" android:src="@drawable/exclamation_small"
android:layout_weight="0" android:layout_weight="0"
android:visibility="invisible"/> android:visibility="invisible"
tools:ignore="DuplicateIds" />
<TextView <TextView
android:id="@+id/textViewNotACKReceiveMsg" android:id="@+id/textViewNotACK"
android:layout_width="fill_parent" android:layout_width="fill_parent"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:text="@string/notAck" android:text="@string/notAck"
android:textColor="#000000" android:textColor="#000000"
android:textSize="13dp" android:textSize="13dp"
android:layout_toRightOf="@+id/imageAck" android:layout_toRightOf="@+id/imageAck"
android:visibility="invisible"/> android:visibility="invisible"
tools:ignore="DuplicateIds" />
<TextView <TextView
android:id="@+id/textViewReceivedDate" android:id="@+id/textViewReceivedDate"
android:layout_width="wrap_content" android:layout_width="wrap_content"

View File

@ -0,0 +1,5 @@
<?xml version="1.0" encoding="utf-8"?>
<resources>
<color name="white">#FFFFFF</color>
<color name="black">#000000</color>
</resources>

View File

@ -167,11 +167,11 @@ public class AlarmActivity extends Activity {
{ {
acknowledged.add((alarm.ack == 1)? true: false); acknowledged.add((alarm.ack == 1)? true: false);
SM.Debug("ALARM", "SC_ID> " + alarm.sc_id + " | " SM.Debug("ALARM", "SC_ID> " + alarm.sc_id + " | "
+ (parentTab.VehHashbySc_id.get(alarm.sc_id) == null ? "null" : parentTab.VehHashbySc_id.get(alarm.sc_id).name )); + (parentTab.getVehHashByScId().get(alarm.sc_id) == null ? "null" : parentTab.getVehHashByScId().get(alarm.sc_id).name ));
if (parentTab.VehHashbySc_id.get(alarm.sc_id)!=null) if (parentTab.getVehHashByScId().get(alarm.sc_id)!=null)
alarm.unitName = parentTab.VehHashbySc_id.get(alarm.sc_id).name; alarm.unitName = parentTab.getVehHashByScId().get(alarm.sc_id).name;
@ -254,6 +254,6 @@ public class AlarmActivity extends Activity {
private void setACK(int idx, int type) private void setACK(int idx, int type)
{ {
parentTab.executeNetworkStuff(new String[]{OperationCodes.SendAlarmAcknoledge +"", idx + "", type + ""}); parentTab.executeNetworkStuff(new String[]{OperationCodes.SendAlarmAcknoledge +"", idx + "", type + ""});
//parentTab.sendAlarmAcknoledge(idx, type); //parentTab.sendAlarmAcknowledge(idx, type);
} }
} }

View File

@ -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) + "]");
}
}

View File

@ -3,18 +3,145 @@ package com.safemobile.dispatch;
import androidx.appcompat.app.AppCompatActivity; import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle; import android.os.Bundle;
import android.widget.ArrayAdapter;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.Spinner;
import android.widget.TextView;
import com.google.android.gms.maps.GoogleMap;
import com.google.android.gms.maps.SupportMapFragment;
import com.safemobile.lib.AppParams;
import com.safemobile.lib.SM; import com.safemobile.lib.SM;
import com.safemobile.lib.Vehicle;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Calendar;
import java.util.Date;
import java.util.Locale;
public class HistoryActivity extends AppCompatActivity { public class HistoryActivity extends AppCompatActivity {
public Bundle savedInstanceState; public Bundle savedInstanceState;
private TabLayoutActivity parentTab;
private GoogleMap googleMap;
private Spinner spinnerVehicle;
private ImageView changeMapType, checkTraffic, slideLayoutImage;
private LinearLayout layoutTraffic, slidelayout, layoutVehicles;
private ArrayList<Vehicle> allVehicle = new ArrayList<>();
private ArrayList<String> allVehicleNames = new ArrayList<>();
private ArrayAdapter<String> adapter;
private boolean showVehicle = true;
@Override @Override
protected void onCreate(Bundle savedInstanceState) { protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState); super.onCreate(savedInstanceState);
this.savedInstanceState = savedInstanceState; this.savedInstanceState = savedInstanceState;
setContentView(R.layout.tabhistory); setContentView(R.layout.tabhistory);
parentTab = (TabLayoutActivity) getParent();
parentTab.historyActivity = this;
Locale locale = new Locale(AppParams.LANGUAGETMP);
Locale.setDefault(locale);
googleMap = parentTab.liveActivity.getMap();
SupportMapFragment mapFragment = (SupportMapFragment) getSupportFragmentManager()
.findFragmentById(R.id.map);
spinnerVehicle = findViewById(R.id.spinnerVehicle);
getVehicles();
adapter = new ArrayAdapter<>(this, android.R.layout.simple_spinner_item, allVehicleNames);
adapter.setDropDownViewResource(android.R.layout.simple_dropdown_item_1line);
spinnerVehicle.setAdapter(adapter);
spinnerVehicle.setSelection(0);
changeMapType();
changeTraffic();
slidelayout = findViewById(R.id.slidelayout);
slideLayoutImage = findViewById(R.id.slideLayoutImage);
layoutVehicles = findViewById(R.id.layoutBig);
// slidelayout.setOnTouchListener((v, event) -> {
// if (showVehicle) {
// layoutVehicles.setVisibility(View.GONE);
// slideLayoutImage.setImageResource(R.drawable.arrow_right);
// showVehicle = false;
// } else {
// layoutVehicles.setVisibility(View.VISIBLE);
// slideLayoutImage.setImageResource(R.drawable.arrow_left);
// showVehicle = true;
// }
// return false;
// });
setDate();
}
private void setDate() {
Calendar calendar = Calendar.getInstance();
Date endDate = calendar.getTime();
calendar.add(Calendar.DATE, -1);
Date startDate = calendar.getTime();
LinearLayout layoutStartPicker = findViewById(R.id.layoutStartPicker);
TextView textViewDate = findViewById(R.id.textViewStartDate);
textViewDate.setText(new SimpleDateFormat("HH:mm, dd.MM.yyyy").format(startDate));
// layoutStartPicker.setOnTouchListener((v, event) -> {
// showDialog(layoutStartPicker);
// return false;
// });
// layoutEndPicker.setOnTouchListener(new OnTouchListener() {
// @Override
// public boolean onTouch(View v, MotionEvent event) {
// showDialog(layoutEndPicker);
// return false;
// }
// });
}
private void changeTraffic() {
ImageView changeTrafficImageView = findViewById(R.id.changeTraffic);
changeTrafficImageView.setOnClickListener(v -> {
if (googleMap.isTrafficEnabled()) {
changeTrafficImageView.setImageResource(R.drawable.traffic_off);
googleMap.setTrafficEnabled(false);
} else {
changeTrafficImageView.setImageResource(R.drawable.traffic);
googleMap.setTrafficEnabled(true);
}
});
}
private void changeMapType() {
changeMapType = findViewById(R.id.changeMapType);
ImageView changeMapTypeImageView = findViewById(R.id.changeMapType);
changeMapType.setOnClickListener(view -> {
if (googleMap.getMapType() == GoogleMap.MAP_TYPE_SATELLITE) {
changeMapTypeImageView.setImageResource(R.drawable.satellite);
googleMap.setMapType(GoogleMap.MAP_TYPE_SATELLITE);
} else {
changeMapTypeImageView.setImageResource(R.drawable.map);
googleMap.setMapType(GoogleMap.MAP_TYPE_NORMAL);
}
});
}
public void getVehicles() {
try {
for (Vehicle vehicle : parentTab.getAllVehicle()) {
allVehicleNames.add(vehicle.name);
allVehicle.add(vehicle);
}
} catch (Exception ex) { }
} }
public void UpdateMap() { public void UpdateMap() {

View File

@ -42,9 +42,8 @@ public class IconContextMenu implements DialogInterface.OnCancelListener,
private static final int LIST_PREFERED_HEIGHT = 65; private static final int LIST_PREFERED_HEIGHT = 65;
private IconMenuAdapter menuAdapter = null; private IconMenuAdapter menuAdapter;
private Activity parentActivity = null; private Activity parentActivity;
private int dialogId = 0;
private IconContextMenuOnClickListener clickHandler = null; private IconContextMenuOnClickListener clickHandler = null;
@ -55,7 +54,6 @@ public class IconContextMenu implements DialogInterface.OnCancelListener,
*/ */
public IconContextMenu(Activity parent, int id) { public IconContextMenu(Activity parent, int id) {
this.parentActivity = parent; this.parentActivity = parent;
this.dialogId = id;
menuAdapter = new IconMenuAdapter(parentActivity); menuAdapter = new IconMenuAdapter(parentActivity);
} }
@ -89,19 +87,13 @@ public class IconContextMenu implements DialogInterface.OnCancelListener,
public Dialog createMenu(String menuItitle) { public Dialog createMenu(String menuItitle) {
final AlertDialog.Builder builder = new AlertDialog.Builder(parentActivity); final AlertDialog.Builder builder = new AlertDialog.Builder(parentActivity);
builder.setTitle(menuItitle); builder.setTitle(menuItitle);
builder.setAdapter(menuAdapter, new DialogInterface.OnClickListener() { builder.setAdapter(menuAdapter, (dialoginterface, i) -> {
@Override
public void onClick(DialogInterface dialoginterface, int i) {
IconContextMenuItem item = (IconContextMenuItem) menuAdapter.getItem(i); IconContextMenuItem item = (IconContextMenuItem) menuAdapter.getItem(i);
if (clickHandler != null)
if (clickHandler != null) {
clickHandler.onClick(item.actionTag); clickHandler.onClick(item.actionTag);
}
}
}); });
builder.setInverseBackgroundForced(true); builder.setInverseBackgroundForced(true);
AlertDialog dialog = builder.create(); AlertDialog dialog = builder.create();
dialog.setOnCancelListener(this); dialog.setOnCancelListener(this);
dialog.setOnDismissListener(this); dialog.setOnDismissListener(this);
@ -117,7 +109,7 @@ public class IconContextMenu implements DialogInterface.OnCancelListener,
} }
private void cleanup() { private void cleanup() {
parentActivity.dismissDialog(dialogId); // parentActivity.dismissDialog(dialogId);
} }
/** /**
@ -131,7 +123,7 @@ public class IconContextMenu implements DialogInterface.OnCancelListener,
* Menu-like list adapter with icon * Menu-like list adapter with icon
*/ */
protected class IconMenuAdapter extends BaseAdapter { protected class IconMenuAdapter extends BaseAdapter {
private Context context = null; private Context context;
private ArrayList<IconContextMenuItem> mItems = new ArrayList<IconContextMenuItem>(); private ArrayList<IconContextMenuItem> mItems = new ArrayList<IconContextMenuItem>();
@ -193,6 +185,7 @@ public class IconContextMenu implements DialogInterface.OnCancelListener,
textView.setTag(item); textView.setTag(item);
textView.setText(item.text); textView.setText(item.text);
textView.setCompoundDrawablesWithIntrinsicBounds(item.image, null, null, null); textView.setCompoundDrawablesWithIntrinsicBounds(item.image, null, null, null);
textView.setTextColor(R.color.black);
return textView; return textView;
} }

View File

@ -9,13 +9,19 @@ import android.content.Intent;
import android.content.IntentFilter; import android.content.IntentFilter;
import android.content.res.Configuration; import android.content.res.Configuration;
import android.content.res.Resources; import android.content.res.Resources;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Matrix;
import android.graphics.Paint;
import android.graphics.Rect;
import android.graphics.Typeface; import android.graphics.Typeface;
import android.os.Bundle; import android.os.Bundle;
import android.os.Handler; import android.os.Handler;
import android.os.Looper; import android.os.Looper;
import android.view.View; import android.view.View;
import android.view.Window; import android.view.Window;
import android.widget.AdapterView;
import android.widget.Button; import android.widget.Button;
import android.widget.GridView; import android.widget.GridView;
import android.widget.ImageButton; import android.widget.ImageButton;
@ -26,11 +32,13 @@ import android.widget.Toast;
import androidx.annotation.NonNull; import androidx.annotation.NonNull;
import com.google.android.gms.maps.CameraUpdateFactory;
import com.google.android.gms.maps.GoogleMap; import com.google.android.gms.maps.GoogleMap;
import com.google.android.gms.maps.OnMapReadyCallback; import com.google.android.gms.maps.OnMapReadyCallback;
import com.google.android.gms.maps.SupportMapFragment; import com.google.android.gms.maps.SupportMapFragment;
import com.google.android.gms.maps.model.BitmapDescriptor;
import com.google.android.gms.maps.model.BitmapDescriptorFactory;
import com.google.android.gms.maps.model.LatLng; import com.google.android.gms.maps.model.LatLng;
import com.google.android.gms.maps.model.Marker;
import com.google.android.gms.maps.model.MarkerOptions; import com.google.android.gms.maps.model.MarkerOptions;
import com.safemobile.activities.AbstractLiveActivity; import com.safemobile.activities.AbstractLiveActivity;
import com.safemobile.activities.AbstractSDParentActivity; import com.safemobile.activities.AbstractSDParentActivity;
@ -94,6 +102,7 @@ public class LiveActivity extends AbstractLiveActivity implements OnMapReadyCall
//value poll //value poll
private double latPoll = 0; private double latPoll = 0;
private double lngPoll = 0; private double lngPoll = 0;
private ArrayList<Marker> markers = new ArrayList<>();
@Override @Override
@ -130,12 +139,11 @@ public class LiveActivity extends AbstractLiveActivity implements OnMapReadyCall
mapFragment.getMapAsync(this); mapFragment.getMapAsync(this);
} }
// create on vehicle long click menu // create on vehicle long click menu
createIconContextMenu(); createIconContextMenu();
// image View for changing map type satellite or map // image View for changing map type satellite or map
ImageView changeMapTypeImageView = (ImageView) findViewById(R.id.changeMapType); ImageView changeMapTypeImageView = findViewById(R.id.changeMapType);
changeMapTypeImageView.setOnClickListener(v -> { changeMapTypeImageView.setOnClickListener(v -> {
if (googleMap.getMapType() == GoogleMap.MAP_TYPE_SATELLITE) { if (googleMap.getMapType() == GoogleMap.MAP_TYPE_SATELLITE) {
changeMapTypeImageView.setImageResource(R.drawable.satellite); changeMapTypeImageView.setImageResource(R.drawable.satellite);
@ -146,7 +154,7 @@ public class LiveActivity extends AbstractLiveActivity implements OnMapReadyCall
} }
}); });
ImageView changeTrafficImageView = (ImageView) findViewById(R.id.changeTraffic); ImageView changeTrafficImageView = findViewById(R.id.changeTraffic);
changeTrafficImageView.setOnClickListener(v -> { changeTrafficImageView.setOnClickListener(v -> {
if (googleMap.isTrafficEnabled()) { if (googleMap.isTrafficEnabled()) {
changeTrafficImageView.setImageResource(R.drawable.traffic_off); changeTrafficImageView.setImageResource(R.drawable.traffic_off);
@ -158,21 +166,21 @@ public class LiveActivity extends AbstractLiveActivity implements OnMapReadyCall
}); });
// change tab header font // change tab header font
TextView textView1 = (TextView) findViewById(R.id.textView1); TextView textView1 = findViewById(R.id.textView1);
textView1.setTypeface(Typeface.createFromAsset(getAssets(), "Sketch_Block.ttf")); textView1.setTypeface(Typeface.createFromAsset(getAssets(), "Sketch_Block.ttf"));
textView1.setTextSize(24); textView1.setTextSize(24);
// get grid view and set empty data adapter // get grid view and set empty data adapter
gridVehicle = (GridView) findViewById(R.id.gridVehicle); gridVehicle = findViewById(R.id.gridVehicle);
if (AppParams.DEMO) { if (AppParams.DEMO) {
disabledVehicles = new ArrayList<>(); disabledVehicles = new ArrayList<>();
for (Vehicle veh : getParentTab().allVehicle) for (Vehicle veh : getParentTab().getAllVehicle())
disabledVehicles.add(!veh.status); disabledVehicles.add(!veh.status);
} }
adapter = new VehiclesGridViewAdapter(activity, context, getParentTab().allVehicle, disabledVehicles); adapter = new VehiclesGridViewAdapter(activity, context, getParentTab().getAllVehicle(), disabledVehicles);
adapter.notifyDataSetChanged(); adapter.notifyDataSetChanged();
gridVehicle.setAdapter(adapter); gridVehicle.setAdapter(adapter);
@ -185,14 +193,16 @@ public class LiveActivity extends AbstractLiveActivity implements OnMapReadyCall
threadUI.start(); threadUI.start();
}); });
// get vehicle menu creation // get vehicle menu creation
gridVehicle.setOnItemLongClickListener(itemLongClickHandler); gridVehicle.setOnItemLongClickListener((adapterView, view, i, l) -> {
contextMenuPosition = position;
iconContextMenu.createMenu(getString(R.string.options)).show();
return true;
});
LinearLayout slideLayout = findViewById(R.id.slidelayout);
LinearLayout slideLayout = (LinearLayout) findViewById(R.id.slidelayout); ImageView slideLayoutImageView = findViewById(R.id.slideLayoutImage);
ImageView slideLayoutImageView = (ImageView) findViewById(R.id.slideLayoutImage); LinearLayout linearLayoutVehicles = findViewById(R.id.layoutBig);
LinearLayout linearLayoutVehicles = (LinearLayout) findViewById(R.id.layoutBig);
slideLayout.setOnClickListener(v -> { slideLayout.setOnClickListener(v -> {
if (showVehicle) { if (showVehicle) {
linearLayoutVehicles.setVisibility(View.GONE); linearLayoutVehicles.setVisibility(View.GONE);
@ -205,7 +215,7 @@ public class LiveActivity extends AbstractLiveActivity implements OnMapReadyCall
} }
}); });
imageViewCheckAll = (ImageButton) findViewById(R.id.imageCheckAll); imageViewCheckAll = findViewById(R.id.imageCheckAll);
imageViewCheckAll.setSelected(false); imageViewCheckAll.setSelected(false);
imageViewCheckAll.setOnClickListener(arg0 -> { imageViewCheckAll.setOnClickListener(arg0 -> {
for (int i = 0; i < displayedVehicles.size(); i++) for (int i = 0; i < displayedVehicles.size(); i++)
@ -221,9 +231,9 @@ public class LiveActivity extends AbstractLiveActivity implements OnMapReadyCall
else else
viewLive.imgViewChecked.setImageResource(R.drawable.unchecked); viewLive.imgViewChecked.setImageResource(R.drawable.unchecked);
Enumeration<Long> keyList = getParentTab().SuperVehHash.keys(); Enumeration<Long> keyList = getParentTab().getSuperVehHash().keys();
while (keyList.hasMoreElements()) { while (keyList.hasMoreElements()) {
(Objects.requireNonNull(getParentTab().SuperVehHash.get((long) keyList.nextElement()))).needUpdate = true; (Objects.requireNonNull(getParentTab().getSuperVehHash().get(keyList.nextElement()))).needUpdate = true;
} }
// change button title // change button title
@ -247,7 +257,7 @@ public class LiveActivity extends AbstractLiveActivity implements OnMapReadyCall
displayVehicle(true, LAT_OUTLIMIT, LNG_OUTLIMIT); displayVehicle(true, LAT_OUTLIMIT, LNG_OUTLIMIT);
}); });
displayButton = (Button) findViewById(R.id.buttonDisplay); displayButton = findViewById(R.id.buttonDisplay);
displayButton.setText(getString(R.string.displayAll)); displayButton.setText(getString(R.string.displayAll));
@ -257,9 +267,9 @@ public class LiveActivity extends AbstractLiveActivity implements OnMapReadyCall
for (int i = 0; i < displayedVehicles.size(); i++) for (int i = 0; i < displayedVehicles.size(); i++)
displayedVehicles.set(i, true); displayedVehicles.set(i, true);
Enumeration<Long> keyList = getParentTab().SuperVehHash.keys(); Enumeration<Long> keyList = getParentTab().getSuperVehHash().keys();
while (keyList.hasMoreElements()) while (keyList.hasMoreElements())
(Objects.requireNonNull(getParentTab().SuperVehHash.get((long) keyList.nextElement()))).needUpdate = true; (Objects.requireNonNull(getParentTab().getSuperVehHash().get(keyList.nextElement()))).needUpdate = true;
// change button title // change button title
if (displayButton.getText().toString().equals(getString(R.string.displayAll))) { if (displayButton.getText().toString().equals(getString(R.string.displayAll))) {
@ -297,11 +307,8 @@ public class LiveActivity extends AbstractLiveActivity implements OnMapReadyCall
@Override @Override
public void onMapReady(@NonNull GoogleMap googleMap) { public void onMapReady(@NonNull GoogleMap googleMap) {
this.googleMap = googleMap; this.googleMap = googleMap;
GoogleMapsInfoBubble infoBubble = new GoogleMapsInfoBubble(getLayoutInflater(), this, getParentTab().getSuperVehHash());
// Add a marker in Sydney and move the camera this.googleMap.setInfoWindowAdapter(infoBubble);
LatLng sydney = new LatLng(-34, 151);
this.googleMap.addMarker(new MarkerOptions().position(sydney).title("Marker in Sydney"));
this.googleMap.moveCamera(CameraUpdateFactory.newLatLng(sydney));
} }
@ -419,7 +426,7 @@ public class LiveActivity extends AbstractLiveActivity implements OnMapReadyCall
// send change to AppServer // send change to AppServer
optionForUnit(radioCode, MENU_POLL, liveVehicle.get(contextMenuPosition).id + ""); optionForUnit(radioCode, MENU_POLL, liveVehicle.get(contextMenuPosition).id + "");
if (AppParams.DEMO) { if (AppParams.DEMO) {
getParentTab().imei = liveVehicle.get(contextMenuPosition).sc_id + ""; getParentTab().setImei(liveVehicle.get(contextMenuPosition).sc_id + "");
getParentTab().updateDemoPosition(); getParentTab().updateDemoPosition();
getParentTab().updateResultsPollInUi("realpha"); getParentTab().updateResultsPollInUi("realpha");
} }
@ -433,36 +440,101 @@ public class LiveActivity extends AbstractLiveActivity implements OnMapReadyCall
}); });
} }
/**
* create context menu
*/
@Override
public Dialog onCreateDialog(int id) {
if (id == 1) {
return iconContextMenu.createMenu(getString(R.string.options));
}
return super.onCreateDialog(id);
}
/* list item long click handler
* used to show the context menu
*/
private final AdapterView.OnItemLongClickListener itemLongClickHandler = ((parent, view, position, id) -> {
// save position
contextMenuPosition = position;
showDialog(1);
return true;
});
public void displayVehicle(boolean withZoom, double latZoom, double lngZoom) { public void displayVehicle(boolean withZoom, double latZoom, double lngZoom) {
//TODO: add makers for vehicles if (googleMap != null) {
String openWindow = "";
for (Marker marker : markers) {
if (marker.isInfoWindowShown()) {
openWindow = marker.getTitle();
}
}
googleMap.clear();
for (int i = 0; i < displayedVehicles.size(); i++) {
if (displayedVehicles.get(i)) {
SuperVehicle tmpSuper = getParentTab().getSuperVehHash().get(Long.valueOf(liveVehicle.get(i).imei));
if (tmpSuper != null) {
LatLng newLocation = new LatLng(tmpSuper.lat, tmpSuper.lng);
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);
if (openWindow.equals(marker.getTitle()))
marker.showInfoWindow();
markers.add(marker);
}
}
}
}
} }
public void showOpenedBalloon(boolean demo) { public void showOpenedBalloon(boolean demo) {
//TODO: add show balloon //TODO: add show balloon
} }
private BitmapDescriptor getProperBitmap(int largeIcon, String text) {
Bitmap bitmap = BitmapFactory.decodeResource(getResources(), largeIcon);
Bitmap textBitmap = getTextAsDrawable(this, text);
Bitmap b3 = overlay(bitmap, textBitmap);
return BitmapDescriptorFactory.fromBitmap(b3);
}
public static Bitmap overlay(Bitmap bmp1, Bitmap bmp2) {
int maxWidth = Math.max(bmp1.getWidth(), bmp2.getWidth());
Bitmap bmOverlay = Bitmap.createBitmap(maxWidth, bmp1.getHeight() + bmp2.getHeight(), bmp1.getConfig());
Canvas canvas = new Canvas(bmOverlay);
canvas.drawBitmap(bmp1, new Matrix(), null);
canvas.drawBitmap(bmp2, 0, bmp1.getHeight(), null);
bmp1.recycle();
bmp2.recycle();
return bmOverlay;
}
public Bitmap getTextAsDrawable(Context context, String text) {
Typeface tf = Typeface.create("Helvetica", Typeface.BOLD);
Paint paint = new Paint(Paint.ANTI_ALIAS_FLAG);
paint.setColor(Color.WHITE);
paint.setTypeface(tf);
paint.setTextSize(convertToPixels(context, 16));
Rect textRect = new Rect();
paint.getTextBounds(text, 0, text.length(), textRect);
Bitmap bitmap = Bitmap.createBitmap(textRect.width(), textRect.height() + 5,
Bitmap.Config.ARGB_8888);
Canvas canvas = new Canvas(bitmap);
paint.setColor(getResources().getColor(R.color.cardview_dark_background));
canvas.drawRect(0, 0, bitmap.getWidth(), bitmap.getHeight(), paint);
float scale = context.getResources().getDisplayMetrics().density;
// text color - #3D3D3D
paint.setColor(Color.rgb(255, 255, 255));
// text size in pixels
// draw text to the Canvas center
Rect bounds = new Rect();
paint.getTextBounds(text, 0, text.length(), bounds);
int x = (bitmap.getWidth() - bounds.width()) / 2;
int y = (bitmap.getHeight() + bounds.height()) / 2;
canvas.drawText(text, x, y, paint);
return bitmap;
}
public int convertToPixels(Context context, int nDP) {
final float conversionScale = context.getResources().getDisplayMetrics().density;
return (int) ((nDP * conversionScale) + 0.5f);
}
public void showLoadingDialog(String message) { public void showLoadingDialog(String message) {
loadingDialog = new Dialog(context); loadingDialog = new Dialog(context);
loadingDialog.requestWindowFeature(Window.FEATURE_NO_TITLE); loadingDialog.requestWindowFeature(Window.FEATURE_NO_TITLE);
@ -470,9 +542,9 @@ public class LiveActivity extends AbstractLiveActivity implements OnMapReadyCall
loadingDialog.setCancelable(true); loadingDialog.setCancelable(true);
loadingDialog.setCanceledOnTouchOutside(false); loadingDialog.setCanceledOnTouchOutside(false);
Button cancel = (Button) loadingDialog.findViewById(R.id.buttonCancel); Button cancel = loadingDialog.findViewById(R.id.buttonCancel);
cancel.setVisibility(View.GONE); cancel.setVisibility(View.GONE);
TextView textView1 = (TextView) loadingDialog.findViewById(R.id.textView1); TextView textView1 = loadingDialog.findViewById(R.id.textView1);
textView1.setText(message); textView1.setText(message);
loadingDialog.show(); loadingDialog.show();
@ -501,8 +573,7 @@ public class LiveActivity extends AbstractLiveActivity implements OnMapReadyCall
disabledVehicles.add(!veh.status); disabledVehicles.add(!veh.status);
// add vehicle to hash Table according to driver_id // add vehicle to hash Table according to driver_id
if (tableHashOverlay.get((int) veh.driver_id) == null) // if doesn't exist if (tableHashOverlay.get((int) veh.driver_id) == null) {
{
ArrayList<SuperVehicle> array = new ArrayList<>(); ArrayList<SuperVehicle> array = new ArrayList<>();
SuperVehicle superVehicle = new SuperVehicle(veh.sc_id, veh.imei, veh.lp, veh.name, veh.driver_id, veh.time_route, veh.GPS_reporting_interval, veh.is_stolen); SuperVehicle superVehicle = new SuperVehicle(veh.sc_id, veh.imei, veh.lp, veh.name, veh.driver_id, veh.time_route, veh.GPS_reporting_interval, veh.is_stolen);
array.add(superVehicle); array.add(superVehicle);
@ -519,7 +590,6 @@ public class LiveActivity extends AbstractLiveActivity implements OnMapReadyCall
} }
// set adapter // set adapter
adapter = new VehiclesGridViewAdapter(activity, context, list, disabledVehicles); adapter = new VehiclesGridViewAdapter(activity, context, list, disabledVehicles);
adapter.notifyDataSetChanged(); adapter.notifyDataSetChanged();
@ -538,7 +608,6 @@ public class LiveActivity extends AbstractLiveActivity implements OnMapReadyCall
// show vehicles in gridView // show vehicles in gridView
private void updateResultsUI() { private void updateResultsUI() {
gridVehicle.setAdapter(adapter); gridVehicle.setAdapter(adapter);
try { try {
// hide loading dialog // hide loading dialog
loadingDialog.cancel(); loadingDialog.cancel();
@ -576,7 +645,6 @@ public class LiveActivity extends AbstractLiveActivity implements OnMapReadyCall
pollReceived(position,lat,lng); pollReceived(position,lat,lng);
} }
public void updatePosition(int pos) { public void updatePosition(int pos) {
contextMenuPosition = pos; contextMenuPosition = pos;
} }
@ -598,11 +666,9 @@ public class LiveActivity extends AbstractLiveActivity implements OnMapReadyCall
final Runnable updateOptionsRUN = this::updateOptionsUI; final Runnable updateOptionsRUN = this::updateOptionsUI;
private void updateOptionsUI() { private void updateOptionsUI() {
SM.Debug("REFRESHDisableEnable" + (Boolean.TRUE.equals(disabledVehicles.get(contextMenuPosition)) ? "true" : "false")); SM.Debug("REFRESHDisableEnable" + (Boolean.TRUE.equals(disabledVehicles.get(contextMenuPosition)) ? "true" : "false"));
// change Enable/Disable in adapter // change Enable/Disable in adapter
adapter.changeDisabled(contextMenuPosition, disabledVehicles.get(contextMenuPosition)); adapter.changeDisabled(contextMenuPosition, disabledVehicles.get(contextMenuPosition));
} }
/** /**
@ -692,7 +758,6 @@ public class LiveActivity extends AbstractLiveActivity implements OnMapReadyCall
// zone and channel change intent // zone and channel change intent
IntentFilter intentFilter = new IntentFilter(OperationCodes.UNIT_STATUS_UPDATE + ""); IntentFilter intentFilter = new IntentFilter(OperationCodes.UNIT_STATUS_UPDATE + "");
this.registerReceiver(mReceiver, intentFilter); this.registerReceiver(mReceiver, intentFilter);
} }
//The BroadcastReceiver that listens for Notification broadcasts //The BroadcastReceiver that listens for Notification broadcasts
@ -723,4 +788,9 @@ public class LiveActivity extends AbstractLiveActivity implements OnMapReadyCall
} }
} }
}; };
@Override
public GoogleMap getMap() {
return googleMap;
}
} }

View File

@ -280,9 +280,9 @@ public class RadioActivity extends Activity {
{ {
super.onResume(); super.onResume();
// get all vehicles from TabLayoutActivity // get all vehicles from TabLayoutActivity
if(!allVehicle.equals(parentTab.allVehicle)) if(!allVehicle.equals(parentTab.getAllVehicle()))
{ {
allVehicle = parentTab.allVehicle; allVehicle = parentTab.getAllVehicle();
UpdateVehicle(); UpdateVehicle();
} }
/* /*
@ -908,7 +908,7 @@ public class RadioActivity extends Activity {
radioAll.setChecked(false); radioAll.setChecked(false);
radioGroup.setChecked(false); radioGroup.setChecked(false);
selectedCallType = PRIVATECall; selectedCallType = PRIVATECall;
textViewCallType.setText(parentTab.SuperVehHash.get((long)imei).name); textViewCallType.setText(parentTab.getSuperVehHash().get((long)imei).name);
layoutSpinnerCallType.setVisibility(View.VISIBLE); layoutSpinnerCallType.setVisibility(View.VISIBLE);
} }
else if (calltype==103) else if (calltype==103)
@ -936,8 +936,8 @@ public class RadioActivity extends Activity {
} }
if (callstatus==1) if (callstatus==1)
{ {
if (parentTab.SuperVehHash.get((long)imei)!=null) if (parentTab.getSuperVehHash().get((long)imei)!=null)
textViewMessageStatus.setText(parentTab.SuperVehHash.get((long)imei).name); textViewMessageStatus.setText(parentTab.getSuperVehHash().get((long)imei).name);
else else
textViewMessageStatus.setText("Imei: "+Long.toString(imei)); textViewMessageStatus.setText("Imei: "+Long.toString(imei));
} }

View File

@ -12,7 +12,6 @@ import java.util.Locale;
import java.util.Timer; import java.util.Timer;
import java.util.TimerTask; import java.util.TimerTask;
/** fix import */
import com.safemobile.activities.AbstractEmptyActivity; import com.safemobile.activities.AbstractEmptyActivity;
import com.safemobile.activities.AbstractLiveActivity; import com.safemobile.activities.AbstractLiveActivity;
import com.safemobile.activities.AbstractMessagesActivity; import com.safemobile.activities.AbstractMessagesActivity;
@ -200,16 +199,16 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
if(AppParams.DEMO) if(AppParams.DEMO)
{ {
allVehicle.add(new Vehicle(101, "101", 101, "101", 101, 101, 101, 0)); getAllVehicle().add(new Vehicle(101, "101", 101, "101", 101, 101, 101, 0));
allVehicle.add(new Vehicle(102, "102", 102, "102", 102, 102, 102, 0)); getAllVehicle().add(new Vehicle(102, "102", 102, "102", 102, 102, 102, 0));
allVehicle.add(new Vehicle(103, "103", 103, "Ambulance", 78, 103, 103, 0)); getAllVehicle().add(new Vehicle(103, "103", 103, "Ambulance", 78, 103, 103, 0));
allVehicle.add(new Vehicle(104, "104", 104, "104", 104, 104, 104, 0)); getAllVehicle().add(new Vehicle(104, "104", 104, "104", 104, 104, 104, 0));
allVehicle.add(new Vehicle(105, "105", 105, "Police", 105, 105, 105, 0)); getAllVehicle().add(new Vehicle(105, "105", 105, "Police", 105, 105, 105, 0));
allVehicle.add(new Vehicle(106, "106", 106, "Mike", 106, 106, 106, 0)); getAllVehicle().add(new Vehicle(106, "106", 106, "Mike", 106, 106, 106, 0));
allVehicle.add(new Vehicle(107, "107", 107, "Rob", 107, 107, 107, 0)); getAllVehicle().add(new Vehicle(107, "107", 107, "Rob", 107, 107, 107, 0));
allVehicle.add(new Vehicle(108, "108", 108, "Ben", 108, 108, 108, 0)); getAllVehicle().add(new Vehicle(108, "108", 108, "Ben", 108, 108, 108, 0));
allVehicle.add(new Vehicle(109, "109", 109, "Taxi_3", 109, 109, 109, 0)); getAllVehicle().add(new Vehicle(109, "109", 109, "Taxi_3", 109, 109, 109, 0));
allVehicle.add(new Vehicle(110, "110", 110, "Pam", 110, 110, 110, 0)); getAllVehicle().add(new Vehicle(110, "110", 110, "Pam", 110, 110, 110, 0));
listSMS = new ArrayList<SMS>(); listSMS = new ArrayList<SMS>();
@ -219,7 +218,7 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
listSMS.add(new SMS(3, 1, 1328060100, "i'm at the train station", 0, 102)); listSMS.add(new SMS(3, 1, 1328060100, "i'm at the train station", 0, 102));
listSMS.add(new SMS(4, 1, 1121016818, "I'll be right there", 0, 103)); listSMS.add(new SMS(4, 1, 1121016818, "I'll be right there", 0, 103));
for(Vehicle veh:allVehicle) for(Vehicle veh: getAllVehicle())
{ {
SuperVehicle tmpSuper = new SuperVehicle(veh.sc_id,veh.imei,veh.lp, veh.name, veh.driver_id, veh.time_route, veh.GPS_reporting_interval, veh.is_stolen); SuperVehicle tmpSuper = new SuperVehicle(veh.sc_id,veh.imei,veh.lp, veh.name, veh.driver_id, veh.time_route, veh.GPS_reporting_interval, veh.is_stolen);
if (veh.sc_id == 101) if (veh.sc_id == 101)
@ -243,8 +242,8 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
else if (veh.sc_id == 110) else if (veh.sc_id == 110)
tmpSuper.SetDataFromLastPos(41.748391,-87.933497, Calendar.getInstance().getTimeInMillis(), 47, "Historic U.S. 66, Burr Ridge, IL 60527 , USA", true); tmpSuper.SetDataFromLastPos(41.748391,-87.933497, Calendar.getInstance().getTimeInMillis(), 47, "Historic U.S. 66, Burr Ridge, IL 60527 , USA", true);
SuperVehHash.put(Long.valueOf(veh.imei), tmpSuper); getSuperVehHash().put(Long.valueOf(veh.imei), tmpSuper);
VehHashbySc_id.put(veh.sc_id, veh); getVehHashByScId().put(veh.sc_id, veh);
} }
} }
@ -254,7 +253,6 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
// do not dim the display // do not dim the display
getWindow().addFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON); getWindow().addFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON);
// get NewMessage Visual Element // get NewMessage Visual Element
layoutNewMessage = (RelativeLayout) findViewById(R.id.layoutNewMessage); layoutNewMessage = (RelativeLayout) findViewById(R.id.layoutNewMessage);
textViewNMMessage = (TextView) findViewById(R.id.textViewNMMessage); textViewNMMessage = (TextView) findViewById(R.id.textViewNMMessage);
@ -267,11 +265,11 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
tabHost = getTabHost(); // The activity TabHost tabHost = getTabHost(); // The activity TabHost
tabHost.setTag("Tab Panel"); tabHost.setTag("Tab Panel");
tabWidget = (TabWidget) findViewById(android.R.id.tabs); tabWidget = findViewById(android.R.id.tabs);
tabWidget.setVisibility(View.GONE); tabWidget.setVisibility(View.GONE);
intent = new Intent[7]; intent = new Intent[8];
tabspecs = new TabSpec[7]; tabspecs = new TabSpec[8];
// add live tab // add live tab
try try
@ -290,23 +288,6 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
.setContent(intent[0]); .setContent(intent[0]);
} }
// add history tab
try
{
//intent[1] = new Intent(context, HistoryActivity.class);
//tabspecs[1] = tabHost.newTabSpec("History")
// .setIndicator("History", res.getDrawable(R.drawable.ic_tab_history_selected))
// .setContent(intent[1]);
}
catch(NoClassDefFoundError e)
{
// exception when GoogleApi not exists
//intent[1] = new Intent(context, AbstractEmptyActivity.class);
//tabspecs[1] = tabHost.newTabSpec("History")
// .setIndicator("History", res.getDrawable(R.drawable.ic_tab_history_selected))
// .setContent(intent[1]);
}
// add text tab // add text tab
intent[1] = new Intent(context, MessagesActivity.class); intent[1] = new Intent(context, MessagesActivity.class);
tabspecs[1] = tabHost.newTabSpec("Text") tabspecs[1] = tabHost.newTabSpec("Text")
@ -343,6 +324,21 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
.setIndicator("SafeMobile", res.getDrawable(AppParams.DEMO ? R.drawable.icon_demo : R.drawable.ic_launcher)) .setIndicator("SafeMobile", res.getDrawable(AppParams.DEMO ? R.drawable.icon_demo : R.drawable.ic_launcher))
.setContent(intent[6]); .setContent(intent[6]);
// add history tab
try
{
intent[7] = new Intent(context, HistoryActivity.class);
tabspecs[7] = tabHost.newTabSpec("History")
.setIndicator("History", res.getDrawable(R.drawable.ic_tab_history_selected))
.setContent(intent[7]);
} catch(NoClassDefFoundError e) {
// exception when GoogleApi not exists
intent[7] = new Intent(context, AbstractEmptyActivity.class);
tabspecs[7] = tabHost.newTabSpec("History")
.setIndicator("History", res.getDrawable(R.drawable.ic_tab_history_selected))
.setContent(intent[1]);
}
// add tab in tabHost // add tab in tabHost
// for(int i=0;i<7;i++ // for(int i=0;i<7;i++
for (TabSpec tab: tabspecs) { for (TabSpec tab: tabspecs) {
@ -355,12 +351,9 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
imageViewSlideMenu = (ImageView) findViewById(R.id.imageViewSlideMenu); imageViewSlideMenu = (ImageView) findViewById(R.id.imageViewSlideMenu);
// get Live Button // get Live Button
buttonLive = (ImageButton) findViewById(R.id.buttonLive); buttonLive = findViewById(R.id.buttonLive);
buttonLive.setOnClickListener(new OnClickListener() { buttonLive.setOnClickListener(v -> {
@Override if (!buttonLive.isSelected()) {
public void onClick(View v) {
if(!buttonLive.isSelected())
{
// select button // select button
buttonLive.setSelected(true); buttonLive.setSelected(true);
// deselect other buttons // deselect other buttons
@ -374,16 +367,12 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
tabHost.setCurrentTabByTag("Live"); tabHost.setCurrentTabByTag("Live");
AppParams.crtTab = AppParams.Tabs.live; AppParams.crtTab = AppParams.Tabs.live;
} }
}
}); });
// get History Button // get History Button
buttonHistory = (ImageButton) findViewById(R.id.buttonHistory); buttonHistory = findViewById(R.id.buttonHistory);
buttonHistory.setOnClickListener(new OnClickListener() { buttonHistory.setOnClickListener(v -> {
@Override if (!buttonHistory.isSelected()) {
public void onClick(View v) {
if(!buttonHistory.isSelected())
{
// select button // select button
buttonHistory.setSelected(true); buttonHistory.setSelected(true);
// deselect other buttons // deselect other buttons
@ -397,16 +386,12 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
tabHost.setCurrentTabByTag("History"); tabHost.setCurrentTabByTag("History");
AppParams.crtTab = AppParams.Tabs.history; AppParams.crtTab = AppParams.Tabs.history;
} }
}
}); });
// get Text Button // get Text Button
buttonText= (ImageButton) findViewById(R.id.buttonText); buttonText= findViewById(R.id.buttonText);
buttonText.setOnClickListener(new OnClickListener() { buttonText.setOnClickListener(v -> {
@Override if (!buttonText.isSelected()) {
public void onClick(View v) {
if(!buttonText.isSelected())
{
// select button // select button
buttonText.setSelected(true); buttonText.setSelected(true);
// deselect other buttons // deselect other buttons
@ -420,10 +405,23 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
tabHost.setCurrentTabByTag("Text"); tabHost.setCurrentTabByTag("Text");
AppParams.crtTab = AppParams.Tabs.message; AppParams.crtTab = AppParams.Tabs.message;
if(AppParams.DEMO && messageActivity.allVehicle.size()== 0) if (AppParams.DEMO && messageActivity.getAllVehicle().size()== 0) {
{ // select button
messageActivity.UpdateVehs(allVehicle); buttonText.setSelected(true);
messageActivity.UpdateSMS(listSMS); // deselect other buttons
buttonAlarms.setSelected(false);
buttonLive.setSelected(false);
buttonRadio.setSelected(false);
buttonRecordings.setSelected(false);
buttonSetup.setSelected(false);
buttonHistory.setSelected(false);
// select tab
tabHost.setCurrentTabByTag("Text");
AppParams.crtTab = AppParams.Tabs.message;
if (AppParams.DEMO && messageActivity.getAllVehicle().size()== 0) {
messageActivity.updateVehicles(getAllVehicle());
messageActivity.updateSMS(listSMS);
} }
} }
} }
@ -453,7 +451,7 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
if(radioActivity!= null && radioActivity.allVehicle!= null && radioActivity.allVehicle.size()==0) if(radioActivity!= null && radioActivity.allVehicle!= null && radioActivity.allVehicle.size()==0)
{ {
radioActivity.allVehicle = allVehicle; radioActivity.allVehicle = getAllVehicle();
radioActivity.UpdateVehicle(); radioActivity.UpdateVehicle();
} }
} }
@ -611,24 +609,21 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
}); });
// get About Button // get About Button
buttonLogo = (ImageButton) findViewById(R.id.buttonLogo); buttonLogo = findViewById(R.id.buttonLogo);
buttonLogo.setOnClickListener(new OnClickListener() { buttonLogo.setOnClickListener(v -> {
@Override
public void onClick(View v) {
// create dialog // create dialog
final Dialog dialog = new Dialog(context); final Dialog dialog = new Dialog(context);
dialog.setTitle(AppParams.DEMO ? getString(R.string.app_name_demo) : getString(R.string.app_name)); dialog.setTitle(AppParams.DEMO ? getString(R.string.app_name_demo) : getString(R.string.app_name));
dialog.setContentView(R.layout.dialog); dialog.setContentView(R.layout.dialog);
ImageView image = (ImageView) dialog.findViewById(R.id.image); ImageView image = dialog.findViewById(R.id.image);
image.setImageResource(AppParams.DEMO ? R.drawable.icon_demo : R.drawable.ic_launcher); image.setImageResource(AppParams.DEMO ? R.drawable.icon_demo : R.drawable.ic_launcher);
TextView text = (TextView) dialog.findViewById(R.id.text); TextView text = dialog.findViewById(R.id.text);
TextView text2 = (TextView) dialog.findViewById(R.id.text2); TextView text2 = dialog.findViewById(R.id.text2);
text.setText(getString(R.string.version) + "1.0.8"); text.setText(getString(R.string.version) + "1.0.8");
text2.setText(getString(R.string.email) + ": support@safemobile.com"); text2.setText(getString(R.string.email) + ": support@safemobile.com");
dialog.setCancelable(true); dialog.setCancelable(true);
dialog.setCanceledOnTouchOutside(true); dialog.setCanceledOnTouchOutside(true);
dialog.show(); dialog.show();
}
}); });
imageViewClose.setOnTouchListener(new OnTouchListener() { imageViewClose.setOnTouchListener(new OnTouchListener() {
@ -679,8 +674,8 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
//list for SMS //list for SMS
if(currentActivity instanceof MessagesActivity) if(currentActivity instanceof MessagesActivity)
{ {
// run update showSMS4unit(int sc_id) form MessageActivity // run update showSMS4unit(int scId) form MessageActivity
((MessagesActivity)currentActivity).showSMS4unit(getVehicle4Imei(imei).sc_id); ((MessagesActivity)currentActivity).showSMS4unit(getVehicle4Imei(imei).scId);
} }
*/ */
} }
@ -751,7 +746,7 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
if(AppParams.DEMO && liveActivity != null) if(AppParams.DEMO && liveActivity != null)
{ {
liveActivity.vehiclesReceived(allVehicle); liveActivity.vehiclesReceived(getAllVehicle());
demoPositionsList(); demoPositionsList();
} }
@ -826,9 +821,9 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
tabHost.setCurrentTabByTag("Text"); tabHost.setCurrentTabByTag("Text");
AppParams.crtTab = AppParams.Tabs.message; AppParams.crtTab = AppParams.Tabs.message;
messageActivity.sc_id = getVehicle4Imei(imei).sc_id; messageActivity.setScId(getVehicle4Imei(getImei()).sc_id);
messageActivity.LASTMESSAGES = false; messageActivity.LASTMESSAGES = false;
messageActivity.GetLastSMS(); messageActivity.getLastSMS();
// disable notification // disable notification
if(mNotificationManager!=null) if(mNotificationManager!=null)
@ -1024,7 +1019,7 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
if(radioActivity!=null) if(radioActivity!=null)
radioActivity.onCreate(radioActivity.savedInstanceState); radioActivity.onCreate(radioActivity.savedInstanceState);
if(messageActivity!=null) if(messageActivity!=null)
messageActivity.onCreate(messageActivity.savedInstanceState); messageActivity.onCreate(messageActivity.getSavedInstanceState());
if(recordingsActivity!=null) if(recordingsActivity!=null)
recordingsActivity.onCreate(recordingsActivity.savedInstanceState); recordingsActivity.onCreate(recordingsActivity.savedInstanceState);
if(alarmActivity!=null) if(alarmActivity!=null)
@ -1055,14 +1050,14 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
public void run() { public void run() {
if(AppParams.crtTab == AppParams.Tabs.live) if(AppParams.crtTab == AppParams.Tabs.live)
{ {
if(SuperVehHash.containsKey((long)101)) if(getSuperVehHash().containsKey((long)101))
{ {
HistPos crtPos = demoPositions.get(demoPosition++ % demoPositions.size()); HistPos crtPos = demoPositions.get(demoPosition++ % demoPositions.size());
SM.Debug("########### UPDATE"); SM.Debug("########### UPDATE");
int sc_id = demoPosition%3 == 0 ? 101:102; int sc_id = demoPosition%3 == 0 ? 101:102;
((SuperVehicle)SuperVehHash.get((long)sc_id)).SetNewPosition(crtPos.lat, crtPos.lng, Calendar.getInstance().getTime().getTime(), crtPos.speed); ((SuperVehicle) getSuperVehHash().get((long)sc_id)).SetNewPosition(crtPos.lat, crtPos.lng, Calendar.getInstance().getTime().getTime(), crtPos.speed);
liveActivity.refreshMap(); liveActivity.refreshMap();
} }
} }
@ -1075,9 +1070,9 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
HistPos crtPos = demoPositions.get(demoPosition++ % demoPositions.size()); HistPos crtPos = demoPositions.get(demoPosition++ % demoPositions.size());
SM.Debug("########### UPDATE"); SM.Debug("########### UPDATE");
int sc_id = Integer.parseInt(imei); int sc_id = Integer.parseInt(getImei());
((SuperVehicle)SuperVehHash.get((long)sc_id)).SetNewPosition(crtPos.lat + 0.0002, crtPos.lng + 0.0002, Calendar.getInstance().getTime().getTime(), crtPos.speed+2); ((SuperVehicle) getSuperVehHash().get((long)sc_id)).SetNewPosition(crtPos.lat + 0.0002, crtPos.lng + 0.0002, Calendar.getInstance().getTime().getTime(), crtPos.speed+2);
mess = "Lat:" + String.format("%5f", crtPos.lat + 0.0002) + ", Lng:" + String.format("%5f", crtPos.lng + 0.0002); setMess("Lat:" + String.format("%5f", crtPos.lat + 0.0002) + ", Lng:" + String.format("%5f", crtPos.lng + 0.0002));
liveActivity.refreshMap(); liveActivity.refreshMap();
} }
@ -1143,7 +1138,7 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
// when connection becomes true after it was false // when connection becomes true after it was false
if(allVehicle.size() == 0) if(getAllVehicle().size() == 0)
//connectTask.doIn(OperationCodes.GetVehicles, new Object[] {AppParams.USERID}); //connectTask.doIn(OperationCodes.GetVehicles, new Object[] {AppParams.USERID});
new ConnectTask().execute(new String[] {OperationCodes.GetVehicles + "", AppParams.USERID + ""}); new ConnectTask().execute(new String[] {OperationCodes.GetVehicles + "", AppParams.USERID + ""});
//getVehicles(AppParams.USERID); //getVehicles(AppParams.USERID);
@ -1237,25 +1232,18 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
GPSmsg GPSPos= new GPSmsg(msg); GPSmsg GPSPos= new GPSmsg(msg);
//SM.Debug("Got new GPS pos data:" + GPSPos.data); //SM.Debug("Got new GPS pos data:" + GPSPos.data);
if(SuperVehHash.get(GPSPos.gpsValue.imei) != null) if (getSuperVehHash().get(GPSPos.gpsValue.imei) != null) {
{ getSuperVehHash().get(GPSPos.gpsValue.imei).SetNewPosition(GPSPos.gpsValue.lat, GPSPos.gpsValue.lng, GPSPos.gpsValue.timeGMT, GPSPos.gpsValue.speed);
((SuperVehicle)SuperVehHash.get(GPSPos.gpsValue.imei)).SetNewPosition(GPSPos.gpsValue.lat, GPSPos.gpsValue.lng, GPSPos.gpsValue.timeGMT, GPSPos.gpsValue.speed);
if(SuperVehHash.get(GPSPos.gpsValue.imei).needUpdate)
{
if (getSuperVehHash().get(GPSPos.gpsValue.imei).needUpdate) {
//list for live //list for live
if(AppParams.crtTab == AppParams.Tabs.live) if (AppParams.crtTab == AppParams.Tabs.live) {
{
//SM.Debug("+++++ duda +++++"); //SM.Debug("+++++ duda +++++");
SM.Debug("currentActivity instanceof LiveActivity"); SM.Debug("currentActivity instanceof LiveActivity");
try try {
{
if(liveActivity != null) if(liveActivity != null)
liveActivity.refreshMap(); liveActivity.refreshMap();
} } catch (Exception ex) {
catch (Exception ex)
{
SM.Debug("Error load hash:"+ex.toString()); SM.Debug("Error load hash:"+ex.toString());
} }
} }
@ -1264,28 +1252,26 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
} }
@Override @Override
public void onPollReceived(TCPEvent event) public void onPollReceived(TCPEvent event) {
{
SM.Debug("Got POLL GPS message"); SM.Debug("Got POLL GPS message");
TCPmsg msg= event.msg(); TCPmsg msg= event.msg();
GPSmsg GPSPos= new GPSmsg(msg); GPSmsg GPSPos= new GPSmsg(msg);
imei = Long.toString(GPSPos.gpsValue.imei); setImei(Long.toString(GPSPos.gpsValue.imei));
mess = "LAT:"+Double.toString(GPSPos.gpsValue.lat)+" LNG:"+Double.toString(GPSPos.gpsValue.lng); setMess("LAT:"+Double.toString(GPSPos.gpsValue.lat)+" LNG:"+Double.toString(GPSPos.gpsValue.lng));
SM.Debug("Got new Poll pos data:" + GPSPos.data); SM.Debug("Got new Poll pos data:" + GPSPos.data);
if(SuperVehHash.get(GPSPos.gpsValue.imei) != null)
{ if(getSuperVehHash().get(GPSPos.gpsValue.imei) != null) {
((SuperVehicle)SuperVehHash.get(GPSPos.gpsValue.imei)).SetNewPosition(GPSPos.gpsValue.lat, GPSPos.gpsValue.lng, GPSPos.gpsValue.timeGMT, GPSPos.gpsValue.speed); ((SuperVehicle) getSuperVehHash().get(GPSPos.gpsValue.imei)).SetNewPosition(GPSPos.gpsValue.lat, GPSPos.gpsValue.lng, GPSPos.gpsValue.timeGMT, GPSPos.gpsValue.speed);
//if is not check i need to force check to put on the map //if is not check i need to force check to put on the map
Boolean forceChecked =false; Boolean forceChecked =false;
if (!SuperVehHash.get(GPSPos.gpsValue.imei).needUpdate) if (!getSuperVehHash().get(GPSPos.gpsValue.imei).needUpdate) {
{ getSuperVehHash().get(GPSPos.gpsValue.imei).needUpdate =true;
SuperVehHash.get(GPSPos.gpsValue.imei).needUpdate =true;
forceChecked =true; forceChecked =true;
} }
//back to standard procedures to put on the map //back to standard procedures to put on the map
if(SuperVehHash.get(GPSPos.gpsValue.imei).needUpdate) if(getSuperVehHash().get(GPSPos.gpsValue.imei).needUpdate)
{ {
//list for live //list for live
@ -1298,7 +1284,7 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
int x = 0; int x = 0;
if (forceChecked) if (forceChecked)
{ {
for (Vehicle veh : allVehicle) for (Vehicle veh : getAllVehicle())
{ {
if (veh.imei.compareTo(Long.toString(GPSPos.gpsValue.imei))==0) break; if (veh.imei.compareTo(Long.toString(GPSPos.gpsValue.imei))==0) break;
x++; x++;
@ -1307,7 +1293,7 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
else x = -1; else x = -1;
if(liveActivity!=null) if(liveActivity!=null)
{ {
if (x!=allVehicle.size()) if (x!= getAllVehicle().size())
liveActivity.pollReceived(x ,GPSPos.gpsValue.lat,GPSPos.gpsValue.lng); liveActivity.pollReceived(x ,GPSPos.gpsValue.lat,GPSPos.gpsValue.lng);
else else
liveActivity.pollReceived(-1 ,GPSPos.gpsValue.lat,GPSPos.gpsValue.lng); liveActivity.pollReceived(-1 ,GPSPos.gpsValue.lat,GPSPos.gpsValue.lng);
@ -1333,9 +1319,9 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
//list for SMS //list for SMS
if(AppParams.crtTab == AppParams.Tabs.message) if(AppParams.crtTab == AppParams.Tabs.message)
{ {
//SM.Debug("currentActivity instanceof MessagesActivity - NewSMS"); //SM.Debug("currentActivity instanceof MessagesActivity - newSMS");
if(messageActivity != null) if(messageActivity != null)
messageActivity.UpdateSMS(sms.smsList); messageActivity.updateSMS(sms.smsList);
} }
} }
catch(Exception ex) catch(Exception ex)
@ -1360,10 +1346,10 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
for(Vehicle veh:vMSG.vehList) for(Vehicle veh:vMSG.vehList)
{ {
SuperVehicle tmpSuper = new SuperVehicle(veh.sc_id,veh.imei,veh.lp, veh.name, veh.driver_id, veh.time_route, veh.GPS_reporting_interval, veh.is_stolen); SuperVehicle tmpSuper = new SuperVehicle(veh.sc_id,veh.imei,veh.lp, veh.name, veh.driver_id, veh.time_route, veh.GPS_reporting_interval, veh.is_stolen);
SuperVehHash.put(Long.valueOf(veh.imei), tmpSuper); getSuperVehHash().put(Long.valueOf(veh.imei), tmpSuper);
VehHashbySc_id.put(veh.sc_id, veh); getVehHashByScId().put(veh.sc_id, veh);
} }
SM.Debug(" #$############# " + SuperVehHash.size() + " \nVEH " + vMSG.vehList.size()); SM.Debug(" #$############# " + getSuperVehHash().size() + " \nVEH " + vMSG.vehList.size());
} }
catch (Exception ex) catch (Exception ex)
{ {
@ -1384,9 +1370,9 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
{ {
SM.Debug("currentActivity instanceof MessagesActivity"); SM.Debug("currentActivity instanceof MessagesActivity");
if(messageActivity != null) if(messageActivity != null)
messageActivity.UpdateVehs(vMSG.vehList); messageActivity.updateVehicles(vMSG.vehList);
} }
allVehicle = vMSG.vehList; setAllVehicle(vMSG.vehList);
} }
public void onLastSMSsReceived(TCPEvent event) { public void onLastSMSsReceived(TCPEvent event) {
@ -1401,7 +1387,7 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
{ {
//SM.Debug("currentActivity instanceof MessagesActivity"); //SM.Debug("currentActivity instanceof MessagesActivity");
if(messageActivity != null) if(messageActivity != null)
messageActivity.UpdateSMS(sms.smsList); messageActivity.updateSMS(sms.smsList);
} }
} }
catch (Exception ex) catch (Exception ex)
@ -1447,7 +1433,7 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
SM.Debug("Got smsComfirm msg.data:" + msg.data); SM.Debug("Got smsComfirm msg.data:" + msg.data);
if (messageActivity != null) if (messageActivity != null)
messageActivity.ConfirmSMS(sms.data, msg.seqID); messageActivity.confirmSMS(sms.data, msg.seqID);
} }
@Override @Override
@ -1459,8 +1445,8 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
SM.Debug("Message:" + tempArr[1]); SM.Debug("Message:" + tempArr[1]);
// change Visual Elements // change Visual Elements
imei = tempArr[0]; setImei(tempArr[0]);
mess = tempArr[1]; setMess(tempArr[1]);
long time = Calendar.getInstance().getTimeInMillis() / 1000; long time = Calendar.getInstance().getTimeInMillis() / 1000;
try { try {
// get time from the last received sms and divide it to 1000 to convert it to seconds // get time from the last received sms and divide it to 1000 to convert it to seconds
@ -1470,28 +1456,19 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
} }
// if tab is not TextTab // if tab is not TextTab
if(tabHost.getCurrentTab() != 2) if(tabHost.getCurrentTab() != 2) {
{
myHandler.post(UpdateResults); myHandler.post(UpdateResults);
//mHandler.dispatchMessage(new Message()); //mHandler.dispatchMessage(new Message());
} } else
else myHandler.post(() -> {
myHandler.post(new Runnable() {
@Override
public void run() {
// create Notification // create Notification
createNotification(AppParams.messageNotif); createNotification(AppParams.messageNotif);
}
}); });
//list for SMS //list for SMS
if(AppParams.crtTab == AppParams.Tabs.message && messageActivity!= null) if(AppParams.crtTab == AppParams.Tabs.message && messageActivity!= null) {
{ SM.Debug("currentActivity instanceof MessagesActivity - newSMS | " + tempArr[0] + " | " + tempArr[1]);
SM.Debug("currentActivity instanceof MessagesActivity - NewSMS | " + tempArr[0] + " | " + tempArr[1]); messageActivity.newSMS(tempArr[0], tempArr[1], time);
messageActivity.NewSMS(tempArr[0], tempArr[1], time);
} }
} }
@Override @Override
@ -1525,15 +1502,13 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
@Override @Override
public void onLastPositionsReceived(TCPEvent event) { public void onLastPositionsReceived(TCPEvent event) {
TCPmsg msg= event.msg(); TCPmsg msg= event.msg();
SM.Debug("Got lastpos"); SM.Debug("Got last pos");
//SM.Debug("Got lastpos :" + msg.allData);
LastPosmsg lastPos= new LastPosmsg(msg); LastPosmsg lastPos= new LastPosmsg(msg);
//SM.Debug("Got LastPost msg.data:" + msg.data); //SM.Debug("Got LastPost msg.data:" + msg.data);
for(LastPos posMsg: lastPos.PosList) for(LastPos posMsg: lastPos.PosList) {
{ if(getSuperVehHash().get(posMsg.imei) != null)
if(SuperVehHash.get(posMsg.imei) != null) getSuperVehHash().get(posMsg.imei).SetDataFromLastPos(posMsg.lat, posMsg.lng, posMsg.timeGMT, posMsg.speed, posMsg.Address, posMsg.isON);
((SuperVehicle)SuperVehHash.get(posMsg.imei)).SetDataFromLastPos(posMsg.lat, posMsg.lng, posMsg.timeGMT, posMsg.speed, posMsg.Address, posMsg.isON);
} }
} }
@ -1883,40 +1858,40 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
//list for SMS //list for SMS
if(AppParams.crtTab == AppParams.Tabs.alarms) if(AppParams.crtTab == AppParams.Tabs.alarms)
{ {
SM.Debug("currentActivity instanceof AlarmActivity - NewSMS | " + tempArr[0] + " | " + tempArr[1]); SM.Debug("currentActivity instanceof AlarmActivity - newSMS | " + tempArr[0] + " | " + tempArr[1]);
getAlarms(AppParams.USERID); getAlarms(AppParams.USERID);
} }
// if tab is not TextTab // if tab is not TextTab
if(tabHost.getCurrentTab() != 5) if(tabHost.getCurrentTab() != 5)
{ {
// change Visual Elements // change Visual Elements
imei = UnitIMEI; setImei(UnitIMEI);
switch (msg.opCode) switch (msg.opCode)
{ {
case 135: mess = "speed "+tempArr[1]; case 135: setMess("speed "+tempArr[1]);
break; break;
case 136: mess = "landmark "+tempArr[1]; case 136: setMess("landmark "+tempArr[1]);
break; break;
case 137: mess = "zone "+tempArr[1]; case 137: setMess("zone "+tempArr[1]);
break; break;
case 138: mess = "emergency"; case 138: setMess("emergency");
break; break;
case 140: mess = "telemetry "+ tempArr[1]; case 140: setMess("telemetry "+ tempArr[1]);
break; break;
default: default:
mess = "emergency"; setMess("emergency");
} }
myHandler.post(UpdateResultsAlarm); myHandler.post(UpdateResultsAlarm);
if ((msg.opCode==138)&&(AppParams.crtTab == AppParams.Tabs.live)) if ((msg.opCode==138)&&(AppParams.crtTab == AppParams.Tabs.live))
{ {
if(SuperVehHash.get(Long.parseLong(UnitIMEI)) != null) if(getSuperVehHash().get(Long.parseLong(UnitIMEI)) != null)
{ {
//if is not check i need to force check to put on the map //if is not check i need to force check to put on the map
Boolean forceChecked =false; Boolean forceChecked =false;
if (!SuperVehHash.get(Long.parseLong(UnitIMEI)).needUpdate) if (!getSuperVehHash().get(Long.parseLong(UnitIMEI)).needUpdate)
{ {
SuperVehHash.get(Long.parseLong(UnitIMEI)).needUpdate =true; getSuperVehHash().get(Long.parseLong(UnitIMEI)).needUpdate =true;
forceChecked =true; forceChecked =true;
} }
try try
@ -1924,7 +1899,7 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
int x = 0; int x = 0;
if (forceChecked) if (forceChecked)
{ {
for (Vehicle veh : allVehicle) for (Vehicle veh : getAllVehicle())
{ {
if (veh.imei.compareTo(UnitIMEI)==0) break; if (veh.imei.compareTo(UnitIMEI)==0) break;
x++; x++;
@ -1933,10 +1908,10 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
else x = -1; else x = -1;
if(liveActivity != null) if(liveActivity != null)
{ {
if (x!=allVehicle.size()) if (x!= getAllVehicle().size())
liveActivity.emergencyAlarmReceived(x ,SuperVehHash.get(Long.parseLong(UnitIMEI)).lat,SuperVehHash.get(Long.parseLong(UnitIMEI)).lng); liveActivity.emergencyAlarmReceived(x , getSuperVehHash().get(Long.parseLong(UnitIMEI)).lat, getSuperVehHash().get(Long.parseLong(UnitIMEI)).lng);
else else
liveActivity.emergencyAlarmReceived(-1, SuperVehHash.get(Long.parseLong(UnitIMEI)).lat,SuperVehHash.get(Long.parseLong(UnitIMEI)).lng); liveActivity.emergencyAlarmReceived(-1, getSuperVehHash().get(Long.parseLong(UnitIMEI)).lat, getSuperVehHash().get(Long.parseLong(UnitIMEI)).lng);
} }
} }
catch (Exception ex) catch (Exception ex)
@ -1963,8 +1938,8 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
if (rec.typeID==1) if (rec.typeID==1)
rec.NameForDisplay = AppParams.USERNAME; rec.NameForDisplay = AppParams.USERNAME;
else { else {
if (SuperVehHash.get((long)rec.subID)!=null) if (getSuperVehHash().get((long)rec.subID)!=null)
rec.NameForDisplay = SuperVehHash.get((long)rec.subID).name; rec.NameForDisplay = getSuperVehHash().get((long)rec.subID).name;
} }
} }
@ -2045,10 +2020,10 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
activePopupType= MsgType.ALARM; activePopupType= MsgType.ALARM;
imageViewPopUp.setImageResource(R.drawable.siren_on); imageViewPopUp.setImageResource(R.drawable.siren_on);
slideTabsText.setText(getString(R.string.newAlarm)); slideTabsText.setText(getString(R.string.newAlarm));
if (getVehicle4Imei(imei)!=null) if (getVehicle4Imei(getImei())!=null)
textViewNMFrom.setText(getString(R.string.from) + ": " + getVehicle4Imei(imei).name); textViewNMFrom.setText(getString(R.string.from) + ": " + getVehicle4Imei(getImei()).name);
else textViewNMFrom.setText(getString(R.string.from) + ": " + imei); else textViewNMFrom.setText(getString(R.string.from) + ": " + getImei());
textViewNMMessage.setText("TYPE: " + mess); textViewNMMessage.setText("TYPE: " + getMess());
// show layout // show layout
layoutNewMessage.setVisibility(View.VISIBLE); layoutNewMessage.setVisibility(View.VISIBLE);
@ -2085,7 +2060,7 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
// set TextViews // set TextViews
String from = ""; String from = "";
Vehicle fromVehicle = null; Vehicle fromVehicle = null;
if((fromVehicle = getVehicle4Imei(imei)) != null) if((fromVehicle = getVehicle4Imei(getImei())) != null)
from = fromVehicle.name; from = fromVehicle.name;
if(tcp!=null && !AppParams.DEMO) if(tcp!=null && !AppParams.DEMO)
@ -2094,7 +2069,7 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
imageViewPopUp.setImageResource(R.drawable.poll); imageViewPopUp.setImageResource(R.drawable.poll);
slideTabsText.setText("Poll Reply"); slideTabsText.setText("Poll Reply");
textViewNMFrom.setText("From: " + from); textViewNMFrom.setText("From: " + from);
textViewNMMessage.setText(mess); textViewNMMessage.setText(getMess());
// show layout // show layout
layoutNewMessage.setVisibility(View.VISIBLE); layoutNewMessage.setVisibility(View.VISIBLE);
@ -2111,7 +2086,7 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
imageViewPopUp.setImageResource(R.drawable.poll); imageViewPopUp.setImageResource(R.drawable.poll);
slideTabsText.setText("Poll Reply"); slideTabsText.setText("Poll Reply");
textViewNMFrom.setText("From: " + from); textViewNMFrom.setText("From: " + from);
textViewNMMessage.setText(mess); textViewNMMessage.setText(getMess());
// show layout // show layout
layoutNewMessage.setVisibility(View.VISIBLE); layoutNewMessage.setVisibility(View.VISIBLE);
/* /*
@ -2143,8 +2118,8 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
activePopupType = MsgType.SMS; activePopupType = MsgType.SMS;
imageViewPopUp.setImageResource(R.drawable.message); imageViewPopUp.setImageResource(R.drawable.message);
slideTabsText.setText("New Message"); slideTabsText.setText("New Message");
textViewNMFrom.setText("From: " + getVehicle4Imei(imei).name); textViewNMFrom.setText("From: " + getVehicle4Imei(getImei()).name);
textViewNMMessage.setText("MSG: " + mess); textViewNMMessage.setText("MSG: " + getMess());
// show layout // show layout
layoutNewMessage.setVisibility(View.VISIBLE); layoutNewMessage.setVisibility(View.VISIBLE);
@ -2157,11 +2132,11 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
} }
else if(AppParams.DEMO) else if(AppParams.DEMO)
{ {
mess = "i got your sms"; setMess("i got your sms");
activePopupType = MsgType.SMS; activePopupType = MsgType.SMS;
imageViewPopUp.setImageResource(R.drawable.message); imageViewPopUp.setImageResource(R.drawable.message);
slideTabsText.setText("New Message"); slideTabsText.setText("New Message");
textViewNMFrom.setText("From: " + getVehicle4Imei(imei).name); textViewNMFrom.setText("From: " + getVehicle4Imei(getImei()).name);
textViewNMMessage.setText("MSG: " + "i got your sms"); textViewNMMessage.setText("MSG: " + "i got your sms");
// show layout // show layout
layoutNewMessage.setVisibility(View.VISIBLE); layoutNewMessage.setVisibility(View.VISIBLE);
@ -2181,31 +2156,31 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
public void createNotification(int icon) { public void createNotification(int icon) {
mNotificationManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE); mNotificationManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
String tickerText = "SafeMobile Dispatch: New Message from " + imei; String tickerText = "SafeMobile Dispatch: New Message from " + getImei();
String contentTitle = "New Message from " + imei; String contentTitle = "New Message from " + getImei();
String contentText = "\"" + mess + "\""; String contentText = "\"" + getMess() + "\"";
Vehicle veh = getVehicle4Imei(imei); Vehicle veh = getVehicle4Imei(getImei());
int icon_value = icon; int icon_value = icon;
switch(icon) switch(icon)
{ {
case AppParams.messageNotif: case AppParams.messageNotif:
contentText = "\"" + mess + "\""; contentText = "\"" + getMess() + "\"";
contentTitle = "New Message from " + imei; contentTitle = "New Message from " + getImei();
icon = R.drawable.message; icon = R.drawable.message;
break; break;
case AppParams.pollNotif: case AppParams.pollNotif:
contentText = "\"" + mess + "\"" ; contentText = "\"" + getMess() + "\"" ;
contentTitle = "Poll Reply from " + (veh !=null ? getVehicle4Imei(imei).name : imei); contentTitle = "Poll Reply from " + (veh !=null ? getVehicle4Imei(getImei()).name : getImei());
tickerText = "SafeMobile Dispatch: Poll Reply from " + (veh !=null ? getVehicle4Imei(imei).name : imei); tickerText = "SafeMobile Dispatch: Poll Reply from " + (veh !=null ? getVehicle4Imei(getImei()).name : getImei());
icon = R.drawable.poll; icon = R.drawable.poll;
break; break;
case AppParams.alertNotif: case AppParams.alertNotif:
String vehName = getString(R.string.from) + ": " + imei; String vehName = getString(R.string.from) + ": " + getImei();
if(veh!=null) if(veh!=null)
vehName = getString(R.string.from) + ": " + (veh !=null ? getVehicle4Imei(imei).name : imei); vehName = getString(R.string.from) + ": " + (veh !=null ? getVehicle4Imei(getImei()).name : getImei());
contentText ="\"" + mess + "\""; contentText ="\"" + getMess() + "\"";
contentTitle = getString(R.string.newAlarm) + vehName; contentTitle = getString(R.string.newAlarm) + vehName;
tickerText = "SafeMobile Dispatch: " + getString(R.string.newAlarm) + vehName; tickerText = "SafeMobile Dispatch: " + getString(R.string.newAlarm) + vehName;
icon = R.drawable.alert; icon = R.drawable.alert;
@ -2240,7 +2215,7 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
private Vehicle getVehicle4Imei(String imei) private Vehicle getVehicle4Imei(String imei)
{ {
Vehicle veh = null; Vehicle veh = null;
for(Vehicle vehicle: allVehicle) for(Vehicle vehicle: getAllVehicle())
//SM.Debug("Vehicle name:"+vehicle.name+" IMEI:"+vehicle.imei); //SM.Debug("Vehicle name:"+vehicle.name+" IMEI:"+vehicle.imei);
if(vehicle.imei.equals(imei)) if(vehicle.imei.equals(imei))
veh = vehicle; veh = vehicle;
@ -2297,20 +2272,20 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
} }
@Override @Override
public double best_zoom(double LATMAX,double LATmin,double LNGMAX,double LNGmin) public double best_zoom(double latMax, double latMin, double lngMax, double lngMin)
{ {
double height =400; double height =400;
double width =400; double width =400;
double dlat = Math.abs(LATMAX - LATmin); double dlat = Math.abs(latMax - latMin);
double dlon = Math.abs(LNGMAX - LNGmin); double dlon = Math.abs(lngMax - lngMin);
if(dlat == 0 && dlon == 0) if(dlat == 0 && dlon == 0)
{ {
if ((LATMAX==LATmin)&&(LATMAX==0)&&(LNGMAX==LNGmin)&&(LNGMAX==0)) return 2; if ((latMax == latMin)&&(latMax ==0)&&(lngMax == lngMin)&&(lngMax ==0)) return 2;
//return 17; //return 17;
} }
// Center latitude in radians // Center latitude in radians
double clat = Math.PI*(LATmin + LATMAX)/360.; double clat = Math.PI*(latMin + latMax)/360.;
double C = 0.0000107288; double C = 0.0000107288;
double z0 = Math.ceil(Math.log(dlat/(C*height))/0.693); double z0 = Math.ceil(Math.log(dlat/(C*height))/0.693);
@ -2340,19 +2315,19 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
} }
} }
public void optionForUnit(int radioCode, int opCode, int sc_id, int value) public void optionForUnit(int radioCode, int opCode, int scId, int value)
{ {
boolean res = tcp.Write("0.0", "#"+radioCode+"#"+opCode+"#" + sc_id+"#" +value + "#"); boolean res = tcp.Write("0.0", "#"+radioCode+"#"+opCode+"#" + scId+"#" +value + "#");
if(res){ if(res){
SM.Debug("Message (optionForUnit) sent to app server radioCode:"+radioCode+ " opCode:"+opCode+ " sc_id:"+sc_id+ " value:"+value); SM.Debug("Message (optionForUnit) sent to app server radioCode:"+radioCode+ " opCode:"+opCode+ " scId:"+scId+ " value:"+value);
}else{ }else{
SM.Debug("Could not send message(optionForUnit)!!"); SM.Debug("Could not send message(optionForUnit)!!");
} }
} }
public void getSMS4unit(int sc_id, long timeGMT) public void getSMS4unit(int scId, long timeGMT)
{ {
boolean res = tcp.Write("0.0", "#22#"+sc_id+"#" +timeGMT+"#"); boolean res = tcp.Write("0.0", "#22#"+scId+"#" +timeGMT+"#");
if(res){ if(res){
SM.Debug("Message (getLastSMS) sent to app server"); SM.Debug("Message (getLastSMS) sent to app server");
}else{ }else{
@ -2370,11 +2345,11 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
} }
} }
public void SendSMS(String seqID,int sc_id, String txt) public void SendSMS(String seqID,int scId, String txt)
{ {
boolean res = tcp.Write(seqID, "#24#" + AppParams.USERID + "#" + sc_id + "#" + txt + "#"); boolean res = tcp.Write(seqID, "#24#" + AppParams.USERID + "#" + scId + "#" + txt + "#");
if(res){ if(res){
SM.Debug("Message (SendSMS) sent to app server sc_id:"+sc_id+ " txt:"+txt); SM.Debug("Message (SendSMS) sent to app server scId:"+scId+ " txt:"+txt);
}else{ }else{
SM.Debug("Could not send message(getLastSMS)!!"); SM.Debug("Could not send message(getLastSMS)!!");
} }
@ -2410,10 +2385,10 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
} }
} }
public void getHistoryPos(int sc_id, long timeGMTStart, long timeGMTStop) public void getHistoryPos(int scId, long timeGMTStart, long timeGMTStop)
{ {
HistSeqID = "1."+Integer.toString((int) (System.currentTimeMillis() / 1000L)); HistSeqID = "1."+Integer.toString((int) (System.currentTimeMillis() / 1000L));
boolean res = tcp.Write(HistSeqID,"#26#"+sc_id+"#"+timeGMTStart+"#"+timeGMTStop+"#"); boolean res = tcp.Write(HistSeqID,"#26#"+scId+"#"+timeGMTStart+"#"+timeGMTStop+"#");
if(res){ if(res){
SM.Debug("Message (getHistoryPos) sent to app server"); SM.Debug("Message (getHistoryPos) sent to app server");
}else{ }else{
@ -2550,7 +2525,7 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
{ {
Long.parseLong(params[2]); Long.parseLong(params[2]);
} }
catch (Exception e) { catch (Exception ignored) {
} }
getRecentSMSs(Integer.parseInt(params[1]), Long.parseLong(params[2])); getRecentSMSs(Integer.parseInt(params[1]), Long.parseLong(params[2]));
@ -2573,7 +2548,7 @@ public class TabLayoutActivity extends AbstractSDParentActivity{
break; break;
case OperationCodes.SendAlarmAcknoledge: case OperationCodes.SendAlarmAcknoledge:
sendAlarmAcknoledge(Integer.parseInt(params[1]), Integer.parseInt(params[2])); sendAlarmAcknowledge(Integer.parseInt(params[1]), Integer.parseInt(params[2]));
break; break;
case OperationCodes.GetHistoryPositions: case OperationCodes.GetHistoryPositions:

View File

@ -1,21 +1,16 @@
package com.safemobile.lib.sound; package com.safemobile.lib.sound;
import java.io.BufferedReader; import com.safemobile.lib.SM;
import java.io.IOException; import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream; import java.io.OutputStream;
import java.io.PrintWriter;
import java.net.Socket; import java.net.Socket;
import java.net.UnknownHostException; import java.net.UnknownHostException;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Iterator; import java.util.Iterator;
import java.util.LinkedList;
import java.util.List; import java.util.List;
import com.safemobile.lib.SM;
import com.safemobile.lib.TCPmsg;
public class TCPaudioClient implements Runnable{ public class TCPaudioClient implements Runnable{
private boolean alive = true; private boolean alive = true;

View File

@ -188,7 +188,7 @@
android:layout_width="wrap_content" android:layout_width="wrap_content"
android:layout_height="fill_parent"> android:layout_height="fill_parent">
<TextView <TextView
android:id="@+id/textViewSendMsg" android:id="@+id/textView1"
android:layout_width="wrap_content" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:layout_gravity="center_vertical" android:layout_gravity="center_vertical"
@ -210,7 +210,8 @@
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:layout_gravity="center_vertical" android:layout_gravity="center_vertical"
android:gravity="center_vertical" android:gravity="center_vertical"
android:inputType="text" > android:inputType="text"
android:autofillHints="">
</EditText> </EditText>
</LinearLayout> </LinearLayout>
<LinearLayout <LinearLayout

View File

@ -105,9 +105,7 @@
android:layout_weight="0" android:layout_weight="0"
android:paddingRight="5dp" android:paddingRight="5dp"
android:visibility="gone"/> android:visibility="gone"/>
<!-- android:background="@drawable/addmessage_selector" -->
</LinearLayout> </LinearLayout>
</RelativeLayout> </RelativeLayout>
<RelativeLayout <RelativeLayout
@ -120,8 +118,6 @@
android:layout_height="fill_parent" android:layout_height="fill_parent"
android:weightSum="1"> android:weightSum="1">
<LinearLayout <LinearLayout
android:layout_width="200dp" android:layout_width="200dp"
android:layout_height="fill_parent" android:layout_height="fill_parent"
@ -267,7 +263,6 @@
android:text="@string/display" /> android:text="@string/display" />
</LinearLayout> </LinearLayout>
</LinearLayout> </LinearLayout>
</LinearLayout> </LinearLayout>
<LinearLayout <LinearLayout
@ -288,14 +283,14 @@
style="?sliders" /> style="?sliders" />
</LinearLayout> </LinearLayout>
<LinearLayout <fragment
android:id="@+id/layoutGoogleMaps"
android:layout_width="fill_parent" android:layout_width="fill_parent"
android:layout_height="fill_parent" android:layout_height="fill_parent"
android:id="@+id/map"
android:layout_toRightOf="@id/slidelayout" android:layout_toRightOf="@id/slidelayout"
android:layout_weight="1" android:layout_weight="1"
android:orientation="horizontal" > android:name="com.google.android.gms.maps.SupportMapFragment" />
</LinearLayout>
</LinearLayout> </LinearLayout>
<ImageView <ImageView
@ -333,9 +328,5 @@
android:gravity="center_vertical"/> android:gravity="center_vertical"/>
</LinearLayout> </LinearLayout>
</RelativeLayout> </RelativeLayout>
</RelativeLayout> </RelativeLayout>

View File

@ -10,27 +10,7 @@
android:layout_width="fill_parent" android:layout_width="fill_parent"
android:layout_height="fill_parent" android:layout_height="fill_parent"
android:background="#000000"> android:background="#000000">
<LinearLayout android:layout_width="fill_parent" android:layout_height="wrap_content" android:id="@+id/linearLayout2" android:orientation="vertical">
<!--
<LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:id="@+id/linearLayout3">
<LinearLayout android:layout_width="80dp" android:id="@+id/linearLayout4" android:layout_height="wrap_content">
<Button android:layout_width="wrap_content" android:text="Create tabs" android:layout_height="wrap_content" android:id="@+id/button1"></Button>
</LinearLayout>
<LinearLayout android:layout_height="match_parent" android:id="@+id/linearLayout5" android:layout_width="match_parent">
<LinearLayout android:layout_width="100dp" android:layout_height="match_parent" android:id="@+id/linearLayout7" android:layout_weight="0.29" android:weightSum="1">
<Button android:text="Remove selected tab" android:layout_height="wrap_content" android:id="@+id/button3" android:layout_width="wrap_content"></Button>
</LinearLayout>
<EditText android:layout_width="wrap_content" android:id="@+id/editText1" android:layout_height="wrap_content" android:inputType="number" android:layout_weight="13.86">
<requestFocus></requestFocus>
</EditText>
<LinearLayout android:layout_width="80dp" android:layout_height="match_parent" android:id="@+id/linearLayout7" android:layout_weight="0.29" android:weightSum="1">
<Button android:layout_width="wrap_content" android:text="Add tab" android:layout_height="wrap_content" android:id="@+id/button2" android:layout_weight="0.25"></Button>
</LinearLayout>
</LinearLayout>
</LinearLayout>
-->
</LinearLayout>
<LinearLayout <LinearLayout
android:layout_width="fill_parent" android:layout_width="fill_parent"
android:id="@+id/linearLayout6" android:id="@+id/linearLayout6"
@ -162,7 +142,6 @@
android:layout_gravity="center_vertical"/> android:layout_gravity="center_vertical"/>
</LinearLayout> </LinearLayout>
</LinearLayout> </LinearLayout>
</LinearLayout>
</LinearLayout> </LinearLayout>
</RelativeLayout> </RelativeLayout>
</RelativeLayout> </RelativeLayout>

View File

@ -186,7 +186,7 @@
android:layout_width="wrap_content" android:layout_width="wrap_content"
android:layout_height="fill_parent"> android:layout_height="fill_parent">
<TextView <TextView
android:id="@+id/textViewSendMsg" android:id="@+id/textView1"
android:layout_width="wrap_content" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:layout_gravity="center_vertical" android:layout_gravity="center_vertical"
@ -209,7 +209,8 @@
android:layout_gravity="center_vertical" android:layout_gravity="center_vertical"
android:gravity="center_vertical" android:gravity="center_vertical"
android:inputType="text" android:inputType="text"
android:maxLength="255" > android:maxLength="255"
android:autofillHints="">
</EditText> </EditText>
</LinearLayout> </LinearLayout>
<LinearLayout <LinearLayout

View File

@ -232,4 +232,7 @@
<item >German</item> <item >German</item>
<item >Romanian</item> <item >Romanian</item>
</string-array> </string-array>
<string name="speedMph">%1$d mph</string>
</resources> </resources>

View File

@ -236,4 +236,7 @@
<item >Spanish</item> <item >Spanish</item>
<item >Russian</item> <item >Russian</item>
</string-array> </string-array>
<string name="speedMph">%1$d mph</string>
</resources> </resources>

View File

@ -233,4 +233,7 @@
<item >Turca</item> <item >Turca</item>
<item >Romana</item> <item >Romana</item>
</string-array> </string-array>
<string name="speedMph">%1$d mph</string>
</resources> </resources>

View File

@ -232,4 +232,7 @@
<item >German</item> <item >German</item>
<item >Romanian</item> <item >Romanian</item>
</string-array> </string-array>
<string name="speedMph">%1$d mph</string>
</resources> </resources>

View File

@ -254,4 +254,8 @@
</string-array> </string-array>
<string name="title_activity_new_live">NewLiveActivity</string> <string name="title_activity_new_live">NewLiveActivity</string>
<string name="title_activity_google_maps">GoogleMapsActivity</string> <string name="title_activity_google_maps">GoogleMapsActivity</string>
<string name="speedMph">%1$d mph</string>
</resources> </resources>