How to change ttk.progressBar color in python
Does anyone know how I can change the color of my ttk.progressBar? It now shows a green color, and I would love to have it blue.
import ttk
self.progressBar = ttk.Progressbar(frame3, length=560, maximum=100, mode='determinate');
self.progressBar.place(x=-5, y=60)
Solution 1:
You can change the color of a progressbar, but it is tricky. First, you need to understand that if you use the default theme, which is the default theme if you do not specify a theme in the tk.style
. Then it will pass all the information it needs to the operating system, which will do the drawing using its style, disregarding style info you passed it. meaning it will draw a Window's style green progressbar on Windows and so on and so forth. What you need to do is change the theme to a custom one that ttk draws. Try the "clam"
style, it is one of the best looking styles that ttk allows you to chose from. here is a working adapted excerpt from a script I wrote:
import Tkinter as tk
import ttk as ttk
root = tk.Tk()
frame = tk.Frame(root)
frame.grid()
s = ttk.Style()
s.theme_use('clam')
s.configure("red.Horizontal.TProgressbar", foreground='red', background='red')
ttk.Progressbar(frame, style="red.Horizontal.TProgressbar", orient="horizontal",
length=600, mode="determinate", maximum=4, value=1).grid(row=1, column=1)
frame.pack()
and here is a picture confirming it works.
Solution 2:
You need to use a style to set the progress bar color. The progress bar style elements are:
Element | Defines |
---|---|
troughcolor |
background of full widget |
background |
background of progress bar |
darkcolor |
bottom & right progress bar innermost border |
lightcolor |
top & left bar progress bar innermost border |
bordercolor |
outline border of the progress bar (outside the above border) and the whole widget |
If you want the borders to be the same color as the progress bar, you can use this code:
TROUGH_COLOR = 'blue'
BAR_COLOR = 'green'
style.configure("bar.Horizontal.TProgressbar", troughcolor=TROUGH_COLOR,
bordercolor=TROUGH_COLOR, background=BAR_COLOR, lightcolor=BAR_COLOR,
darkcolor=BAR_COLOR)
Solution 3:
I find out that for me it wont work, I don't want to say this is wrong however I have found use [ troughcolor ] to change background and [ background ] for indicator bar
not working for me
s.configure("red.Horizontal.TProgressbar", foreground='red', background='red')
my working way
s.configure("red.Horizontal.TProgressbar", troughcolor ='gray', background='red')