Я получаю изображение по URL-адресу с указанием размера. Например, скоро появится размер 120x40.
@Composable частное развлечение RowScope.PanelLogo(logo: Logo?) { val imageUrl = логотип?.url val imageWidth = логотип?.width!! val imageHeight = logo.height!! val Painter = RememberAsyncImagePainter( модель = ImageRequest.Builder(LocalContext.current) .data(URL-изображения) .decoderFactory(SvgDecoder.Factory()) .size(Размер(imageWidth, imageHeight)) .строить() ) val isImageValid = !imageUrl.isNullOrEmpty() &&painter.state — это AsyncImagePainter.State.Success AnimatedVisibility(visible = isImageValid) { Изображение( художник = художник, contentDescription = "фото", contentScale = ContentScale.FillWidth ) } } У меня очень маленькое изображение, и я не вижу его должным образом.
Я пытаюсь преобразовать 120x40 в dp, но выдает ошибку.
val imageWidth = logo?.width?.dp val imageHeight = логотип?.height?.dp

Я хочу показать точный размер, поступающий с сервера.
ОБНОВЛЕНИЕ
import androidx.compose.animation.AnimatedVisibility импортировать androidx.compose.foundation.Image импортировать androidx.compose.foundation.layout.RowScope импортировать androidx.compose.runtime.Composable импортировать androidx.compose.ui.layout.ContentScale импортировать androidx.compose.ui.platform.LocalContext импортировать androidx.compose.ui.unit.dp импортировать катушку.compose.AsyncImagePainter импортировать coin.compose.rememberAsyncImagePainter импортировать катушку.decode.SvgDecoder импортировать катушку.запрос.ImageRequest импортировать катушку.размер.Размер @Композитный частное развлечение RowScope.PanelClientLogo(logo: Logo?) { val imageUrl = логотип?.url val imageWidth = логотип?.width?.dp val imageHeight = логотип?.height?.dp val Painter = RememberAsyncImagePainter( модель = ImageRequest.Builder(LocalContext.current) .data(URL-изображения) .decoderFactory(SvgDecoder.Factory()) .size(Размер(imageWidth, imageHeight)) .строить() ) val isImageValid = !imageUrl.isNullOrEmpty() &&painter.state — это AsyncImagePainter.State.Success AnimatedVisibility(visible = isImageValid) { Изображение( художник = художник, contentDescription = "фото", contentScale = ContentScale.FillWidth ) } } Логотип класса данных (URL-значение: String?, Ширина значения: Int?, Высота значения: Int) ОБНОВЛЕНИЕ 2
import androidx.compose.animation.AnimatedVisibility импортировать androidx.compose.foundation.Image импортировать androidx.compose.foundation.layout.RowScope импортировать androidx.compose.runtime.Composable импортировать androidx.compose.ui.layout.ContentScale импортировать androidx.compose.ui.platform.LocalContext импортировать androidx.compose.ui.unit.dp импортировать катушку.compose.AsyncImagePainter импортировать coin.compose.rememberAsyncImagePainter импортировать катушку.decode.SvgDecoder импортировать катушку.запрос.ImageRequest @Композитный частное развлечение RowScope.PanelClientLogo(logo: Logo?) { val imageUrl = логотип?.url val imageWidth = логотип?.width?.dp val imageHeight = логотип?.height?.dp val Painter = RememberAsyncImagePainter( модель = ImageRequest.Builder(LocalContext.current) .data(URL-изображения) .decoderFactory(SvgDecoder.Factory()) .size(coil.size.Size(imageWidth, imageHeight)) .строить() ) val isImageValid = !imageUrl.isNullOrEmpty() &&painter.state — это AsyncImagePainter.State.Success AnimatedVisibility(visible = isImageValid) { Изображение( художник = художник, contentDescription = "фото", contentScale = ContentScale.FillWidth ) } } Логотип класса данных (URL-значение: String?, Ширина значения: Int?, Высота значения: Int)
