diff --git a/doc/planning/FancyZonesBacklog.md b/doc/planning/FancyZonesBacklog.md index 459f644869ce..a94b41ca40b5 100644 --- a/doc/planning/FancyZonesBacklog.md +++ b/doc/planning/FancyZonesBacklog.md @@ -3,25 +3,17 @@ This file captures the prioritized list of issues the FancyZones team will tackle ## On deck -Implement multi-mon editor support [195](https://github.com/microsoft/PowerToys/issues/195) -Add telemetry to new editor [196](https://github.com/microsoft/PowerToys/issues/196) ## Backlog Add tests to the new editor [197](https://github.com/microsoft/PowerToys/issues/197) -Hitting Esc while dragging should cancel the drag and not move the window into a zone [170](https://github.com/microsoft/PowerToys/issues/170) -Flash Zones is wayyyy too slow with multiple large monitors [167](https://github.com/microsoft/PowerToys/issues/167) Cycle through windows in a Zone [175](https://github.com/microsoft/PowerToys/issues/175) Minimize/restore windows in a zone as a group [174](https://github.com/microsoft/PowerToys/issues/174) FancyZones should support custom layouts for different "environments" [177](https://github.com/microsoft/PowerToys/issues/177) -Win+arrow works between monitors [161](https://github.com/microsoft/PowerToys/issues/161) Win+arrow is directional based on zone rect [162](https://github.com/microsoft/PowerToys/issues/162) Dragging a zoned window should restore size to a checkpointed size instead of current rect [166](https://github.com/microsoft/PowerToys/issues/166) FancyZones should merge with MTND and include zone moves in the pop-up [178](https://github.com/microsoft/PowerToys/issues/178) Drag to edge of screen automatically switches virtual desktops [168](https://github.com/microsoft/PowerToys/issues/168) -Different color schemes [165](https://github.com/microsoft/PowerToys/issues/165) -Ensure you can easily see zone while dragging [163](https://github.com/microsoft/PowerToys/issues/163) Visual updates for Win+Arrow [171](https://github.com/microsoft/PowerToys/issues/171) -Add a CLI for FancyZones [180](https://github.com/microsoft/PowerToys/issues/180) Add "magnetic dragging and resizing" mode to FancyZones [181](https://github.com/microsoft/PowerToys/issues/181) Create layout from current windows [159](https://github.com/microsoft/PowerToys/issues/159) Zone sets that have a dynamic number of zones [160](https://github.com/microsoft/PowerToys/issues/160) diff --git a/src/modules/fancyzones/FancyZones.png b/src/modules/fancyzones/FancyZones.png index 107c1749f50b..73d0cb0fd1d9 100644 Binary files a/src/modules/fancyzones/FancyZones.png and b/src/modules/fancyzones/FancyZones.png differ diff --git a/src/modules/fancyzones/FancyZonesSettings.png b/src/modules/fancyzones/FancyZonesSettings.png deleted file mode 100644 index edbe76a8c420..000000000000 Binary files a/src/modules/fancyzones/FancyZonesSettings.png and /dev/null differ diff --git a/src/modules/fancyzones/FancyZonesSettings1.png b/src/modules/fancyzones/FancyZonesSettings1.png new file mode 100644 index 000000000000..005fde70d6c8 Binary files /dev/null and b/src/modules/fancyzones/FancyZonesSettings1.png differ diff --git a/src/modules/fancyzones/FancyZonesSettings2.png b/src/modules/fancyzones/FancyZonesSettings2.png new file mode 100644 index 000000000000..13b8c388aa44 Binary files /dev/null and b/src/modules/fancyzones/FancyZonesSettings2.png differ diff --git a/src/modules/fancyzones/README.md b/src/modules/fancyzones/README.md index 8eacbd3924f0..713a69d5e797 100644 --- a/src/modules/fancyzones/README.md +++ b/src/modules/fancyzones/README.md @@ -1,43 +1,64 @@ # Overview -Fancy Zones is a window manager that is designed to make it easy to arrange and snap windows into efficient layouts for your workflow and also to restore these layouts quickly. Fancy Zones allows the user to define a set of window locations for a desktop that are drag targets for windows. When the user drags a window into a zone, the windows is resized and repositioned to fill that zone. +FancyZones is a window manager that is designed to make it easy to arrange and snap windows into efficient layouts for your workflow and also to restore these layouts quickly. FancyZones allows the user to define a set of window locations for a desktop that are drag targets for windows. When the user drags a window into a zone, the windows is resized and repositioned to fill that zone. -![Fancy Zones](FancyZones.png) +![FancyZones](FancyZones.png) -To get started with Fancy Zones, you need to enable the utility in Power Toys settings and then invoke the Fancy Zones setup UI. There is a button in settings to invoke this UI, or you can press Win+` (note that this shortcut can be changed in the settings dialog) to launch it. When first launched, the UI presents a list of zone layouts that can be quickly adjusted by how many windows are on the monitor. Choosing a layout shows a preview of that layout on the monitor. Pressing the save and close button sets that layout to the monitor. +To get started with FancyZones, you need to enable the utility in PowerToys settings and then invoke the FancyZones editor UI. +There is a button in settings to invoke the editor, or you can press Win+` (note that this shortcut can be changed in the settings dialog) to launch it. +If you have multiple monitors, to edit the zone settings on each monitor, move the mouse to the desired monitor and then press Win+` to launch the editor UI for that monitor, or move the PowerToys settings window to the desired monitor and then launch the editor UI using the `Edit zones` button. -![Fancy Zones Picker](Picker.png) +When first launched, the UI presents a list of zone layouts that can be quickly adjusted by how many windows are on the monitor. Choosing a layout shows a preview of that layout on the monitor. Pressing the save and close button sets that layout to the monitor. -The editor also supports creating and saving custom layouts. This functionality is in the “Custom” tab in the editor UI. There are two ways to create custom zone layouts, window layout and table layout. These can also be thought of as additive and subtractive models. The additive window layout model starts with a blank layout and supports adding zones that can be dragged and resized similar to windows. +![FancyZones Picker](Picker.png) -![Fancy Zones Window Editor Mode](WindowEditor.png) +The editor also supports creating and saving custom layouts. This functionality is in the `Custom` tab in the editor UI. +There are two ways to create custom zone layouts, window layout and table layout. These can also be thought of as additive and subtractive models. +The additive window layout model starts with a blank layout and supports adding zones that can be dragged and resized similar to windows. + +![FancyZones Window Editor Mode](WindowEditor.png) The subtractive table layout model starts with a table layout and allows zones to be created by splitting and merging zones and then resizing the gutter between zones. +To merge two zone, press and hold the left mouse button and drag the mouse until a second zone is selected, then release the button and a popup menu will show up. -![Fancy Zones Table Editor Mode](TableEditor.png) +![FancyZones Table Editor Mode](TableEditor.png) The backlog for the utility can be found [here](https://github.com/Microsoft/PowerToys/tree/master/doc/planning/FancyZonesBacklog.md) and the source code is [here](https://github.com/Microsoft/PowerToys/tree/master/src/modules/fancyzones). +# Snapping a window to two zones (EXPERIMENTAL) + +If two zones are adjacent, a window can be snapped to the sum of their area (rounded to the minimum rectangle that contains both). When the mouse cursor in near the common edge of two zones, both zones are activated simultaneously, allowing to drop the window on both. +**NOTE:** when snapping a window to two zones, restoring the window when the app is restarted is not supported yet. + +![Two Zones Activation](TwoZonesActivation.png) + # Shortcut Keys | Shortcut | Action | | ----------- | ----------- | | Win + ` | Launches editor (this shortcut is editable in the settings dialog) | -| Win+Ctrl+\ | Cycles through saved layouts with the corresponding number of zones | -| Win+Left/Right Arrow | Move focused window between zones (only if Override snap hotkeys setting is enabled, in that case only the `Win+Left Arrow` and `Win+Right Arrow` are overriden, while the `Win+Up Arrow` and `Win+Down Arrow` keep working as usual) | +| Win+Left/Right Arrow | Move focused window between zones (only if `Override Windows Snap hotkeys` setting is turned on, in that case only the `Win+Left Arrow` and `Win+Right Arrow` are overriden, while the `Win+Up Arrow` and `Win+Down Arrow` keep working as usual) | + +FancyZones doesn't override the Windows 10 `Win+Shift+Arrow` to quickly move a window to an adjacent monitor. # Settings | Setting | Description | | --------- | ------------- | | Configure the zone editor hotkey | To change the default hotkey, click on the textbox (it's not necessary to select or delete the text) and then press on the keyboard the desired key combination | | Enable zones while dragging with the shift key | Toggles between auto-snap mode with the shift key disabling snapping during a drag and manual snap mode where pressing the shift key during a drag enables snapping | -| Override Windows Snap hotkeys (win+arrow) to move between zones | When this option is on and Fancy Zones is running, it overrides two Windows Snap keys: `Win+Left Arrow` and `Win+Right Arrow` | -| Flash zones when the active FancyZones layout changes | Briefly flash the zone layout when the layout changes or a new virtual desktop is activated | -| Keep windows in their zones when the screen resolution changes | After a screen resolution change, if this setting is enabled, Fancy Zones will resize and reposition windows into the zones they were previously in | -| Keep windows in their zones when the active FancyZones layout changes | When this option is on, Fancy Zones will resize and position windows into the new zone layout by maintaining the previous zone number location of each window | +| Override Windows Snap hotkeys (Win+Arrow) to move between zones | When this option is on and FancyZones is running, it overrides two Windows Snap keys: `Win+Left Arrow` and `Win+Right Arrow` | +| Keep windows in their zones when the screen resolution changes | After a screen resolution change, if this setting is enabled, FancyZones will resize and reposition windows into the zones they were previously in | +| Keep windows in their zones when the active FancyZones layout changes | When this option is on, FancyZones will resize and position windows into the new zone layout by maintaining the previous zone number location of each window | | Keep windows in their zones when the active virtual desktop changes | If an application is pinned to all virtual desktops, this setting will keep that window in the same zone on all desktops | | Move newly created windows to the last known zone | Automatically move a newly opened window into the last zone location that application was in | -| Follow mouse cursor instead of focus when launching editor in a multi screen environment | When this option is on, the editor hotkey will launch the editor on the monitor where the mouse cursor is, when this option is off, the editor hotkey will launch the editor on monitor where the current active window is | -| Zone Highlight Color (Default #0078D7) | the color that a zone becomes when it is the active drop target during a window drag | +| Follow mouse cursor instead of focus when launching editor in a multi-monitor environment | When this option is on, the editor hotkey will launch the editor on the monitor where the mouse cursor is, when this option is off, the editor hotkey will launch the editor on monitor where the current active window is | +| Show zones on all monitors while dragging a window | By default FancyZones shows only the zones available on the current monitor, this feature may have performance impact when turned on | +| Show zones on all monitors while dragging a window | When the zones are activated, the dragged window is made transparent to improve the zones visibility | +| Zone highlight color (Default #008CFF) | The color that a zone becomes when it is the active drop target during a window drag | +| Zone Inactive color (Default #F5FCFF) | The color that zones become when they are not an active drop during a window drag | +| Zone border color (Default #FFFFFF) | The color of the border of active and inactive zones | +| Zone opacity (%) (Default 50%) | The percentage of opacity of active and inactive zones | | Exclude applications from snapping to zones | Add the applications name, or part of the name, one per line (e.g., adding `Notepa` will match both `Notepad.exe` and `Notepad++.exe`, to match only `Notepad.exe` add the `.exe` extension) | -![Fancy Zones Settings UI](FancyZonesSettings.png) +![FancyZones Settings UI](FancyZonesSettings1.png) + +![FancyZones Settings UI](FancyZonesSettings2.png) diff --git a/src/modules/fancyzones/TableEditor.png b/src/modules/fancyzones/TableEditor.png index 6aea729924c5..2d4961821726 100644 Binary files a/src/modules/fancyzones/TableEditor.png and b/src/modules/fancyzones/TableEditor.png differ diff --git a/src/modules/fancyzones/TwoZonesActivation.png b/src/modules/fancyzones/TwoZonesActivation.png new file mode 100644 index 000000000000..9f64d2cc7dbc Binary files /dev/null and b/src/modules/fancyzones/TwoZonesActivation.png differ diff --git a/src/modules/fancyzones/WindowEditor.png b/src/modules/fancyzones/WindowEditor.png index 877055f2428b..1f0c0c432b48 100644 Binary files a/src/modules/fancyzones/WindowEditor.png and b/src/modules/fancyzones/WindowEditor.png differ