为什么我的“透明”叠加层视图不透明?

时间:2012-10-03 12:34:07

标签: java android xml overlay transparency

我有一个简单布局的活动(一堆彩色面板),我试图在顶部的透明视图上叠加一个小的移动图形。就像@umar here我正在关注this tutorial,但我的叠加视图拒绝透明。我可以让视图出现,它包含它应该是什么,但视图的背景是黑色的,但我试图让它透明失败。我已经尝试了一些在SO上提到的解决方案,它总是出现相同的。

我的布局:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/everything"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical"
android:background="#00ffffff"
>

<LinearLayout
    android:id="@+id/row_1_bg"
    android:layout_width="fill_parent"
    android:layout_height="0dip"
    android:layout_weight="1"
    android:orientation="horizontal"
    >

    <FrameLayout
        android:layout_height="fill_parent"
        android:layout_width="100dp"
        >

        <LinearLayout
            android:id="@+id/row_1_table"
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:orientation="vertical"
            android:background="#808080"
            >

            <LinearLayout
                android:layout_width="fill_parent"
                android:layout_height="0dip"
                android:layout_weight="1"
                android:orientation="horizontal"
                >

            <TextView  
                android:id="@+id/row_1_pantone"
                android:paddingLeft="6dip"
                android:textColor="#f0f0f0"
                android:textStyle="bold"
                android:gravity="center_vertical"
                android:layout_width="fill_parent"
                android:layout_height="fill_parent"
                >
            </TextView>
        </LinearLayout>

        <LinearLayout
            android:layout_width="fill_parent"
            android:layout_height="0dip"
            android:layout_weight="1"
            android:orientation="horizontal"
            >
            <TextView  
                android:id="@+id/row_1_rgb"
                android:paddingLeft="6dip"
                android:textColor="#f0f0f0"
                android:textStyle="bold"
                android:gravity="center_vertical"
                android:layout_width="fill_parent"
                android:layout_height="fill_parent"
                >
            </TextView>
        </LinearLayout>
        <LinearLayout
            android:layout_width="fill_parent"
            android:layout_height="0dip"
            android:layout_weight="1"
            android:orientation="horizontal"
            >
            <TextView  
                android:id="@+id/row_1_hex"
                android:paddingLeft="6dip"
                android:textColor="#f0f0f0"
                android:textStyle="bold"
                android:gravity="center_vertical"
                android:layout_width="fill_parent"
                android:layout_height="fill_parent"
                >
            </TextView>
        </LinearLayout>
    </LinearLayout>
</FrameLayout>
</LinearLayout>

<LinearLayout 
android:layout_height="fill_parent" 
android:layout_width="fill_parent" 
xmlns:android="http://schemas.android.com/apk/res/android" 
android:paddingRight="5px" 
android:paddingTop="5px" 
android:paddingLeft="5px" 
android:gravity="bottom" 
android:orientation="vertical"
android:background="#00808080"> 

<barry.pantone.TransparentPanel 
        android:layout_height="wrap_content" 
        android:layout_width="fill_parent" 
        android:id="@+id/transparent_panel" 
        android:paddingRight="5px" 
        android:paddingTop="5px" 
        android:paddingLeft="5px" 
        android:paddingBottom="5px"
        android:background="#00808080"> 

        <Button 
            android:layout_height="wrap_content" 
            android:layout_width="wrap_content" 
            android:id="@+id/button_click_me" 
            android:text="Click Me!"
            /> 
</barry.pantone.TransparentPanel> 
</LinearLayout>

</LinearLayout>

My TransparentPanel.java直接来自教程,使用:

innerPaint.setARGB(225, 75, 75, 75);

制作透明面板,这是我在主要活动中的onCreate:

public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);

    Resources res = getResources();
    sPantone = res.getStringArray(R.array.pantone); // gets colour definitions

    iHeight = getWindowManager().getDefaultDisplay().getHeight();

    PopulateTable (); // draws colours in the various layout elements
    }

问题在于,无论我在视图中做什么都没关系 - 我可以在该视图中的其他元素上绘制一个半透明面板,但叠加视图本身有一个黑色背景,模糊了布局下面。如果有人能帮助我理解为什么透明度不起作用,我将永远感激。

非常感谢

巴兹

修改

根据另一个想法,我尝试将叠加层的定义移到自己的XML文件中,并使用LayoutInflater来扩充和添加新视图。不。完全相同 - 附加视图具有扎实的背景。这是tranny.xml布局:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 
android:background="#80000040"
android:layout_height="fill_parent" 
android:layout_width="fill_parent" 
xmlns:android="http://schemas.android.com/apk/res/android" 
android:paddingRight="5dip" 
android:paddingTop="5dip" 
android:paddingLeft="5dip" 
android:gravity="bottom" 
android:orientation="vertical"
> 
<Button 
    android:layout_height="wrap_content" 
    android:layout_width="wrap_content" 
    android:id="@+id/button_click_me" 
    android:text="Click Me!"
    /> 
</LinearLayout>

这是来自onCreate的代码,用于扩充新视图并将其添加到主布局中:

private View view;
ViewGroup parent = (ViewGroup) findViewById(R.id.everything);
view = LayoutInflater.from(getBaseContext()).inflate(R.layout.tranny, parent, false);
parent.addView(view);

基本上我已经开始使用不同的技术创建完全相同的结果。方便第一次了解LayoutInflater,但没有帮助重新透明:(

1 个答案:

答案 0 :(得分:0)

好的,没有答案,所以我假设无法使用parent.addView(view)添加具有透明背景的重叠视图。我曾希望在我的布局右侧边缘(滚动条)上添加一个狭窄的透明视图,我可以在其中绘制一个位图,指示显示项目的大列表中的位置。

相反,我现在让我的整个布局略微变窄,并为右边缘的一个狭窄的LinearLayout留下了空间,它有一个黑色的背景,而进入 我画了我的位图,所以我明白了:

enter image description here

我更倾向于将指针放在颜色块的顶部,但除非将来某位大师发现这个问题并向我们展示如何做到这一点,我已经足够接近了。

巴兹。