Как установить непрозрачность формы?
Я уже знаю, как установить непрозрачность фонового изображения, но мне нужно установить непрозрачность моего объекта формы.
В моем приложении для Android у меня это выглядит так:
![enter image description here]()
и я хочу сделать эту черную область немного прозрачной, как здесь, например, я могу видеть круги, хотя это "Добро пожаловать...":
![enter image description here]()
Вот мой код формы:
<?xml version="1.0" encoding="UTF-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/shape_my"">
<stroke android:width="4dp" android:color="#636161" />
<padding android:left="20dp"
android:top="20dp"
android:right="20dp"
android:bottom="20dp" />
<corners android:radius="24dp" />
</shape>
Как я могу это сделать?
Ответы
Ответ 1
В общем, вам просто нужно определить слегка прозрачный цвет при создании фигуры.
Вы можете добиться этого, установив цвет альфа-канала.
#FF000000
вы получите сплошной черный цвет, тогда как #00000000
получит 100% прозрачный черный цвет (ну, очевидно, он не черный).
Цветовая схема выглядит так: #AARRGGBB
там A обозначает альфа-канал, R обозначает красный цвет, G - зеленый, а B - синий.
То же самое применяется, если вы задаете цвет в Java. Там он будет выглядеть только как 0xFF000000
.
UPDATE
В вашем случае вам нужно добавить solid
node. Как ниже.
<?xml version="1.0" encoding="UTF-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/shape_my"">
<stroke android:width="4dp" android:color="#636161" />
<padding android:left="20dp"
android:top="20dp"
android:right="20dp"
android:bottom="20dp" />
<corners android:radius="24dp" />
<solid android:color="#88000000" />
</shape>
Цвет здесь полупрозрачный черный.
Ответ 2
используйте этот код ниже как progress.xml:
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<item android:id="@android:id/background">
<shape>
<corners android:radius="5dip" />
<gradient
android:startColor="#ff9d9e9d"
android:centerColor="#ff5a5d5a"
android:centerY="0.75"
android:endColor="#ff747674"
android:angle="270"
/>
</shape>
</item>
<item android:id="@android:id/secondaryProgress">
<clip>
<shape>
<solid android:color="#00000000" />
</shape>
</clip>
</item>
<item android:id="@android:id/progress">
<clip>
<shape>
<solid android:color="#00000000" />
</shape>
</clip>
</item>
</layer-list>
где:
- "прогресс" - это текущий прогресс перед большим пальцем, а "secondaryProgress" - это прогресс после большого пальца.
- color = "# 00000000" - идеальная прозрачность.
- ПРИМЕЧАНИЕ. Файл, указанный выше, относится к по умолчанию для android res и для 2.3.7, он доступен в источниках android по адресу: frameworks/base/core/res/res/drawable/progress_horizontal.xml. Для более новых версий вы должны найти файл по умолчанию для файла поиска, соответствующий вашей версии Android.
после этого используйте его в макете, содержащей xml:
<SeekBar
android:id="@+id/myseekbar"
...
android:progressDrawable="@drawable/progress"
/>
вы также можете настроить большой палец с помощью пользовательского значка seek_thumb.png:
android:thumb="@drawable/seek_thumb"
Ответ 3
Используйте этот, я написал это в своем приложении,
<?xml version="1.0" encoding="utf-8"?>
<!-- res/drawable/rounded_edittext.xml -->
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="rectangle" android:padding="10dp">
<solid android:color="#882C383E"/>
<corners
android:bottomRightRadius="5dp"
android:bottomLeftRadius="5dp"
android:topLeftRadius="5dp"
android:topRightRadius="5dp"/>
</shape>