Ответ 1
Вы можете создать ресурс (layer drawable xml) для вашей границы ImageView
(фактически фон) и объявить в своем theme
, что фоновым ресурсом ImageView
является гибкий xml.
Если вам нужна эта "граница", которая должна быть изменена в соответствии с состоянием ImageView
(focused
, selected
и т.д.), тогда вы должны создать больше растягивателей слоев и поместить их в селектор xml ( состояние доступно).
Затем в вашей теме вы должны установить фон ImageView
таким образом selector.xml
.
Обновить
Ниже приведен пример того, как указать простую рамку для ваших изображений, что приведет к
Вы должны
- создать новый файл для рисования слоя (
image_border.xml
), - изменить/создать файл
styles.xml
- изменить/создать файл
colors.xml
- измените ваш XML файл макета (или ваш код), чтобы применить стиль к
ImageView
.
Рез/вытяжка/image_border.xml
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<item>
<shape android:shape="rectangle">
<gradient android:angle="90"
android:startColor="@color/image_border_start"
android:centerColor="@color/image_border_center"
android:endColor="@color/image_border_end" />
</shape>
</item>
<item android:top="2dp" android:left="2dp"
android:right="2dp" android:bottom="2dp">
<shape android:shape="rectangle">
<solid android:color="@color/default_back_color" />
</shape>
</item>
</layer-list>
res/values /styles.xml
Добавьте следующие строки:
<style name="myImageView">
<!-- 3dp so the background border to be visible -->
<item name="android:padding">3dp</item>
<item name="android:background">@drawable/image_border</item>
<item name="android:scaleType">fitCenter</item>
</style>
res/values /colors.xml
Добавьте следующие строки:
<color name="image_border_start">#40990000</color>
<color name="image_border_end">#FF660000</color>
<color name="image_border_center">#FFFF3333</color>
И, наконец, укажите стиль вашего ImageView
в макете xml:
<ImageView android:id="@+id/my_image"
android:layout_width="100dp" android:layout_height="100dp"
android:src="@drawable/efteling"
style="@style/myImageView" />