DocumentScreen layout: big image + miniatures

This commit is contained in:
Pierre-Yves Nicolas
2025-06-07 07:17:55 +02:00
committed by pynicolas
parent 5292f5bdb3
commit 2b1b537f67

View File

@@ -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")
}
} }
} }