Reputation: 1225
I'd like to have an app with black buttons and labels, and with white text, and thus, would like to have white space separating these widgets. I suppose that in order to do so, it would be necessary to convert the background from the default color, which is black, to white. What is the best way of accomplishing this? Thank you!
Upvotes: 30
Views: 85722
Reputation: 164
Every Layout has a canvas, which can be used as canvas.before or canvas.after and then you get the desired output. If you have some sort of Layout, like a BoxLayout, then you can use canvas.before with the Color instruction like this.
Here I am showing a more complex example with an image, that I am trying in a Food App.
<MainUI>:
BoxLayout:
orientation:"vertical"
padding:10
spacing:10
canvas.before:
Color:
rgba:1,1,1,0.4
Rectangle:
pos:self.pos
size:self.size
source:"images/bg1.png"
this works with anything, and it looks like this.
Now if you just make the transparency to 100% or 1 in the Color > rgba instruction, and simply remove the image instruction.
<MainUI>:
BoxLayout:
orientation:"vertical"
padding:10
spacing:10
canvas.before:
Color:
rgba:1,1,1,1
Rectangle:
pos:self.pos
size:self.size
and it turns the full background white.
Upvotes: 0
Reputation: 56
I have created a module for this purpose. Please check: Details on Github
#Change background color of a kivy layout
#Place the CustomGraphics.py file to a folder
#code starts here
import sys
sys.path.append([path to CustomGraphics.py])
from CustomModules import CustomGraphics
from kivy.app import App
from kivy.uix.boxlayout import BoxLayout
from kivy.uix.label import Label
class TestApp(App):
def build(self):
layout = BoxLayout(orientation='vertical', size=(Window.width, Window.height))
label = Label(text="Remember my name: It's Smruti Ranjan Gochhayat")
layout.add_widget(label)
CustomGraphics.SetBG(layout, bg_color=[1,0,0,1])
return layout
if __name__ == '__main__':
TestApp().run()
#code ends here
I wish it is helpful for some people
Upvotes: 1
Reputation: 29450
A simple way is to simply draw a big white rectangle behind your root widget. For instance, in kivy language you could do
<YourRootWidget>:
canvas.before:
Color:
rgba: 1, 1, 1, 1
Rectangle:
pos: self.pos
size: self.size
I think you can also actually directly set the colour that kivy clears the window background with, which is exposed as Window.clearcolor
. You would do this with
from kivy.core.window import Window
Window.clearcolor = (1, 1, 1, 1)
You would probably need to put this before anything else in your app, as it won't affect anything if run after the window has been created.
Upvotes: 80