Compare commits
No commits in common. "bc73528681b585f08b42fa75883bf01cd04d980f" and "72b82fa4e4f846c7e33ce9f45b0938b9f1bb2920" have entirely different histories.
bc73528681
...
72b82fa4e4
6 changed files with 25 additions and 119 deletions
|
@ -123,12 +123,6 @@ dependencies {
|
||||||
|
|
||||||
implementation("org.jetbrains.kotlinx:kotlinx-serialization-json:1.5.0")
|
implementation("org.jetbrains.kotlinx:kotlinx-serialization-json:1.5.0")
|
||||||
|
|
||||||
|
|
||||||
// Ktor
|
|
||||||
val ktor_version = "2.3.1"
|
|
||||||
implementation("io.ktor:ktor-client-core:$ktor_version")
|
|
||||||
implementation("io.ktor:ktor-client-cio:$ktor_version")
|
|
||||||
|
|
||||||
implementation(platform("dev.forkhandles:forkhandles-bom:2.6.0.0"))
|
implementation(platform("dev.forkhandles:forkhandles-bom:2.6.0.0"))
|
||||||
implementation("dev.forkhandles:result4k")
|
implementation("dev.forkhandles:result4k")
|
||||||
|
|
||||||
|
@ -149,6 +143,5 @@ dependencies {
|
||||||
|
|
||||||
implementation("org.jetbrains.kotlinx:kotlinx-datetime:0.4.0")
|
implementation("org.jetbrains.kotlinx:kotlinx-datetime:0.4.0")
|
||||||
|
|
||||||
// Map Compose library
|
|
||||||
implementation("ovh.plrapps:mapcompose:2.7.1")
|
|
||||||
}
|
}
|
|
@ -2,6 +2,9 @@
|
||||||
|
|
||||||
package ru.nm17.narodmon.ui.elements
|
package ru.nm17.narodmon.ui.elements
|
||||||
|
|
||||||
|
import android.content.Context
|
||||||
|
import android.content.Intent
|
||||||
|
import android.net.Uri
|
||||||
import androidx.compose.foundation.clickable
|
import androidx.compose.foundation.clickable
|
||||||
import androidx.compose.foundation.layout.Column
|
import androidx.compose.foundation.layout.Column
|
||||||
import androidx.compose.foundation.layout.padding
|
import androidx.compose.foundation.layout.padding
|
||||||
|
@ -19,7 +22,9 @@ import androidx.compose.runtime.Composable
|
||||||
import androidx.compose.ui.Modifier
|
import androidx.compose.ui.Modifier
|
||||||
import androidx.compose.ui.res.stringResource
|
import androidx.compose.ui.res.stringResource
|
||||||
import androidx.compose.ui.unit.dp
|
import androidx.compose.ui.unit.dp
|
||||||
|
import androidx.activity.ComponentActivity
|
||||||
import androidx.compose.ui.platform.LocalUriHandler
|
import androidx.compose.ui.platform.LocalUriHandler
|
||||||
|
import androidx.core.content.ContextCompat.startActivity
|
||||||
import ru.nm17.narodmon.R
|
import ru.nm17.narodmon.R
|
||||||
import kotlin.system.exitProcess
|
import kotlin.system.exitProcess
|
||||||
|
|
||||||
|
@ -35,7 +40,7 @@ fun AgreementDialog(modifier: Modifier = Modifier, onClick: () -> Unit) {
|
||||||
Text(text = stringResource(id = R.string.agreement_dialog_text))
|
Text(text = stringResource(id = R.string.agreement_dialog_text))
|
||||||
Divider(Modifier.padding(vertical = 8.dp))
|
Divider(Modifier.padding(vertical = 8.dp))
|
||||||
ListItem(
|
ListItem(
|
||||||
headlineContent = {
|
headlineText = {
|
||||||
Text(
|
Text(
|
||||||
text = stringResource(id = R.string.privacy_policy),
|
text = stringResource(id = R.string.privacy_policy),
|
||||||
style = MaterialTheme.typography.titleSmall
|
style = MaterialTheme.typography.titleSmall
|
||||||
|
@ -51,7 +56,7 @@ fun AgreementDialog(modifier: Modifier = Modifier, onClick: () -> Unit) {
|
||||||
)
|
)
|
||||||
|
|
||||||
ListItem(
|
ListItem(
|
||||||
headlineContent = {
|
headlineText = {
|
||||||
Text(
|
Text(
|
||||||
text = stringResource(id = R.string.user_agreement),
|
text = stringResource(id = R.string.user_agreement),
|
||||||
style = MaterialTheme.typography.titleSmall
|
style = MaterialTheme.typography.titleSmall
|
||||||
|
|
|
@ -35,6 +35,7 @@ import androidx.compose.ui.Modifier
|
||||||
import androidx.compose.ui.text.font.FontStyle
|
import androidx.compose.ui.text.font.FontStyle
|
||||||
import androidx.compose.ui.text.font.FontWeight
|
import androidx.compose.ui.text.font.FontWeight
|
||||||
import androidx.compose.ui.unit.dp
|
import androidx.compose.ui.unit.dp
|
||||||
|
import androidx.navigation.compose.NavHost
|
||||||
import androidx.navigation.compose.rememberNavController
|
import androidx.navigation.compose.rememberNavController
|
||||||
import kotlinx.coroutines.delay
|
import kotlinx.coroutines.delay
|
||||||
import kotlinx.coroutines.launch
|
import kotlinx.coroutines.launch
|
||||||
|
|
|
@ -1,97 +1,46 @@
|
||||||
package ru.nm17.narodmon.ui.pages
|
package ru.nm17.narodmon.ui.pages
|
||||||
|
|
||||||
import androidx.compose.foundation.layout.Arrangement
|
|
||||||
import androidx.compose.foundation.layout.Column
|
import androidx.compose.foundation.layout.Column
|
||||||
import androidx.compose.foundation.layout.Row
|
import androidx.compose.foundation.layout.Row
|
||||||
import androidx.compose.foundation.layout.height
|
|
||||||
import androidx.compose.foundation.layout.padding
|
import androidx.compose.foundation.layout.padding
|
||||||
import androidx.compose.material3.ExperimentalMaterial3Api
|
import androidx.compose.material3.ExperimentalMaterial3Api
|
||||||
import androidx.compose.material3.FilterChip
|
import androidx.compose.material3.FilterChip
|
||||||
import androidx.compose.material3.Text
|
import androidx.compose.material3.Text
|
||||||
import androidx.compose.runtime.Composable
|
import androidx.compose.runtime.Composable
|
||||||
import androidx.compose.runtime.LaunchedEffect
|
|
||||||
import androidx.compose.runtime.getValue
|
|
||||||
import androidx.compose.runtime.mutableStateOf
|
|
||||||
import androidx.compose.runtime.remember
|
|
||||||
import androidx.compose.runtime.setValue
|
|
||||||
import androidx.compose.ui.Modifier
|
import androidx.compose.ui.Modifier
|
||||||
import androidx.compose.ui.geometry.Offset
|
|
||||||
import androidx.compose.ui.platform.LocalConfiguration
|
|
||||||
import androidx.compose.ui.res.stringResource
|
import androidx.compose.ui.res.stringResource
|
||||||
import androidx.compose.ui.unit.dp
|
|
||||||
import androidx.navigation.NavController
|
import androidx.navigation.NavController
|
||||||
import ovh.plrapps.mapcompose.api.scale
|
import ru.nm17.narodmon.Greeting
|
||||||
import ovh.plrapps.mapcompose.api.setScroll
|
|
||||||
import ovh.plrapps.mapcompose.ui.MapUI
|
|
||||||
import ru.nm17.narodmon.R
|
import ru.nm17.narodmon.R
|
||||||
import ru.nm17.narodmon.ui.elements.GenericNavScaffold
|
import ru.nm17.narodmon.ui.elements.GenericNavScaffold
|
||||||
import ru.nm17.narodmon.ui.viewmodel.MapViewModel
|
|
||||||
|
|
||||||
enum class SensorsFilter {
|
|
||||||
All, Thermometer, Camera,
|
|
||||||
}
|
|
||||||
|
|
||||||
@ExperimentalMaterial3Api
|
@ExperimentalMaterial3Api
|
||||||
@Composable
|
@Composable
|
||||||
fun SensorsPage(navController: NavController) {
|
fun SensorsPage(navController: NavController) {
|
||||||
val mapVM by remember { mutableStateOf(MapViewModel()) }
|
|
||||||
var filter by remember { mutableStateOf(SensorsFilter.All) }
|
|
||||||
|
|
||||||
val scrConfig = LocalConfiguration.current
|
|
||||||
val mapHeight = scrConfig.screenHeightDp / 3
|
|
||||||
|
|
||||||
LaunchedEffect(mapVM) {
|
|
||||||
// TODO: Подгружать сохранённую позицию
|
|
||||||
mapVM.state.setScroll(Offset(28702.6F, 14787.6F))
|
|
||||||
mapVM.state.scale = 1.4658884F
|
|
||||||
}
|
|
||||||
|
|
||||||
GenericNavScaffold(
|
GenericNavScaffold(
|
||||||
title = { Text(text = stringResource(R.string.sensors_page_title)) }
|
title = { Text(text = stringResource(R.string.sensors_page_title)) }
|
||||||
) {
|
) {
|
||||||
Column(modifier = Modifier.padding(it)) {
|
Column {
|
||||||
|
Greeting("Hello sensors")
|
||||||
MapUI(state = mapVM.state, modifier = Modifier.height(mapHeight.dp))
|
Row {
|
||||||
|
|
||||||
Row(
|
|
||||||
modifier = Modifier.padding(horizontal = 8.dp),
|
|
||||||
horizontalArrangement = Arrangement.spacedBy(8.dp),
|
|
||||||
) {
|
|
||||||
SensorsFilterChip(
|
|
||||||
name = stringResource(R.string.sensors_filter_all),
|
|
||||||
checkFilter = { filter == SensorsFilter.All },
|
|
||||||
updateFilter = { filter = SensorsFilter.All },
|
|
||||||
)
|
|
||||||
|
|
||||||
SensorsFilterChip(
|
|
||||||
name = stringResource(R.string.sensors_filter_temp),
|
|
||||||
checkFilter = { filter == SensorsFilter.Thermometer },
|
|
||||||
updateFilter = { filter = SensorsFilter.Thermometer },
|
|
||||||
)
|
|
||||||
|
|
||||||
SensorsFilterChip(
|
|
||||||
name = stringResource(R.string.sensors_filter_camera),
|
|
||||||
checkFilter = { filter == SensorsFilter.Camera },
|
|
||||||
updateFilter = { filter = SensorsFilter.Camera },
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
//Text(mapVM.state.scroll.toString())
|
|
||||||
//Text(mapVM.state.scale.toString())
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@OptIn(ExperimentalMaterial3Api::class)
|
|
||||||
@Composable
|
|
||||||
fun SensorsFilterChip(
|
|
||||||
name: String,
|
|
||||||
checkFilter: () -> Boolean,
|
|
||||||
updateFilter: () -> Unit,
|
|
||||||
) {
|
|
||||||
FilterChip(
|
FilterChip(
|
||||||
selected = checkFilter(),
|
selected = true,
|
||||||
onClick = updateFilter,
|
onClick = { },
|
||||||
label = { Text(name) },
|
label = { Text("Temp") }
|
||||||
)
|
)
|
||||||
|
|
||||||
|
FilterChip(
|
||||||
|
selected = false,
|
||||||
|
onClick = { },
|
||||||
|
label = { Text("Abc") }
|
||||||
|
)
|
||||||
|
|
||||||
|
FilterChip(
|
||||||
|
selected = false,
|
||||||
|
onClick = { },
|
||||||
|
label = { Text("Def") }
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
|
@ -1,39 +0,0 @@
|
||||||
package ru.nm17.narodmon.ui.viewmodel
|
|
||||||
|
|
||||||
import androidx.compose.runtime.getValue
|
|
||||||
import androidx.compose.runtime.mutableStateOf
|
|
||||||
import androidx.lifecycle.ViewModel
|
|
||||||
import io.ktor.client.HttpClient
|
|
||||||
import io.ktor.client.engine.cio.CIO
|
|
||||||
import io.ktor.client.request.get
|
|
||||||
import io.ktor.client.statement.bodyAsChannel
|
|
||||||
import io.ktor.utils.io.jvm.javaio.toInputStream
|
|
||||||
import ovh.plrapps.mapcompose.api.addLayer
|
|
||||||
import ovh.plrapps.mapcompose.core.TileStreamProvider
|
|
||||||
import ovh.plrapps.mapcompose.ui.state.MapState
|
|
||||||
import java.io.InputStream
|
|
||||||
|
|
||||||
class MapViewModel : ViewModel() {
|
|
||||||
private val client = HttpClient(CIO)
|
|
||||||
|
|
||||||
private val tileStreamProvider = TileStreamProvider { row, col, zoom ->
|
|
||||||
requestTile(row, col, zoom)
|
|
||||||
}
|
|
||||||
|
|
||||||
private val mapSize = 32768
|
|
||||||
val state: MapState by mutableStateOf(
|
|
||||||
MapState(
|
|
||||||
levelCount = 8,
|
|
||||||
fullWidth = mapSize,
|
|
||||||
fullHeight = mapSize,
|
|
||||||
workerCount = 16,
|
|
||||||
).apply {
|
|
||||||
addLayer(tileStreamProvider)
|
|
||||||
}
|
|
||||||
)
|
|
||||||
|
|
||||||
private suspend fun requestTile(row: Int, col: Int, zoom: Int): InputStream {
|
|
||||||
val response = client.get("https://tile.openstreetmap.org/${zoom}/${col}/${row}.png")
|
|
||||||
return response.bodyAsChannel().toInputStream()
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -15,7 +15,4 @@
|
||||||
<string name="agreement_dialog_title">Примите необходимые соглашения</string>
|
<string name="agreement_dialog_title">Примите необходимые соглашения</string>
|
||||||
<string name="sensors_page_title">Сенсоры</string>
|
<string name="sensors_page_title">Сенсоры</string>
|
||||||
<string name="waiting_for_user_agreement">Ожидаю соглашение пользователя</string>
|
<string name="waiting_for_user_agreement">Ожидаю соглашение пользователя</string>
|
||||||
<string name="sensors_filter_all">Все</string>
|
|
||||||
<string name="sensors_filter_temp">Термометры</string>
|
|
||||||
<string name="sensors_filter_camera">Камеры</string>
|
|
||||||
</resources>
|
</resources>
|
Loading…
Add table
Reference in a new issue