Set title background color
Asked Answered
L

13

108

In my android application I want the standard/basic title bar to change color.

To change the text color you have setTitleColor(int color), is there a way to change the background color of the bar?

Lampion answered 12/2, 2010 at 12:21 Comment(2)
I think no need to use custom title to change background color to title bar. check this postMccreery
I would look at Edwinfad's answer instead of the outdated accepted one.Digit
H
190

This thread will get you started with building your own title bar in a xml file and using it in your activities

Edit

Here is a brief summary of the content of the link above - This is just to set the color of the text and the background of the title bar - no resizing, no buttons, just the simpliest sample

res/layout/mytitle.xml - This is the view that will represent the title bar

<?xml version="1.0" encoding="utf-8"?>
<TextView
  xmlns:android="http://schemas.android.com/apk/res/android"
  android:id="@+id/myTitle"
  android:text="This is my new title"
  android:layout_width="fill_parent"
  android:layout_height="fill_parent"
  android:textColor="@color/titletextcolor"
   />

res/values/themes.xml - We want to keep the default android theme and just need to change the background color of the title background. So we create a theme that inherits the default theme and set the background style to our own style.

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <style name="customTheme" parent="android:Theme"> 
        <item name="android:windowTitleBackgroundStyle">@style/WindowTitleBackground</item>   
    </style> 
</resources>

res/values/styles.xml - This is where we set the theme to use the color we want for the title background

<?xml version="1.0" encoding="utf-8"?>
<resources> 
   <style name="WindowTitleBackground">     
        <item name="android:background">@color/titlebackgroundcolor</item>                   
    </style>
</resources>

res/values/colors.xml - Set here the color you want

<?xml version="1.0" encoding="utf-8"?>
<resources>   
    <color name="titlebackgroundcolor">#3232CD</color>
    <color name="titletextcolor">#FFFF00</color>
</resources>

In the AndroidMANIFEST.xml, set the theme attribute either in the application (for the whole application) or in the activity (only this activity) tags

<activity android:name=".CustomTitleBar" android:theme="@style/customTheme" ...

From the Activity (called CustomTitleBar) :

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);

        requestWindowFeature(Window.FEATURE_CUSTOM_TITLE);
        setContentView(R.layout.main);
        getWindow().setFeatureInt(Window.FEATURE_CUSTOM_TITLE, R.layout.mytitle);

}
Herries answered 18/2, 2010 at 1:26 Comment(10)
Most of the time just providing a link is a very cheap, and on stackoverflow not really liked answer. Try to get some of the knowledge from the link onto this page. You will get more and more knowledge in the community, and even if the link is down you answer still provides some search terms that can direct other people in the direction.Uncomfortable
@Uncomfortable : You are totally right - So I updated the post with the simpliest sample so that people can get started with instead of reading through the thread in the above linkHerries
See my answer below for use with a superclass to apply it to all children . (for ex : Activity->YourRootSuperClass->AnyOfYourActivity) Updates given in my post below would go in the YourRootSuperClassYield
After overwriting the android styling you don't need to add the custom title from code if you just want to change the background colorUncomfortable
As Janusz said, you don't need to have a custom View if you only want to override the used style (not adding new Views). In that case you also don't need to request a FEATURE_CUSTOM_STYLE. Finally, you can define the style a the application level to apply it to all your activities at once. Thanks for the code, by the way.Anaconda
this is not changing the background color of the title only text color is getting changed. even if I am changing the color of title bar <color name="titlebackgroundcolor">#3232CD</color>. Am I doing something wrong?Coney
The background color does not fill the entire title area. There is still a small amount of the default blue around the edges.Greenlaw
As @pratikbutani mentioned in a different answer, I found this blog post to be the simplest, most effective way to do this.Built
What if for accessibility purposes (e.g. TalkBack) you wanted the HOME and TITLE to be a single button. What would one do?Hysterogenic
its not working here #31157722Astyanax
Y
18

Thanks for this clear explanation, however I would like to add a bit more to your answer by asking a linked question (don't really want to do a new post as this one is the basement on my question).

I'm declaring my titlebar in a Superclass from which, all my other activities are children, to have to change the color of the bar only once. I would like to also add an icon and change the text in the bar. I have done some testing, and managed to change either one or the other but not both at the same time (using setFeatureDrawable and setTitle). The ideal solution would be of course to follow the explanation in the thread given in the link, but as i'm declaring in a superclass, i have an issue due to the layout in setContentView and the R.id.myCustomBar, because if i remember well i can call setContentView only once...

EDIT Found my answer :

For those who, like me, like to work with superclasses because it's great for getting a menu available everywhere in an app, it works the same here.

Just add this to your superclass:

requestWindowFeature(Window.FEATURE_CUSTOM_TITLE);
    setContentView(R.layout.customtitlebar);
    getWindow().setFeatureInt(Window.FEATURE_CUSTOM_TITLE, R.layout.customtitlebar);
    customTitleText = (TextView) findViewById(R.id.customtitlebar);

(you have to declare the textview as protected class variable)

And then the power of this is that, everywhere in you app (if for instance all your activities are children of this class), you just have to call

customTitleText.setText("Whatever you want in title");

and your titlebar will be edited.

The XML associated in my case is (R.layout.customtitlebar) :

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="horizontal" android:layout_width="fill_parent"
android:layout_height="fill_parent" android:background="@color/background">
<ImageView android:layout_width="25px" android:layout_height="25px"
    android:src="@drawable/icontitlebar"></ImageView>
<TextView android:id="@+id/customtitlebar"
    android:layout_width="wrap_content" android:layout_height="fill_parent"
    android:text="" android:textColor="@color/textcolor" android:textStyle="bold"
    android:background="@color/background" android:padding="3px" />
</LinearLayout>
Yield answered 27/4, 2010 at 13:24 Comment(2)
@Yield do i have to make different class for title bar then only i can use it?Grosmark
its not working here #31157722Astyanax
M
11

There is another way to change the background color, however it is a hack and might fail on future versions of Android if the View hierarchy of the Window and its title is changed. However, the code won't crash, just miss setting the wanted color, in such a case.

In your Activity, like onCreate, do:

View titleView = getWindow().findViewById(android.R.id.title);
if (titleView != null) {
  ViewParent parent = titleView.getParent();
  if (parent != null && (parent instanceof View)) {
    View parentView = (View)parent;
    parentView.setBackgroundColor(Color.rgb(0x88, 0x33, 0x33));
  }
}
Maugham answered 2/12, 2010 at 19:26 Comment(2)
very good one and simple too. But I want to ask you one thing that this one is doing it from code so it is little delayed. In order to avoid such situation I will have to write every thing in the xml and nothing in the code. so can you please guide me in that?Coney
I think you have the solution in the selected answer above. You need to define a custom theme for the activity and set its android:windowTitleBackgroundStyle to the color you want.Maugham
P
10

This code helps to change the background of the title bar programmatically in Android. Change the color to any color you want.

public void onCreate(Bundle savedInstanceState) 
{
    super.onCreate(savedInstanceState);
    setContentView(R.layout.your_layout);
    getActionBar().setBackgroundDrawable(new ColorDrawable(Color.parseColor("#1c2833")));

}
Panaggio answered 21/11, 2016 at 20:10 Comment(4)
This was introduced in API 11 (3.0 Honeycomb) which is certainly outdated enough at this point to consider this a valid option.Digit
But I am still using it in all my recent applications with targetSdkVersion="23" without getting any deprecated info.Panaggio
Absolutely, it is 100% fine to use this. It has not been replaced with anything, but using it before API 11 (which very few people will be doing) should be avoided, at least without a compatibility library.Digit
Use getSupportActionBar() instead if you are using AppCompatActivitySaito
I
6
protected void onCreate(Bundle savedInstanceState) {        
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    View titleView = getWindow().findViewById(android.R.id.title);
    if (titleView != null) {
      ViewParent parent = titleView.getParent();
      if (parent != null && (parent instanceof View)) {
        View parentView = (View)parent;
        parentView.setBackgroundColor(Color.RED);
      }
    }

on above code you can try you can use title instead of titlebar this will affect on all activity in your application

Include answered 5/4, 2013 at 11:49 Comment(0)
R
2

I suppose no. You can create titleless activity and create your own title bar in activity layout.

Check this, Line 63 and below:

getWindow().setFeatureInt(Window.FEATURE_CUSTOM_TITLE, R.layout.custom_title_1)

sets customview instead of default title view.

Retinite answered 12/2, 2010 at 12:38 Comment(1)
How/where can I create a custom/own title bar?Lampion
C
2

Take a peek in platforms/android-2.1/data/res/layout/screen.xml of the SDK. It seems to define a title there. You can frequently examine layouts like this and borrow the style="?android:attr/windowTitleStyle" styles which you can then use and override in your own TextViews.

You may be able to even select the title for direct tweaking by doing:

TextView title = (TextView)findViewById(android.R.id.title);
Cabasset answered 17/2, 2010 at 23:5 Comment(1)
Good answers above but is it possible to just color the title bar without having to create a custom layout for it?Fibula
O
2

Try with the following code

View titleView = getWindow().findViewById(android.R.id.title);
    if (titleView != null) {
      ViewParent parent = titleView.getParent();
      if (parent != null && (parent instanceof View)) {
        View parentView = (View)parent;
        parentView.setBackgroundColor(Color.RED);
      }
    }

also use this link its very useful : http://nathanael.hevenet.com/android-dev-changing-the-title-bar-background/

Otero answered 5/4, 2013 at 11:12 Comment(1)
Does this still work with Lollipop? titleView seems to return null for me.Primp
D
2

There is an easier alternative to change the color of the title bar, by using the v7 appcompat support library provided by Google.

See this link on how to to setup this support library: https://developer.android.com/tools/support-library/setup.html

Once you have done that, it's sufficient to add the following lines to your res/values/styles.xml file:

<style name="AppTheme" parent="AppBaseTheme">
    <item name="android:actionBarStyle">@style/ActionBar</item>
</style>

<!-- Actionbar Theme -->
<style name="ActionBar" parent="Widget.AppCompat.Light.ActionBar.Solid.Inverse">
    <item name="android:background">@color/titlebackgroundcolor</item>
</style>

(assuming that "titlebackgroundcolor" is defined in your res/values/colors.xml, e.g.:

<color name="titlebackgroundcolor">#0000AA</color>

)

Dispermous answered 14/10, 2014 at 16:36 Comment(1)
When you target only Android 5, then there's an even simpler alternative, see [developer.android.com/training/material/….Dispermous
F
2

I have done this by changing style color values in "res" -> "values" -> "colors.xml" enter image description here

This will change colors for entire project which is fine with me.

enter image description here

Flirtatious answered 20/10, 2018 at 11:4 Comment(0)
L
1

Things seem to have gotten better/easier since Android 5.0 (API level 21).

I think what you're looking for is something like this:

<style name="AppTheme" parent="AppBaseTheme">
    <!-- Top-top notification/status bar color: -->
    <!--<item name="colorPrimaryDark">#000000</item>-->
    <!-- App bar color: -->
    <item name="colorPrimary">#0000FF</item>
</style>

See here for reference:

https://developer.android.com/training/material/theme.html#ColorPalette

Liken answered 7/12, 2017 at 5:31 Comment(0)
N
1

Paste this code after setContentView or into onCreate

if you have a color code use this ;

getSupportActionBar().setBackgroundDrawable(new ColorDrawable(Color.parseColor("#408ed4")));

if you want a specific code from Color library use this ;

getSupportActionBar().setBackgroundDrawable(new ColorDrawable(Color.WHITE));
Nguyen answered 5/6, 2020 at 23:39 Comment(0)
S
0

you can use it.

  toolbar.setTitleTextColor(getResources().getColor(R.color.white));
Shermy answered 6/3, 2019 at 9:12 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.