Reputation: 8386
I've the following OptionMenu:
self.textoprioridad = Label(self.frameTwo, text = "Prioridad: ", justify="center")
self.textoprioridad.grid(row=n, column=4)
var2 = StringVar()
menu2 = OptionMenu(self.frameTwo, var2, "Primera pieza", "Esta semana", "Normal", "Baja")
menu2.grid(row=n, column=5, ipadx=10)
var2.set("Primera pieza")
self.optionmenus_prioridad.append((menu2, var2))
That shows something like this:
The thing is that if I choose Normal
from the list, the button resized and it makes smaller:
I would like to know if it's any way to keep the OptionMenu button with the initial size, like this:
Thanks in advance.
Upvotes: 6
Views: 5229
Reputation: 728
Specify a sticky
in the grid
method so that it knows how wide to needs to be:
button.grid(sticky="WE")
This method is better than specifying a set width
in the grid
method becuase it means that the widget will always span the length of the column.
sticky
is a key that shows where the widget will stick too. if you say sticky='W'
than the widget will stick to the left of the column. By making is EW
it will stick to the left and right, and therefore stretch it's self to the length of the column. NOTE: it's North South East West
Upvotes: 3
Reputation: 385970
One solution is to give the widget a specific size by specifying the width
attribute:
menu2.configure(width=20)
Another solution is to have the widgets "stick" to the sides of their container:
menu2.grid(row=n, column=5, ipadx=10, sticky="ew")
Using the second option, the widgets can still possibly resize, but they are constrained by the size of the column they are in. If one resizes they all resize, guaranteeing they will always be uniform in size.
Upvotes: 3
Reputation: 369074
Specify width by config(width=desired-width)
:
menu2.config(width=20)
Upvotes: 7