В разных размерах экрана [Pixel 9 против маленького телефона] компонент карты, в том числе изображение и кнопку «Воспроизвести снова», - идеально подходит на эмулятор Pixel 9, соответствующая экрану предварительного просмотра. Тем не менее, на меньшем экране телефона размер сокращается, и кнопка «Воспроизвести снова» скрывается. Это может быть связано с изображением, имеющим фиксированный размер 160.dp. Как я могу убедиться, что он идеально подходит для всех экранов при сохранении предполагаемого внешнего вида 160.dp? /strong>
pixel 9 Экран эмулятора
< strong> малый эмулятор телефона
code:
флажок «Результат» Результат «Компонируемая функция. < /strong> < /p>
package com.example.drivinglicenseexamapp.ui.screen.exam_mode_screen
import androidx.compose.foundation.Image
import androidx.compose.foundation.background
import androidx.compose.foundation.layout.Arrangement
import androidx.compose.foundation.layout.Column
import androidx.compose.foundation.layout.Row
import androidx.compose.foundation.layout.Spacer
import androidx.compose.foundation.layout.fillMaxSize
import androidx.compose.foundation.layout.fillMaxWidth
import androidx.compose.foundation.layout.height
import androidx.compose.foundation.layout.padding
import androidx.compose.foundation.layout.size
import androidx.compose.foundation.shape.RoundedCornerShape
import androidx.compose.material3.Button
import androidx.compose.material3.ButtonDefaults
import androidx.compose.material3.Card
import androidx.compose.material3.CardDefaults
import androidx.compose.material3.Text
import androidx.compose.runtime.Composable
import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
import androidx.compose.ui.graphics.Color
import androidx.compose.ui.res.colorResource
import androidx.compose.ui.res.painterResource
import androidx.compose.ui.text.font.FontWeight
import androidx.compose.ui.tooling.preview.Preview
import androidx.compose.ui.unit.dp
import androidx.compose.ui.unit.sp
import com.example.drivinglicenseexamapp.R
import com.example.drivinglicenseexamapp.ui.theme.BlueBackgroundColor
import com.example.drivinglicenseexamapp.ui.theme.ButtonColor
import com.example.drivinglicenseexamapp.ui.theme.ButtonColorLightBlue
import com.example.drivinglicenseexamapp.ui.theme.LightBackgroundColor
@Composable
fun ResultScreen(
correctAnswer: Int,
size: Int,
navigateToQuiz: () -> Unit,
navigateToHome: () -> Unit,
navigateToAnswer: () -> Unit,
) {
Column(
modifier = Modifier.background(color = BlueBackgroundColor)
) {
Card(
colors = CardDefaults.cardColors(
containerColor = LightBackgroundColor
),
modifier = Modifier
.fillMaxSize()
.padding(8.dp)
) {
Column(
verticalArrangement = Arrangement.SpaceBetween,
modifier = Modifier.fillMaxSize()
) {
BoxResult(correctAnswer, size, navigateToQuiz)
Column {
Button(
onClick = navigateToAnswer,
modifier = Modifier
.fillMaxWidth()
.padding(horizontal = 16.dp)
.height(50.dp),
colors = ButtonDefaults.buttonColors(
containerColor = ButtonColor
),
shape = RoundedCornerShape(16.dp)
) {
Text(text = "Show Answer", fontSize = 24.sp, fontWeight = FontWeight.Bold, color = Color.White)
}
Button(
onClick = navigateToHome,
colors = ButtonDefaults.buttonColors(
containerColor = ButtonColor
),
shape = RoundedCornerShape(16.dp),
modifier = Modifier
.fillMaxWidth()
.padding(16.dp)
.height(50.dp)
) {
Text(
text = "Close",
fontSize = 24.sp,
fontWeight = FontWeight.Bold,
color = Color.White
)
}
}
}
}
}
}
@Composable
fun BoxResult(
correctAnswer: Int,
size: Int,
navigateToQuiz: () -> Unit,
) {
Column(modifier = Modifier.padding(16.dp)) {
Card(
colors = CardDefaults.cardColors(
containerColor = BlueBackgroundColor
),
modifier = Modifier
.fillMaxWidth()
.fillMaxSize(0.4f)
) {
Column(
verticalArrangement = Arrangement.Center,
horizontalAlignment = Alignment.CenterHorizontally,
modifier = Modifier
.padding(16.dp)
.fillMaxSize()
) {
Image(
painter = painterResource(id = R.drawable.balloons),
contentDescription = "",
modifier = Modifier.size(160.dp)
)
Spacer(modifier = Modifier.height(32.dp))
Button(
onClick = navigateToQuiz,
colors = ButtonDefaults.buttonColors(
containerColor = ButtonColorLightBlue
),
modifier = Modifier
.fillMaxWidth()
.size(50.dp)
) {
Text(
text = "Play Again",
fontSize = 20.sp,
fontWeight = FontWeight.Bold
)
}
}
}
Spacer(modifier = Modifier.height(16.dp))
Column(modifier = Modifier.padding(8.dp)) {
Row {
TextResult(title = "CORRECT", value = "$correctAnswer")
Spacer(modifier = Modifier.weight(1f))
TextResult(title = "INCORRECT", value = "${size - correctAnswer}")
}
Spacer(modifier = Modifier.height(24.dp))
Row(horizontalArrangement = Arrangement.Center, modifier = Modifier.fillMaxWidth()) {
TextResult(
title = "RESULT",
value = "${if (correctAnswer == 0) 0 else (correctAnswer * 100) / size}%"
)
}
}
}
}
@Composable
fun TextResult(
title: String,
value: String,
modifier: Modifier = Modifier
) {
Column(horizontalAlignment = Alignment.CenterHorizontally) {
Text(
text = title,
fontSize = 20.sp,
fontWeight = FontWeight.Bold,
color = colorResource(id = R.color.black),
)
Spacer(modifier = Modifier.height(8.dp))
Text(
text = value,
fontSize = 20.sp,
fontWeight = FontWeight.Bold,
)
}
}
@Preview
@Composable
private fun QuizResultScreenPreview() {
ResultScreen( correctAnswer = 1, size = 5, {}, {},{})
//BoxResult()
//TextResult(title = "title", value = "value")
}
Подробнее здесь: https://stackoverflow.com/questions/794 ... to-differe
Как сделать компоненты пользовательского интерфейса в JetPack Project Project должным образом адаптироваться к разным ра ⇐ Android
Форум для тех, кто программирует под Android
1738891492
Anonymous
В разных размерах экрана [Pixel 9 против маленького телефона] компонент карты, в том числе изображение и кнопку «Воспроизвести снова», - идеально подходит на эмулятор Pixel 9, соответствующая экрану предварительного просмотра. Тем не менее, на меньшем экране телефона размер сокращается, и кнопка «Воспроизвести снова» скрывается. Это может быть связано с изображением, имеющим фиксированный размер 160.dp. [b] Как я могу убедиться, что он идеально подходит для всех экранов при сохранении предполагаемого внешнего вида 160.dp? /strong>
pixel 9 Экран эмулятора [/b]
< strong> малый эмулятор телефона
code:
флажок «Результат» Результат «Компонируемая функция. < /strong> < /p>
package com.example.drivinglicenseexamapp.ui.screen.exam_mode_screen
import androidx.compose.foundation.Image
import androidx.compose.foundation.background
import androidx.compose.foundation.layout.Arrangement
import androidx.compose.foundation.layout.Column
import androidx.compose.foundation.layout.Row
import androidx.compose.foundation.layout.Spacer
import androidx.compose.foundation.layout.fillMaxSize
import androidx.compose.foundation.layout.fillMaxWidth
import androidx.compose.foundation.layout.height
import androidx.compose.foundation.layout.padding
import androidx.compose.foundation.layout.size
import androidx.compose.foundation.shape.RoundedCornerShape
import androidx.compose.material3.Button
import androidx.compose.material3.ButtonDefaults
import androidx.compose.material3.Card
import androidx.compose.material3.CardDefaults
import androidx.compose.material3.Text
import androidx.compose.runtime.Composable
import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
import androidx.compose.ui.graphics.Color
import androidx.compose.ui.res.colorResource
import androidx.compose.ui.res.painterResource
import androidx.compose.ui.text.font.FontWeight
import androidx.compose.ui.tooling.preview.Preview
import androidx.compose.ui.unit.dp
import androidx.compose.ui.unit.sp
import com.example.drivinglicenseexamapp.R
import com.example.drivinglicenseexamapp.ui.theme.BlueBackgroundColor
import com.example.drivinglicenseexamapp.ui.theme.ButtonColor
import com.example.drivinglicenseexamapp.ui.theme.ButtonColorLightBlue
import com.example.drivinglicenseexamapp.ui.theme.LightBackgroundColor
@Composable
fun ResultScreen(
correctAnswer: Int,
size: Int,
navigateToQuiz: () -> Unit,
navigateToHome: () -> Unit,
navigateToAnswer: () -> Unit,
) {
Column(
modifier = Modifier.background(color = BlueBackgroundColor)
) {
Card(
colors = CardDefaults.cardColors(
containerColor = LightBackgroundColor
),
modifier = Modifier
.fillMaxSize()
.padding(8.dp)
) {
Column(
verticalArrangement = Arrangement.SpaceBetween,
modifier = Modifier.fillMaxSize()
) {
BoxResult(correctAnswer, size, navigateToQuiz)
Column {
Button(
onClick = navigateToAnswer,
modifier = Modifier
.fillMaxWidth()
.padding(horizontal = 16.dp)
.height(50.dp),
colors = ButtonDefaults.buttonColors(
containerColor = ButtonColor
),
shape = RoundedCornerShape(16.dp)
) {
Text(text = "Show Answer", fontSize = 24.sp, fontWeight = FontWeight.Bold, color = Color.White)
}
Button(
onClick = navigateToHome,
colors = ButtonDefaults.buttonColors(
containerColor = ButtonColor
),
shape = RoundedCornerShape(16.dp),
modifier = Modifier
.fillMaxWidth()
.padding(16.dp)
.height(50.dp)
) {
Text(
text = "Close",
fontSize = 24.sp,
fontWeight = FontWeight.Bold,
color = Color.White
)
}
}
}
}
}
}
@Composable
fun BoxResult(
correctAnswer: Int,
size: Int,
navigateToQuiz: () -> Unit,
) {
Column(modifier = Modifier.padding(16.dp)) {
Card(
colors = CardDefaults.cardColors(
containerColor = BlueBackgroundColor
),
modifier = Modifier
.fillMaxWidth()
.fillMaxSize(0.4f)
) {
Column(
verticalArrangement = Arrangement.Center,
horizontalAlignment = Alignment.CenterHorizontally,
modifier = Modifier
.padding(16.dp)
.fillMaxSize()
) {
Image(
painter = painterResource(id = R.drawable.balloons),
contentDescription = "",
modifier = Modifier.size(160.dp)
)
Spacer(modifier = Modifier.height(32.dp))
Button(
onClick = navigateToQuiz,
colors = ButtonDefaults.buttonColors(
containerColor = ButtonColorLightBlue
),
modifier = Modifier
.fillMaxWidth()
.size(50.dp)
) {
Text(
text = "Play Again",
fontSize = 20.sp,
fontWeight = FontWeight.Bold
)
}
}
}
Spacer(modifier = Modifier.height(16.dp))
Column(modifier = Modifier.padding(8.dp)) {
Row {
TextResult(title = "CORRECT", value = "$correctAnswer")
Spacer(modifier = Modifier.weight(1f))
TextResult(title = "INCORRECT", value = "${size - correctAnswer}")
}
Spacer(modifier = Modifier.height(24.dp))
Row(horizontalArrangement = Arrangement.Center, modifier = Modifier.fillMaxWidth()) {
TextResult(
title = "RESULT",
value = "${if (correctAnswer == 0) 0 else (correctAnswer * 100) / size}%"
)
}
}
}
}
@Composable
fun TextResult(
title: String,
value: String,
modifier: Modifier = Modifier
) {
Column(horizontalAlignment = Alignment.CenterHorizontally) {
Text(
text = title,
fontSize = 20.sp,
fontWeight = FontWeight.Bold,
color = colorResource(id = R.color.black),
)
Spacer(modifier = Modifier.height(8.dp))
Text(
text = value,
fontSize = 20.sp,
fontWeight = FontWeight.Bold,
)
}
}
@Preview
@Composable
private fun QuizResultScreenPreview() {
ResultScreen( correctAnswer = 1, size = 5, {}, {},{})
//BoxResult()
//TextResult(title = "title", value = "value")
}
Подробнее здесь: [url]https://stackoverflow.com/questions/79419774/how-to-make-ui-components-in-a-jetpack-compose-project-adapt-properly-to-differe[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия