@@ -261,6 +261,7 @@ void displayUpdate()
261261 paintLogging (&iconPropertyList);
262262 displaySivVsOpenShort (&iconPropertyList);
263263 displayBatteryVsEthernet (&iconPropertyList);
264+ displayFullIPAddress (&iconPropertyList); // Bottom left - 128x64 only
264265 setRadioIcons (&iconPropertyList);
265266 break ;
266267 case (STATE_ROVER_NO_FIX):
@@ -269,6 +270,7 @@ void displayUpdate()
269270 paintLogging (&iconPropertyList);
270271 displaySivVsOpenShort (&iconPropertyList);
271272 displayBatteryVsEthernet (&iconPropertyList);
273+ displayFullIPAddress (&iconPropertyList); // Bottom left - 128x64 only
272274 setRadioIcons (&iconPropertyList);
273275 break ;
274276 case (STATE_ROVER_FIX):
@@ -277,6 +279,7 @@ void displayUpdate()
277279 paintLogging (&iconPropertyList);
278280 displaySivVsOpenShort (&iconPropertyList);
279281 displayBatteryVsEthernet (&iconPropertyList);
282+ displayFullIPAddress (&iconPropertyList); // Bottom left - 128x64 only
280283 setRadioIcons (&iconPropertyList);
281284 break ;
282285 case (STATE_ROVER_RTK_FLOAT):
@@ -285,6 +288,7 @@ void displayUpdate()
285288 paintLogging (&iconPropertyList);
286289 displaySivVsOpenShort (&iconPropertyList);
287290 displayBatteryVsEthernet (&iconPropertyList);
291+ displayFullIPAddress (&iconPropertyList); // Bottom left - 128x64 only
288292 setRadioIcons (&iconPropertyList);
289293 break ;
290294 case (STATE_ROVER_RTK_FIX):
@@ -293,6 +297,7 @@ void displayUpdate()
293297 paintLogging (&iconPropertyList);
294298 displaySivVsOpenShort (&iconPropertyList);
295299 displayBatteryVsEthernet (&iconPropertyList);
300+ displayFullIPAddress (&iconPropertyList); // Bottom left - 128x64 only
296301 setRadioIcons (&iconPropertyList);
297302 break ;
298303
@@ -309,27 +314,32 @@ void displayUpdate()
309314 paintLogging (&iconPropertyList);
310315 displaySivVsOpenShort (&iconPropertyList);
311316 displayBatteryVsEthernet (&iconPropertyList);
317+ displayFullIPAddress (&iconPropertyList); // Bottom left - 128x64 only
312318 setRadioIcons (&iconPropertyList);
313319 break ;
314320 case (STATE_BASE_TEMP_SURVEY_STARTED):
315321 paintLogging (&iconPropertyList);
316322 displayBatteryVsEthernet (&iconPropertyList); // Top right
323+ displayFullIPAddress (&iconPropertyList); // Bottom left - 128x64 only
317324 setRadioIcons (&iconPropertyList);
318325 paintBaseTempSurveyStarted (&iconPropertyList);
319326 break ;
320327 case (STATE_BASE_TEMP_TRANSMITTING):
321328 paintLogging (&iconPropertyList);
322329 displayBatteryVsEthernet (&iconPropertyList); // Top right
330+ displayFullIPAddress (&iconPropertyList); // Bottom left - 128x64 only
323331 setRadioIcons (&iconPropertyList);
324332 paintRTCM (&iconPropertyList);
325333 break ;
326334 case (STATE_BASE_FIXED_NOT_STARTED):
327335 displayBatteryVsEthernet (&iconPropertyList); // Top right
336+ displayFullIPAddress (&iconPropertyList); // Bottom left - 128x64 only
328337 setRadioIcons (&iconPropertyList);
329338 break ;
330339 case (STATE_BASE_FIXED_TRANSMITTING):
331340 paintLogging (&iconPropertyList);
332341 displayBatteryVsEthernet (&iconPropertyList); // Top right
342+ displayFullIPAddress (&iconPropertyList); // Bottom left - 128x64 only
333343 setRadioIcons (&iconPropertyList);
334344 paintRTCM (&iconPropertyList);
335345 break ;
@@ -1771,11 +1781,11 @@ void paintConnectingToNtripCaster()
17711781void paintIPAddress ()
17721782{
17731783 char ipAddress[16 ];
1774- snprintf (ipAddress, sizeof (ipAddress), " %d.%d.%d.%d " ,
1784+ snprintf (ipAddress, sizeof (ipAddress), " %s " ,
17751785#ifdef COMPILE_ETHERNET
1776- ETH.localIP ()[ 0 ], ETH. localIP ()[ 1 ], ETH. localIP ()[ 2 ], ETH. localIP ()[ 3 ] );
1786+ ETH.localIP (). toString () );
17771787#else // COMPILE_ETHERNET
1778- 0 , 0 , 0 , 0 );
1788+ " 0.0.0.0 " );
17791789#endif // COMPILE_ETHERNET
17801790
17811791 oled->setFont (QW_FONT_5X7); // Set font to smallest
@@ -1809,6 +1819,26 @@ void paintIPAddress()
18091819 }
18101820}
18111821
1822+ void displayFullIPAddress (std::vector<iconPropertyBlinking> *iconList) // Bottom left - 128x64 only
1823+ {
1824+ if (present.display_type == DISPLAY_128x64)
1825+ {
1826+ char myAddress[16 ];
1827+
1828+ uint8_t networkType = networkGetType ();
1829+ IPAddress ipAddress = networkGetIpAddress (networkType);
1830+
1831+ if (ipAddress != IPAddress ((uint32_t )0 ))
1832+ {
1833+ snprintf (myAddress, sizeof (myAddress), " %s" , ipAddress.toString ());
1834+
1835+ oled->setFont (QW_FONT_5X7); // Set font to smallest
1836+ oled->setCursor (0 , 55 );
1837+ oled->print (ipAddress);
1838+ }
1839+ }
1840+ }
1841+
18121842void paintMACAddress4digit (uint8_t xPos, uint8_t yPos)
18131843{
18141844 char macAddress[5 ];
@@ -2091,7 +2121,7 @@ void displayWiFiConfig()
20912121
20922122 // Convert to string
20932123 char myIP[20 ] = {' \0 ' };
2094- snprintf (myIP, sizeof (myIP), " %d.%d.%d.%d " , myIpAddress[ 0 ], myIpAddress[ 1 ], myIpAddress[ 2 ], myIpAddress[ 3 ] );
2124+ snprintf (myIP, sizeof (myIP), " %s " , myIpAddress. toString () );
20952125
20962126 char myIPFront[displayMaxCharacters + 1 ]; // 1 for null terminator
20972127 char myIPBack[displayMaxCharacters + 1 ]; // 1 for null terminator
@@ -3018,7 +3048,7 @@ void displayConfigViaEthernet()
30183048
30193049 char ipAddress[16 ];
30203050 IPAddress localIP = ETH.localIP ();
3021- snprintf (ipAddress, sizeof (ipAddress), " %d.%d.%d.%d " , localIP[ 0 ], localIP[ 1 ], localIP[ 2 ], localIP[ 3 ] );
3051+ snprintf (ipAddress, sizeof (ipAddress), " %s " , localIP. toString () );
30223052
30233053 int displayWidthChars = ((present.display_type == DISPLAY_128x64) ? 21 : 10 );
30243054
0 commit comments