kopia lustrzana https://github.com/meshtastic/Meshtastic-Android
Merge remote-tracking branch 'root/master' into dev
commit
ffca8e5f47
|
@ -21,6 +21,7 @@ import com.geeksville.mesh.database.entity.Packet
|
||||||
import com.geeksville.mesh.service.MeshService
|
import com.geeksville.mesh.service.MeshService
|
||||||
import kotlinx.coroutines.Dispatchers
|
import kotlinx.coroutines.Dispatchers
|
||||||
import kotlinx.coroutines.launch
|
import kotlinx.coroutines.launch
|
||||||
|
import kotlin.math.max
|
||||||
|
|
||||||
/// Given a human name, strip out the first letter of the first three words and return that as the initials for
|
/// Given a human name, strip out the first letter of the first three words and return that as the initials for
|
||||||
/// that user. If the original name is only one word, strip vowels from the original name and if the result is
|
/// that user. If the original name is only one word, strip vowels from the original name and if the result is
|
||||||
|
@ -119,12 +120,15 @@ class UIViewModel(app: Application) : AndroidViewModel(app), Logging {
|
||||||
val builder = config.toBuilder()
|
val builder = config.toBuilder()
|
||||||
if (value > 0) {
|
if (value > 0) {
|
||||||
builder.preferencesBuilder.positionBroadcastSecs = value
|
builder.preferencesBuilder.positionBroadcastSecs = value
|
||||||
|
builder.preferencesBuilder.gpsUpdateInterval = value
|
||||||
|
builder.preferencesBuilder.sendOwnerInterval = max(1, 3600 / value).toInt()
|
||||||
builder.preferencesBuilder.locationShare =
|
builder.preferencesBuilder.locationShare =
|
||||||
MeshProtos.LocationSharing.LocEnabled
|
MeshProtos.LocationSharing.LocEnabled
|
||||||
} else
|
} else {
|
||||||
|
builder.preferencesBuilder.positionBroadcastSecs = Int.MAX_VALUE
|
||||||
builder.preferencesBuilder.locationShare =
|
builder.preferencesBuilder.locationShare =
|
||||||
MeshProtos.LocationSharing.LocDisabled
|
MeshProtos.LocationSharing.LocDisabled
|
||||||
|
}
|
||||||
setRadioConfig(builder.build())
|
setRadioConfig(builder.build())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -629,9 +629,14 @@ class MeshService : Service(), Logging {
|
||||||
|
|
||||||
if (dataPacket != null) {
|
if (dataPacket != null) {
|
||||||
|
|
||||||
if (myInfo.myNodeNum == packet.from)
|
if (myInfo.myNodeNum == packet.from) {
|
||||||
debug("Ignoring packet sent from our node")
|
// Handle position updates from the device
|
||||||
else {
|
if (data.portnumValue == Portnums.PortNum.POSITION_APP_VALUE) {
|
||||||
|
val rxTime = if (packet.rxTime != 0) packet.rxTime else currentSecond()
|
||||||
|
handleReceivedPosition(packet.from, MeshProtos.Position.parseFrom(data.payload), rxTime)
|
||||||
|
} else
|
||||||
|
debug("Ignoring packet sent from our node, portnum=${data.portnumValue} ${bytes.size} bytes")
|
||||||
|
} else {
|
||||||
debug("Received data from $fromId, portnum=${data.portnumValue} ${bytes.size} bytes")
|
debug("Received data from $fromId, portnum=${data.portnumValue} ${bytes.size} bytes")
|
||||||
|
|
||||||
dataPacket.status = MessageStatus.RECEIVED
|
dataPacket.status = MessageStatus.RECEIVED
|
||||||
|
|
|
@ -86,32 +86,34 @@ class MapFragment : ScreenFragment("Map"), Logging {
|
||||||
return FeatureCollection.fromFeatures(locations)
|
return FeatureCollection.fromFeatures(locations)
|
||||||
}
|
}
|
||||||
|
|
||||||
fun zoomToNodes(map: MapboxMap) {
|
|
||||||
if (nodesWithPosition.isNotEmpty()) {
|
|
||||||
val update = if (nodesWithPosition.size >= 2) {
|
|
||||||
// Multiple nodes, make them all fit on the map view
|
|
||||||
val bounds = LatLngBounds.Builder()
|
|
||||||
|
|
||||||
// Add all positions
|
|
||||||
bounds.includes(nodesWithPosition.map { it.position!! }
|
|
||||||
.map { LatLng(it.latitude, it.longitude) })
|
|
||||||
|
|
||||||
CameraUpdateFactory.newLatLngBounds(bounds.build(), 150)
|
|
||||||
} else {
|
|
||||||
// Only one node, just zoom in on it
|
|
||||||
val it = nodesWithPosition[0].position!!
|
|
||||||
|
|
||||||
val cameraPos = CameraPosition.Builder().target(
|
|
||||||
LatLng(it.latitude, it.longitude)
|
|
||||||
).zoom(9.0).build()
|
|
||||||
CameraUpdateFactory.newCameraPosition(cameraPos)
|
|
||||||
}
|
|
||||||
map.animateCamera(update, 1000)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
nodePositions.setGeoJson(getCurrentNodes()) // Update node positions
|
nodePositions.setGeoJson(getCurrentNodes()) // Update node positions
|
||||||
zoomToNodes(map)
|
}
|
||||||
|
|
||||||
|
fun zoomToNodes(map: MapboxMap) {
|
||||||
|
val nodesWithPosition = model.nodeDB.nodes.value?.values?.filter { it.validPosition != null }
|
||||||
|
if (nodesWithPosition != null && nodesWithPosition.isNotEmpty()) {
|
||||||
|
val update = if (nodesWithPosition.size >= 2) {
|
||||||
|
// Multiple nodes, make them all fit on the map view
|
||||||
|
val bounds = LatLngBounds.Builder()
|
||||||
|
|
||||||
|
// Add all positions
|
||||||
|
bounds.includes(nodesWithPosition.map { it.position!! }
|
||||||
|
.map { LatLng(it.latitude, it.longitude) })
|
||||||
|
|
||||||
|
CameraUpdateFactory.newLatLngBounds(bounds.build(), 150)
|
||||||
|
} else {
|
||||||
|
// Only one node, just zoom in on it
|
||||||
|
val it = nodesWithPosition[0].position!!
|
||||||
|
|
||||||
|
val cameraPos = CameraPosition.Builder().target(
|
||||||
|
LatLng(it.latitude, it.longitude)
|
||||||
|
).zoom(9.0).build()
|
||||||
|
CameraUpdateFactory.newCameraPosition(cameraPos)
|
||||||
|
}
|
||||||
|
map.animateCamera(update, 1000)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun onCreateView(
|
override fun onCreateView(
|
||||||
|
@ -132,12 +134,6 @@ class MapFragment : ScreenFragment("Map"), Logging {
|
||||||
|
|
||||||
var mapView: MapView? = null
|
var mapView: MapView? = null
|
||||||
|
|
||||||
/**
|
|
||||||
* Mapbox native code can crash painfully if you ever call a mapbox view function while the view is not actively being show
|
|
||||||
*/
|
|
||||||
private val isViewVisible: Boolean
|
|
||||||
get() = view != null && isResumed && (mapView?.isDestroyed != false)
|
|
||||||
|
|
||||||
override fun onViewCreated(viewIn: View, savedInstanceState: Bundle?) {
|
override fun onViewCreated(viewIn: View, savedInstanceState: Bundle?) {
|
||||||
super.onViewCreated(viewIn, savedInstanceState)
|
super.onViewCreated(viewIn, savedInstanceState)
|
||||||
|
|
||||||
|
@ -164,9 +160,7 @@ class MapFragment : ScreenFragment("Map"), Logging {
|
||||||
style.addLayer(labelLayer)
|
style.addLayer(labelLayer)
|
||||||
}
|
}
|
||||||
|
|
||||||
//map.uiSettings.isScrollGesturesEnabled = true
|
map.uiSettings.isRotateGesturesEnabled = false
|
||||||
//map.uiSettings.isZoomGesturesEnabled = true
|
|
||||||
|
|
||||||
// Provide initial positions
|
// Provide initial positions
|
||||||
model.nodeDB.nodes.value?.let { nodes ->
|
model.nodeDB.nodes.value?.let { nodes ->
|
||||||
onNodesChanged(map, nodes.values)
|
onNodesChanged(map, nodes.values)
|
||||||
|
@ -175,10 +169,9 @@ class MapFragment : ScreenFragment("Map"), Logging {
|
||||||
|
|
||||||
// Any times nodes change update our map
|
// Any times nodes change update our map
|
||||||
model.nodeDB.nodes.observe(viewLifecycleOwner, Observer { nodes ->
|
model.nodeDB.nodes.observe(viewLifecycleOwner, Observer { nodes ->
|
||||||
debug("Nodes updated! map visible = $isViewVisible")
|
onNodesChanged(map, nodes.values)
|
||||||
if (isViewVisible)
|
|
||||||
onNodesChanged(map, nodes.values)
|
|
||||||
})
|
})
|
||||||
|
zoomToNodes(map)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Ładowanie…
Reference in New Issue