aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--XMonad/Layout/Magnifier.hs82
1 files changed, 56 insertions, 26 deletions
diff --git a/XMonad/Layout/Magnifier.hs b/XMonad/Layout/Magnifier.hs
index 633bd65..f25fd9b 100644
--- a/XMonad/Layout/Magnifier.hs
+++ b/XMonad/Layout/Magnifier.hs
@@ -2,11 +2,10 @@
-----------------------------------------------------------------------------
-- |
-- Module : XMonad.Layout.Magnifier
--- Copyright : (c) Peter De Wachter 2007
+-- Copyright : (c) Peter De Wachter and Andrea Rossato 2007
-- License : BSD-style (see xmonad/LICENSE)
--
--- Maintainer : Peter De Wachter <pdewacht@gmail.com>,
--- andrea.rossato@unibz.it
+-- Maintainer : andrea.rossato@unibz.it
-- Stability : unstable
-- Portability : unportable
--
@@ -18,11 +17,13 @@
-----------------------------------------------------------------------------
-module XMonad.Layout.Magnifier (
- -- * Usage
- -- $usage
- magnifier,
- magnifier') where
+module XMonad.Layout.Magnifier
+ ( -- * Usage
+ -- $usage
+ magnifier,
+ magnifier',
+ MagnifyMsg (..)
+ ) where
import Graphics.X11.Xlib (Window, Rectangle(..))
import XMonad
@@ -43,24 +44,54 @@ import XMonad.Layout.LayoutModifier
-- For more detailed instructions on editing the layoutHook see:
--
-- "XMonad.Doc.Extending#Editing_the_layout_hook"
+--
+-- Magnifier supports some commands. To used them add something like
+-- that to your key bindings:
+--
+-- > , ((modMask x .|. controlMask , xK_plus ), sendMessage MagnifyMore)
+-- > , ((modMask x .|. controlMask , xK_minus), sendMessage MagnifyLess)
+-- > , ((modMask x .|. controlMask , xK_o ), sendMessage ToggleOff )
+-- > , ((modMask x .|. controlMask .|. shiftMask, xK_o ), sendMessage ToggleOn )
+--
+-- For detailed instruction on editing the key binding see
+-- "XMonad.Doc.Extending#Editing_key_bindings".
--- | Increase the size of the window that has focus, unless it is the
--- master window.
+-- | Increase the size of the window that has focus
magnifier :: l a -> ModifiedLayout Magnifier l a
-magnifier = ModifiedLayout (M True)
+magnifier = ModifiedLayout (Mag 1.5 On All)
--- | Increase the size of the window that has focus, even if it is the
+-- | Increase the size of the window that has focus, unless if it is the
-- master window.
magnifier' :: l a -> ModifiedLayout Magnifier l a
-magnifier' = ModifiedLayout (M False)
+magnifier' = ModifiedLayout (Mag 1.5 On NoMaster)
+
+data MagnifyMsg = MagnifyMore | MagnifyLess | ToggleOn | ToggleOff deriving ( Typeable )
+instance Message MagnifyMsg
-data Magnifier a = M Bool deriving (Read, Show)
+data Magnifier a = Mag Zoom Toggle MagnifyMaster deriving (Read, Show)
+
+type Zoom = Double
+
+data Toggle = On | Off deriving (Read, Show)
+data MagnifyMaster = All | NoMaster deriving (Read, Show)
instance LayoutModifier Magnifier Window where
- modifierDescription (M b) = (if b then "" else "All") ++ "Magnifier"
- redoLayout (M b) = if b
- then unlessMaster applyMagnifier
- else applyMagnifier
+ redoLayout (Mag z On All ) = applyMagnifier z
+ redoLayout (Mag z On NoMaster) = unlessMaster $ applyMagnifier z
+ redoLayout _ = nothing
+ where nothing _ _ wrs = return (wrs, Nothing)
+
+ handleMess (Mag z On t) m
+ | Just MagnifyMore <- fromMessage m = return . Just $ (Mag (z + 0.1) On t)
+ | Just MagnifyLess <- fromMessage m = return . Just $ (Mag (z - 0.1) On t)
+ | Just ToggleOff <- fromMessage m = return . Just $ (Mag (z + 0.1) Off t)
+ handleMess (Mag z Off t) m
+ | Just ToggleOn <- fromMessage m = return . Just $ (Mag z On t)
+ handleMess _ _ = return Nothing
+
+ modifierDescription (Mag _ On All ) = "Magnifier"
+ modifierDescription (Mag _ On NoMaster) = "Magnifier NoMaster"
+ modifierDescription (Mag _ Off _ ) = "Magnifier (off)"
type NewLayout a = Rectangle -> Stack a -> [(Window, Rectangle)] -> X ([(Window, Rectangle)], Maybe (Magnifier a))
@@ -68,19 +99,18 @@ unlessMaster :: NewLayout a -> NewLayout a
unlessMaster mainmod r s wrs = if null (up s) then return (wrs, Nothing)
else mainmod r s wrs
-applyMagnifier :: Rectangle -> t -> [(Window, Rectangle)] -> X ([(Window, Rectangle)], Maybe a)
-applyMagnifier r _ wrs = do focused <- withWindowSet (return . peek)
- let mag (w,wr) ws | focused == Just w = ws ++ [(w, shrink r $ magnify wr)]
- | otherwise = (w,wr) : ws
- return (reverse $ foldr mag [] wrs, Nothing)
+applyMagnifier :: Double -> Rectangle -> t -> [(Window, Rectangle)] -> X ([(Window, Rectangle)], Maybe a)
+applyMagnifier z r _ wrs = do focused <- withWindowSet (return . peek)
+ let mag (w,wr) ws | focused == Just w = ws ++ [(w, shrink r $ magnify z wr)]
+ | otherwise = (w,wr) : ws
+ return (reverse $ foldr mag [] wrs, Nothing)
-magnify :: Rectangle -> Rectangle
-magnify (Rectangle x y w h) = Rectangle x' y' w' h'
+magnify :: Double -> Rectangle -> Rectangle
+magnify zoom (Rectangle x y w h) = Rectangle x' y' w' h'
where x' = x - fromIntegral (w' - w) `div` 2
y' = y - fromIntegral (h' - h) `div` 2
w' = round $ fromIntegral w * zoom
h' = round $ fromIntegral h * zoom
- zoom = 1.5 :: Double
shrink :: Rectangle -> Rectangle -> Rectangle
shrink (Rectangle sx sy sw sh) (Rectangle x y w h) = Rectangle x' y' w' h'