设置Android布局元素的背景颜色

我试图,有点克隆的设计活动来自一组关于Android UI设计的幻灯片。然而,我有一个非常简单的任务的问题。

我已经创建了如图所示的布局,头部是RelativeLayout中的TextView。现在我想改变RelativeLayout的背景颜色,但是我似乎不知道该怎么做。

我知道我可以在XML文件中的RelativeLayout标记中设置android:background属性,但是我应该将它设置为什么呢?我想定义一个新的颜色,我可以在多个地方使用。它是drawable还是string?

此外,我希望有一个非常简单的方法来从Eclipse Android UI设计器,我必须错过?

我现在有点沮丧,因为这应该是一个最多只需点击几下就能执行的活动。所以任何帮助都是非常感激的。:)

Android活动设计

700342 次浏览

你可以为你的颜色使用android:background="#DC143C"或任何其他RGB值。我以这种方式使用它没有问题,如在这里所述

你可以使用简单的色彩资源,通常在res/values/colors.xml中指定。

<color name="red">#ffff0000</color>

并通过android:background="@color/red"来使用它。这种颜色也可以用于其他任何地方,例如作为文本颜色。以同样的方式在XML中引用它,或者通过getResources().getColor(R.color.red)在代码中获取它。

你也可以使用任何可拉的资源作为背景,使用android:background="@drawable/mydrawable"(这意味着9patch绘制,普通位图,形状绘制,..)。

上面的答案很不错。如果你愿意,你也可以像这样编程

首先,你的布局应该有一个ID。通过在res/layout/*.xml中写入+id行来添加

<RelativeLayout ...
...
android:id="@+id/your_layout_id"
...
</RelativeLayout>

然后,在Java代码中进行以下更改。

RelativeLayout rl = (RelativeLayout)findViewById(R.id.your_layout_id);
rl.setBackgroundColor(Color.RED);

除此之外,如果你在colors.xml中定义了颜色,那么你也可以通过编程来做:

rl.setBackgroundColor(ContextCompat.getColor(getContext(), R.color.red));

res/values/colors.xml.


<color name="red">#ffff0000</color>
android:background="@color/red"

例子对我没用,但是

android:background="#(hexidecimal here without these parenthesis)"

为我工作在相对布局元素作为一个属性。

如果你想快速改变颜色(并且你没有记住十六进制数字),android有一些预设的颜色,你可以这样访问:

android:background="@android:color/black"

有15种颜色供你选择,非常适合快速测试,而且你不需要设置额外的文件。

设置values/colors.xml文件并像上面解释的那样直接使用十六进制仍然可以工作。

Android studio 2.1.2(或更早)将允许你从色轮中选择:

Color Wheel in Android Studio

我通过在我的布局中添加以下内容来获得这一点:

android:background="#FFFFFF"

然后我点击FFFFFF颜色,点击出现的灯泡。

以上的答案都是静态的。我想我可以给出一个有力的答案。需要同步的两个文件是相对于布局的foo.xml和对应于这个R.layout.foo的Java类的activity_bar.java

foo.xml中为整个布局设置一个id:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout android:id="@+id/foo" .../>

并在activity_bar.java中设置onCreate()中的颜色:

public class activity_bar extends AppCompatActivty {


@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.foo);


//Set an id to the layout
RelativeLayout currentLayout =
(RelativeLayout) findViewById(R.id.foo);


currentLayout.setBackgroundColor(Color.RED);
...
}
...
}

我希望这能有所帮助。

芬兰湾的科特林

linearLayout.setBackgroundColor(Color.rgb(0xf4,0x43,0x36))

<color name="newColor">#f44336</color>

-

linearLayout.setBackgroundColor(ContextCompat.getColor(vista.context, R.color.newColor))

4种可能的方法,用你需要的。

1. 芬兰湾的科特林

val ll = findViewById<LinearLayout>(R.id.your_layout_id)
ll.setBackgroundColor(ContextCompat.getColor(this, R.color.white))

2. 数据绑定

<LinearLayout
android:background="@{@color/white}"

更有用的语句-

<LinearLayout
android:background="@{model.colorResId}"

3.XML

<LinearLayout
android:background="#FFFFFF"


<LinearLayout
android:background="@color/white"

4. Java

LinearLayout ll = (LinearLayout) findViewById(R.id.your_layout_id);
ll.setBackgroundColor(ContextCompat.getColor(this, R.color.white));