Add icon_transformation option (take this from Blind playbook)

It can use Blind common.drawing tools to implement some magic.

I may merge this into Radical and kill Blind as everything else
is pretty much deprecated at this point. Blind was never more
than a hack.
This commit is contained in:
Emmanuel Lepage Vallee 2014-02-19 22:09:19 -05:00
parent 1dea6095b0
commit 7046b40f83
7 changed files with 97 additions and 63 deletions

135
README.md
View File

@ -142,50 +142,51 @@ Multiple items can have multiple sets of options.
### Menu options ### Menu options
| Name | Description | Type | | Name | Description | Type |
| --------------- | -------------------------------------------------- | ----------------------------- | | ------------------- | -------------------------------------------------- | ----------------------------- |
| bg | Background color | String/gradient/pattern | | bg | Background color | String/gradient/pattern |
| fg | Foreground (text) color | String/gradient/pattern | | fg | Foreground (text) color | String/gradient/pattern |
| bg_focus | Background of focussed items | String/gradient/pattern | | bg_focus | Background of focussed items | String/gradient/pattern |
| fg_focus | Foreground of focussed items | String/gradient/pattern | | fg_focus | Foreground of focussed items | String/gradient/pattern |
| bg_hover | Background of hoverred items | String/gradient/pattern | | bg_hover | Background of hoverred items | String/gradient/pattern |
| fg_hover | Foreground of hoverred items | String/gradient/pattern | | fg_hover | Foreground of hoverred items | String/gradient/pattern |
| bg_alternate | Alternate background color | String/gradient/pattern | | bg_alternate | Alternate background color | String/gradient/pattern |
| bg_highlight | Highlight background color | String/gradient/pattern | | bg_highlight | Highlight background color | String/gradient/pattern |
| bg_header | Header (see widgets section) color | String/gradient/pattern | | bg_header | Header (see widgets section) color | String/gradient/pattern |
| bg_prefix | Prefix background for item_styles that support it | String/gradient/pattern | | bg_prefix | Prefix background for item_styles that support it | String/gradient/pattern |
| border_color | Border color | String/gradient/pattern | | border_color | Border color | String/gradient/pattern |
| border_width | Border width | number | | border_width | Border width | number |
| item_height | Default height of items | number | | item_height | Default height of items | number |
| item_width | Default width of items | number | | item_width | Default width of items | number |
| width | Original width | number | | width | Original width | number |
| default_width | Default menu width | number | | default_width | Default menu width | number |
| icon_size | Icon size | number | | icon_size | Icon size | number |
| auto_resize | Resize menu if items are too large | boolean | | auto_resize | Resize menu if items are too large | boolean |
| parent_geometry | Set the menu parent | geometry array | | parent_geometry | Set the menu parent | geometry array |
| arrow_type | Set the arrow type when use arrow style | see "arrow_type" enum | | arrow_type | Set the arrow type when use arrow style | see "arrow_type" enum |
| visible | Show or hide the menu | boolean | | visible | Show or hide the menu | boolean |
| direction | The direction from which the arrow will point | "left","right","top","bottom" | | direction | The direction from which the arrow will point | "left","right","top","bottom" |
| row | Number of row (in grid layout) | number | | row | Number of row (in grid layout) | number |
| column | Number of columns (in grid layout) | number | | column | Number of columns (in grid layout) | number |
| layout | The menu layout (default:vertical) | see "Menu layouts" section | | layout | The menu layout (default:vertical) | see "Menu layouts" section |
| style | The menu style (default:arrow) | see "Menu style" | | style | The menu style (default:arrow) | see "Menu style" |
| item_style | The item style (default:basic) | see "Item style" | | item_style | The item style (default:basic) | see "Item style" |
| filter | Filter the menu when the user type | boolean | | filter | Filter the menu when the user type | boolean |
| show_filter | Show a filter widget at the bottom | boolean | | show_filter | Show a filter widget at the bottom | boolean |
| filter_string | Default filter string | string | | filter_string | Default filter string | string |
| fkeys_prefix | Display F1-F12 indicators for easy navigation | boolean | | fkeys_prefix | Display F1-F12 indicators for easy navigation | boolean |
| underlay_alpha | Underlay (see item options) opacity | 0-1 | | underlay_alpha | Underlay (see item options) opacity | 0-1 |
| filter_prefix | Text to be shown at begenning of the filter string | string | | filter_prefix | Text to be shown at begenning of the filter string | string |
| max_items | Maximum number of items before showing scrollbar | number | | max_items | Maximum number of items before showing scrollbar | number |
| enable_keyboard | Enable or disable keyboard navigation / hooks | boolean | | enable_keyboard | Enable or disable keyboard navigation / hooks | boolean |
| disable_markup | Disable pango markup in items text | boolean | | disable_markup | Disable pango markup in items text | boolean |
| x | X position (absolute) | number | | x | X position (absolute) | number |
| y | Y position (absolute) | number | | y | Y position (absolute) | number |
| sub_menu_on | Show submenu on selection or when clicking | see "event" enum | | sub_menu_on | Show submenu on selection or when clicking | see "event" enum |
| select_on | The event used to trigger item selection | see "event" enum | | select_on | The event used to trigger item selection | see "event" enum |
| overlay | A layer on top of the item | function(data,item,cr,w,h) | | overlay | A layer on top of the item | function(data,item,cr,w,h) |
| opacity | Make this menu translucent (require a compositor) | number (0 to 1) | | opacity | Make this menu translucent (require a compositor) | number (0 to 1) |
| icon_transformation | Hijack the icon drawing function | function(icon,data,item) |
###Item options ###Item options
@ -241,6 +242,14 @@ here is the list:
Menu also emit many signals, the syntax is usually `PROPERTY_NAME::changed`. Menu also emit many signals, the syntax is usually `PROPERTY_NAME::changed`.
Some others are `item::moved`, `item::swapped`, `item::removed`, `item::appended` Some others are `item::moved`, `item::swapped`, `item::removed`, `item::appended`
Here is an example of how to catch an "opacity" change:
```lua
mymenu:connect_signal("opacity::changed",function(value)
-- Do something
end)
```
Most item_layout also repackage the default widget signals. It usually does the Most item_layout also repackage the default widget signals. It usually does the
same as using the `buttonX` menu attributes, but is preferrable in some scenarios same as using the `buttonX` menu attributes, but is preferrable in some scenarios
like when a modifier is applied. like when a modifier is applied.
@ -276,20 +285,26 @@ An example of how to use them:
Radical also use the some of the same theme options as awful.menu, plus some: Radical also use the some of the same theme options as awful.menu, plus some:
| Name | Description | Type | | Name | Description | Type |
| ---------------------------- | ------------------------------------- | ---------------------- | | ---------------------------- | ------------------------------------- | ------------------------- |
| menu_height | Menu height | String/Gradient/Pattern | | menu_height | Menu height | String/Gradient/Pattern |
| menu_width | Menu default/minimum width | Number | | menu_width | Menu default/minimum width | Number |
| menu_border_width | Border width | Number | | menu_border_width | Border width | Number |
| menu_border_color | Border color | String/Gradient/Pattern | | menu_border_color | Border color | String/Gradient/Pattern |
| menu_fg_normal | Text/Foreground color | String/Gradient/Pattern | | menu_fg_normal | Text/Foreground color | String/Gradient/Pattern |
| menu_bg_focus | Selected item color | String/Gradient/Pattern | | menu_bg_focus | Selected item color | String/Gradient/Pattern |
| menu_bg_header | Header widget background color | String/Gradient/Pattern | | menu_bg_header | Header widget background color | String/Gradient/Pattern |
| menu_bg_alternate | Scrollbar and other widget color | String/Gradient/Pattern | | menu_bg_alternate | Scrollbar and other widget color | String/Gradient/Pattern |
| menu_bg_normal | Default background | String/Gradient/Pattern | | menu_bg_normal | Default background | String/Gradient/Pattern |
| menu_bg_highlight | Highlighted item background | String/Gradient/Pattern | | menu_bg_highlight | Highlighted item background | String/Gradient/Pattern |
| menu_submenu_icon | Sub menu pixmap (aka >) | Path/Pattern | | menu_submenu_icon | Sub menu pixmap (aka >) | Path/Pattern |
| menu_separator_color | Menu separator color | String/Gradient/Pattern | | menu_separator_color | Menu separator color | String/Gradient/Pattern |
| menu_opacity | Use your favorite compositor | Number (0=0%, 1=100%) | | menu_opacity | Use your favorite compositor | Number (0=0%, 1=100%) |
| draw_underlay | Function returning the underlay pixmap | Function | | menu_draw_underlay | Function returning the underlay pixmap | function(array,width) |
| menu_icon_transformation | The function used to draw the icon | function(image,data,item) |
Styling can also be done using the icon_transformation option. This feature
allow masks such as desaturation, tinting, invert or some matrix to be applied
on the pixmap before it is being drawn. This function take the path/surface as
only parameter and return the transformed surface.

View File

@ -342,6 +342,7 @@ local function new(args)
select_on = args.select_on or module.event.HOVER, select_on = args.select_on or module.event.HOVER,
overlay = args.overlay or nil, overlay = args.overlay or nil,
opacity = args.opacity or beautiful.menu_opacity or 1, opacity = args.opacity or beautiful.menu_opacity or 1,
icon_transformation = args.icon_transformation or nil,
}, },
get_map = { get_map = {
is_menu = function() return true end, is_menu = function() return true end,

View File

@ -74,7 +74,8 @@ end
local function new(args) local function new(args)
local t,auto_release = tag.selected(capi.client.focus and capi.client.focus.screen or capi.mouse.screen),args.auto_release local t,auto_release = tag.selected(capi.client.focus and capi.client.focus.screen or capi.mouse.screen),args.auto_release
local currentMenu = menu({filter = true, show_filter=true, autodiscard = true, local currentMenu = menu({filter = true, show_filter=true, autodiscard = true,
disable_markup=true,fkeys_prefix=not auto_release,width=(((capi.screen[capi.client.focus and capi.client.focus.screen or capi.mouse.screen]).geometry.width)/2)}) disable_markup=true,fkeys_prefix=not auto_release,width=(((capi.screen[capi.client.focus and capi.client.focus.screen or capi.mouse.screen]).geometry.width)/2),
icon_transformation = beautiful.alttab_icon_transformation})
currentMenu:add_key_hook({}, "Tab", "press", select_next) currentMenu:add_key_hook({}, "Tab", "press", select_next)
@ -102,7 +103,7 @@ local function new(args)
l.fit = function (s,w,h) return 5*h,h end l.fit = function (s,w,h) return 5*h,h end
currentMenu:add_item({ currentMenu:add_item({
text = v.name, text = v.name,
icon = module.icon_transform and module.icon_transform(v.icon or module.default_icon) or v.icon or module.default_icon, icon = v.icon or module.default_icon,
suffix_widget = not auto_release and l or nil, suffix_widget = not auto_release and l or nil,
selected = capi.client.focus and capi.client.focus == v, selected = capi.client.focus and capi.client.focus == v,
underlay = underlays, underlay = underlays,

3
impl/tasklist/README.md Normal file
View File

@ -0,0 +1,3 @@
### Beautiful options
tasklist_icon_transformation | function(image) |

View File

@ -157,7 +157,8 @@ local function new(screen)
disable_markup = true, disable_markup = true,
overlay = function(data,item,cd,w,h) overlay = function(data,item,cd,w,h)
-- print("foo!") -- print("foo!")
end end,
icon_transformation = beautiful.tasklist_icon_transformation
} }
-- Clear the menu and repopulate it -- Clear the menu and repopulate it

View File

@ -33,6 +33,14 @@ function module.paint_underlay(data,item,cr,width,height)
cr:restore() cr:restore()
end end
-- Apply icon transformation
function module.set_icon(self,image)
if self._data.icon_transformation then
image = self._data.icon_transformation(image,self._data,self._item)
end
wibox.widget.imagebox.set_image(self,image)
end
-- Setup the item icon -- Setup the item icon
function module:setup_icon(item,data) function module:setup_icon(item,data)
local icon = wibox.widget.imagebox() local icon = wibox.widget.imagebox()
@ -40,6 +48,9 @@ function module:setup_icon(item,data)
local w,h = wibox.widget.imagebox.fit(...) local w,h = wibox.widget.imagebox.fit(...)
return w+3,h return w+3,h
end end
icon._data = data
icon._item = item
icon.set_image = module.set_icon
if item.icon then if item.icon then
icon:set_image(item.icon) icon:set_image(item.icon)
end end

View File

@ -55,6 +55,8 @@ local function create_item(item,data,args)
local icon_flex = wibox.layout.align.horizontal() local icon_flex = wibox.layout.align.horizontal()
local icon = wibox.widget.imagebox() local icon = wibox.widget.imagebox()
icon.fit = function(...) return icon_fit(data,...) end icon.fit = function(...) return icon_fit(data,...) end
icon._data = data
icon.set_image = horizontal.set_icon
if args.icon then if args.icon then
icon:set_image(args.icon) icon:set_image(args.icon)
end end