aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDavid Roundy <droundy@darcs.net>2007-10-15 18:55:04 +0200
committerDavid Roundy <droundy@darcs.net>2007-10-15 18:55:04 +0200
commit214d101f1f04ce0730a2f28a5d0ab1b68df989c5 (patch)
treee8dac02474bb3aa840ce5ca62cf85f3a03aa9106
parentdaa49542004ca5774f793ecb3f8a76b83156d055 (diff)
downloadXMonadContrib-214d101f1f04ce0730a2f28a5d0ab1b68df989c5.tar.gz
XMonadContrib-214d101f1f04ce0730a2f28a5d0ab1b68df989c5.tar.xz
XMonadContrib-214d101f1f04ce0730a2f28a5d0ab1b68df989c5.zip
compute a reasonable navigation color based on focussed color.
darcs-hash:20071015165504-72aca-ed7515ee2d90caa4a9fcfe64ab0c73de6d876166.gz
-rw-r--r--WindowNavigation.hs31
1 files changed, 22 insertions, 9 deletions
diff --git a/WindowNavigation.hs b/WindowNavigation.hs
index 915257f..707ef48 100644
--- a/WindowNavigation.hs
+++ b/WindowNavigation.hs
@@ -20,11 +20,11 @@ module XMonadContrib.WindowNavigation (
-- $usage
windowNavigation,
Navigate(..), Direction(..),
- navigateColor, noNavigateBorders
+ navigateColor, navigateBrightness,
+ noNavigateBorders, defaultWNConfig
) where
import Graphics.X11.Xlib ( Rectangle(..), Window, Pixel, setWindowBorder )
-import Control.Monad ( when )
import Control.Monad.Reader ( ask )
import Data.List ( nub, sortBy, (\\) )
import XMonad
@@ -67,7 +67,7 @@ data Direction = U | D | R | L deriving ( Read, Show, Eq )
instance Message Navigate
data WNConfig =
- WNC { showNavigable :: Bool
+ WNC { brightness :: Maybe Double -- Indicates a fraction of the focus color.
, upColor :: String
, downColor :: String
, leftColor :: String
@@ -76,14 +76,19 @@ data WNConfig =
noNavigateBorders :: WNConfig
noNavigateBorders =
- defaultWNConfig {showNavigable = False}
+ defaultWNConfig {brightness = Just 0}
navigateColor :: String -> WNConfig
navigateColor c =
- WNC True c c c c
+ WNC Nothing c c c c
+
+navigateBrightness :: Double -> WNConfig
+navigateBrightness f | f > 1 = navigateBrightness 1
+ | f < 0 = navigateBrightness 0
+navigateBrightness f = defaultWNConfig { brightness = Just f }
defaultWNConfig :: WNConfig
-defaultWNConfig = WNC True "#0000FF" "#00FFFF" "#FF0000" "#FF00FF"
+defaultWNConfig = WNC (Just 0.5) "#0000FF" "#00FFFF" "#FF0000" "#FF00FF"
data NavigationState a = NS Point [(a,Rectangle)]
@@ -94,8 +99,16 @@ windowNavigation conf = ModifiedLayout (WindowNavigation conf (I Nothing))
instance LayoutModifier WindowNavigation Window where
redoLayout (WindowNavigation conf (I state)) rscr s wrs =
- do XConf { normalBorder = nbc } <- ask
- [uc,dc,lc,rc] <- mapM stringToPixel [upColor conf, downColor conf, leftColor conf, rightColor conf]
+ do XConf { normalBorder = nbc, focusedBorder = fbc } <- ask
+ [uc,dc,lc,rc] <-
+ case brightness conf of
+ Just frac -> return $ map round [myc,myc,myc,myc]
+ -- Note: The following is a fragile crude hack... it really only
+ -- works properly when the only non-zero color is blue. We should
+ -- split the color into components and average *those*.
+ where myc = (1-frac)*(fromIntegral nbc) + frac*(fromIntegral fbc)
+ Nothing -> mapM stringToPixel [upColor conf, downColor conf,
+ leftColor conf, rightColor conf]
let dirc U = uc
dirc D = dc
dirc L = lc
@@ -114,7 +127,7 @@ instance LayoutModifier WindowNavigation Window where
wothers = case state of Just (NS _ wo) -> map fst wo
_ -> []
mapM_ (sc nbc) (wothers \\ map fst wnavigable)
- when (showNavigable conf) $ mapM_ (\(win,c) -> sc c win) wnavigablec
+ mapM_ (\(win,c) -> sc c win) wnavigablec
return (wrs, Just $ WindowNavigation conf $ I $ Just $ NS pt wnavigable)
handleMess (WindowNavigation conf (I (Just (NS pt wrs)))) m