Java tutorial
package report; import java.io.File; import java.io.FileInputStream; import java.io.IOException; import java.io.InputStream; import java.net.URL; import java.sql.*; import java.text.DecimalFormat; import java.text.DecimalFormatSymbols; import java.text.SimpleDateFormat; import java.time.Instant; import java.util.*; import java.util.Date; import java.util.logging.Level; import java.util.logging.Logger; import javax.mail.internet.InternetAddress; import org.apache.commons.io.FileUtils; import org.apache.commons.io.IOUtils; import org.json.simple.JSONArray; import org.json.simple.JSONObject; import org.json.simple.JSONValue; import org.json.simple.parser.JSONParser; import org.json.simple.parser.ParseException; public class mainReport { private static final String VERSION = "0.0.1"; private static final String CONFIG_FILE = "report.conf"; private static boolean SEND_EMAIL; // ------------------------------------------------------------------------ // Replace keys found in target String with their corresponding values // Key format: ${key[:arg]} public static final char KEY_START_ESC = '\\'; public static final String KEY_START = "${"; public static final String KEY_END = "}"; public static final String DFT_DELIM = "="; public static final String ARG_DELIM = ":"; private static final String START_DELIM = KEY_START; // "${"; private static final String END_DELIM = KEY_END; // "}"; private static String MAIL_FROM; // ------------------------------------------------------------------------ private static String url; private static String user; private static String password; private static String osrm; // ------------------------------------------------------------------------ private static final Logger LOGGER = Logger.getLogger(Thread.currentThread().getStackTrace()[0].getClassName()); static DecimalFormatSymbols formatSymbols = new DecimalFormatSymbols(Locale.getDefault()); private static String[] deviceID; private static String[] deviceSpeedLimit; private static String date_trt; public static final char CSV_SEPARATOR_CHAR = '|'; private static final double DISTANCE_MINI_ENTRE_POINT = 0.5D; //Distance en kilomtre private static boolean INTERPOLATION; //Distance en kilomtre private static final int ARRET_MAX = 600; //Dure maxi d'arrt private static String TEMPLATE_NAME; private static int nbrarret = 0; private static String iconSpeed = "\"\"";; private static String iconSpeed60 = "\"\"";; private static String iconSpeed65 = "\"\"";; private static String iconSpeed70 = "\"\"";; private static String iconBegin = "\"\""; //private static String iconEnd = "\"\""; private static String iconEnd = "\"\""; //private static String iconOne = ""; private static String iconOne = "\"\""; private static String iconTwo = "\"\""; private static String iconFree = ""; private static String iconFor = ""; private static String iconFive = ""; private static String iconSix = ""; private static String iconSeven = ""; private static String iconEigth = ""; private static String iconNine = ""; private static String iconTen = ""; private static String iconOnze = ""; private static String iconDouze = ""; private static String iconTreize = ""; private static String iconQuatorze = ""; private static String iconQuinze = ""; private static String iconSeize = ""; private static String iconDixsept = ""; private static String iconDixhuit = ""; private static String iconDixneuf = ""; private static String iconVingt = ""; private static String iconStopNOK = "\"\""; private static String iconEvent = "\"\""; private static String iconAccAlarm = "\"\""; private static String iconDecAlarm = "\"\""; public static void main(String[] args) throws IOException, ClassNotFoundException { // TODO Auto-generated method stub Connection con = null; Statement st = null; ResultSet rs = null; String sql = null; boolean flag = false; boolean sendmail = false; String accountID; String pathInfos = ""; String stopsInfos = ""; String eventsInfos = ""; String secuInfos = ""; // <script type="text/javascript"> // stopsInfos[0] = Array(Array(Array(-18.14335, 49.38557, 20151208184519, "", null, 0)), "1273 TAM -WULLING"); // </script> String Infos = ""; //new Array(new Array(null, stops[0], null), new Array(path[1], stops[1], events[1]), new Array(path[2], stops[2], events[2]), new Array(path[3], stops[3], events[3]), new Array(null, stops[4], null), new Array(path[5], stops[5], events[5]), new Array(null, stops[6], null)) String gMapElts = "new Array("; String infoTab = ""; //Food & Beverage - Compte-rendu du 08/12/2015 String titre_date = ""; String mail_to = ""; String MAIL_SUBJECT = ""; String MAIL_MESSAGE = ""; int nbrdevice = 0; LinkedList<Events> pointsList; LinkedList<Events> pointsListnw; if (args.length == 0) accountID = "telo"; else accountID = args[0]; //File htmlTemplateFile = new File("d:\\template-V0.html"); readConfig(CONFIG_FILE); File htmlTemplateFile = new File(TEMPLATE_NAME); String htmlString; htmlString = FileUtils.readFileToString(htmlTemplateFile); try { Class.forName("com.mysql.jdbc.Driver"); con = DriverManager.getConnection(url, user, password); st = con.createStatement(); pointsList = createTemporaryTable(con, st, accountID); //"FROM_UNIXTIME(dateEvt,'%d%m%Y%H%i%s') CREATE TEMPORARY TABLE datatmpEvt( accountID varchar(45), deviceID varchar(45), dateEvt Timestamp, lat double, lon double, speed int);"; //calculTemp(con, st); //System.out.println("pointsList:" + pointsList.size()); nbrdevice = deviceID.length; //System.out.println("Nombre de device: " + nbrdevice); for (int i = 0; i < deviceID.length; i++) { //pointsListnw = addpoints(accountID, deviceID[i], pointsList); //System.out.println("pointsList:" + pointsList.size()+" pointsListnw:" + pointsListnw.size()); // Creation info du tableau infoTab = infoTab + createinfoTab(con, st, accountID, deviceID[i], i, pointsList); pathInfos = createpathInfos(con, st, deviceID[i], i, pointsList); if (pathInfos != null) { pathInfos = "<script type=\"text/javascript\"> pathInfos[" + i + "] = " + pathInfos + ";</script>"; Infos = Infos + pathInfos; System.out.println(pathInfos); } stopsInfos = createstopsInfos(con, st, deviceID[i], i, pointsList); if (stopsInfos == null) stopsInfos = createstopsInfosnull(con, st, accountID, deviceID[i]); if (stopsInfos != null) { stopsInfos = "<script type=\"text/javascript\"> stopsInfos[" + i + "] = " + stopsInfos + ";</script>"; Infos = Infos + stopsInfos; System.out.println(stopsInfos); } eventsInfos = createeventsInfos(con, st, deviceID[i], i, pointsList); if (eventsInfos != null) { eventsInfos = "<script type=\"text/javascript\"> eventsInfos[" + i + "] = " + eventsInfos + ";</script>"; Infos = Infos + eventsInfos; System.out.println(eventsInfos); } String pathElts = "path[" + i + "]"; if (pathInfos == null) pathElts = "null"; String stopElts = "stops[" + i + "]"; if (stopsInfos == null) stopElts = "null"; String eventsElts = "events[" + i + "]"; if (eventsInfos == null) eventsElts = "null"; if (i > 0) gMapElts = gMapElts + ", "; gMapElts = gMapElts + "new Array(" + pathElts + ", " + stopElts + ", " + eventsElts + ")"; //System.out.println(Infos); secuInfos = secuInfos + createsecuInfos(deviceID[i], i, pointsList); } gMapElts = gMapElts + ")"; //System.out.println(gMapElts); sql = "SELECT notifyEmail, allowNotify, suspendUntilTime FROM Account WHERE accountID='" + accountID + "';"; rs = st.executeQuery(sql); if (rs.next()) { mail_to = rs.getObject("notifyEmail") != null ? rs.getString("notifyEmail") : null; int allowNotify = rs.getObject("allowNotify") != null ? rs.getInt("allowNotify") : 0; int suspendUntilTime = rs.getObject("suspendUntilTime") != null ? rs.getInt("suspendUntilTime") : 0; if (mail_to != null && allowNotify > 0 && suspendUntilTime == 0) { sendmail = true; } } } catch (SQLException ex) { LOGGER.severe(ex.getMessage()); } finally { try { if (rs != null) { rs.close(); } if (st != null) { st.close(); } if (con != null) { con.close(); } } catch (SQLException ex) { LOGGER.warning(ex.getMessage()); } } String title = "Araka"; String filename = ""; Calendar cal = Calendar.getInstance(); cal.add(Calendar.DATE, -1); Date dateBefore1Days = cal.getTime(); System.out.println(new SimpleDateFormat("dd/MM/yyyy").format(dateBefore1Days)); date_trt = new SimpleDateFormat("dd/MM/yyyy").format(dateBefore1Days); String date_SpeedChart = new SimpleDateFormat("yyyy-MM-dd").format(dateBefore1Days); titre_date = accountID + " - Compte-rendu du " + date_trt; htmlString = htmlString.replace("$title", title); htmlString = htmlString.replace("$GAT_Infos", Infos); htmlString = htmlString.replace("$GAT_gMapElts", gMapElts); htmlString = htmlString.replace("$GAT_infoTab", infoTab); htmlString = htmlString.replace("$GAT_nbrdevice", Integer.toString(nbrdevice)); htmlString = htmlString.replace("$GAT_Titre_date", titre_date); htmlString = htmlString.replace("$GAT_dateBegin", date_trt + " 00:00:00"); htmlString = htmlString.replace("$GAT_dateEnd", date_trt + " 23:59:59"); htmlString = htmlString.replace("$GAT_dateBSpeed", "\"" + date_SpeedChart + " 00:00:00\""); htmlString = htmlString.replace("$GAT_dateESpeed", "\"" + date_SpeedChart + " 23:59:59\""); htmlString = htmlString.replace("$GAT_secuInfos", secuInfos); htmlString = htmlString.replace("$GAT_iconSpeed", iconSpeed); htmlString = htmlString.replace("$GAT_60iconSpeed", iconSpeed60); htmlString = htmlString.replace("$GAT_65iconSpeed", iconSpeed65); htmlString = htmlString.replace("$GAT_70iconSpeed", iconSpeed70); htmlString = htmlString.replace("$GAT_iconBegin", iconBegin); htmlString = htmlString.replace("$GAT_iconEnd", iconEnd); htmlString = htmlString.replace("$GAT_iconOne", iconOne); htmlString = htmlString.replace("$GAT_iconTwo", iconOne); htmlString = htmlString.replace("$GAT_iconStopNOK", iconStopNOK); htmlString = htmlString.replace("$GAT_iconiconEvent", iconEvent); htmlString = htmlString.replace("$GAT_iconAccAlarm", iconAccAlarm); htmlString = htmlString.replace("$GAT_iconDecAlarm", iconDecAlarm); String datefile = new SimpleDateFormat("dd-MM-yyyy").format(dateBefore1Days); filename = accountID + "_COMPTE-RENDU_" + datefile + ".html"; File newHtmlFile = new File(filename); FileUtils.writeStringToFile(newHtmlFile, htmlString); SendMail mail = new SendMail(); try { if (sendmail && SEND_EMAIL) { MAIL_MESSAGE = "Compte: " + accountID + "\n"; MAIL_MESSAGE = MAIL_MESSAGE + "Rapport: Parcours et Scurit du " + date_trt + " 00:00:00 au " + date_trt + " 23:59:59"; MAIL_SUBJECT = titre_date; mail.mailovh(MAIL_FROM, mail_to, MAIL_SUBJECT, MAIL_MESSAGE, filename); } } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } } public static String createinfoTab(Connection c, Statement s, String acId, String dvId, int irang, LinkedList pList) { // <tr> // <td>3</td> Rang // <td>113</td> Identif // <td>9114 TAN -JAC 3.5T</td> Info vhicule // <td>2015-12-08 06:59:07</td> date dbut // <td>2015-12-08 13:37:40</td> date fin // <td>00-00-00 02:15:34</td> roulage // <td>00-00-00 04:22:59</td> Arrt // <td>51</td> distance total // <td>22</td> vitesse moyenne // <td>79</td> Vitesse max // <td><input type="checkbox" style="cursor:pointer;" id="cb3" // title="Cliquez ici pour afficher le trajet de ce vhicule" // onclick="if (this.checked) {if (isReplayRunning) // pausePathReplay(true, true);if (curCheckedRowId > -1) {if (sb = // document.getElementById('sliderbg' + curCheckedRowId)) // sb.style.display = 'none';if (cb = document.getElementById('cb' + // curCheckedRowId)) cb.title='Cliquez ici pour afficher le trajet de ce // vhicule';};gMapDisplayData(3, true, true, // false);secuDisplayData(3,true);curCheckedRowId=3;this.title='Cliquez // ici pour masquer le trajet de ce vhicule';}else // {pausePathReplay(true, true);if (sb = // document.getElementById('sliderbg' + 3)) sb.style.display = // 'none';pathFilterDiv.style.display = 'none';gMapHideData(3, // false);secuDisplayData(3,false);curCheckedRowId = // -1;this.title='Cliquez ici pour afficher le trajet de ce // vhicule';};"></td> // <input type="checkbox" style="cursor:pointer;" id="cb0" // title="Cliquez ici pour afficher le trajet de ce vhicule" // onclick="if (this.checked) {if (isReplayRunning) // pausePathReplay(true, true);if (curCheckedRowId > -1) {if (sb = // document.getElementById('sliderbg' + curCheckedRowId)) // sb.style.display = 'none';if (cb = document.getElementById('cb' + // curCheckedRowId)) cb.title='Cliquez ici pour afficher le trajet de ce // vhicule';};gMapDisplayData(0, true, true, // false);secuDisplayData(0,true);curCheckedRowId=0;this.title='Cliquez // ici pour masquer le trajet de ce vhicule';}else {gMapHideData(0, // false);secuDisplayData(0,false);curCheckedRowId = // -1;this.title='Cliquez ici pour afficher le trajet de ce // vhicule';};"> // <td>-18.93935 47.56441</td> coordonne evenement // </tr> boolean flag; ResultSet rs = null; int nb = 0; String infoTab = ""; double odometreDeb = 0; double odometreFin = 0; double latitudemax = 0; double longitudemax = 0; double odometerKMlast = 0; double odometerOffsetKMlast = 0; double distance = 0; Timestamp dateEVlast = null, dateEVdeb = null; int speedmax = 0; int dureeroulage = 0; int dureearret = 0; formatSymbols.setDecimalSeparator('.'); DecimalFormat dec = new DecimalFormat("#00.000000", formatSymbols); DecimalFormat deckms = new DecimalFormat("#0.0"); infoTab = "<tr><td>" + irang + "</td><td>" + dvId + "</td>"; String sql = "select accountID, deviceID, vehicleMake, vehicleModel, licensePlate FROM Device where accountID='" + acId + "' and deviceID='" + dvId + "';"; try { rs = s.executeQuery(sql); if (rs.next()) { String vehicleMake = rs.getObject("vehicleMake") != null ? rs.getString("vehicleMake") : null; String vehicleModel = rs.getObject("vehicleModel") != null ? rs.getString("vehicleModel") : null; String licensePlate = rs.getObject("licensePlate") != null ? rs.getString("licensePlate") : null; infoTab = infoTab + "<td>" + licensePlate + " " + vehicleModel + "</td>"; } } catch (SQLException ex) { LOGGER.severe(ex.getMessage()); } distance = 0.0D; dureearret = 0; dureeroulage = 0; double duree = 0.; double vitessemoy = 0.0; int nbvitesse = 0; int nbreq = 0; int indpoint = 0; int ipoint = 0; int j = 0; String request = ""; Events evtlast = null; for (int i = 0; i < pList.size(); i++) { Events evt = (Events) pList.get(i); if (evt.getDeviceID().equals(dvId)) { if (nb == 0) { dateEVdeb = evt.getDateEvt(); request = request + "loc=" + dec.format(evt.getLatitude()) + "," + dec.format(evt.getLongitude()); // point de dpart nbreq++; } if (evt.getSpeed() > 0) { if (i + 1 < pList.size()) { duree = 0; Events evtp = (Events) pList.get(i + 1); if (evtp.getDeviceID().equals(dvId)) duree = (evtp.getDateEvt().getTime() - evt.getDateEvt().getTime()) / 1000.0; } dureeroulage = (int) (dureeroulage + duree); // Calcul temps de roulage vitessemoy = vitessemoy + (int) evt.getSpeed(); nbvitesse++; } else { duree = 0; if (i + 1 < pList.size()) { Events evtp = (Events) pList.get(i + 1); if (evtp.getDeviceID().equals(dvId)) duree = (evtp.getDateEvt().getTime() - evt.getDateEvt().getTime()) / 1000.0; } dureearret = (int) (dureearret + duree); // Calcul temps d'arrt //request = request + "loc=" + dec.format(evt.getLatitude()) + "," + dec.format(evt.getLongitude()); //pour le calcul de distance, en prend en compte que les arrts nbreq++; } if (evt.getSpeed() > speedmax) { speedmax = (int) evt.getSpeed(); latitudemax = evt.getLatitude(); longitudemax = evt.getLongitude(); } if (evt.getSpeed() > evt.getSpeedMax()) { // Vrification vitesse maximum request = request + "loc=" + dec.format(evt.getLatitude()) + "," + dec.format(evt.getLongitude()); nbreq++; } dateEVlast = evt.getDateEvt(); evtlast = evt; nb++; } } if (nb > 1) { request = request + "loc=" + dec.format(evtlast.getLatitude()) + "," + dec.format(evtlast.getLongitude()); nbreq++; } if (nbreq > 1) { request = osrm + request + "&instructions=false&alt=false"; String rep = sendGet(request, "viaroute"); double distcalc = Double.parseDouble(rep) / 1000.0; distance = distcalc; System.out.println("Distance: " + distcalc + " total: " + (int) distance + "kms" + " req:" + request); } if (nb > 1) { //System.out.println("Distance OSRM: " + deckms.format(distance)); // distance = (odometerKMlast + odometerOffsetKMlast) - odometreDeb; //System.out.println("Distance: " + (int) distance + "kms"); //System.out.println("Vitesse max: " + speedmax + "kms/h"); //System.out.println("Temps roulage: " + (int) dureeroulage + "s"); //double vitessemoy = distance / (dureeroulage / 3600.0); vitessemoy = vitessemoy / nbvitesse; //System.out.println("Vitesse moy: " + (int) vitessemoy + " kms/h"); int numberOfDays; int numberOfHours; int numberOfMinutes; int numberOfSeconds; if (distance < 1) { vitessemoy = 0; speedmax = 0; dureeroulage = 0; dureearret = 0; } // numberOfDays = dureeroulage / 86400; numberOfHours = ((int) dureeroulage % 86400) / 3600; numberOfMinutes = (((int) dureeroulage % 86400) % 3600) / 60; numberOfSeconds = (((int) dureeroulage % 86400) % 3600) % 60; String roulage = numberOfHours + ":" + numberOfMinutes + ":" + numberOfSeconds; numberOfHours = ((int) dureearret % 86400) / 3600; numberOfMinutes = (((int) dureearret % 86400) % 3600) / 60; numberOfSeconds = (((int) dureearret % 86400) % 3600) % 60; String arret = numberOfHours + ":" + numberOfMinutes + ":" + numberOfSeconds; //System.out.println("Temps arrt: " + (int) dureearret + "s" + " " + arret); // long diff = dateEVlast.getTime() - dateEVdeb.getTime() ; // int dureeTH = (int) diff / 1000; // if (vitessemoy > 150) vitessemoy = 0; // System.out.println("Temps Total: " + dureeTH + "s"); infoTab = infoTab + "<td>" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(dateEVdeb.getTime()) + "</td>"; infoTab = infoTab + "<td>" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(dateEVlast.getTime()) + "</td>"; infoTab = infoTab + "<td>00-00-00 " + roulage + "</td>"; infoTab = infoTab + "<td>00-00-00 " + arret + "</td>"; infoTab = infoTab + "<td>" + (int) distance + "</td>"; infoTab = infoTab + "<td>" + (int) vitessemoy + "</td>"; infoTab = infoTab + "<td>" + speedmax + "</td>"; infoTab = infoTab + "<td><input type=\"checkbox\" style=\"cursor:pointer;\" id=\"cb" + irang + "\" title=\"Cliquez ici pour afficher le trajet de ce véhicule\" onclick=\"if (this.checked) {if (isReplayRunning) pausePathReplay(true, true);if (curCheckedRowId > -1) {if (sb = document.getElementById('sliderbg' + curCheckedRowId)) sb.style.display = 'none';if (cb = document.getElementById('cb' + curCheckedRowId)) cb.title='Cliquez ici pour afficher le trajet de ce véhicule';};gMapDisplayData(" + irang + ", true, true, false);secuDisplayData(" + irang + ",true);curCheckedRowId=" + irang + ";this.title='Cliquez ici pour masquer le trajet de ce véhicule';}else {pausePathReplay(true, true);if (sb = document.getElementById('sliderbg' + " + irang + ")) sb.style.display = 'none';pathFilterDiv.style.display = 'none';gMapHideData(" + irang + ", false);secuDisplayData(" + irang + ",false);curCheckedRowId = -1;this.title='Cliquez ici pour afficher le trajet de ce vé;hicule';};\"></td>"; infoTab = infoTab + "<td>" + dec.format(latitudemax) + " " + dec.format(longitudemax) + "</td></tr>"; } else { infoTab = infoTab + "<td></td><td></td><td></td><td></td><td>0</td><td>0</td><td>0</td>"; infoTab = infoTab + "<td><input type=\"checkbox\" style=\"cursor:pointer;\" id=\"cb" + irang + "\" title=\"Cliquez ici pour afficher le trajet de ce véhicule\" onclick=\"if (this.checked) {if (isReplayRunning) pausePathReplay(true, true);if (curCheckedRowId > -1) {if (sb = document.getElementById('sliderbg' + curCheckedRowId)) sb.style.display = 'none';if (cb = document.getElementById('cb' + curCheckedRowId)) cb.title='Cliquez ici pour afficher le trajet de ce véhicule';};gMapDisplayData(" + irang + ", true, true, false);secuDisplayData(" + irang + ",true);curCheckedRowId=" + irang + ";this.title='Cliquez ici pour masquer le trajet de ce véhicule';}else {gMapHideData(" + irang + ", false);secuDisplayData(" + irang + ",false);curCheckedRowId = -1;this.title='Cliquez ici pour afficher le trajet de ce véhicule';};\"></td>"; infoTab = infoTab + "<td></td></tr>"; } //System.out.println("infoTab: " + infoTab); return infoTab; } public static String createstopsInfos(Connection c, Statement s, String dvId, int irang, LinkedList pList) { boolean flag; boolean first; ResultSet rs = null; String stopsInfos = ""; String accountID = ""; String deviceID = ""; String deviceIDlast = ""; Double latitude = 0.0; Double longitude = 0.0; Timestamp dateEV; Timestamp dateEVfirst, timestamp = null; String temps = ""; String temps2 = ""; String datem; int vitesse = 0; int tmps, nbstop = 0; int nb = 0, nblecture = 0; int indexlast = 0; double speedlast = -1; boolean havenext = false; String request = ""; formatSymbols.setDecimalSeparator('.'); DecimalFormat dec = new DecimalFormat("#00.000000", formatSymbols); nbrarret = 0; //stopsInfos[3]=Array(Array(Array(-18.94387,47.50355,20151208065907,"",null,0),Array(-18.93862,47.50042,70152,"00-00-00 00:03:20",70512,0) LinkedList<Events> pListemp = new LinkedList<Events>(); for (int i = 0; i < pList.size(); i++) { Events evt = (Events) pList.get(i); if (evt.getDeviceID().equals(dvId)) { if (!(speedlast == 0 && evt.getSpeed() == 0)) { pListemp.add(new Events(evt.getAccountID(), evt.DeviceID, evt.getLatitude(), evt.getLongitude(), evt.getSpeed(), evt.getDateEvt(), evt.getOdometerKM(), evt.getOdometerOffsetKM(), (int) evt.getStatusCode(), (int) evt.getSpeedMax(), evt.getHeading())); } speedlast = evt.getSpeed(); } } for (int i = 0; i < pListemp.size(); i++) { Events evt = (Events) pListemp.get(i); if (i == 0) { stopsInfos = "Array(" + dec.format(evt.getLatitude()) + ", " + dec.format(evt.getLongitude()) + ", " + new SimpleDateFormat("yyyyMMddHHmmss").format(evt.getDateEvt()) + ", \"\", null, " + evt.getSpeed() + ")"; accountID = evt.getAccountID(); speedlast = evt.getSpeed(); indexlast = i; nbstop++; request = request + "loc=" + dec.format(evt.getLatitude()) + "," + dec.format(evt.getLongitude()); } else { if (evt.getSpeed() < 1.) { tmps = getDuration(pListemp, dvId, i); if (i == (indexlast + 1) && speedlast < 1) { } else { if (tmps > ARRET_MAX) { temps = "\"00-00-00 " + getDurationString(tmps) + "\""; Calendar cal = Calendar.getInstance(); cal.setTimeInMillis(evt.getDateEvt().getTime()); cal.add(Calendar.SECOND, tmps); timestamp = new Timestamp(cal.getTime().getTime()); temps2 = new SimpleDateFormat("HHmmss").format(timestamp); datem = new SimpleDateFormat("HHmmss").format(evt.getDateEvt()); stopsInfos = stopsInfos + ", Array(" + dec.format(evt.getLatitude()) + ", " + dec.format(evt.getLongitude()) + ", " + datem + ", " + temps + ", " + temps2 + ", " + evt.getSpeed() + ")"; nbstop++; nbrarret++; indexlast = i; //request = request + "loc=" + dec.format(evt.getLatitude()) + "," + dec.format(evt.getLongitude()); } } } speedlast = evt.getSpeed(); } } if (pListemp.size() > 2 && indexlast != (pListemp.size() - 1)) { Events evt = (Events) pListemp.get(pListemp.size() - 1); stopsInfos = stopsInfos + ", Array(" + dec.format(evt.getLatitude()) + ", " + dec.format(evt.getLongitude()) + ", " + new SimpleDateFormat("yyyyMMddHHmmss").format(evt.getDateEvt()) + ", \"\", null, " + evt.getSpeed() + ")"; //request = request + "loc=" + dec.format(evt.getLatitude()) + "," + dec.format(evt.getLongitude()); } //System.out.println("stopsInfos Dernier points: "+stopsInfos); if (nbstop > 0) { /*if (nbstop > 1){ Events evt = (Events) pList.get(indexlast); stopsInfos = stopsInfos + ", Array(" + dec.format(evt.getLatitude())+", "+ dec.format(evt.getLongitude())+", "+new SimpleDateFormat("yyyyMMddHHmmss").format(evt.getDateEvt())+", \"\", null, "+evt.getSpeed()+")"; nbstop++; }*/ stopsInfos = stopsInfos + ")"; String sql = "SELECT accountID, deviceID, vehicleMake, vehicleModel, licensePlate FROM Device where accountID='" + accountID + "' and deviceID='" + dvId + "';"; try { rs = s.executeQuery(sql); if (rs.next()) { String vehicleMake = rs.getObject("vehicleMake") != null ? rs.getString("vehicleMake") : null; String vehicleModel = rs.getObject("vehicleModel") != null ? rs.getString("vehicleModel") : null; String licensePlate = rs.getObject("licensePlate") != null ? rs.getString("licensePlate") : null; stopsInfos = "Array(Array(" + stopsInfos + ", \"" + licensePlate + " " + vehicleModel + "\")"; } rs.close(); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } //System.out.println("stopsInfos: "+nbstop); //System.out.println(stopsInfos); } else { stopsInfos = null; System.out.println(deviceIDlast + " AUCUN stopsInfos"); } return stopsInfos; } public static String createstopsInfosnull(Connection c, Statement s, String acId, String dvId) { ResultSet rs = null; String stopsInfos = ""; formatSymbols.setDecimalSeparator('.'); DecimalFormat dec = new DecimalFormat("#00.000000", formatSymbols); String sql = "SELECT accountID, FROM_UNIXTIME(timestamp) as timestamp, deviceID, latitude, longitude, speedKPH FROM EventData WHERE accountID='" + acId + "' AND deviceID='" + dvId + "' AND longitude >0.0 ORDER BY timestamp DESC LIMIT 1;"; try { rs = s.executeQuery(sql); if (rs.next()) { stopsInfos = "Array("; int speedKPH = rs.getObject("speedKPH") != null ? rs.getInt("speedKPH") : null; Timestamp dateEV = rs.getTimestamp("timestamp"); double latitude = rs.getObject("latitude") != null ? rs.getDouble("latitude") : null; double longitude = rs.getObject("longitude") != null ? rs.getDouble("longitude") : null; stopsInfos = stopsInfos + "Array(" + dec.format(latitude) + ", " + dec.format(longitude) + ", " + new SimpleDateFormat("yyyyMMddHHmmss").format(dateEV) + ", \"\", null, 0))"; sql = "SELECT accountID, deviceID, vehicleMake, vehicleModel, licensePlate FROM Device where accountID='" + acId + "' and deviceID='" + dvId + "';"; ResultSet rs1 = s.executeQuery(sql); if (rs1.next()) { String vehicleMake = rs1.getObject("vehicleMake") != null ? rs1.getString("vehicleMake") : null; String vehicleModel = rs1.getObject("vehicleModel") != null ? rs1.getString("vehicleModel") : null; String licensePlate = rs1.getObject("licensePlate") != null ? rs1.getString("licensePlate") : null; stopsInfos = "Array(" + stopsInfos + ", \"" + licensePlate + " " + vehicleModel + "\")"; } rs1.close(); } rs.close(); System.out.println(dvId + " stopsInfosnull"); //System.out.println(stopsInfos); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } return stopsInfos; } public static String createpathInfos(Connection c, Statement s, String dvId, int irang, LinkedList pList) { boolean flag, first; ResultSet rs = null; String accountID = ""; String deviceID = ""; String deviceIDlast = ""; Double latitude = 0.0; Double longitude = 0.0; Timestamp dateEV = null; String dateEVbegin = ""; String dateEVend = ""; String datem; int vitesse = 0; int tmps, nbpath = 0; int nb = 0; String pathinfos = ""; int indexbegin = 0, indexend = 0; formatSymbols.setDecimalSeparator('.'); DecimalFormat dec = new DecimalFormat("#00.000000", formatSymbols); for (int i = 0; i < pList.size(); i++) { Events evt = (Events) pList.get(i); accountID = evt.getAccountID(); if (evt.getDeviceID().equals(dvId)) { int k = i + 1; tmps = 0; if (k < pList.size()) { Events evtnxt = (Events) pList.get(k); if (evtnxt.getDeviceID().equals(dvId)) { double diff = evtnxt.getDateEvt().getTime() - evt.getDateEvt().getTime(); tmps = (int) diff / 1000; } } if (nbpath == 0) { pathinfos = "Array("; dateEVbegin = new SimpleDateFormat("yyyMMddHHmmss").format(evt.getDateEvt()); datem = new SimpleDateFormat("yyyyMMddHHmmss").format(evt.getDateEvt()); indexbegin = i; } else { datem = new SimpleDateFormat("HHmmss").format(evt.getDateEvt()); pathinfos = pathinfos + ", "; } pathinfos = pathinfos + "Array(" + dec.format(evt.getLatitude()) + ", " + dec.format(evt.getLongitude()) + ", " + datem + ", " + evt.getHeading() + ", " + (int) evt.getSpeed() + ")"; nbpath++; dateEVend = new SimpleDateFormat("yyyMMddHHmmss").format(evt.getDateEvt()); indexend = i; } } Events evt = (Events) pList.get(indexbegin); Events evtnxt = (Events) pList.get(indexend); int distance = (int) (evtnxt.getOdometerKM() - evt.getOdometerKM()); if (nbpath > 1 && distance > 1) { pathinfos = pathinfos + ")"; String sql = "SELECT accountID, deviceID, vehicleMake, vehicleModel, licensePlate FROM Device where accountID='" + accountID + "' and deviceID='" + dvId + "';"; try { rs = s.executeQuery(sql); if (rs.next()) { String vehicleMake = rs.getObject("vehicleMake") != null ? rs.getString("vehicleMake") : null; String vehicleModel = rs.getObject("vehicleModel") != null ? rs.getString("vehicleModel") : null; String licensePlate = rs.getObject("licensePlate") != null ? rs.getString("licensePlate") : null; pathinfos = "Array(" + pathinfos + ", \"" + dateEVbegin + "\", \"" + dateEVend + "\", 1)"; } } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } System.out.println("Nb de points path: " + nbpath); System.out.println(pathinfos); } else { pathinfos = null; System.out.println(deviceIDlast + " AUCUN pathInfos"); } return pathinfos; } public static String createeventsInfos(Connection c, Statement s, String dvId, int irang, LinkedList pList) { boolean flag; ResultSet rs = null; String eventsInfos = ""; String accountID = ""; String deviceID = ""; String deviceIDlast = ""; Double latitude = 0.0; Double longitude = 0.0; float vitesse = 0; String accountIDlast = ""; Double latitudelast = 0.0; Double longitudelast = 0.0; Timestamp dateEVlast = null; int speed, speedmax = 0, nbevents = 0; int dureepararret = 0; int nbrdepvitesse = 0; int dureedepvitesse = 0; formatSymbols.setDecimalSeparator('.'); DecimalFormat dec = new DecimalFormat("#00.000000", formatSymbols); speedmax = 0; for (int i = 0; i < pList.size(); i++) { Events evt = (Events) pList.get(i); if (evt.getDeviceID().equalsIgnoreCase(dvId)) { accountID = evt.getAccountID(); deviceID = evt.getDeviceID(); if (speedmax < evt.getSpeed()) { speedmax = (int) evt.getSpeed(); latitudelast = evt.getLatitude(); longitudelast = evt.getLongitude(); dateEVlast = evt.getDateEvt(); } if (evt.getSpeed() > evt.getSpeedMax()) { // Vrification vitesse maximum nbrdepvitesse++; if (nbevents == 0) { eventsInfos = "Array("; } else eventsInfos = eventsInfos + ", "; int limit = 60; if (evt.getSpeed() > 65) limit = 65; if (evt.getSpeed() > 70) limit = 70; eventsInfos = eventsInfos + "Array(" + dec.format(evt.getLatitude()) + ", " + dec.format(evt.getLongitude()) + ", " + new SimpleDateFormat("yyyyMMddHHmmss").format(evt.getDateEvt()) + ", " + new SimpleDateFormat("HHmmss").format(evt.getDateEvt()) + ",\"\", \"Vitesse maximale\", " + evt.getSpeed() + ", " + limit + ")"; nbevents++; } } } if (speedmax > 0) { if (nbevents == 0) { eventsInfos = "Array("; } else eventsInfos = eventsInfos + ", "; //Array(Array(-18.94375, 47.50367, 20151208070953, 289, 0), Array(-18.94341, 47.50208, 71013, 309, 32)) eventsInfos = eventsInfos + "Array(" + dec.format(latitudelast) + ", " + dec.format(longitudelast) + ", " + new SimpleDateFormat("yyyyMMddHHmmss").format(dateEVlast) + ", " + new SimpleDateFormat("HHmmss").format(dateEVlast) + ",\"\", \"Vitesse maximale\", " + speedmax + ", -2" + ")"; nbevents++; } if (nbevents > 0) { eventsInfos = eventsInfos + ")"; String sql = "SELECT accountID, deviceID, vehicleMake, vehicleModel, licensePlate FROM Device where accountID='" + accountID + "' and deviceID='" + deviceID + "';"; try { rs = s.executeQuery(sql); if (rs.next()) { String vehicleMake = rs.getObject("vehicleMake") != null ? rs.getString("vehicleMake") : null; String vehicleModel = rs.getObject("vehicleModel") != null ? rs.getString("vehicleModel") : null; String licensePlate = rs.getObject("licensePlate") != null ? rs.getString("licensePlate") : null; eventsInfos = "Array(" + eventsInfos + ", \"" + licensePlate + " " + vehicleModel + "\")"; } } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } System.out.println(deviceIDlast + " eventsInfos"); //System.out.println(eventsInfos); } else { eventsInfos = null; System.out.println(deviceIDlast + " AUCUN eventsInfos"); } return eventsInfos; } public static String createsecuInfos(String dvId, int irang, LinkedList pList) { String secuInfos = ""; int nbinfo = 0; int nbrdepvitesse = 0; for (int i = 0; i < pList.size(); i++) { Events evt = (Events) pList.get(i); if (evt.getDeviceID().equalsIgnoreCase(dvId)) { /*if (evt.getSpeed() < 1 ){ // Vrification nombre d'arrt int tmps = getDuration(pList, dvId, i); if (tmps > ARRET_MAX){ nbrarret ++; nbinfo ++; } } */ if (evt.getSpeed() > evt.getSpeedMax()) { // Vrification vitesse maximum nbrdepvitesse++; nbinfo++; } } } if (nbinfo > 0) { //nbrarret = nbrarret - 2; //On enlve le point de dpart et d'arriv if (nbrarret < 1) nbrarret = 0; secuInfos = secuInfos + "<div id=\"secu" + irang + "\" class=\"secuInfos\"><img id=\"imgEvent" + irang + "\" class=\"siCatIcon\"/><label class=\"siLabel\">Evènements"; secuInfos = secuInfos + "</label><hr /><br /><table><tr><td><table class=\"alignToChart tableSecuInfos\"><tr><td class=\"tsiLabel\">Nombre total d'arrê ts</td>"; secuInfos = secuInfos + "<td class=\"tsiData\">" + nbrarret + "</td></tr>" + "<tr><td class=\"tsiLabel\">Nombre d'arrê ts non-autorisés</td><td class=\"tsiData\">0</td></tr></table>" + "</td><td><img id=\"secTabImgLegendStopOK" + irang + "\" class=\"secTabLegendImgAlt\"></td></tr></table><br /><table><tr><td>"; secuInfos = secuInfos + "<table class=\"alignToChart tableSecuInfos\"><tr>" + "<td class=\"tsiLabel\">Nombre total de dépassements de vitesse</td><td class=\"tsiData\">" + nbrdepvitesse + "</td></tr>" + "<tr><td class=\"tsiLabel\">Durée totale en dépassement de vitesse</td><td class=\"tsiData\">00:00:00</td></tr><tr><td class=\"tsiLabel\">Dépassements de vitesse / durée de roulage</td><td class=\"tsiData\">0.0%</td></tr></table></td><td>"; secuInfos = secuInfos + "<img id=\"secTabImgLegendSpeed" + irang + "\" class=\"secTabLegendImg\"></td></tr></table><br /><table><tr><td>" + "<table class=\"alignToChart tableSecuInfos\"><tr><td class=\"tsiLabel\">Nombre d'accélérations hors-norme</td>" + "<td class=\"tsiData\">0</td></tr><tr><td class=\"tsiLabel\">Durée en accélération hors-norme</td><td class=\"tsiData\">00:00:00</td></tr>" + "<tr><td class=\"tsiLabel\">Accélérations hors-norme / durée de roulage</td><td class=\"tsiData\">0.0%</td></tr></table></td><td><img id=\"secTabImgAccAlarm" + irang + "\" class=\"secTabLegendImg\"></td></tr></table><br />"; secuInfos = secuInfos + "<table><tr><td><table class=\"alignToChart tableSecuInfos\"><tr><td class=\"tsiLabel\">Nombre de décélérations hors-norme</td><td class=\"tsiData\">0</td>" + "</tr><tr><td class=\"tsiLabel\">Durée en décélération hors-norme</td><td class=\"tsiData\">00:00:00</td></tr><tr><td class=\"tsiLabel\">Décélérations hors-norme / durée de roulage" + "</td><td class=\"tsiData\">0.0%</td></tr></table></td><td><img id=\"secTabImgDecAlarm" + irang + "\" class=\"secTabLegendImg\"></td></tr></table><br /><br />"; secuInfos = secuInfos + "<img id=\"imgChart" + irang + "\" class=\"siCatIcon\"/><label class=\"siLabel\">Vitesse</label><hr /><br />" + "<div class=\"alignToChart\">Sélectionnez une zone du graphe avec la souris pour zoomer. Double-cliquez pour revenir au niveau de zoom initial." + "<br/>Passez la souris sur la graphe pour afficher le détail d'un point.</div><br/><div><div id=\"speedChart" + irang + "\" class=\"speedChart\"></div></div><br/><br/></div>"; } return secuInfos; } public static double tempsDep(double tms1, double tmsap, double tmsav, int vit1, int vitap, int vitav, int vitmax) { double tmps = 0; double dtms = tmsap - tms1; double dvit = Math.abs(vit1 - vitap); double dtmsA = tms1 - tmsav; double dvitA = Math.abs(vit1 - vitav); double kms = dvit / dtms; double kmsA = dvitA / dtmsA; tmps = (vit1 - vitmax) / kms + (vit1 - vitmax) / kmsA; //System.out.println("dtms:" +dtms + " dvit:"+ dvit+" dtmsA:" +dtmsA + " dvitA:"+ dvitA); return tmps; }; private static int getDuration(LinkedList pList, String dvId, int index) { int tmps = 0; Events evt = (Events) pList.get(index); tmps = 0; if (index == 0) { for (int j = index + 1; j < pList.size(); j++) { Events evtnxt = (Events) pList.get(j); if (evtnxt.getSpeed() > 1.0) { double diff = evtnxt.getDateEvt().getTime() - evt.getDateEvt().getTime(); tmps = (int) diff / 1000; j = pList.size(); } } } else { Events evtbef = (Events) pList.get(index - 1); if (evtbef.getSpeed() > 0.) { for (int j = index + 1; j < pList.size(); j++) { Events evtnxt = (Events) pList.get(j); if (evtnxt.getSpeed() > 1.0) { double diff = evtnxt.getDateEvt().getTime() - evt.getDateEvt().getTime(); tmps = (int) diff / 1000; j = pList.size(); } } } } /*for (int i = index; i < pList.size(); i++) { Events evt = (Events) pList.get(i); if (evt.getDeviceID().equals(dvId)) { int k = i + 1; tmps = 0; if (k < pList.size()){ Events evtnxt = (Events) pList.get(k); if (evtnxt.getDeviceID().equals(dvId)){ double diff = evtnxt.getDateEvt().getTime() - evt.getDateEvt().getTime(); tmps = (int) diff / 1000; i = pList.size(); } } } }*/ //System.out.println("duree: "+tmps); return tmps; } private static String getDurationString(int seconds) { int hours = seconds / 3600; int minutes = (seconds % 3600) / 60; seconds = seconds % 60; return twoDigitString(hours) + ":" + twoDigitString(minutes) + ":" + twoDigitString(seconds); } private static String twoDigitString(int number) { if (number == 0) { return "00"; } if (number / 10 == 0) { return "0" + number; } return String.valueOf(number); } public static boolean calculProx(double latitude, double longitude, double latitudelast, double longitudelast) { boolean proxim = false; if (Math.abs(latitudelast - latitude) < 0.00009 && Math.abs(longitudelast - longitude) < 0.00009) proxim = true; else proxim = false; return proxim; } public static LinkedList createTemporaryTable(Connection c, Statement s, String account) { ResultSet rs = null; boolean flag, proximite; boolean first = true; boolean topwrite = true; boolean statuslast = true; String devIDlast = ""; String acIDlast = ""; Timestamp dateEVlast = null; double latitudelast = 0; double longitudelast = 0; double odometerKMlast = 0; double odometerOffsetKMlast = 0; int headinglast = 0; double vitesselast = 0; int statusCodelast = -1; int nbevt = 0; int duree = 0; int i = 0; int nbrDevice = 0; formatSymbols.setDecimalSeparator('.'); DecimalFormat dec = new DecimalFormat("#00.000000", formatSymbols); Calendar cal = Calendar.getInstance(); cal.add(Calendar.DATE, -1); Date dateBefore1Days = cal.getTime(); //System.out.println(new SimpleDateFormat("yyyy-MM-dd").format(dateBefore1Days)); date_trt = new SimpleDateFormat("yyyy-MM-dd").format(dateBefore1Days); String date_fin = date_trt + " 23:59:59"; date_trt = date_trt + " 00:00:00"; LinkedList<Events> eventsList = new LinkedList<Events>(); StringBuffer sb = new StringBuffer(); //String sentence = "CREATE TEMPORARY TABLE datatmpEvt( tmpid int NOT NULL AUTO_INCREMENT, accountID varchar(45), deviceID varchar(45), dateEvt Timestamp, lat double, lon double, speed int, tmps int, first boolean, odometerKM double, odometerOffsetKM double, statusCode int, deviceSpeedLimit int,PRIMARY KEY(tmpid), INDEX(tmpid));"; try { Statement st = c.createStatement(); //s.executeUpdate(sentence); String sql = "SELECT count(*) as nbrDevice from Device WHERE accountID='" + account + "';"; ResultSet rs1 = st.executeQuery(sql); if (rs1.next()) { nbrDevice = rs1.getObject("nbrDevice") != null ? rs1.getInt("nbrDevice") : null; deviceID = new String[nbrDevice]; deviceSpeedLimit = new String[nbrDevice]; sql = "SELECT accountID, deviceID, speedLimitKPH from Device WHERE accountID='" + account + "';"; ResultSet rs2 = st.executeQuery(sql); for (flag = rs2.next(); flag; flag = rs2.next()) { deviceID[i] = rs2.getString("deviceID"); deviceSpeedLimit[i] = rs2.getString("speedLimitKPH"); //System.out.println(rs2.getString("accountID") + " " + deviceID[i]+" Vitesse limite:"+deviceSpeedLimit[i]+"kms/h"); i++; } //String sql = "SELECT accountID, FROM_UNIXTIME(timestamp) as timestamp, deviceID, latitude, longitude, speedKPH FROM EventData WHERE accountID='telo' and deviceID='telo1' and DATE_FORMAT(FROM_UNIXTIME(timestamp),'%y-%m-%d') = DATE_FORMAT(DATE_SUB(NOW(), INTERVAL 1 day),'%y-%m-%d') order by deviceID,timestamp;"; //DATE_FORMAT(NOW(),'%y-%m-%d') sql = "SELECT accountID, FROM_UNIXTIME(timestamp) as timestamp, deviceID, latitude, longitude, speedKPH, odometerKM, odometerOffsetKM, statusCode, heading FROM EventData WHERE accountID='" + account + "' and longitude <> 0.0 and FROM_UNIXTIME(timestamp) >= '" + date_trt + "' and FROM_UNIXTIME(timestamp) <= '" + date_fin + "' order by deviceID,timestamp;"; System.out.println(sql); rs = st.executeQuery(sql); // lecture premier enregistrement if (rs.next()) { acIDlast = rs.getObject("accountID") != null ? rs.getString("accountID") : null; devIDlast = rs.getObject("accountID") != null ? rs.getString("deviceID") : null; dateEVlast = rs.getTimestamp("timestamp"); latitudelast = rs.getObject("latitude") != null ? rs.getDouble("latitude") : null; longitudelast = rs.getObject("longitude") != null ? rs.getDouble("longitude") : null; vitesselast = rs.getObject("speedKPH") != null ? rs.getInt("speedKPH") : null; statusCodelast = rs.getObject("statusCode") != null ? rs.getInt("statusCode") : null; //vitesselast = 0.; odometerKMlast = rs.getObject("odometerKM") != null ? rs.getDouble("odometerKM") : null; odometerOffsetKMlast = rs.getObject("odometerOffsetKM") != null ? rs.getDouble("odometerOffsetKM") : null; int statusCode = rs.getObject("statusCode") != null ? rs.getInt("statusCode") : null; headinglast = rs.getObject("heading") != null ? rs.getInt("heading") : 0; statuslast = true; int speedLimit = 0; for (int id = 0; id < nbrDevice; id++) { if (devIDlast.equalsIgnoreCase(deviceID[id])) { speedLimit = Integer.parseInt(deviceSpeedLimit[id]); id = nbrDevice; } else speedLimit = 0; } eventsList.add(new Events(acIDlast, devIDlast, latitudelast, longitudelast, vitesselast, dateEVlast, odometerKMlast, odometerOffsetKMlast, statusCode, speedLimit, headinglast)); nbevt++; //Events evt = (Events) eventsList.get(0); //System.out.println(evt.getAccountID() + " " + evt.getDeviceID() + " " + new SimpleDateFormat("yyy-MM-dd HH:mm:ss").format(evt.getDateEvt()) + " " + dec.format(evt.getLatitude()) + " "+ dec.format(evt.getLongitude()) + " " + evt.getSpeed() + " " + evt.getOdometerKM() + " " + evt.getSpeedMax() + " "+evt.getStatusCode()); for (flag = rs.next(); flag; flag = rs.next()) { String acID = rs.getObject("accountID") != null ? rs.getString("accountID") : null; String devID = rs.getObject("accountID") != null ? rs.getString("deviceID") : null; Timestamp dateEV = rs.getTimestamp("timestamp"); double latitude = rs.getObject("latitude") != null ? rs.getDouble("latitude") : null; double longitude = rs.getObject("longitude") != null ? rs.getDouble("longitude") : null; double vitesse = rs.getObject("speedKPH") != null ? rs.getInt("speedKPH") : null; double odometerKM = rs.getObject("odometerKM") != null ? rs.getDouble("odometerKM") : null; double odometerOffsetKM = rs.getObject("odometerOffsetKM") != null ? rs.getDouble("odometerOffsetKM") : null; statusCode = rs.getObject("statusCode") != null ? rs.getInt("statusCode") : null; int heading = rs.getObject("heading") != null ? rs.getInt("heading") : 0; //System.out.println(acID + " " + devID + " " + new SimpleDateFormat("yyy-MM-dd HH:mm:ss").format(dateEV) + " " + latitude + " "+ longitude + " " + vitesse); //proximite = calculProx(latitude, longitude, latitudelast, longitudelast); for (int id = 0; id < nbrDevice; id++) { if (devIDlast.equalsIgnoreCase(deviceID[id])) { speedLimit = Integer.parseInt(deviceSpeedLimit[id]); id = nbrDevice; } else speedLimit = 0; } if (devIDlast.equalsIgnoreCase(devID)) { /*if (vitesse == 0.0 && vitesselast == 0.0 && (odometerKM - odometerKMlast) < 1){ } else*/ { if (INTERPOLATION) { long diff = dateEV.getTime() - dateEVlast.getTime(); duree = (int) diff / 1000; if (duree > 120) { eventsList = addpointsList(acID, devID, eventsList, latitude, longitude, dateEV, vitesse, odometerKM, odometerOffsetKM, statusCode, speedLimit, heading); nbevt++; } else { eventsList.add(new Events(acID, devID, latitude, longitude, vitesse, dateEV, odometerKM, odometerOffsetKM, statusCode, speedLimit, heading)); nbevt++; //evt = (Events) eventsList.get(eventsList.size()-1); //System.out.println(evt.getAccountID() + " " + evt.getDeviceID() + " " + new SimpleDateFormat("yyy-MM-dd HH:mm:ss").format(evt.getDateEvt()) + " " + dec.format(evt.getLatitude()) + " "+ dec.format(evt.getLongitude()) + " " + evt.getSpeed() + " " + evt.getOdometerKM() + " " + evt.getSpeedMax() + " "+evt.getStatusCode()); } } else { eventsList.add(new Events(acID, devID, latitude, longitude, vitesse, dateEV, odometerKM, odometerOffsetKM, statusCode, speedLimit, heading)); nbevt++; } if (vitesse == 0.0 && vitesselast == 0.0) { } else { devIDlast = devID; acIDlast = acID; dateEVlast = dateEV; latitudelast = latitude; longitudelast = longitude; vitesselast = vitesse; odometerKMlast = odometerKM; odometerOffsetKMlast = odometerOffsetKM; statusCodelast = statusCode; headinglast = heading; } } } else { eventsList.add(new Events(acID, devID, latitude, longitude, vitesse, dateEV, odometerKM, odometerOffsetKM, statusCode, speedLimit, heading)); devIDlast = devID; acIDlast = acID; dateEVlast = dateEV; latitudelast = latitude; longitudelast = longitude; vitesselast = vitesse; odometerKMlast = odometerKM; odometerOffsetKMlast = odometerOffsetKM; statusCodelast = statusCode; headinglast = heading; //evt = (Events) eventsList.get(eventsList.size()-1); //System.out.println(evt.getAccountID() + " " + evt.getDeviceID() + " " + new SimpleDateFormat("yyy-MM-dd HH:mm:ss").format(evt.getDateEvt()) + " " + dec.format(evt.getLatitude()) + " "+ dec.format(evt.getLongitude()) + " " + evt.getSpeed() + " " + evt.getOdometerKM() + " " + evt.getSpeedMax() + " "+evt.getStatusCode()); } /*if (devIDlast.equalsIgnoreCase(devID) && vitesse < 1 && vitesselast < 1) { topwrite = false; } else { long diff = dateEV.getTime() - dateEVlast.getTime() ; duree = (int) diff / 1000; if (devIDlast.equalsIgnoreCase(devID)) { if (statuslast) { first = true; duree = 0; } statuslast = false; } else { statuslast = true; duree = 0; } if (first) { duree = 0; //vitesselast = 0; } for(int id=0 ;id < nbrDevice;id++){ if (devIDlast.equalsIgnoreCase(deviceID[id])){ speedLimit = Integer.parseInt(deviceSpeedLimit[id]); id = nbrDevice; } else speedLimit = 0; } sentence = "INSERT INTO datatmpEvt(accountID, deviceID, dateEvt, lat, lon, speed, tmps, first, odometerKM, odometerOffsetKM, statusCode, deviceSpeedLimit) VALUES(?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)"; PreparedStatement pstmt = c.prepareStatement(sentence); pstmt.setString(1, acIDlast); pstmt.setString(2, devIDlast); pstmt.setTimestamp(3, dateEVlast); pstmt.setDouble(4, latitudelast); pstmt.setDouble(5, longitudelast); pstmt.setDouble(6, vitesselast); pstmt.setInt(7, duree); pstmt.setBoolean(8, first); pstmt.setDouble(9, odometerKMlast); pstmt.setDouble(10, odometerOffsetKMlast); pstmt.setInt(11, statusCodelast); pstmt.setInt(12, speedLimit); pstmt.executeUpdate(); nbevt++; devIDlast = devID; acIDlast = acID; dateEVlast = dateEV; latitudelast = latitude; longitudelast = longitude; vitesselast = vitesse; odometerKMlast = odometerKM; odometerOffsetKMlast = odometerOffsetKM; statusCodelast = statusCode; first = false; }*/ } /*if (topwrite){ for(int id=0 ;id < nbrDevice;id++){ if (devIDlast.equalsIgnoreCase(deviceID[id])){ speedLimit = Integer.parseInt(deviceSpeedLimit[id]); id = nbrDevice; } else speedLimit = 0; } sentence = "INSERT INTO datatmpEvt(accountID, deviceID, dateEvt, lat, lon, speed, tmps, first, odometerKM, odometerOffsetKM, statusCode, deviceSpeedLimit) VALUES(?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)"; PreparedStatement pstmt = c.prepareStatement(sentence); pstmt.setString(1, acIDlast); pstmt.setString(2, devIDlast); pstmt.setTimestamp(3, dateEVlast); pstmt.setDouble(4, latitudelast); pstmt.setDouble(5, longitudelast); pstmt.setDouble(6, 0.0D); pstmt.setInt(7, 0); pstmt.setBoolean(8, first); pstmt.setDouble(9, odometerKMlast); pstmt.setDouble(10, odometerOffsetKMlast); pstmt.setInt(11, statusCodelast); pstmt.setInt(12, speedLimit); pstmt.executeUpdate(); nbevt++; }*/ } rs2.close(); } rs1.close(); rs.close(); for (int j = 0; j < eventsList.size(); j++) { Events evt = (Events) eventsList.get(j); System.out.println(evt.getAccountID() + " " + evt.getDeviceID() + " " + new SimpleDateFormat("yyy-MM-dd HH:mm:ss").format(evt.getDateEvt()) + " " + dec.format(evt.getLatitude()) + " " + dec.format(evt.getLongitude()) + " " + evt.getSpeed() + " " + evt.getOdometerKM() + " " + evt.getSpeedMax() + " " + evt.getStatusCode() + " " + evt.getHeading()); } } catch (SQLException e) { e.printStackTrace(); } System.out.println("Chargement de la table termin. Nb=" + nbevt); return eventsList; } public static LinkedList addpoints(String acId, String dvId, LinkedList pList) { String secuInfos = ""; int nbrarret = 0; int nbrpoints = 0; double distance; int startIndex = 0; int startIndexEnd = 0; LinkedList<Events> pListnw = new LinkedList<Events>(); Events evtnxt = null; for (int i = 0; i < pList.size(); i++) { Events evt = (Events) pList.get(i); if (evt.getDeviceID().equalsIgnoreCase(dvId)) { String request = ""; int k = i + 2; if (k >= pList.size()) k = pList.size(); for (int j = i; j < k; j++) { evtnxt = (Events) pList.get(j); if (evtnxt.getDeviceID().equals(dvId)) { request = request + "loc=" + evtnxt.getLatitude() + "," + evtnxt.getLongitude(); nbrpoints++; startIndexEnd = j; } } if (nbrpoints > 1) { request = osrm + request + "&instructions=false&alt=false"; ArrayList<Location> polyline = sendGetLoc(request, "viaroute"); //distance = Double.parseDouble(rep[0])/1000.0; if (polyline != null) { double tempsnv = (evtnxt.getDateEvt().getTime() - evt.getDateEvt().getTime()) / polyline.size(); double temps = ((evtnxt.getDateEvt().getTime() - evt.getDateEvt().getTime()) / 1000.0) / 3600; //System.out.println("Nombre de point nv:" + polyline.size()+ " tmps a ajouter = "+ tempsnv); for (int ip = 0; ip < polyline.size(); ip++) { double tmps = evt.getDateEvt().getTime() + (tempsnv * (ip + 1)); int dist = Integer.parseInt(((Location) polyline.get(ip)).getDistance()) / 1000; double vitessenv = dist / temps; double lat = ((Location) polyline.get(ip)).getLatitude(); double lon = ((Location) polyline.get(ip)).getLongitude(); Timestamp tm = new Timestamp( (long) (evt.getDateEvt().getTime() + (tempsnv * (ip + 1)))); //System.out.println("ip:" + ip+ "tmps = "+ tmps + " vitessenv: "+vitessenv); //System.out.println("donne l'indice " + ip + " = " +lat+ "," +lon+", "+tm.getTime()+" vit: "+vitessenv); pListnw.add(new Events(acId, dvId, lat, lon, vitessenv, tm, 0.0, 0.0, -1, (int) evt.getSpeedMax(), 0)); if (startIndex < 1) startIndex = i; } } } request = ""; nbrpoints = 0; i = k - 1; } } //pList.addAll(startIndex, pListnw); return pListnw; } public static LinkedList addpointsList(String acId, String dvId, LinkedList pList, double lat, double lon, Timestamp dateEV, double vitesse, double odometerKM, double odometerOffsetKM, int statusCode, int speedLimit, int heading) { double distance; LinkedList<Events> pListnw = new LinkedList<Events>(); Events evtnxt = null; int i = pList.size() - 1; Events evt = (Events) pList.get(i); if (evt.getDeviceID().equalsIgnoreCase(dvId)) { String request = ""; request = "loc=" + evt.getLatitude() + "," + evt.getLongitude() + "loc=" + lat + "," + lon; request = osrm + request + "&instructions=false&alt=false"; //System.out.println(":" +request); ArrayList<Location> polyline = sendGetLoc(request, "viaroute"); if (polyline != null) { double tempsnv = (dateEV.getTime() - evt.getDateEvt().getTime()) / polyline.size(); //System.out.println("dateEV:"+new SimpleDateFormat("yyy-MM-dd HH:mm:ss").format(dateEV)+" evt.getDateEvt():"+new SimpleDateFormat("yyy-MM-dd HH:mm:ss").format(evt.getDateEvt())); double temps = ((dateEV.getTime() - evt.getDateEvt().getTime()) / 1000.0) / 3600; //System.out.println("Nombre de point nv:" + polyline.size()+ " tmps a ajouter = "+ tempsnv+ " dif:"+temps); for (int ip = 0; ip < polyline.size(); ip++) { double tmps = evt.getDateEvt().getTime() + (tempsnv * (ip + 1)); int dist = Integer.parseInt(((Location) polyline.get(ip)).getDistance()) / 1000; double vitessenv = dist / temps; double la = ((Location) polyline.get(ip)).getLatitude(); double lo = ((Location) polyline.get(ip)).getLongitude(); Timestamp tm = new Timestamp((long) (evt.getDateEvt().getTime() + (tempsnv * (ip + 1)))); //System.out.println("ip:" + ip+ "tmps = "+ tmps + " vitessenv: "+vitessenv); //System.out.println("donne l'indice " + ip + " = " +lat+ "," +lon+", "+tm.getTime()+" vit: "+vitessenv); pList.add(new Events(acId, dvId, la, lo, (int) vitessenv, tm, evt.getOdometerKM() + (dist * (ip + 1)), 0.0, -1, speedLimit, heading)); Events evtds = (Events) pList.get(pList.size() - 1); //System.out.println(evtds.getAccountID() + " " + evtds.getDeviceID() + " " + new SimpleDateFormat("yyy-MM-dd HH:mm:ss").format(evtds.getDateEvt()) + " " +evtds.getLatitude() + " "+ evtds.getLongitude() + " " + evtds.getSpeed() + " " + evtds.getOdometerKM() + " " + evtds.getSpeedMax() + " "+evtds.getStatusCode()); } //pList.addAll(pList.size() - 1, pListnw); } else { pList.add(new Events(acId, dvId, lat, lon, (int) vitesse, dateEV, odometerKM, odometerOffsetKM, statusCode, speedLimit, heading)); //System.out.println(acId + " " + dvId + " " + new SimpleDateFormat("yyy-MM-dd HH:mm:ss").format(dateEV) + " " + lat + " "+ lon + " " + vitesse + " " + odometerKM + " " + odometerOffsetKM + " "+speedLimit); } pListnw = pList; } //pList.addAll(startIndex, pListnw); return pListnw; } // HTTP GET request @SuppressWarnings("deprecation") private static String sendGet(String url, String type) { String genreJson; String distance = "0"; //rep = new String[2]; JSONParser parser = new JSONParser(); ArrayList polyline = new ArrayList(); try { JSONArray genreArray = null; if (type.equalsIgnoreCase("match")) { //url = osrm+"loc="+lat1+","+lon1+"&t="+tms1+"loc="+lat2+","+lon2+"&t="+tms2+"&compression=true"; genreJson = IOUtils.toString(new URL(url)); JSONObject genreJsonObject = (JSONObject) JSONValue.parseWithException(genreJson); genreArray = (JSONArray) genreJsonObject.get("matchings"); //System.out.println(genreArray); if (genreArray == null) { System.out.println("JMapData not found in JSON response"); distance = "0"; } else { // get the first genre JSONObject firstGenre = (JSONObject) genreArray.get(0); JSONObject routesummary = (JSONObject) firstGenre.get("route_summary"); distance = routesummary.get("total_distance").toString(); } //rep[0] = distance; } else { //url = osrm+"loc="+lat1+","+lon1+"&loc="+lat2+","+lon2+"&instructions=false&alt=false"; genreJson = IOUtils.toString(new URL(url)); JSONObject genreJsonObject = (JSONObject) JSONValue.parseWithException(genreJson); JSONObject firstGenre = (JSONObject) genreJsonObject.get("route_summary"); //System.out.println(firstGenre.get("total_distance").toString()); distance = firstGenre.get("total_distance").toString(); } } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (ParseException e) { // TODO Auto-generated catch block e.printStackTrace(); } return distance; } // HTTP GET request @SuppressWarnings("deprecation") private static ArrayList<Location> sendGetLoc(String url, String type) { String genreJson; String distance = "0"; ArrayList rep; //rep = new String[2]; JSONParser parser = new JSONParser(); ArrayList polyline = new ArrayList(); try { JSONArray genreArray = null; if (type.equalsIgnoreCase("match")) { //url = "http://192.168.0.12:5000/match?loc="+lat1+","+lon1+"&t="+tms1+"loc="+lat2+","+lon2+"&t="+tms2+"&compression=true"; genreJson = IOUtils.toString(new URL(url)); JSONObject genreJsonObject = (JSONObject) JSONValue.parseWithException(genreJson); genreArray = (JSONArray) genreJsonObject.get("matchings"); //System.out.println(genreArray); if (genreArray == null) { System.out.println("JMapData not found in JSON response"); distance = "0"; } else { // get the first genre JSONObject firstGenre = (JSONObject) genreArray.get(0); JSONObject routesummary = (JSONObject) firstGenre.get("route_summary"); distance = routesummary.get("total_distance").toString(); } //rep[0] = distance; } else { //url = "http://192.168.0.1:5000/viaroute?loc="+lat1+","+lon1+"&loc="+lat2+","+lon2+"&instructions=false&alt=false"; genreJson = IOUtils.toString(new URL(url)); JSONObject genreJsonObject = (JSONObject) JSONValue.parseWithException(genreJson); JSONObject firstGenre = (JSONObject) genreJsonObject.get("route_summary"); //System.out.println(firstGenre.get("total_distance").toString()); distance = firstGenre.get("total_distance").toString(); Object obj = parser.parse(genreJson); JSONObject jsonObject = (JSONObject) obj; String route_geometry = (String) jsonObject.get("route_geometry"); polyline = decodePoly(route_geometry, distance); // Get size and display. //int count = polyline.size(); //System.out.println("Count: " + count); //rep[0] = distance; //rep[1] = polyline.toString(); } } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (ParseException e) { // TODO Auto-generated catch block e.printStackTrace(); } if ((Integer.parseInt(distance) / 1000) < DISTANCE_MINI_ENTRE_POINT) return null; else return polyline; } public static ArrayList decodePoly(String encoded, String distance) { ArrayList poly = new ArrayList(); int index = 0, len = encoded.length(); int lat = 0, lng = 0; while (index < len) { int b, shift = 0, result = 0; do { b = encoded.charAt(index++) - 63; result |= (b & 0x1f) << shift; shift += 5; } while (b >= 0x20); int dlat = ((result & 1) != 0 ? ~(result >> 1) : (result >> 1)); lat += dlat; shift = 0; result = 0; do { b = encoded.charAt(index++) - 63; result |= (b & 0x1f) << shift; shift += 5; } while (b >= 0x20); int dlng = ((result & 1) != 0 ? ~(result >> 1) : (result >> 1)); lng += dlng; Location p = new Location((((double) lat / 1E6)), (((double) lng / 1E6)), distance); poly.add(p); } return poly; } // ------------------------------------------------------------------------ private static void readConfig(String file) { Properties prop = new Properties(); InputStream input = null; try { input = new FileInputStream(file); // load a properties file prop.load(input); // get the property value and print it out url = prop.getProperty("url"); user = prop.getProperty("dbuser"); password = prop.getProperty("dbpassword"); osrm = prop.getProperty("osrm"); MAIL_FROM = prop.getProperty("mailfrom"); TEMPLATE_NAME = prop.getProperty("template"); String email = prop.getProperty("sendmail"); if (email.equalsIgnoreCase("true")) SEND_EMAIL = true; else SEND_EMAIL = false; String interpol = prop.getProperty("interpolation"); if (interpol.equalsIgnoreCase("true")) INTERPOLATION = true; else INTERPOLATION = false; System.out.println(url); System.out.println(user); //System.out.println(password); System.out.println(osrm); System.out.println(MAIL_FROM); System.out.println(TEMPLATE_NAME); System.out.println(SEND_EMAIL); System.out.println(INTERPOLATION); } catch (IOException ex) { ex.printStackTrace(); } finally { if (input != null) { try { input.close(); } catch (IOException e) { e.printStackTrace(); } } } } }