所以在一个Activity中,我有一个SurfaceView,我用它作为绘图画布,有两个布局来提供UI功能。我稍后会使用一个LinearLayout保持按钮和一个RelativeLayout(它从一开始就是GONE,之后称为VISIBLE)。
现在按钮行在屏幕上显示不正确。按钮全部被褪色,好像它们被困在画布后面。我尝试用以下方法设置alpha:
button.getBackground().setAlpha(255);
我尝试将SurfaceView透明化为how to make surfaceview transparent,但这些都没有效果。
有趣的是,如果我将按钮的背景设置为#ff000000(可以在下面的一些按钮中看到,已经测试了一些想法),那么它在画布上看起来完全是黑色的,尽管它现在已经丢失了它的按钮形状不是我想要的!
这是布局:
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/TopLevelView"
android:layout_width="fill_parent"
android:layout_height="fill_parent">
<!-- Drawing Surface -->
<stu.test.project.DrawingSurface
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:id="@+id/drawingSurface"/>
<!-- Button Row -->
<LinearLayout
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:gravity="center"
android:id="@+id/ButtonRow">
<!-- START BUTTON -->
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Start"
android:visibility="gone"
android:id="@+id/startDrawingButtonId"/>
<!-- FINISH BUTTON -->
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Finish"
android:visibility="gone"
android:id="@+id/finishButtonId"/>
<!-- RESET BUTTON -->
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="#ff000000"
android:text="Restart"
android:visibility="gone"
android:id="@+id/resetButtonId"/>
<!-- HOME BUTTON -->
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Home"
android:background="#ff000000"
android:visibility="gone"
android:id="@+id/homeButtonId"/>
<!-- RESTART BUTTON -->
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Restart"
android:background="#ff000000"
android:visibility="gone"
android:id="@+id/restartButtonId"/>
<!-- SAVE BUTTON -->
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Save"
android:background="#ff000000"
android:visibility="gone"
android:id="@+id/saveButtonId"/>
<!-- STATS BUTTON -->
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Stats"
android:visibility="gone"
android:id="@+id/statsButtonId"/>
<!-- EMAIL BUTTON -->
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Send email"
android:visibility="gone"
android:background="#ff000000"
android:id="@+id/emailButtonId"/>
<!-- LOAD BUTTON -->
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Load another record"
android:visibility="gone"
android:background="#ff000000"
android:id="@+id/loadButtonId"/>
<!-- MARKS BUTTON -->
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Add marks"
android:visibility="gone"
android:id="@+id/marksButtonId"/>
</LinearLayout>
<!-- Here is the Marking Scheme Layout -->
<RelativeLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:visibility="gone"
android:background="@drawable/marks_background"
android:id="@+id/marksRelativeLayout">
<!-- Element Title -->
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:id="@+id/markTitle"
android:padding="10dp"/>
<!-- Instructions -->
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Enter the score"
android:id="@+id/markDescription"
android:padding="10dp"
android:layout_centerHorizontal="true"
android:layout_below="@id/markTitle"/>
<!-- Previous Button -->
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Previous"
android:id="@+id/previousMarkButton"
android:layout_below="@id/markDescription"
android:layout_alignParentLeft="true"
android:layout_marginLeft="10dp"/>
<!-- Marking Scheme -->
<RadioGroup
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:padding="10dp"
android:layout_below="@id/markDescription"
android:layout_toRightOf="@id/previousMarkButton"
android:id="@+id/marksRadioGroup">
<RadioButton
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="0"
android:id="@+id/radioButton0"/>
<RadioButton
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="1"
android:id="@+id/radioButton1"/>
<RadioButton
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="2"
android:id="@+id/radioButton2"/>
</RadioGroup>
<!-- Next Button -->
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Next"
android:id="@+id/nextMarkButton"
android:layout_below="@id/markDescription"
android:layout_marginRight="10dp"
android:layout_toRightOf="@id/marksRadioGroup"/>
<!-- Done Button -->
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Done"
android:id="@+id/doneMarkButton"
android:layout_centerHorizontal="true"
android:layout_marginBottom="10dp"
android:layout_below="@id/marksRadioGroup"/>
</RelativeLayout>
</FrameLayout>
这是一张图片:
答案 0 :(得分:1)
如果您希望布局顶部的“按钮行”,只需在LinearLayout上添加:
android:layout_gravity="bottom"
默认情况下,添加到FrameLayout堆栈的视图。
看到你的布局我也注意到所有按钮都具有GONE的可见性。如果行位于surfaceView的顶部,则为了向Button行LinearLayout添加背景。
答案 1 :(得分:1)
您的问题与Android 3.0+上的Holo主题中使用的默认图像有关;看看at this link,这是该主题中用于默认按钮的实际9补丁。注意PNG本身是如何部分透明的?这意味着无论你在它下面放什么颜色,它都会部分显示它的背景。它被设计用于该主题中存在的黑暗背景的顶部。
Holo主题中的所有按钮都是部分透明的,即使是Holo.Light中的按钮,因此您可以使用任何默认按钮背景获得此效果。由于透明度在背景图像中,因此设置Drawable
的alpha不会产生任何影响。正如您已经发现的那样,您可以将按钮背景设置为实体,这不再是问题。
如果你想要一个仍然保持Holo外观的实心按钮,我建议从我给出的链接源中提取PNG图像,并修改9个补丁以获得完全纯色底色。
HTH
答案 2 :(得分:0)
SurfaceView.setZOrderOnTop(false);希望这可以帮到你