mirror of
				https://github.com/meshtastic/firmware.git
				synced 2025-10-25 06:12:48 +00:00 
			
		
		
		
	break out compass display
Show question mark if unknown location
This commit is contained in:
		
							parent
							
								
									9061b3d8c3
								
							
						
					
					
						commit
						3df05cd5c1
					
				| @ -65,21 +65,21 @@ debug_tool = jlink | ||||
| ;  monitor adapter_khz 10000 | ||||
| 
 | ||||
| lib_deps = | ||||
|   https://github.com/meshtastic/esp8266-oled-ssd1306.git ; ESP8266_SSD1306  | ||||
|   https://github.com/meshtastic/esp8266-oled-ssd1306.git ; ESP8266_SSD1306 | ||||
|   SPI | ||||
|   ; 1260 ; OneButton - not used yet | ||||
|   1202 ; CRC32, explicitly needed because dependency is missing in the ble ota update lib | ||||
|   Wire ; explicitly needed here because the AXP202 library forgets to add it | ||||
|   https://github.com/meshtastic/arduino-fsm.git  | ||||
|   https://github.com/meshtastic/arduino-fsm.git | ||||
|   https://github.com/meshtastic/SparkFun_Ublox_Arduino_Library.git | ||||
|   https://github.com/meshtastic/RadioLib.git | ||||
|   https://github.com/meshtastic/TinyGPSPlus.git  | ||||
|    | ||||
|   https://github.com/meshtastic/TinyGPSPlus.git | ||||
| 
 | ||||
| ; Common settings for ESP targes, mixin with extends = esp32_base | ||||
| [esp32_base] | ||||
| platform = espressif32 | ||||
| framework = arduino | ||||
| src_filter =  | ||||
| src_filter = | ||||
|   ${env.src_filter} -<nrf52/> | ||||
| upload_speed = 921600 | ||||
| debug_init_break = tbreak setup | ||||
| @ -98,7 +98,7 @@ board = ttgo-t-beam | ||||
| lib_deps = | ||||
|   ${env.lib_deps} | ||||
|   https://github.com/meshtastic/AXP202X_Library.git | ||||
| build_flags =  | ||||
| build_flags = | ||||
|   ${esp32_base.build_flags} -D TBEAM_V10 | ||||
| 
 | ||||
| ; The original TBEAM board without the AXP power chip and a few other changes | ||||
| @ -106,28 +106,28 @@ build_flags = | ||||
| ;[env:tbeam0.7] | ||||
| ;extends = esp32_base | ||||
| ;board = ttgo-t-beam | ||||
| ;build_flags =  | ||||
| ;build_flags = | ||||
| ;  ${esp32_base.build_flags} -D TBEAM_V07 | ||||
| 
 | ||||
| [env:heltec] | ||||
| ;build_type = debug ; to make it possible to step through our jtag debugger  | ||||
| ;build_type = debug ; to make it possible to step through our jtag debugger | ||||
| extends = esp32_base | ||||
| board = heltec_wifi_lora_32_V2 | ||||
| 
 | ||||
| [env:ttgo-lora32-v1] | ||||
| extends = esp32_base | ||||
| board = ttgo-lora32-v1 | ||||
| build_flags =  | ||||
| build_flags = | ||||
|   ${esp32_base.build_flags} -D TTGO_LORA_V1 | ||||
| 
 | ||||
| ; note: the platformio definition for lora32-v2 seems stale, it is missing a pins_arduino.h file, therefore I don't think it works | ||||
| [env:ttgo-lora32-v2] | ||||
| extends = esp32_base | ||||
| board = ttgo-lora32-v1 | ||||
| build_flags =  | ||||
| build_flags = | ||||
|   ${esp32_base.build_flags} -D TTGO_LORA_V2 | ||||
| 
 | ||||
| ; The Heltec Cubecell plus  | ||||
| ; The Heltec Cubecell plus | ||||
| ; IMPORTANT NOTE: This target doesn't yet work and probably won't ever work.  I'm keeping it around for now. | ||||
| ; For more details see my post in the forum. | ||||
| [env:cubecellplus] | ||||
| @ -136,9 +136,9 @@ framework = arduino | ||||
| board = cubecell_board_plus | ||||
| ; FIXME, bug in cubecell arduino - they are supposed to set ARDUINO | ||||
| build_flags = ${env.build_flags} -DARDUINO=100 -Isrc/cubecell | ||||
| src_filter =  | ||||
| src_filter = | ||||
|   ${env.src_filter} -<esp32/> -<nrf52/> | ||||
|    | ||||
| 
 | ||||
| ; Common settings for NRF52 based targets | ||||
| [nrf52_base] | ||||
| platform = nordicnrf52 | ||||
| @ -146,10 +146,10 @@ framework = arduino | ||||
| debug_tool = jlink | ||||
| build_type = debug ; I'm debugging with ICE a lot now | ||||
| ; note: liboberon provides the AES256 implementation for NRF52 (though not using the hardware acceleration of the NRF52840 - FIXME) | ||||
| build_flags =  | ||||
|   ${env.build_flags} -Wno-unused-variable -Isrc/nrf52 -Isdk-nrfxlib/crypto/nrf_oberon/include -Lsdk-nrfxlib/crypto/nrf_oberon/lib/cortex-m4/hard-float/ -lliboberon_3.0.3  | ||||
| build_flags = | ||||
|   ${env.build_flags} -Wno-unused-variable -Isrc/nrf52 -Isdk-nrfxlib/crypto/nrf_oberon/include -Lsdk-nrfxlib/crypto/nrf_oberon/lib/cortex-m4/hard-float/ -lliboberon_3.0.3 | ||||
| ;-DCFG_DEBUG=3 | ||||
| src_filter =  | ||||
| src_filter = | ||||
|   ${env.src_filter} -<esp32/> | ||||
| lib_ignore = | ||||
|   BluetoothOTA | ||||
| @ -178,7 +178,7 @@ board = nrf52840_dk_modified | ||||
| [env:ppr] | ||||
| extends = nrf52_base | ||||
| board = ppr | ||||
| lib_deps =  | ||||
| lib_deps = | ||||
|   ${env.lib_deps} | ||||
|   UC1701 | ||||
| 
 | ||||
|  | ||||
| @ -52,7 +52,7 @@ namespace meshtastic | ||||
| // A text message frame + debug frame + all the node infos
 | ||||
| static FrameCallback normalFrames[MAX_NUM_NODES + NUM_EXTRA_FRAMES]; | ||||
| static uint32_t targetFramerate = IDLE_FRAMERATE; | ||||
| static char btPIN[16] = "888888";  | ||||
| static char btPIN[16] = "888888"; | ||||
| 
 | ||||
| uint8_t imgBattery[16] = { 0xFF, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0xE7, 0x3C }; | ||||
| 
 | ||||
| @ -73,7 +73,6 @@ static void drawBootScreen(OLEDDisplay *display, OLEDDisplayUiState *state, int1 | ||||
|     char buf[16]; | ||||
|     snprintf(buf, sizeof(buf), "%s", xstr(APP_VERSION)); // Note: we don't bother printing region or now, it makes the string too long
 | ||||
|     display->drawString(SCREEN_WIDTH - 20, 0, buf); | ||||
|      | ||||
| } | ||||
| 
 | ||||
| static void drawFrameBluetooth(OLEDDisplay *display, OLEDDisplayUiState *state, int16_t x, int16_t y) | ||||
| @ -346,6 +345,30 @@ static bool hasPosition(NodeInfo *n) | ||||
| static size_t nodeIndex; | ||||
| static int8_t prevFrame = -1; | ||||
| 
 | ||||
| // Draw the compass and arrow pointing to location
 | ||||
| static void drawCompass(OLEDDisplay *display, int16_t compassX, int16_t compassY, float headingRadian) | ||||
| { | ||||
|     // display->drawXbm(compassX, compassY, compass_width, compass_height,
 | ||||
|     // (const uint8_t *)compass_bits);
 | ||||
| 
 | ||||
|     Point tip(0.0f, 0.5f), tail(0.0f, -0.5f); // pointing up initially
 | ||||
|     float arrowOffsetX = 0.2f, arrowOffsetY = 0.2f; | ||||
|     Point leftArrow(tip.x - arrowOffsetX, tip.y - arrowOffsetY), rightArrow(tip.x + arrowOffsetX, tip.y - arrowOffsetY); | ||||
| 
 | ||||
|     Point *points[] = {&tip, &tail, &leftArrow, &rightArrow}; | ||||
| 
 | ||||
|     for (int i = 0; i < 4; i++) { | ||||
|         points[i]->rotate(headingRadian); | ||||
|         points[i]->scale(COMPASS_DIAM * 0.6); | ||||
|         points[i]->translate(compassX, compassY); | ||||
|     } | ||||
|     drawLine(display, tip, tail); | ||||
|     drawLine(display, leftArrow, tip); | ||||
|     drawLine(display, rightArrow, tip); | ||||
| 
 | ||||
|     display->drawCircle(compassX, compassY, COMPASS_DIAM / 2); | ||||
| } | ||||
| 
 | ||||
| /// Convert an integer GPS coords to a floating point
 | ||||
| #define DegD(i) (i * 1e-7) | ||||
| 
 | ||||
| @ -390,15 +413,17 @@ static void drawNodeInfo(OLEDDisplay *display, OLEDDisplayUiState *state, int16_ | ||||
|     else | ||||
|         snprintf(lastStr, sizeof(lastStr), "%u hours ago", agoSecs / 60 / 60); | ||||
| 
 | ||||
|     static float simRadian; | ||||
|     simRadian += 0.1; // For testing, have the compass spin unless both
 | ||||
|                       // locations are valid
 | ||||
| 
 | ||||
|     static char distStr[20]; | ||||
|     *distStr = 0; // might not have location data
 | ||||
|     float headingRadian = simRadian; | ||||
|     float headingRadian; | ||||
|     NodeInfo *ourNode = nodeDB.getNode(nodeDB.getNodeNum()); | ||||
|     if (ourNode && hasPosition(ourNode) && hasPosition(node)) { | ||||
|     const char *fields[] = {username, distStr, signalStr, lastStr, NULL}; | ||||
|     drawColumns(display, x, y, fields); | ||||
| 
 | ||||
|     // coordinates for the center of the compass/circle
 | ||||
|     int16_t compassX = x + SCREEN_WIDTH - COMPASS_DIAM / 2 - 1, compassY = y + SCREEN_HEIGHT / 2; | ||||
| 
 | ||||
|     if (ourNode && hasPosition(ourNode) && hasPosition(node)) { // display direction toward node
 | ||||
|         Position &op = ourNode->position, &p = node->position; | ||||
|         float d = latLongToMeter(DegD(p.latitude_i), DegD(p.longitude_i), DegD(op.latitude_i), DegD(op.longitude_i)); | ||||
|         if (d < 2000) | ||||
| @ -411,35 +436,14 @@ static void drawNodeInfo(OLEDDisplay *display, OLEDDisplayUiState *state, int16_ | ||||
|         float bearingToOther = bearing(DegD(p.latitude_i), DegD(p.longitude_i), DegD(op.latitude_i), DegD(op.longitude_i)); | ||||
|         float myHeading = estimatedHeading(DegD(p.latitude_i), DegD(p.longitude_i)); | ||||
|         headingRadian = bearingToOther - myHeading; | ||||
|     } else { | ||||
|         drawCompass(display, compassX, compassY, headingRadian); | ||||
|     } else { // direction to node is unknown so display question mark
 | ||||
|         // Debug info for gps lock errors
 | ||||
|         // DEBUG_MSG("ourNode %d, ourPos %d, theirPos %d\n", !!ourNode, ourNode && hasPosition(ourNode), hasPosition(node));
 | ||||
| 
 | ||||
|         display->drawString(compassX - FONT_HEIGHT/4, compassY - FONT_HEIGHT/2, "?"); | ||||
|         display->drawCircle(compassX, compassY, COMPASS_DIAM / 2); | ||||
|     } | ||||
| 
 | ||||
|     const char *fields[] = {username, distStr, signalStr, lastStr, NULL}; | ||||
|     drawColumns(display, x, y, fields); | ||||
| 
 | ||||
|     // coordinates for the center of the compass
 | ||||
|     int16_t compassX = x + SCREEN_WIDTH - COMPASS_DIAM / 2 - 1, compassY = y + SCREEN_HEIGHT / 2; | ||||
|     // display->drawXbm(compassX, compassY, compass_width, compass_height,
 | ||||
|     // (const uint8_t *)compass_bits);
 | ||||
| 
 | ||||
|     Point tip(0.0f, 0.5f), tail(0.0f, -0.5f); // pointing up initially
 | ||||
|     float arrowOffsetX = 0.2f, arrowOffsetY = 0.2f; | ||||
|     Point leftArrow(tip.x - arrowOffsetX, tip.y - arrowOffsetY), rightArrow(tip.x + arrowOffsetX, tip.y - arrowOffsetY); | ||||
| 
 | ||||
|     Point *points[] = {&tip, &tail, &leftArrow, &rightArrow}; | ||||
| 
 | ||||
|     for (int i = 0; i < 4; i++) { | ||||
|         points[i]->rotate(headingRadian); | ||||
|         points[i]->scale(COMPASS_DIAM * 0.6); | ||||
|         points[i]->translate(compassX, compassY); | ||||
|     } | ||||
|     drawLine(display, tip, tail); | ||||
|     drawLine(display, leftArrow, tip); | ||||
|     drawLine(display, rightArrow, tip); | ||||
| 
 | ||||
|     display->drawCircle(compassX, compassY, COMPASS_DIAM / 2); | ||||
| } | ||||
| 
 | ||||
| #if 0 | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Zach Whitehead
						Zach Whitehead