모양의 불투명도를 설정하는 방법은 무엇입니까?


86

배경 이미지의 불투명도를 설정하는 방법을 이미 알고 있지만 모양 개체의 불투명도를 설정해야합니다.

내 Android 앱에는 다음과 같습니다. 여기에 이미지 설명 입력

이 검은 색 영역을 약간 투명하게 만들고 싶습니다. 예를 들어 "Welcome ..."을 통해 원을 볼 수 있습니다.

여기에 이미지 설명 입력

내 모양 코드는 다음과 같습니다.

<?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>

어떻게 할 수 있습니까?


2
모양 개체 코드는 여기에서 도움이 될 것입니다.
Octavian A. Damiean 2011

답변:


201

일반적으로 모양을 만들 때 약간 투명한 색상을 정의하면됩니다.

색상 알파 채널을 설정하여이를 달성 할 수 있습니다.

#FF000000단색 검정 #00000000을 얻을 수 있지만 100 % 투명한 검정을 얻을 수 있습니다 (더 이상 검정색이 아님).

색 구성표는 다음과 같습니다 #AARRGGBB. A는 알파 채널, R은 빨간색, G는 녹색, B는 파란색을 나타냅니다.

Java에서 색상을 설정하는 경우에도 동일하게 적용됩니다. 그것은 단지처럼 보일 것 0xFF000000입니다.

최신 정보

귀하의 경우에는 solid노드 를 추가해야 합니다. 아래와 같습니다.

<?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>

여기의 색상은 반투명 검정색입니다.


codeviewer.org/view/code:1974 - shape.xml. codeviewer.org/view/code:1975 - layout.xml. codeviewer.org/view/code:1976-.java setOpacity는 셰이프에서 작동하지 않습니다. 그리고 shape.xml에 android : background = "# 00000000"을 추가하려고했지만 아무 일도 일어나지 않습니다.
lomza 2011

이것은 중요하지 않습니다 ... 홀수 나는 컬러로 설정 가치, 나는 나의 모양 완전히 투명한 = (무슨
롬자

3
불투명도는 뷰 또는 이미지로만 설정할 수있는 것 같습니다. LinearLayout에서 android : background = "@ drawable / shape"대신 android : background = "# 88000000"을 작성하면 작동합니다. .
lomza 2011

2
모양에도 적용됩니다. 위에 게시 한 것을 시도해 보셨습니까?
Octavian A. Damiean 2011

1
예,하지만 작동하지 않습니다. 이 모든 코드를 컴퓨터에서 시도 했습니까?
lomza 2011

4

아래 코드를 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>

어디:

  • "progress"는 엄지 손가락 이전의 현재 진행률이고 "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"

1

이걸 사용하세요, 저는 이것을 제 앱에 썼습니다.

<?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>
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.