WxHaskell/Button sizing problem

From HaskellWiki
< WxHaskell
Revision as of 19:08, 3 October 2009 by Andy (talk | contribs) (Some proofreading)
Jump to navigation Jump to search

Button Sizing

Note this is for the wxHaskell library.

Let me draw a background first:

gui = do f <- frame [ text := "Button"
                    , clientSize := sz 200 200 ]
         b <- button f [ text := "Button"
                       , clientSize := sz 50 50 ]

From the manual, if we want to set the size of a button, it said set the size of button at the time of creation. It looks alright. However, if we follow the previous code, when we resize the frame, then the button will resize to the default size. In the following, it will just give the same problem.

gui = do f <- frame [ text := "Button"
                    , clientSize := sz 200 200 ]
         b <- button f [ text := "Button" ]
         set b [ clientSize := sz 50 50 ]

Somebody would say I have not set the layout yet. You are right. But the problem would even worse if we set the button to the layout, you never see the button changed. When you run the program, you always see a default sized button. Since, when the you set the layout, the button will force to set back to the default size, example code 3

gui = do f <- frame [ text := "Button"
                    , clientSize := sz 200 200 ]
         b <- button f [ text := "Button"
                       , clientSize := sz 50 50 ]
         set f [ layout := widget b ]

In this example 3, it tells us the frame size will also be changed after we the layout to fit the internal content size. As what i said, it will only give out a default size button. You will say that set the button size after setting the layout. You are right again. It works at the beginning. We can see a button with our intened size. But when we resize the frame, then the program will follow the layout setting, and do the automatic re-adjustment of the frame content, then button will then be set back to the default. It will give the same effect if we are using container.

You might say "Then we can't have a button with the size we want by using wxHaskell". At the moment, there is a way to solve this problem using a panel to store a button. If we resize a frame, it will affect the size of panel, but not the button. Luckily, the size of button will remain the same. By following this, we can make the button any size we wish.

gui = do f <- frame [ text := "Button"
                    , clientSize := sz 200 200 ]
         p <- panel f []
         b <- button p [ text := "Button" ]
         set b [ clientSize := sz 50 50 ]

PS: Remember to set positions manually instead of by gridding (AKA, using layout controls), or else the same problem will happen again.

To create a button with prefered size, remember to use a panel to store (contain, or encpasulate) it.