Как установить непрозрачность формы?

Я уже знаю, как установить непрозрачность фонового изображения, но мне нужно установить непрозрачность моего объекта формы.

В моем приложении для 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>