DDEAutoLLA_D50M57E1.ccpage 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <fragment xmlns="http://www.holeschak.de/BmwDeepObd" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.holeschak.de/BmwDeepObd BmwDeepObd.xsd">
  3. <page name="HOME" display-mode="grid" fontsize="medium" gauges-portrait="3" gauges-landscape="5" logfile="DME_DDE.log">
  4. <strings lang="de">
  5. <string name="HOME">HOME</string>
  6. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_KUEHLMITTELTEMPERATUR_WERT"> Kühlmitteltemperatur [°C]</string>
  7. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_LADELUFTTEMPERATUR_WERT"> Ladelufttemp. [°C]</string>
  8. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_MOTORDREHZAHL_WERT"> Drehzahl [U/min]</string>
  9. <string name="!JOB#LLA_ABGLEICH_LESEN_WERT"> Anhebung Leerlaufdrehzahl [u/min]</string>
  10. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_MOTORMOMENT_AKTUELL_WERT"> Drehmoment [Nm]:</string>
  11. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_UBATT_WERT"> Batteriespannung [V]</string>
  12. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_GENERATORLAST_WERT"> Generatorlast [%]</string>
  13. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_ZUHEIZER_ANSTEUERUNG_WERT"> Zuheizer PWM [%]</string>
  14. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_LADEDRUCK_WERT"> Ladedruck Ist [mbar]</string>
  15. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_LADEDRUCK_SOLL_WERT"> Ladedruck Soll [mbar]</string>
  16. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_UMGEBUNGSDRUCK_WERT"> Luftdruck [mbar]</string>
  17. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_LUFTMASSE_PRO_HUB_WERT"> Luftmasse [mg/Hub]</string>
  18. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_EINSPRITZMENGE_AKTUELL_WERT"> Einspritzmenge [mg]</string>
  19. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_RAILDRUCK_WERT"> Raildruck Ist [bar]</string>
  20. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_RAILDRUCK_SOLL_WERT"> Raildruck Soll [bar]</string>
  21. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_GESCHWINDIGKEIT_WERT"> Geschwindigkeit [km/h]</string>
  22. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_FAHRZEUGBESCHLEUNIGUNG_WERT"> Beschleunigung [m/s²]</string>
  23. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_KUPPLUNGSSCHALTER_ROH_WERT"> Kupplungsschalter</string>
  24. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_KLIMAKOMPRESSOR_STATUS_WERT"> Klimakompressor</string>
  25. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_BEREITSCHAFT_KLIMA_WERT"> Klima Bereitschaft</string>
  26. <string name="!JOB#STATUS_TOENS_IO#STAT_TOG_HIGH_WERT"> TÖNS Heizzeit [ms]</string>
  27. <string name="!JOB#STATUS_TOENS_IO#STAT_TOG_LOW_WERT"> TÖNS Kühlzeit [ms]</string>
  28. </strings>
  29. <strings>
  30. <string name="HOME">HOME</string>
  31. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_KUEHLMITTELTEMPERATUR_WERT"> coolant [°C]</string>
  32. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_LADELUFTTEMPERATUR_WERT"> charge air temperature [°C]</string>
  33. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_MOTORDREHZAHL_WERT"> engine speed [U/min]</string>
  34. <string name="!JOB#LLA_ABGLEICH_LESEN_WERT"> increase idle speed [rpm]</string>
  35. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_MOTORMOMENT_AKTUELL_WERT"> torque [Nm]:</string>
  36. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_UBATT_WERT"> voltage [V]</string>
  37. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_GENERATORLAST_WERT"> alternator load [%]</string>
  38. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_ZUHEIZER_ANSTEUERUNG_WERT"> aux heater PWM [%]</string>
  39. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_LADEDRUCK_SOLL_WERT"> target boost pressure [mbar]</string>
  40. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_LADEDRUCK_WERT"> act. boost pressure [mbar]</string>
  41. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_UMGEBUNGSDRUCK_WERT"> air pressure [mbar]</string>
  42. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_LUFTMASSE_PRO_HUB_WERT"> air mass [mg/stroke]</string>
  43. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_EINSPRITZMENGE_AKTUELL_WERT"> Einspritzmenge [mg]</string>
  44. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_RAILDRUCK_WERT"> act. rail pressure [bar]</string>
  45. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_RAILDRUCK_SOLL_WERT"> Raildruck Soll [bar]</string>
  46. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_GESCHWINDIGKEIT_WERT"> speed [km/h]</string>
  47. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_FAHRZEUGBESCHLEUNIGUNG_WERT"> acceleration [m/s²]</string>
  48. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_KUPPLUNGSSCHALTER_ROH_WERT"> Clutch switch</string>
  49. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_KLIMAKOMPRESSOR_STATUS_WERT"> AC compressor</string>
  50. <string name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_BEREITSCHAFT_KLIMA_WERT"> AC in standby</string>
  51. <string name="!JOB#STATUS_TOENS_IO#STAT_TOG_HIGH_WERT"> TÖNS heating time [ms]</string>
  52. <string name="!JOB#STATUS_TOENS_IO#STAT_TOG_LOW_WERT"> TÖNS cooling time [ms]</string>
  53. </strings>
  54. <display name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_KUEHLMITTELTEMPERATUR_WERT" result="STAT_KUEHLMITTELTEMPERATUR_WERT" grid-type="simple-gauge-round" min-value="-20" max-value="120" log_tag="STAT_KUEHLMITTELTEMPERATUR_WERT" />
  55. <display name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_LADELUFTTEMPERATUR_WERT" result="STAT_LADELUFTTEMPERATUR_WERT" format=".1R" grid-type="simple-gauge-round" min-value="-20" max-value="80" log_tag="STAT_LADELUFTTEMPERATUR_WERT" />
  56. <display name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_MOTORDREHZAHL_WERT" result="STAT_MOTORDREHZAHL_WERT" grid-type="simple-gauge-round" min-value="0" max-value="5000" log_tag="STAT_MOTORDREHZAHL_WERT" />
  57. <display name="!JOB#LLA_ABGLEICH_LESEN_WERT" result="LLA_ABGLEICH_LESEN_WERT" format="L" display-order="0" grid-type="simple-gauge-round" min-value="0" max-value="250" log_tag="LLA" />
  58. <display name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_MOTORMOMENT_AKTUELL_WERT" result="STAT_MOTORMOMENT_AKTUELL_WERT" format="L" grid-type="simple-gauge-round" min-value="0" max-value="600" log_tag="STAT_MOTORMOMENT_AKTUELL_WERT" />
  59. <display name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_UBATT_WERT" result="STAT_UBATT_WERT" grid-type="simple-gauge-round" min-value="0" max-value="15" log_tag="STAT_UBATT_WERT" />
  60. <display name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_GENERATORLAST_WERT" result="STAT_GENERATORLAST_WERT" grid-type="simple-gauge-round" min-value="0" max-value="100" log_tag="STAT_GENERATORLAST_WERT" />
  61. <display name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_ZUHEIZER_ANSTEUERUNG_WERT" result="STAT_ZUHEIZER_ANSTEUERUNG_WERT" grid-type="simple-gauge-round" min-value="0" max-value="100" log_tag="STAT_ZUHEIZER_ANSTEUERUNG_WERT" />
  62. <display name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_LADEDRUCK_SOLL_WERT" result="STAT_LADEDRUCK_SOLL_WERT" format="4.1R" grid-type="simple-gauge-round" min-value="0" max-value="2500" log_tag="STAT_LADEDRUCK_SOLL_WERT" />
  63. <display name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_LADEDRUCK_WERT" result="STAT_LADEDRUCK_WERT" format="4.1R" grid-type="simple-gauge-round" min-value="0" max-value="2500" log_tag="STAT_LADEDRUCK_WERT" />
  64. <display name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_UMGEBUNGSDRUCK_WERT" result="STAT_UMGEBUNGSDRUCK_WERT" format="4.1R" grid-type="simple-gauge-round" min-value="800" max-value="1300" log_tag="STAT_UMGEBUNGSDRUCK_WERT" />
  65. <display name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_LUFTMASSE_PRO_HUB_WERT" result="STAT_LUFTMASSE_PRO_HUB_WERT" format="L" grid-type="simple-gauge-round" min-value="0" max-value="1500" log_tag="STAT_LUFTMASSE_PRO_HUB_WERT" />
  66. <display name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_EINSPRITZMENGE_AKTUELL_WERT" result="STAT_EINSPRITZMENGE_AKTUELL_WERT" format="L" grid-type="simple-gauge-round" min-value="0" max-value="100" log_tag="STAT_EINSPRITZMENGE_AKTUELL_WERT" />
  67. <display name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_RAILDRUCK_WERT" result="STAT_RAILDRUCK_WERT" format="L" grid-type="simple-gauge-round" min-value="0" max-value="1400" log_tag="STAT_RAILDRUCK_WERT" />
  68. <display name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_RAILDRUCK_SOLL_WERT" result="STAT_RAILDRUCK_SOLL_WERT" format="L" grid-type="simple-gauge-round" min-value="0" max-value="1400" log_tag="STAT_RAILDRUCK_SOLL_WERT" />
  69. <display name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_GESCHWINDIGKEIT_WERT" result="STAT_GESCHWINDIGKEIT_WERT" format="L" grid-type="simple-gauge-round" min-value="0" max-value="250" log_tag="STAT_GESCHWINDIGKEIT_WERT" />
  70. <display name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_FAHRZEUGBESCHLEUNIGUNG_WERT" result="STAT_FAHRZEUGBESCHLEUNIGUNG_WERT" format="2.3R" grid-type="simple-gauge-round" min-value="-15" max-value="15" log_tag="STAT_FAHRZEUGBESCHLEUNIGUNG_WERT" />
  71. <display name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_KUPPLUNGSSCHALTER_ROH_WERT" result="STAT_KUPPLUNGSSCHALTER_ROH_WERT" format="L" grid-type="simple-gauge-round" min-value="0" max-value="1" log_tag="STAT_KUPPLUNGSSCHALTER_ROH_WERT" />
  72. <display name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_KLIMAKOMPRESSOR_STATUS_WERT" result="STAT_KLIMAKOMPRESSOR_STATUS_WERT" format="L" grid-type="simple-gauge-round" min-value="0" max-value="1" log_tag="STAT_KLIMAKOMPRESSOR_STATUS_WERT" />
  73. <display name="!JOB#STATUS_MESSWERTBLOCK_LESEN#STAT_BEREITSCHAFT_KLIMA_WERT" result="STAT_BEREITSCHAFT_KLIMA_WERT" format="L" grid-type="simple-gauge-round" min-value="0" max-value="1" log_tag="STAT_BEREITSCHAFT_KLIMA_WERT" />
  74. <display name="!JOB#STATUS_TOENS_IO#STAT_TOG_HIGH_WERT" result="STAT_TOG_HIGH_WERT" format="L" grid-type="simple-gauge-round" min-value="0" max-value="1000" log_tag="STAT_TOG_HIGH_WERT" />
  75. <display name="!JOB#STATUS_TOENS_IO#STAT_TOG_LOW_WERT" result="STAT_TOG_LOW_WERT" format="L" grid-type="simple-gauge-round" min-value="0" max-value="1000" log_tag="STAT_TOG_LOW_WERT" />
  76. <jobs />
  77. <code show_warnings="true">
  78. <![CDATA[
  79. class PageClass
  80. {
  81. // PWM-Wert Ansteuerung Zuheizer, ab dem dieser als AN erkannt wird
  82. private double conf_ZuheizerAnAb = 25;
  83. // PWM-Wert Generatorlast, ab dem eine LL-Anhebung erfolgt
  84. private double conf_GeneratorlastHochAb = 60;
  85. private double conf_GeneratorlastSehrHochAb = 80;
  86. // Motortemperaturen
  87. private double conf_Temp_MotorSehrKaltBis = 25;
  88. private double conf_Temp_MotorKaltBis = 65;
  89. private double conf_Temp_MotorBetriebstempAb = 75;
  90. private double conf_Temp_MotorBetriebstempBis = 95;
  91. private double conf_Temp_MotorHeissAb = 100;
  92. // Ziel-Leerlaufanhebungswerte - es "gewinnt" immer der höchste Wert für die aktuellen Betriebsbedingungen
  93. private int conf_LLA_Basis = 0; // wenn die Kupplung nicht betätigt und auch sonst keine höhere Anhebung aktiv ist
  94. private int conf_LLA_Kupplung = 150;
  95. private int conf_LLA_Zuheizer = 200;
  96. private int conf_LLA_MotorSehrKalt = 150;
  97. private int conf_LLA_MotorKalt = 100;
  98. private int conf_LLA_MotorVorBetriebstemp = 70;
  99. private int conf_LLA_MotorBetriebstemp = 50;
  100. private int conf_LLA_MotorHeiss = 200;
  101. private int conf_LLA_KlimaBereitschaft = 90;
  102. private int conf_LLA_Klimakompressor = 120;
  103. private int conf_LLA_GeneratorlastHoch = 90;
  104. private int conf_LLA_GeneratorlastSehrHoch = 150;
  105. // Konfiguration für Zähler (Anzahl Durchläufe bis eine Aktion eintritt)
  106. // Noch genauer zu ermitteln wie viele Abfragen pro Sekunde bei der DDE5 mit dieser
  107. // Konfiguration im Durchschnitt anfallen.
  108. // alle 5 Durchläufe ergibt ca. 1 Sekunde Verzögerung
  109. private int conf_countdown_ZuheizerAn_max = 10;
  110. private int conf_countdown_Kupplung_max = 10;
  111. private int conf_countdown_Generatorlast_max = 10;
  112. private int conf_countdown_LLA_aus = 15;
  113. // wie häufig sollen zusätzliche Jobs ausgeführt werden?
  114. private int conf_counter_Job2_max = 20; // Job2 = am selben Steuergerät wie der Hauptjob
  115. private int conf_counter_JobSgbd2_max = 98; // JobSgbd2 = auf einem anderen Steuergerät
  116. // Steuergeräte SGBD files für Multijob definieren
  117. public static string[] conf_sgbds = {"D50M57E1", "kombi46r"};
  118. // Statusvariablen
  119. private bool status_MotorHeiss = false;
  120. private bool status_MotorBetriebstemp = false;
  121. private bool status_Kupplung = false;
  122. private bool status_Zuheizer = false;
  123. //private bool status_Klima = false;
  124. private bool status_GeneratorlastHoch = false;
  125. private bool status_GeneratorlastSehrHoch = false;
  126. private int currSgbd = 0; // momentan aktiv abgefragtes Steuergerät, für switch zwischen mehreren
  127. // Zähler
  128. private int countdown_ZuheizerAn = 0;
  129. private int countdown_Kupplung = 0;
  130. private int countdown_Generatorlast = 0;
  131. private int countdown_LLA_aus = 0;
  132. private int counter_Job2 = 0;
  133. private int counter_JobSgbd2 = 0;
  134. // Globale Variablen für Leerlaufanhebung
  135. private int LLA_momentan = 0;
  136. // result objekte für die zusätzlichen Jobs, die nicht in jedem Durchlauf abgefragt werden
  137. // muss global deklariert sein damit trotzdem in jedem Durchlauf die letzten Werte ausgegeben werden können
  138. List<Dictionary<string, EdiabasNet.ResultData>> resultSets_Abgleich;
  139. List<Dictionary<string, EdiabasNet.ResultData>> resultSets_JobSgbd2;
  140. public void ExecuteJob(EdiabasNet ediabas, ref MultiMap<string, EdiabasNet.ResultData> resultDict, bool firstCall)
  141. {
  142. List<Dictionary<string, EdiabasNet.ResultData>> resultSets;
  143. if(firstCall || currSgbd != 0) {
  144. currSgbd = 0;
  145. ediabas.ResolveSgbdFile(conf_sgbds[0]);
  146. //ediabas.ArgString = string.Empty;
  147. //ediabas.ArgBinaryStd = null;
  148. //ediabas.ResultsRequests = string.Empty;
  149. //ediabas.ExecuteJob("INITIALISIERUNG");
  150. }
  151. // Job 1 - ständig zu aktualisierende Werte
  152. ediabas.ArgString = "JA;ILMMG;IPLAD;IPUMG;IUBAT;IMOAK;INMOT;SPLAD;ITKUM;ITLAL;IPRDR;IAFZG;IVKMH;ITZUH;IGENL;RSKUP;IKLIS;IBKLI;SPRDR;IMEIA";
  153. ediabas.ArgBinaryStd = null;
  154. ediabas.ResultsRequests = string.Empty;
  155. ediabas.ExecuteJob("STATUS_MESSWERTBLOCK_LESEN");
  156. resultSets = ediabas.ResultSets;
  157. if (resultSets != null && resultSets.Count >= 2)
  158. {
  159. EdiabasThread.MergeResultDictionarys(ref resultDict, resultSets[1]);
  160. }
  161. // Job 2 - wird nur bei jedem X-ten Durchlauf ausgeführt (definiert von [conf_counter_Job2_max])
  162. // Ergebnisse werden in globaler Variable vorgehalten und die letzten Werte in jedem Durchlauf ausgegeben
  163. if(counter_Job2 == 0) {
  164. ediabas.ArgString = "lla";
  165. ediabas.ArgBinaryStd = null;
  166. ediabas.ResultsRequests = string.Empty;
  167. ediabas.ExecuteJob("ABGLEICH_LESEN");
  168. resultSets_Abgleich = ediabas.ResultSets;
  169. counter_Job2++;
  170. }
  171. else if(counter_Job2 >= conf_counter_Job2_max) {
  172. counter_Job2 = 0;
  173. }
  174. else {
  175. counter_Job2++;
  176. }
  177. // da diese Werte nicht in jedem Durchlauf vom Steuergerät gelesen werden sind die Ergebnisdaten in einer
  178. // globalen Variablen gespeichert und werden jedesmal übernommen, auch wenn nicht ganz aktuell
  179. if (resultSets_Abgleich != null && resultSets_Abgleich.Count >= 2)
  180. {
  181. EdiabasThread.MergeResultDictionarys(ref resultDict, resultSets_Abgleich[1], "LLA_");
  182. }
  183. // Eingangswerte für automatische Leerlaufanhebung holen
  184. EdiabasNet.ResultData resultData;
  185. // Kupplungsschalter
  186. bool mom_Kupplung = false;
  187. if (resultSets[1].TryGetValue("STAT_KUPPLUNGSSCHALTER_ROH_WERT", out resultData))
  188. {
  189. if (resultData.OpData is Double) {
  190. if(((Double)resultData.OpData) > 0.0) mom_Kupplung = true;
  191. }
  192. }
  193. // Klimakompressor
  194. bool mom_Klimakompressor = false;
  195. if (resultSets[1].TryGetValue("STAT_KLIMAKOMPRESSOR_STATUS_WERT", out resultData))
  196. {
  197. if (resultData.OpData is Double) {
  198. if(((Double)resultData.OpData) > 0.0) mom_Klimakompressor = true;
  199. }
  200. }
  201. // Klima-Bereitschaft
  202. bool mom_KlimaBereitschaft = false;
  203. if (resultSets[1].TryGetValue("STAT_BEREITSCHAFT_KLIMA_WERT", out resultData))
  204. {
  205. if (resultData.OpData is Double) {
  206. if(((Double)resultData.OpData) > 0.0) mom_KlimaBereitschaft = true;
  207. }
  208. }
  209. // Zuheizer-Ansteuerung
  210. Double mom_Zuheizer_PWM = 0;
  211. if (resultSets[1].TryGetValue("STAT_ZUHEIZER_ANSTEUERUNG_WERT", out resultData))
  212. {
  213. if (resultData.OpData is Double)
  214. {
  215. mom_Zuheizer_PWM = ((Double)resultData.OpData);
  216. }
  217. }
  218. // Generatorlast
  219. Double mom_Generatorlast_PWM = 0;
  220. if (resultSets[1].TryGetValue("STAT_GENERATORLAST_WERT", out resultData))
  221. {
  222. if (resultData.OpData is Double)
  223. {
  224. mom_Generatorlast_PWM = ((Double)resultData.OpData);
  225. }
  226. }
  227. // Motortemperatur
  228. Double mom_MotorTemp = 0;
  229. if (resultSets[1].TryGetValue("STAT_KUEHLMITTELTEMPERATUR_WERT", out resultData))
  230. {
  231. if (resultData.OpData is Double)
  232. {
  233. mom_MotorTemp = ((Double)resultData.OpData);
  234. }
  235. }
  236. // Abgleichwert Leerlaufanhebung
  237. if (resultSets_Abgleich[1].TryGetValue("LLA_ABGLEICH_LESEN_WERT", out resultData))
  238. {
  239. if (resultData.OpData is Double)
  240. {
  241. LLA_momentan = (int)((Double)resultData.OpData);
  242. }
  243. }
  244. // Automatische Leerlaufanhebung
  245. int LLA_neu = 0;
  246. // Kupplungsschalter
  247. // der countdown dient dazu dass die Leerlaufanhebung erst zurückgenommen wird,
  248. // wenn die Kupplung schon eine Zeit lang nicht betätigt ist
  249. if (mom_Kupplung || status_Kupplung) {
  250. if(mom_Kupplung) countdown_Kupplung = conf_countdown_Kupplung_max;
  251. if(!status_Kupplung) status_Kupplung = true;
  252. if(conf_LLA_Kupplung > LLA_neu) LLA_neu = conf_LLA_Kupplung;
  253. }
  254. if (countdown_Kupplung > 0){
  255. countdown_Kupplung--;
  256. }
  257. else if (countdown_Kupplung == 0){
  258. countdown_Kupplung = -1;
  259. status_Kupplung = false;
  260. if(conf_LLA_Basis > LLA_neu) LLA_neu = conf_LLA_Basis;
  261. }
  262. // Zuheizer
  263. // der countdown dient dazu dass die Leerlaufanhebung erst zurückgenommen wird,
  264. // wenn der Zuheizer schon eine Zeit lang inaktiv ist (also z.B. nicht nur kurz wegen zu hoher Generatorlast abgeschaltet wurde)
  265. if (mom_Zuheizer_PWM > conf_ZuheizerAnAb || status_Zuheizer) {
  266. if(mom_Zuheizer_PWM > conf_ZuheizerAnAb) countdown_ZuheizerAn = conf_countdown_ZuheizerAn_max;
  267. if(!status_Zuheizer) status_Zuheizer = true;
  268. if(conf_LLA_Zuheizer > LLA_neu) LLA_neu = conf_LLA_Zuheizer;
  269. }
  270. if (countdown_ZuheizerAn > 0) {
  271. countdown_ZuheizerAn--;
  272. }
  273. else if (countdown_ZuheizerAn == 0) {
  274. countdown_ZuheizerAn = -1;
  275. status_Zuheizer = false;
  276. if(conf_LLA_Basis > LLA_neu) LLA_neu = conf_LLA_Basis;
  277. }
  278. // Generatorlast
  279. if (mom_Generatorlast_PWM > conf_GeneratorlastSehrHochAb || status_GeneratorlastSehrHoch) {
  280. if(mom_Generatorlast_PWM > conf_GeneratorlastSehrHochAb) countdown_Generatorlast = conf_countdown_Generatorlast_max;
  281. if(!status_GeneratorlastSehrHoch) status_GeneratorlastSehrHoch = true;
  282. if(conf_LLA_GeneratorlastSehrHoch > LLA_neu) LLA_neu = conf_LLA_GeneratorlastSehrHoch;
  283. }
  284. else if (mom_Generatorlast_PWM > conf_GeneratorlastHochAb || status_GeneratorlastHoch) {
  285. if(mom_Generatorlast_PWM > conf_GeneratorlastHochAb) countdown_Generatorlast = conf_countdown_Generatorlast_max;
  286. if(!status_GeneratorlastHoch) status_GeneratorlastHoch = true;
  287. if(conf_LLA_GeneratorlastHoch > LLA_neu) LLA_neu = conf_LLA_GeneratorlastHoch;
  288. }
  289. if (countdown_Generatorlast > 0) {
  290. countdown_Generatorlast--;
  291. }
  292. else if (countdown_Generatorlast == 0) {
  293. countdown_Generatorlast = -1;
  294. status_GeneratorlastHoch = false;
  295. status_GeneratorlastSehrHoch = false;
  296. if(conf_LLA_Basis > LLA_neu) LLA_neu = conf_LLA_Basis;
  297. }
  298. // Klimakompressor und Klimabereitschaft
  299. if (mom_Klimakompressor) {
  300. if(conf_LLA_Klimakompressor > LLA_neu) LLA_neu = conf_LLA_Klimakompressor;
  301. }
  302. else if (mom_KlimaBereitschaft) {
  303. if(conf_LLA_KlimaBereitschaft > LLA_neu) LLA_neu = conf_LLA_KlimaBereitschaft;
  304. }
  305. // Drehzahlanhebung je nach Motortemperatur,
  306. if(mom_MotorTemp < conf_Temp_MotorSehrKaltBis) {
  307. // Motor ist sehr kalt
  308. status_MotorBetriebstemp = false;
  309. if(conf_LLA_MotorSehrKalt > LLA_neu) LLA_neu = conf_LLA_MotorSehrKalt;
  310. }
  311. else if(mom_MotorTemp < conf_Temp_MotorKaltBis) {
  312. // Motor ist kalt
  313. status_MotorBetriebstemp = false;
  314. if(conf_LLA_MotorKalt > LLA_neu) LLA_neu = conf_LLA_MotorKalt;
  315. }
  316. else if(mom_MotorTemp >= conf_Temp_MotorKaltBis && mom_MotorTemp < conf_Temp_MotorBetriebstempAb) {
  317. // Motor ist nicht mehr kalt, aber noch nicht auf Betriebstemperatur
  318. status_MotorBetriebstemp = false;
  319. if(conf_LLA_MotorVorBetriebstemp > LLA_neu) LLA_neu = conf_LLA_MotorVorBetriebstemp;
  320. }
  321. else if(mom_MotorTemp >= conf_Temp_MotorBetriebstempAb && mom_MotorTemp < conf_Temp_MotorHeissAb && !status_MotorHeiss) {
  322. // Motor ist auf Betriebstemperatur
  323. status_MotorBetriebstemp = true;
  324. if(conf_LLA_MotorBetriebstemp > LLA_neu) LLA_neu = conf_LLA_MotorBetriebstemp;
  325. }
  326. else if(mom_MotorTemp >= conf_Temp_MotorBetriebstempAb && mom_MotorTemp < conf_Temp_MotorBetriebstempBis && status_MotorHeiss) {
  327. // Temperatur ist nachdem Status HEISS wieder weit genug gefallen -> Betriebstemperatur
  328. status_MotorHeiss = false;
  329. status_MotorBetriebstemp = true;
  330. if(conf_LLA_MotorBetriebstemp > LLA_neu) LLA_neu = conf_LLA_MotorBetriebstemp;
  331. }
  332. else if(mom_MotorTemp >= conf_Temp_MotorHeissAb) {
  333. // Motor ist HEISS -> weitere LL Anhebung um die Kühlung zu verbessern aktivieren
  334. // deaktivierung sobald die Temperatur wieder unter [conf_Temp_MotorBetriebstempBis] gefallen ist
  335. status_MotorHeiss = true;
  336. status_MotorBetriebstemp = false;
  337. if(conf_LLA_MotorHeiss > LLA_neu) LLA_neu = conf_LLA_MotorHeiss;
  338. }
  339. // Motor auf Betriebstemperatur - reduziere LL auf minimum "conf_LLA_Basis" nach einiger Zeit
  340. if(status_MotorBetriebstemp && LLA_neu == conf_LLA_MotorBetriebstemp) {
  341. if(countdown_LLA_aus == 0) {
  342. LLA_neu = conf_LLA_Basis;
  343. }
  344. else if(countdown_LLA_aus > 0) {
  345. countdown_LLA_aus--;
  346. }
  347. }
  348. else {
  349. countdown_LLA_aus = conf_countdown_LLA_aus;
  350. }
  351. // wenn der Ziel-LLA-Wert sich vom aktuell eingestellten unterscheidet -> Abgleich verstellen
  352. if (LLA_momentan != LLA_neu) {
  353. ediabas.ArgString = "lla;" + LLA_neu;
  354. ediabas.ArgBinaryStd = null;
  355. ediabas.ResultsRequests = "JOB_STATUS";
  356. ediabas.ExecuteJob("ABGLEICH_VERSTELLEN");
  357. //resultSets = ediabas.ResultSets;
  358. //if (resultSets != null && resultSets.Count >= 2)
  359. //{
  360. // EdiabasThread.MergeResultDictionarys(ref resultDict, resultSets[1]);
  361. //}
  362. // Ablaufvariable wieder zurücksetzen, sonst würde diese funktion nun bei jedem folgenden durchlauf ausgeführt werden...
  363. LLA_momentan = LLA_neu;
  364. conf_counter_Job2_max = 0;
  365. }
  366. // Job SGBD 2
  367. if(counter_JobSgbd2 == 0) {
  368. counter_JobSgbd2++;
  369. try {
  370. // try/catch, damit nicht der ganze Durchlauf abgebrochen und
  371. // gar keine Daten zurückgeliefert werden, falls das Steuergerät nicht
  372. // antwortet.
  373. currSgbd = 1;
  374. ediabas.ResolveSgbdFile(conf_sgbds[currSgbd]);
  375. //ediabas.ArgString = string.Empty;
  376. //ediabas.ArgBinaryStd = null;
  377. //ediabas.ResultsRequests = string.Empty;
  378. //ediabas.ExecuteJob("INITIALISIERUNG");
  379. ediabas.ArgString = string.Empty;
  380. ediabas.ArgBinaryStd = null;
  381. ediabas.ResultsRequests = string.Empty;
  382. ediabas.ExecuteJob("STATUS_TOENS_IO");
  383. resultSets_JobSgbd2 = ediabas.ResultSets;
  384. }
  385. catch {
  386. // dann halt nicht
  387. }
  388. }
  389. else if (counter_JobSgbd2 >= conf_counter_JobSgbd2_max) {
  390. counter_JobSgbd2 = 0;
  391. }
  392. else {
  393. counter_JobSgbd2++;
  394. }
  395. if (resultSets_JobSgbd2 != null && resultSets_JobSgbd2.Count >= 2)
  396. {
  397. EdiabasThread.MergeResultDictionarys(ref resultDict, resultSets_JobSgbd2[1]);
  398. }
  399. }
  400. public string FormatResult(JobReader.PageInfo pageInfo, MultiMap<string, EdiabasNet.ResultData> resultDict, string resultName, ref Android.Graphics.Color? textColor)
  401. {
  402. string result = string.Empty;
  403. double value;
  404. bool found;
  405. switch (resultName)
  406. {
  407. case "STAT_MOTORDREHZAHL_WERT":
  408. value = ActivityMain.GetResultDouble(resultDict, resultName, 0, out found);
  409. // result format: {0,[DIGITS TOTAL INCL COMMA],[0|0.0|0.00|0.000...]}
  410. result = string.Format(ActivityMain.Culture, "{0,4:0}", value);
  411. // Liste der möglichen Farbnamen: https://docs.microsoft.com/en-us/dotnet/api/android.graphics.color?view=xamarin-android-sdk-9
  412. if (found && value <= 4000) textColor = Android.Graphics.Color.White;
  413. else if (found && value <= 4250) textColor = Android.Graphics.Color.Yellow;
  414. else if (found && value <= 4500) textColor = Android.Graphics.Color.Orange;
  415. else if (found && value > 4500) textColor = Android.Graphics.Color.Red;
  416. else textColor = Android.Graphics.Color.Gray;
  417. break;
  418. case "STAT_UBATT_WERT":
  419. value = ActivityMain.GetResultDouble(resultDict, resultName, 0, out found);
  420. // result format: {0,[DIGITS TOTAL INCL COMMA],[0|0.0|0.00|0.000...]}
  421. result = string.Format(ActivityMain.Culture, "{0,4:0.0}", value);
  422. if (found && value < 10.5) textColor = Android.Graphics.Color.Red;
  423. else if (found && value < 11.5) textColor = Android.Graphics.Color.Orange;
  424. else if (found && value <= 12.5) textColor = Android.Graphics.Color.Yellow;
  425. else if (found && value <= 13.2) textColor = Android.Graphics.Color.Gray;
  426. else if (found && value <= 14.5) textColor = Android.Graphics.Color.White;
  427. else if (found && value > 14.5) textColor = Android.Graphics.Color.Red;
  428. else textColor = Android.Graphics.Color.Gray;
  429. break;
  430. case "STAT_GENERATORLAST_WERT":
  431. value = ActivityMain.GetResultDouble(resultDict, resultName, 0, out found);
  432. // result format: {0,[DIGITS TOTAL INCL COMMA],[0|0.0|0.00|0.000...]}
  433. result = string.Format(ActivityMain.Culture, "{0,3:0}", value);
  434. if (found && value <= 60) textColor = Android.Graphics.Color.White;
  435. else if (found && value <= 70) textColor = Android.Graphics.Color.Yellow;
  436. else if (found && value <= 80) textColor = Android.Graphics.Color.Orange;
  437. else if (found && value > 80) textColor = Android.Graphics.Color.Red;
  438. else textColor = Android.Graphics.Color.Gray;
  439. break;
  440. case "STAT_ZUHEIZER_ANSTEUERUNG_WERT":
  441. value = ActivityMain.GetResultDouble(resultDict, resultName, 0, out found);
  442. // result format: {0,[DIGITS TOTAL INCL COMMA],[0|0.0|0.00|0.000...]}
  443. result = string.Format(ActivityMain.Culture, "{0,3:0}", value);
  444. if (found && value <= 60) textColor = Android.Graphics.Color.White;
  445. else if (found && value <= 70) textColor = Android.Graphics.Color.Yellow;
  446. else if (found && value <= 80) textColor = Android.Graphics.Color.Orange;
  447. else if (found && value > 80) textColor = Android.Graphics.Color.Red;
  448. else textColor = Android.Graphics.Color.Gray;
  449. break;
  450. case "STAT_KUEHLMITTELTEMPERATUR_WERT":
  451. value = ActivityMain.GetResultDouble(resultDict, resultName, 0, out found);
  452. result = string.Format(ActivityMain.Culture, "{0,3:0}", value);
  453. if (found && value < 75) textColor = Android.Graphics.Color.Blue;
  454. else if (found && value <= 105) textColor = Android.Graphics.Color.White;
  455. else if (found && value <= 110) textColor = Android.Graphics.Color.Yellow;
  456. else if (found && value <= 115) textColor = Android.Graphics.Color.Orange;
  457. else if (found && value > 115) textColor = Android.Graphics.Color.Red;
  458. else textColor = Android.Graphics.Color.Gray;
  459. break;
  460. case "STAT_LADELUFTTEMPERATUR_WERT":
  461. value = ActivityMain.GetResultDouble(resultDict, resultName, 0, out found);
  462. result = string.Format(ActivityMain.Culture, "{0,3:0}", value);
  463. if (found && value <= 55) textColor = Android.Graphics.Color.White;
  464. else if (found && value <= 65) textColor = Android.Graphics.Color.Yellow;
  465. else if (found && value <= 75) textColor = Android.Graphics.Color.Orange;
  466. else if (found && value > 85) textColor = Android.Graphics.Color.Red;
  467. else textColor = Android.Graphics.Color.Gray;
  468. break;
  469. }
  470. return result;
  471. }
  472. }
  473. ]]>
  474. </code>
  475. </page>
  476. </fragment>