Двумя наиболее распространенными типами форматов изображений являются растровые и векторные изображения.
Формат растровой графики содержит пиксели: крошечные отдельные квадраты, содержащие цвет (состоящий из красного, зеленого, синего и альфа-значений). При объединении большого количества пикселей можно сформировать очень детальное изображение, например фотографию. Растровая графика имеет фиксированное разрешение (фиксированное количество пикселей). Это означает, что при увеличении размера изображения оно теряет детализацию и может возникнуть пикселизация. Примерами форматов растровой графики являются JPEG, PNG и WEBP.
Векторные изображения, с другой стороны, представляют собой масштабируемое математическое представление визуального элемента на экране. Вектор — это набор команд, описывающих, как нарисовать изображение на экране, например, линию, точку или заливку. При масштабировании вектора на экране он не потеряет качества, поскольку математическая формула сохранит взаимосвязь между различными командами. Хорошим примером ImageVector являются символы материала, поскольку все они могут быть определены с помощью математических формул.
ImageBitmap
В Compose растровое изображение (часто называемое Bitmap
) можно загрузить в экземпляр ImageBitmap
, а BitmapPainter
отвечает за отрисовку растрового изображения на экране.
Для простых случаев использования можно использовать painterResource()
, который создает ImageBitmap
и возвращает объект Painter
(в данном случае — BitmapPainter
):
Image( painter = painterResource(id = R.drawable.dog), contentDescription = stringResource(id = R.string.dog_content_description) )
Если вам требуется дополнительная настройка (например, собственная реализация рисовальщика ) и вам нужен доступ к самому ImageBitmap
, вы можете загрузить его следующим образом:
val imageBitmap = ImageBitmap.imageResource(R.drawable.dog)
ImageVector
VectorPainter
отвечает за рисование ImageVector
на экране. ImageVector
поддерживает подмножество команд SVG. Не все изображения можно представить в векторном виде (например, фотографии, сделанные камерой, невозможно преобразовать в вектор).
Вы можете создать собственный ImageVector
, импортировав существующий векторный XML-файл с возможностью рисования (импортированный в Android Studio с помощью инструмента импорта ) или реализовав класс и введя команды пути вручную.
В простых случаях использования painterResource()
работает для класса ImageBitmap
так же, как и для ImageVectors
, возвращая в качестве результата VectorPainter
. painterResource()
обрабатывает загрузку VectorDrawables
и BitmapDrawables
в VectorPainter
и BitmapPainter
соответственно. Чтобы загрузить VectorDrawable
в изображение, используйте:
Image( painter = painterResource(id = R.drawable.baseline_shopping_cart_24), contentDescription = stringResource(id = R.string.shopping_cart_content_desc) )
Если вам потребуется дополнительная настройка и вам нужен доступ к самому ImageVector
, вы можете загрузить его следующим образом:
val imageVector = ImageVector.vectorResource(id = R.drawable.baseline_shopping_cart_24)
Рекомендуется для вас
- Примечание: текст ссылки отображается, когда JavaScript отключен.
- Пользовательский художник {:#custom-painter}
- Ресурсы в Compose
- Загрузка изображений {:#loading-images}