Layouts
Putting widgets in their place
Geometry Managers
data:image/s3,"s3://crabby-images/669d3/669d32baf8dcf405a076779cd1f87b2eb848144d" alt="Pack, Grid, and Place Layouts"
Grid Layouts
Grid layouts are used most frequently,
so we will focus on the Grid Manager
Simple Grid
Open up simplegrid.py
and add these two labels:
field_heading = tkinter.Label(window)
field_heading.config(text="Field Name", font="Verdana 10 bold")
field_heading.grid(row=0, column=0)
value_heading = tkinter.Label(window)
value_heading.config(text="Value", font="Verdana 10 bold")
value_heading.grid(row=0, column=1)
Your app should have two bold labels side by side
Complete Your Grid
data:image/s3,"s3://crabby-images/1d849/1d849488e757837cb912a41235b17963b844fe71" alt="Simple Grid Demo"
Add widgets so your app looks (sort of) like the example
Resizing
We can configure columns to resize at different rates:
data:image/s3,"s3://crabby-images/8e8cb/8e8cb209b574cbe3c4a46148c91f889108668d49" alt="Simple Grid Demo"
window.columnconfigure(0, weight=0)
window.columnconfigure(1, weight=1)
Your grid should grow to fit a resized window
Stickiness
Widgets are aligned within cells using compass points:
data:image/s3,"s3://crabby-images/ae9a0/ae9a0af5817d162c407b7d51f610c87f5bff9bfa" alt="Sticky Locations"
Sticky Label
Here’s how you would stretch an entry field:
firstname_entry = tkinter.Entry(window)
firstname_entry.grid(row=1, col=1, sticky="we")
Your “First Name” entry should resize with the window
Complex Grid
data:image/s3,"s3://crabby-images/8f2b4/8f2b49d01943348ac60f66659dc5eb2460dee793" alt="Complex Grid"
Open up membermanager.py
.
Now we will use the same concept to create
a more complex layout.
Divide into Cells
data:image/s3,"s3://crabby-images/1f9d5/1f9d5bd163ebdb6e1540e9a0cdb358e7ae1721e7" alt="Dividing Up a Complex Grid"
Divide your layout into cells by drawing lines
between neighbouring widgets.
Identify Content Cells
data:image/s3,"s3://crabby-images/5cf86/5cf86ace1998de508d66bd9805e1bafe48f4c7cd" alt="Identifying Content Cells"
Highlight every cell which contains
the top left corner of a widget.
Find Spanning Cells
data:image/s3,"s3://crabby-images/bc96c/bc96c5b0f6010156684e601196396edd73d80753" alt="Measuring Rowspan and Colspan"
Highlight row spans and column spans
for any widgets that need it.
Apply Settings
You can now use the information to arrange the widgets in the grid:
title_label = tkinter.Label(window)
title_label.config(text="Super Duper Member Manager")
title_label.grid(row=0, column=0, columnspan=4)
Apply the correct row, column and spans to all widgets
Challenge:
Happy Shopper
data:image/s3,"s3://crabby-images/02272/02272e881c03eced8b2c37039278f926e811d095" alt="Happy Shopper Challenge"
Create a new app called happyshopper.py
and reproduce this grid layout.
data:image/s3,"s3://crabby-images/e9962/e996295eabb5b48e6095b986f5eb6f28630910fa" alt="Thumbs Up!"
Layouts: Complete!
Cool, now we need to make it all actually work…
Take me to the next chapter!