DocumentScreen layout: big image + miniatures
This commit is contained in:
committed by
pynicolas
parent
5292f5bdb3
commit
2b1b537f67
@@ -20,26 +20,34 @@ import androidx.compose.foundation.Image
|
|||||||
import androidx.compose.foundation.background
|
import androidx.compose.foundation.background
|
||||||
import androidx.compose.foundation.layout.Arrangement
|
import androidx.compose.foundation.layout.Arrangement
|
||||||
import androidx.compose.foundation.layout.Box
|
import androidx.compose.foundation.layout.Box
|
||||||
|
import androidx.compose.foundation.layout.Column
|
||||||
import androidx.compose.foundation.layout.PaddingValues
|
import androidx.compose.foundation.layout.PaddingValues
|
||||||
import androidx.compose.foundation.layout.Row
|
import androidx.compose.foundation.layout.Row
|
||||||
import androidx.compose.foundation.layout.Spacer
|
import androidx.compose.foundation.layout.Spacer
|
||||||
import androidx.compose.foundation.layout.fillMaxSize
|
import androidx.compose.foundation.layout.fillMaxSize
|
||||||
import androidx.compose.foundation.layout.fillMaxWidth
|
import androidx.compose.foundation.layout.fillMaxWidth
|
||||||
|
import androidx.compose.foundation.layout.height
|
||||||
import androidx.compose.foundation.layout.padding
|
import androidx.compose.foundation.layout.padding
|
||||||
import androidx.compose.foundation.layout.size
|
import androidx.compose.foundation.layout.size
|
||||||
import androidx.compose.foundation.layout.width
|
import androidx.compose.foundation.layout.width
|
||||||
import androidx.compose.foundation.lazy.LazyColumn
|
import androidx.compose.foundation.lazy.LazyColumn
|
||||||
|
import androidx.compose.foundation.lazy.LazyRow
|
||||||
import androidx.compose.foundation.lazy.items
|
import androidx.compose.foundation.lazy.items
|
||||||
import androidx.compose.material.icons.Icons
|
import androidx.compose.material.icons.Icons
|
||||||
import androidx.compose.material.icons.automirrored.filled.ArrowBack
|
import androidx.compose.material.icons.automirrored.filled.ArrowBack
|
||||||
|
import androidx.compose.material.icons.filled.Add
|
||||||
|
import androidx.compose.material.icons.filled.Clear
|
||||||
|
import androidx.compose.material.icons.filled.Close
|
||||||
import androidx.compose.material.icons.filled.Share
|
import androidx.compose.material.icons.filled.Share
|
||||||
import androidx.compose.material3.BottomAppBar
|
import androidx.compose.material3.BottomAppBar
|
||||||
import androidx.compose.material3.Button
|
import androidx.compose.material3.Button
|
||||||
import androidx.compose.material3.ExperimentalMaterial3Api
|
import androidx.compose.material3.ExperimentalMaterial3Api
|
||||||
|
import androidx.compose.material3.FloatingActionButton
|
||||||
import androidx.compose.material3.Icon
|
import androidx.compose.material3.Icon
|
||||||
import androidx.compose.material3.IconButton
|
import androidx.compose.material3.IconButton
|
||||||
import androidx.compose.material3.MaterialTheme
|
import androidx.compose.material3.MaterialTheme
|
||||||
import androidx.compose.material3.Scaffold
|
import androidx.compose.material3.Scaffold
|
||||||
|
import androidx.compose.material3.SmallFloatingActionButton
|
||||||
import androidx.compose.material3.Text
|
import androidx.compose.material3.Text
|
||||||
import androidx.compose.material3.TopAppBar
|
import androidx.compose.material3.TopAppBar
|
||||||
import androidx.compose.material3.TopAppBarDefaults
|
import androidx.compose.material3.TopAppBarDefaults
|
||||||
@@ -78,22 +86,26 @@ fun DocumentScreen(
|
|||||||
)
|
)
|
||||||
},
|
},
|
||||||
bottomBar = {
|
bottomBar = {
|
||||||
BottomAppBar(
|
Column {
|
||||||
containerColor = Color.Transparent
|
PageList(pageIds, imageLoader)
|
||||||
) {
|
BottomAppBar(
|
||||||
Row(
|
actions = {
|
||||||
modifier = Modifier.fillMaxWidth(),
|
Button(onClick = onSharePressed) {
|
||||||
horizontalArrangement = Arrangement.SpaceEvenly
|
Icon(Icons.Default.Share, contentDescription = "Share")
|
||||||
) {
|
Spacer(Modifier.width(8.dp))
|
||||||
Button(onClick = onSharePressed) {
|
Text("Share")
|
||||||
Icon(Icons.Default.Share, contentDescription = "Share")
|
}
|
||||||
Spacer(Modifier.width(8.dp))
|
Spacer(modifier = Modifier.size(8.dp))
|
||||||
Text("Share")
|
Button(onClick = onSavePressed) {
|
||||||
|
Text("Save")
|
||||||
|
}
|
||||||
|
},
|
||||||
|
floatingActionButton = {
|
||||||
|
FloatingActionButton(onClick = onBackPressed) {
|
||||||
|
Icon(Icons.Default.Close, contentDescription = "Close")
|
||||||
|
}
|
||||||
}
|
}
|
||||||
Button(onClick = onSavePressed) {
|
)
|
||||||
Text("Save")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
) { padding -> DocumentPreview(pageIds, padding, imageLoader, onDeleteImage) }
|
) { padding -> DocumentPreview(pageIds, padding, imageLoader, onDeleteImage) }
|
||||||
@@ -106,37 +118,69 @@ private fun DocumentPreview(
|
|||||||
imageLoader: (String) -> Bitmap,
|
imageLoader: (String) -> Bitmap,
|
||||||
onDeleteImage: (String) -> Unit,
|
onDeleteImage: (String) -> Unit,
|
||||||
) {
|
) {
|
||||||
Box(
|
Column (
|
||||||
modifier = Modifier
|
modifier = Modifier
|
||||||
.fillMaxSize()
|
.fillMaxSize()
|
||||||
.background(MaterialTheme.colorScheme.surfaceContainer)
|
.background(MaterialTheme.colorScheme.surfaceContainer)
|
||||||
.padding(PaddingValues(top = padding.calculateTopPadding()))
|
.padding(padding)
|
||||||
) {
|
) {
|
||||||
Text(
|
|
||||||
"${pageIds.size} pages",
|
Box (
|
||||||
modifier = Modifier.padding(start = 16.dp, top = 16.dp).align(Alignment.TopStart),
|
modifier = Modifier.fillMaxSize()
|
||||||
style = MaterialTheme.typography.titleMedium
|
) {
|
||||||
)
|
// TODO Make it possible to zoom on the image
|
||||||
LazyColumn (
|
Image(
|
||||||
contentPadding = PaddingValues(20.dp),
|
bitmap = imageLoader(pageIds[0]).asImageBitmap(),
|
||||||
|
contentDescription = null,
|
||||||
|
modifier = Modifier
|
||||||
|
.padding(4.dp)
|
||||||
|
.align(Alignment.Center)
|
||||||
|
)
|
||||||
|
Text("1 / ${pageIds.size}",
|
||||||
|
color = MaterialTheme.colorScheme.inverseOnSurface,
|
||||||
|
modifier = Modifier.align(Alignment.BottomEnd)
|
||||||
|
.padding(all = 8.dp)
|
||||||
|
.background(MaterialTheme.colorScheme.inverseSurface.copy(alpha = 0.5f))
|
||||||
|
.padding(all = 4.dp)
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Composable
|
||||||
|
private fun PageList(
|
||||||
|
pageIds: List<String>,
|
||||||
|
imageLoader: (String) -> Bitmap
|
||||||
|
) {
|
||||||
|
Box {
|
||||||
|
LazyRow(
|
||||||
|
contentPadding = PaddingValues(8.dp),
|
||||||
modifier = Modifier
|
modifier = Modifier
|
||||||
.padding(horizontal = 16.dp)
|
.fillMaxWidth()
|
||||||
.align(Alignment.Center),
|
.padding(vertical = 4.dp)
|
||||||
verticalArrangement = Arrangement.spacedBy(12.dp)
|
.background(MaterialTheme.colorScheme.secondaryContainer),
|
||||||
|
horizontalArrangement = Arrangement.spacedBy(8.dp)
|
||||||
) {
|
) {
|
||||||
items(pageIds) { id ->
|
items(pageIds) { id ->
|
||||||
// TODO Display small images rather than big ones
|
// TODO Use small images rather than big ones
|
||||||
// TODO Make it possible to zoom on an image
|
|
||||||
val bitmap = imageLoader(id).asImageBitmap()
|
val bitmap = imageLoader(id).asImageBitmap()
|
||||||
Image(
|
Image(
|
||||||
bitmap = bitmap,
|
bitmap = bitmap,
|
||||||
contentDescription = null,
|
contentDescription = null,
|
||||||
modifier = Modifier
|
modifier = Modifier
|
||||||
.size(200.dp)
|
.height(120.dp)
|
||||||
.padding(4.dp)
|
.padding(4.dp)
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
SmallFloatingActionButton(
|
||||||
|
onClick = {},
|
||||||
|
modifier = Modifier
|
||||||
|
.align(Alignment.CenterEnd)
|
||||||
|
.padding(8.dp)
|
||||||
|
) {
|
||||||
|
Icon(imageVector = Icons.Default.Add, contentDescription = "Add page")
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user