diff options
author | Norbert Zeh <nzeh@cs.dal.ca> | 2009-03-11 02:36:17 +0100 |
---|---|---|
committer | Norbert Zeh <nzeh@cs.dal.ca> | 2009-03-11 02:36:17 +0100 |
commit | 4555e6e2f7f08941270c77b8e37b1af7a083c772 (patch) | |
tree | 9e8306ea23362efd3b266720a218689da1518dac /XMonad/Layout | |
parent | 19f3604c0b6cf621ce96201a2290d6e5f200f55a (diff) | |
download | XMonadContrib-4555e6e2f7f08941270c77b8e37b1af7a083c772.tar.gz XMonadContrib-4555e6e2f7f08941270c77b8e37b1af7a083c772.tar.xz XMonadContrib-4555e6e2f7f08941270c77b8e37b1af7a083c772.zip |
More predictable aspect ratio in GridVariants.Grid
The old version fairly arbitrarily decided to prefer windows that are too
high over those that are too wide. The new version chooses the number of
columns so that all windows on the screen are as close as possible to the
desired aspect ratio. As a side effect, the layout changes much more
predictably under addition and removal of clients.
darcs-hash:20090311013617-18a2b-487e30d300b83871e572c4a535b4474b120accca.gz
Diffstat (limited to 'XMonad/Layout')
-rw-r--r-- | XMonad/Layout/GridVariants.hs | 14 |
1 files changed, 12 insertions, 2 deletions
diff --git a/XMonad/Layout/GridVariants.hs b/XMonad/Layout/GridVariants.hs index 15fed70..2d47a5a 100644 --- a/XMonad/Layout/GridVariants.hs +++ b/XMonad/Layout/GridVariants.hs @@ -135,8 +135,18 @@ arrangeAspectGrid :: Rectangle -> Int -> Rational -> [Rectangle] arrangeAspectGrid rect@(Rectangle _ _ rw rh) nwins aspect = arrangeGrid rect nwins (min nwins ncols) where - ncols = ceiling $ sqrt $ ( fromRational - ( (fromIntegral rw * fromIntegral nwins) / (fromIntegral rh * aspect) ) :: Double) + scr_a = fromIntegral rw / fromIntegral rh + fcols = sqrt ( fromRational $ scr_a * fromIntegral nwins / aspect ) :: Double + cols1 = floor fcols :: Int + cols2 = ceiling fcols :: Int + rows1 = ceiling ( fromIntegral nwins / fromIntegral cols1 :: Rational ) :: Int + rows2 = floor ( fromIntegral nwins / fromIntegral cols2 :: Rational ) :: Int + a1 = scr_a * fromIntegral rows1 / fromIntegral cols1 + a2 = scr_a * fromIntegral rows2 / fromIntegral cols2 + ncols | cols1 == 0 = cols2 + | rows2 == 0 = cols1 + | a1 / aspect < aspect / a2 = cols1 + | otherwise = cols2 arrangeGrid :: Rectangle -> Int -> Int -> [Rectangle] arrangeGrid (Rectangle rx ry rw rh) nwins ncols = |