Я изучаю JetPack Compose и пытаюсь импортировать изображения в своем приложении, используя катушку, но по какой -то причине все, что я получаю, это белый фон. < /p>
package com.spirovski.movieapp.widgets
import androidx.compose.animation.AnimatedVisibility
import androidx.compose.foundation.Image
import androidx.compose.foundation.clickable
import androidx.compose.foundation.layout.Arrangement
import androidx.compose.foundation.layout.Column
import androidx.compose.foundation.layout.Row
import androidx.compose.foundation.layout.fillMaxWidth
import androidx.compose.foundation.layout.padding
import androidx.compose.foundation.layout.size
import androidx.compose.foundation.shape.CornerSize
import androidx.compose.foundation.shape.RoundedCornerShape
import androidx.compose.material.icons.Icons
import androidx.compose.material.icons.filled.KeyboardArrowDown
import androidx.compose.material.icons.filled.KeyboardArrowUp
import androidx.compose.material3.Card
import androidx.compose.material3.CardDefaults
import androidx.compose.material3.HorizontalDivider
import androidx.compose.material3.Icon
import androidx.compose.material3.MaterialTheme
import androidx.compose.material3.Surface
import androidx.compose.material3.Text
import androidx.compose.runtime.Composable
import androidx.compose.runtime.getValue
import androidx.compose.runtime.mutableStateOf
import androidx.compose.runtime.remember
import androidx.compose.runtime.setValue
import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
import androidx.compose.ui.graphics.Color
import androidx.compose.ui.graphics.RectangleShape
import androidx.compose.ui.platform.LocalContext
import androidx.compose.ui.text.SpanStyle
import androidx.compose.ui.text.buildAnnotatedString
import androidx.compose.ui.text.font.FontWeight
import androidx.compose.ui.text.withStyle
import androidx.compose.ui.tooling.preview.Preview
import androidx.compose.ui.unit.dp
import androidx.compose.ui.unit.sp
import coil3.compose.AsyncImage
import coil3.compose.rememberAsyncImagePainter
import coil3.request.ImageRequest
import coil3.request.crossfade
import coil3.request.transformations
import coil3.transform.CircleCropTransformation
import com.spirovski.movieapp.model.Movie
import com.spirovski.movieapp.model.getMovies
@Preview
@Composable
fun MovieRow(movie: Movie = getMovies()[0], onItemClick: (String) -> Unit = {}) {
var expanded by remember {
mutableStateOf(false)
}
Card(modifier = Modifier
.padding(4.dp)
.fillMaxWidth()
//.height(130.dp)
.clickable {
onItemClick(movie.id)
},
shape = RoundedCornerShape(corner = CornerSize(16.dp)),
elevation = CardDefaults.cardElevation(6.dp)
) {
Row(verticalAlignment = Alignment.CenterVertically,
horizontalArrangement = Arrangement.Start) {
Surface(modifier = Modifier
.padding(12.dp)
.size(100.dp),
shape = RectangleShape,
shadowElevation = 4.dp
) {
AsyncImage(
model = ImageRequest.Builder(LocalContext.current)
.data(movie.poster)
.crossfade(true) // Enable crossfade
.build(),
contentDescription = "Movie Poster"
)
// Icon(imageVector = Icons.Default.AccountBox, contentDescription = "Movie Image")
}
Column(modifier = Modifier.padding(4.dp)) {
Text(text = movie.title,
style = MaterialTheme.typography.titleLarge)
Text(text = "Director: ${movie.title}",
style = MaterialTheme.typography.bodySmall)
Text(text = "Released: ${movie.year}",
style = MaterialTheme.typography.bodySmall)
AnimatedVisibility(visible = expanded) {
Column {
Text(buildAnnotatedString {
withStyle(style = SpanStyle(color = Color.DarkGray,
fontSize = 13.sp,
fontWeight = FontWeight.Bold)) {
append("Plot: ")
}
withStyle(style = SpanStyle(color = Color.DarkGray,
fontSize = 13.sp,
fontWeight = FontWeight.Light)) {
append(movie.plot)
}
}, modifier = Modifier.padding(6.dp))
HorizontalDivider(modifier = Modifier.padding(3.dp))
Text(text = "Director: ${movie.director}", style = MaterialTheme.typography.bodySmall)
Text(text = "Actors: ${movie.actors}", style = MaterialTheme.typography.bodySmall)
Text(text = "Rating: ${movie.rating}", style = MaterialTheme.typography.bodySmall)
}
}
Icon(imageVector = if(expanded) Icons.Filled.KeyboardArrowUp else Icons.Filled.KeyboardArrowDown,
contentDescription = "Down Arrow",
modifier = Modifier.size(25.dp).clickable {
expanded = !expanded
},
tint = Color.DarkGray)
}
}
}
}
< /code>
Я получаю свои изображения из другого класса, в котором есть вся информация о моих фильмах. Я пытался измениться и не использовать асинтечное значение и с художником, но все же они не появляются.
Подробнее здесь: https://stackoverflow.com/questions/796 ... using-coil
Почему мои изображения не загружаются при использовании катушки? [закрыто] ⇐ Android
Форум для тех, кто программирует под Android
1747397587
Anonymous
Я изучаю JetPack Compose и пытаюсь импортировать изображения в своем приложении, используя катушку, но по какой -то причине все, что я получаю, это белый фон. < /p>
package com.spirovski.movieapp.widgets
import androidx.compose.animation.AnimatedVisibility
import androidx.compose.foundation.Image
import androidx.compose.foundation.clickable
import androidx.compose.foundation.layout.Arrangement
import androidx.compose.foundation.layout.Column
import androidx.compose.foundation.layout.Row
import androidx.compose.foundation.layout.fillMaxWidth
import androidx.compose.foundation.layout.padding
import androidx.compose.foundation.layout.size
import androidx.compose.foundation.shape.CornerSize
import androidx.compose.foundation.shape.RoundedCornerShape
import androidx.compose.material.icons.Icons
import androidx.compose.material.icons.filled.KeyboardArrowDown
import androidx.compose.material.icons.filled.KeyboardArrowUp
import androidx.compose.material3.Card
import androidx.compose.material3.CardDefaults
import androidx.compose.material3.HorizontalDivider
import androidx.compose.material3.Icon
import androidx.compose.material3.MaterialTheme
import androidx.compose.material3.Surface
import androidx.compose.material3.Text
import androidx.compose.runtime.Composable
import androidx.compose.runtime.getValue
import androidx.compose.runtime.mutableStateOf
import androidx.compose.runtime.remember
import androidx.compose.runtime.setValue
import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
import androidx.compose.ui.graphics.Color
import androidx.compose.ui.graphics.RectangleShape
import androidx.compose.ui.platform.LocalContext
import androidx.compose.ui.text.SpanStyle
import androidx.compose.ui.text.buildAnnotatedString
import androidx.compose.ui.text.font.FontWeight
import androidx.compose.ui.text.withStyle
import androidx.compose.ui.tooling.preview.Preview
import androidx.compose.ui.unit.dp
import androidx.compose.ui.unit.sp
import coil3.compose.AsyncImage
import coil3.compose.rememberAsyncImagePainter
import coil3.request.ImageRequest
import coil3.request.crossfade
import coil3.request.transformations
import coil3.transform.CircleCropTransformation
import com.spirovski.movieapp.model.Movie
import com.spirovski.movieapp.model.getMovies
@Preview
@Composable
fun MovieRow(movie: Movie = getMovies()[0], onItemClick: (String) -> Unit = {}) {
var expanded by remember {
mutableStateOf(false)
}
Card(modifier = Modifier
.padding(4.dp)
.fillMaxWidth()
//.height(130.dp)
.clickable {
onItemClick(movie.id)
},
shape = RoundedCornerShape(corner = CornerSize(16.dp)),
elevation = CardDefaults.cardElevation(6.dp)
) {
Row(verticalAlignment = Alignment.CenterVertically,
horizontalArrangement = Arrangement.Start) {
Surface(modifier = Modifier
.padding(12.dp)
.size(100.dp),
shape = RectangleShape,
shadowElevation = 4.dp
) {
AsyncImage(
model = ImageRequest.Builder(LocalContext.current)
.data(movie.poster)
.crossfade(true) // Enable crossfade
.build(),
contentDescription = "Movie Poster"
)
// Icon(imageVector = Icons.Default.AccountBox, contentDescription = "Movie Image")
}
Column(modifier = Modifier.padding(4.dp)) {
Text(text = movie.title,
style = MaterialTheme.typography.titleLarge)
Text(text = "Director: ${movie.title}",
style = MaterialTheme.typography.bodySmall)
Text(text = "Released: ${movie.year}",
style = MaterialTheme.typography.bodySmall)
AnimatedVisibility(visible = expanded) {
Column {
Text(buildAnnotatedString {
withStyle(style = SpanStyle(color = Color.DarkGray,
fontSize = 13.sp,
fontWeight = FontWeight.Bold)) {
append("Plot: ")
}
withStyle(style = SpanStyle(color = Color.DarkGray,
fontSize = 13.sp,
fontWeight = FontWeight.Light)) {
append(movie.plot)
}
}, modifier = Modifier.padding(6.dp))
HorizontalDivider(modifier = Modifier.padding(3.dp))
Text(text = "Director: ${movie.director}", style = MaterialTheme.typography.bodySmall)
Text(text = "Actors: ${movie.actors}", style = MaterialTheme.typography.bodySmall)
Text(text = "Rating: ${movie.rating}", style = MaterialTheme.typography.bodySmall)
}
}
Icon(imageVector = if(expanded) Icons.Filled.KeyboardArrowUp else Icons.Filled.KeyboardArrowDown,
contentDescription = "Down Arrow",
modifier = Modifier.size(25.dp).clickable {
expanded = !expanded
},
tint = Color.DarkGray)
}
}
}
}
< /code>
Я получаю свои изображения из другого класса, в котором есть вся информация о моих фильмах. Я пытался измениться и не использовать асинтечное значение и с художником, но все же они не появляются.
Подробнее здесь: [url]https://stackoverflow.com/questions/79620122/why-my-images-are-not-loading-while-using-coil[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия