Difference between revisions of "Release notes/1.1"

From Inkscape Wiki
Jump to navigation Jump to search
(46 intermediate revisions by 2 users not shown)
Line 22: Line 22:


<translate>
<translate>
== Release highlights ==
== Release highlights ==


Line 29: Line 30:
The most notable changes include:
The most notable changes include:


* A Welcome dialog, where the theme and the new document's size or file to open can be selected
* A '''Welcome dialog''', where the theme can be selected, and some choices for the new document's size or file to open are available
* A Commands palette that opens when the <kbd>?</kbd> key is pressed and that allows to search and use many functions without having to use a keyboard shortcut or going through the menus
* A '''Commands palette''' that opens when the <kbd>?</kbd> key is pressed and that allows to search and use many functions without having to use a keyboard shortcut or going through the menus
* It is now possible to copy, cut and paste parts of paths with the Node tool
* It is now possible to '''copy, cut and paste parts of paths''' with the Node tool
* The dialog docking system has been rewritten, which resolves many issues with Inkscape's docked dialogs and allows you to dock dialogs on either side of the screen
* The dialog docking system has been rewritten, which resolves many issues with Inkscape's docked dialogs and allows you to dock dialogs on either side of the screen
* New Outline overlay mode that displays object outlines while also showing their real colors
* New '''Outline Overlay mode''' that displays object outlines while also showing their real colors
* Preferences options are now easier to find by using the new search field
* Preferences options are now easier to find by using the '''new search field'''
* It is no longer necessary to remember to click on 'Export' in the PNG Export dialog, as the exporting will already happen after the click on 'Save' in the file selection dialog.
* It is '''no longer necessary to remember to click on 'Export'''' in the PNG Export dialog, as the exporting will already happen after the click on 'Save' in the file selection dialog.
* Export as '''JPG, TIFF, optimized PNG and WebP''' directly from Inkscape


== Important changes ==
== Important changes ==
Line 43: Line 45:
* Inkscape no longer depends on GtkSpell and ASpell but on GSpell for spell checking.
* Inkscape no longer depends on GtkSpell and ASpell but on GSpell for spell checking.
* lib2geom has been moved [https://gitlab.com/inkscape/lib2geom into its own git submodule] (like the extensions), a new release is available.
* lib2geom has been moved [https://gitlab.com/inkscape/lib2geom into its own git submodule] (like the extensions), a new release is available.
* Inkscape now ships a /share/themes folder with two custom themes that are only suitable for use with Inkscape (as a git submodule)


== Improvements ==
== General user interface ==
 
 
* [https://en.wikipedia.org/wiki/XInclude XInclude] support (see [https://gitlab.com/inkscape/inkscape/-/merge_requests/1150 !1150]) ''TODO: Move to a "technical" or "advanced" section?''
* Shell mode: a history of commands is now remembered and can be accessed with the up and down arrow keys. [Tab ... autocompletion?]
* Recognize layers in SVG files exported from CorelDraw (see [https://gitlab.com/inkscape/inkscape/-/merge_requests/2046 !2046])
* @import statements in CSS sheets are now processed in the correct order, so their styles are no longer overwritten unintentionally.


=== General user interface ===
=== Command palette ===


==== Color Sliders ====
* Pressing <kbd>?</kbd> will open the new Command palette.
Arrows on color sliders are bigger and have white fill and black outline.
* In the little overlay, a type-forward search allows you to find any available command to execute on the whole drawing or selection. The list of available commands is currently restricted to those commands that have already been converted to 'actions', as part of an ongoing effort. Additionally, it includes the option to import or open files from Inkscape's document usage history.
We also fixed artefacts on HiDPi monitors.
** Some commands allow you to indicate parameters. A little keyboard icon will show you when the program expects a parameter (such as an angle for rotation, or a fraction for scaling). Note that the unit that is used for parameters is usually 'px', not the display unit. Some parameters require a specific format (like a comma-separated list of values for moving). The format is often indicated in the description of the command, e.g. to align selected objects to the last selected one's left side, find the 'align objects' command, then type 'left last'.
https://gitlab.com/inkscape/inkscape/-/merge_requests/2733
** Some commands do nothing visible in the user interface (yet), as either
*** they only work in conjunction with other commands, such as commands that change how a file is exported, or commands that export the file. These need to be entered in order, e.g. <code>export type</code> ⯈ type 'png' ⯈ press <kbd>Enter</kbd> ⯈ press <kbd>?</kbd> ⯈ <code>export file name</code> ⯈ type a file name ⯈ press <kbd>Enter</kbd> ⯈ press <kbd>?</kbd> ⯈ <code>export do</code> ⯈ press <kbd>Enter</kbd>; <code>export do</code> in this example can also be used repeatedly to export the updated image to the same file name) or
*** they produce output on the command line (like commands asking for coordinates of objects), which you will only see if you have started Inkscape from the command line.
* Press <kbd>Enter</kbd> to execute any command.
* By pressing the <kbd>↑</kbd> (upwards arrow key), you enter the history mode, where you can choose between commands that you have already used.
* To close the palette, if not using any of the commands offered, you can press <kbd>?</kbd> again, or just click on the canvas.


==== Commands palette ====
If a keyboard shortcut is available for the selected command, it will show up in the command palette (in the form that it is saved in the keyboard shortcut file).
In the settings, at <code>Edit → Preferences → Interface: Command palette</code>, you can select some of the info you would like the palette to display. In addition to the translated action name, it can also show the English names of the commands and the corresponding command line argument name.


This feature was added by Google Summer of Code Student Abhay Raj Singh in 2020. Learn more about the feature's development [https://gitlab.com/rathod-sahaab/gsoc-2020-inkscape on GitLab].
This feature was added by Google Summer of Code Student Abhay Raj Singh in 2020. You can learn more about the feature's development [https://gitlab.com/rathod-sahaab/gsoc-2020-inkscape on GitLab] or in [https://dev.to/rathod_sahaab/inkscape-command-palette-merged-15c2 Abhay's blog entry]. ([https://gitlab.com/inkscape/ux/-/issues/31 UX issue #31], [https://gitlab.com/inkscape/inkscape/-/merge_requests/2072  MR #2072])
[https://gitlab.com/inkscape/ux/-/issues/31 UX issue 31] [https://gitlab.com/inkscape/inkscape/-/merge_requests/2072  MR 2072]


<gallery mode="packed" heights=450px>
<gallery mode="packed" heights=450px>
Line 68: Line 70:
</gallery>
</gallery>


=== Canvas ===
=== Paste on top of selection ===


==== 'Outline Overlay' display mode ====
When pasting an object from the clipboard onto the canvas, Inkscape will now by default paste it right above the currently selected object. This feature can be disabled in <code>Edit → Preferences → Behavior → Selecting: Paste on top of selection instead of layer-top</code> ([https://gitlab.com/inkscape/inkscape/-/merge_requests/2476 MR #2476], [https://gitlab.com/inkscape/ux/-/issues/65 Usability test #65]).


In this mode, a toned down view of the drawing (not click-sensitive) is shown behind the (click-sensitive) object outlines.  
<gallery mode="packed" heights=450px>
The opacity of the original drawing in this view mode can be set in <code>Edit → Preferences → Rendering: Outline overlay opacity</code>.
File:Pasting on top of selected.gif| Pasting on top of selection
</gallery>


[[File:Outline Overlay Preview.png|650px|frameless|center]]
== Canvas ==


==== 'Gray scale' display mode ====
=== New Display mode ===


In this mode, all colors are displayed in grayscale, making this a useful feature for checking contrast. Can be activated in <code>View Gray Scale</code>
* 'Outline Overlay' display mode: In this mode, a toned down view of the drawing (not click-sensitive) is shown behind the (click-sensitive) object outlines. The opacity of the original drawing in this view mode can be set in <code>Edit → Preferences Rendering: Outline overlay opacity</code>.


==== Handles ====
<gallery mode="packed" heights=450px>
File:Outline Overlay Preview.png|Outline Overlay Display mode
</gallery>


New vector-based handels. These designs are not SVGs and are hardcoded.
=== Handles ===
The maximal handle size has been increased, so users with HiDPI displays will be able to enlarge them to a more comfortable size.
<code>Edit → Preferences → Interface: Handle size</code>


 
* Inkscape now uses vector-based handles, which are currently hardcoded (not SVG) ([https://gitlab.com/inkscape/inkscape/-/merge_requests/2334 MR #2334])
[https://gitlab.com/inkscape/inkscape/-/merge_requests/2334 2334]
* The maximum handle size has been increased, so users with HiDPI displays will be able to enlarge them to a more comfortable size from <code>Edit → Preferences → Interface: Handle size</code>
[https://gitlab.com/inkscape/inkscape/-/merge_requests/2344 2344]
* Rotation center handles have been made more visible


[[File:Handels.png]]
[[File:Handels.png]]


=== Tools ===
== Tools ==


==== Calligraphy Tool ====
=== Calligraphy Tool ===


* The tool now supports units for the width, with a much increased precision (up to three digits after the decimal separator, e.g. 0.005). The old, zoom-dependent width behavior is accessible with the unit '%'.
* The tool now supports units for the width, with a much increased precision (up to three digits after the decimal separator, e.g. 0.005). The old, zoom-dependent width behavior is accessible with the unit '%'.
* The entry field for 'Mass' has been moved towards left (for LTR languages) on the tool's tool controls bar, emphasizing its importance ([https://gitlab.com/inkscape/inkscape/-/merge_requests/2816 MR #2816])


==== Connector tool ====
=== Connector tool ===


* Connection lines now update in real time while objects are moved  
* Connection lines now update in real time while objects are moved
* New sub-point connections for clones and groups, allowing users to use Inkscape to connect diagrams together like in other drafting tools:


<gallery mode="packed" heights=250px>
=== Node tool ===
File:Sub connector points.gif|New sub-connector points
</gallery>


==== Node tool ====
The node tool now allows to copy, cut and paste a selection of nodes. These nodes can be inserted into the original path, into a different path or they can be pasted as a completely new path.
 
The node tool now allows to copy, cut and paste a selection of nodes. These nodes can be inserted into the original path, into a different path or they can be pasted as a completely new path.


<gallery mode="packed" heights=500px>
<gallery mode="packed" heights=500px>
Line 117: Line 115:
</gallery>
</gallery>


==== Selector Tool ====
=== Selector Tool ===


A new selection mode for the lasso/rubber-band selection was added, which can now select every object that is either within the box or that touches its boundaries. The mode can be activated by pressing the corresponding button in the Selector tool's tool controls bar. On canvas, the mode is visualized by changing the color of the selection box to dashed red line while dragging.
* A new selection mode for the lasso/rubber-band selection was added, which can now select every object that is either within the box or that touches its boundaries. The mode can be activated by pressing the corresponding button in the Selector tool's tool controls bar. On canvas, the mode is visualized by changing the color of the selection box to dashed red line while dragging ([https://gitlab.com/inkscape/inkscape/-/merge_requests/2520 MR #2520]).
 
TODO: record with new dashed line indicator instead of red
[https://gitlab.com/inkscape/inkscape/-/merge_requests/2520 2520]


[[File:Touch rect.gif]]
[[File:Touch rect.gif]]


==== Text Tool ====
=== Text Tool ===


* Text-in-a-shape can now make use of justified text alignment.
* Text-in-a-shape can now make use of justified text alignment.
* Highlight all shapes: When editing text-in-shape or text-on-path, highlight all shapes, not only the first rectangle. [https://gitlab.com/inkscape/inkscape/-/merge_requests/2468 2468]
* Highlight all shapes: When editing text-in-shape or text-on-path, all shapes are highlighted, not only the first ([https://gitlab.com/inkscape/inkscape/-/merge_requests/2468 MR #2468]) and the orientation / position of the shapes is shown correctly (e.g. display rotated rectangle as being rotated).
* Also apply correct transformation (e.g. display rotated rectangle).
* removed the close button from this dialog  [https://gitlab.com/inkscape/inkscape/-/merge_requests/2523 2523]


=== Dialogs ===
== Dialogs ==


==== Docking ====
=== General ===
 
* Arrows on color sliders now have better visibility
 
=== Docking ===
 
Dialogs can now be docked on the left of the Inkscape window. They're now displayed as tabs, with optional label and icon. The dialog tabs can be combined to new floating docks. Tabs can be closed by middle mouse click, right-click and selecting to close, or by clicking on the x icon.
 
The work for this big code refactoring was undertaken by Google Summer of Code Student Valentin Ionita in 2020. You can learn more about his work [https://gitlab.com/vanntile/inkscape-gsoc-2020 on GitLab] ([https://gitlab.com/vanntile/inkscape-gsoc-2020/-/blob/master/RFC.md technical documentation]).


The docking feature has been refactored by Google Summer of Code Student Valentin Ionita in 2020. You can learn more about his work [https://gitlab.com/vanntile/inkscape-gsoc-2020 on GitLab]
([https://gitlab.com/vanntile/inkscape-gsoc-2020/-/blob/master/RFC.md technical documentation]).
[[File:Docking demo.gif]]
[[File:Docking demo.gif]]


Known issues:
=== Preferences dialog ===
- Dragging tab to undock does not work on Windows


==== Preferences dialog ====
* The preferences dialog now features a search bar, which performs a recursive search over all the nested categories of settings:
 
** press '''<code>F3</code>''' or '''<code>Ctrl + G</code>''' for next result
* Added new search bar in the preferences dialogue that performs a recursive search over all the nested categories of settings
** press '''<code>Shift + F3</code>''' or '''<code>Ctrl + Shift+G</code>''' for previous result
** press '''<code>F3</code>''' or '''<code>Ctrl+G</code>''' for next result
* In <code>Edit → Preferences → Imported images: Import</code>, there is a new option that allows you to disable relative paths to linked files ("Store absolute file path for linked images", deactivated by default).
** press '''<code>Shift+F3</code>''' or '''<code>Ctrl+Shift+G</code>''' for previous result
* In <code>Edit → Preferences → Rendering</code>, there is a new option to <code>Redraw while editing</code>, which improves performance of redrawing with some faster CPUs ("Responsive", active by default, or "Conservative").
* In <code>Edit → Preferences → Imported images: Import</code>, there is a new option that allows you to disable relative paths to linked files ("Store absolute file path for linked images", active by default).
* In <code>Edit → Preferences → Behavior Scrolling</code>, the setting '''Mouse wheel zooms by default''' has been removed. This setting can now be set by disabling the modifier 'Ctrl' for '''Canvas zoom''', and enabling it for '''Vertical pan''' instead (see section about 'Customization' below for more information).
* In <code>Edit → Preferences → Rendering</code>, there is a new option to <code>Redraw while editing</code>, which improves performance of redrawing with some faster CPUs ("Responsive", active by default).
* In <code>Edit → Preferences → Interface Keyboard</code>, in the new '''Modifiers''' tab, you can customize keyboard shortcut modifiers for on-canvas mouse actions (for example holding <kbd>Ctrl</kbd> for scaling while keeping the object's aspect ratio can be changed to Shift) [Known issue: doesn't survive a restart]
* In <code>Edit → Preferences → Behaviour → Scrolling</code>, The setting '''Mouse wheel zooms by default''' has been removed, this setting can now be set by changing the Modifier setting '''Canvas zoom''' to remove the Ctrl modifier (see above).
* The Zoom correction factor in <code>Edit → Preferences → Interface</code> now works correctly for other units than mm and remembers values below 100%.  
* The Zoom correction factor in <code>Edit → Preferences → Interface</code> now works correctly for other units than mm and remembers values below 100%.  
* There is an option now to adjust the number shown in the Zoom field in the bottom right corner to match the real world scale. The new option is active by default, so that, after adjusting the factor for your monitor, at 100% zoom, your document page is as large on the screen as it is in reality.
* There is an option now to adjust the number shown in the Zoom field in the bottom right corner to match the real world scale. The new option is active by default, so that, after adjusting the factor for your monitor, at 100% zoom, your document page is as large on the screen as it is in reality.
Line 160: Line 155:
</gallery>
</gallery>


==== 'About Inkscape' dialog ====
=== 'About Inkscape' dialog ===
 
The <code>Help → About Inkscape</code> dialog has been rebuilt from scratch with a larger window (and image) and a tabbed interface.


The Help > About Inkscape dialog has been rebuilt from scratch with a larger window (and image) and a tabbed interface.
* The user-contributed About Screen artwork is now displayed much larger, as it should be!
* The user-contributed About Screen artwork is now displayed much larger, as it should be!
* Authors and translators are now featured on separate tabs.
* Authors and translators are now featured on separate tabs.
Line 168: Line 164:
* All the tabs include calls to action or links to the official website for more information.
* All the tabs include calls to action or links to the official website for more information.
* The current version of Inkscape is displayed on a button. When clicked, the full version information is copied to the clipboard, so it can be used in bug reports, for example.
* The current version of Inkscape is displayed on a button. When clicked, the full version information is copied to the clipboard, so it can be used in bug reports, for example.
* In the bottom right corner, there is an additional small button with a little beetle on it. Clicking that button will copy extensive information about available software library versions, in addition to operating system and Inkscape version information.


<gallery mode="packed" heights=600px>
<gallery mode="packed" heights=600px>
File:New about dialog.gif|The reworked About Inkscape dialog
File:New about dialog.gif|The reworked About Inkscape dialog <span style="color:red;">Todo: Re-record this!</span>
</gallery>
</gallery>


==== Fill and Stroke ====
=== Fill and Stroke ===
<code>Object → Fill and stroke → Stroke Style</code>


* '''Hairline stroke style''' can now be set in the dialog. This type of stroke is always 1px wide, independent of the zoom level. This feature is useful for laser cutters and plotters.
* The stroke's width can now be set to '''Hairline''' in the dialog at <code>Object → Fill and stroke → Stroke Style</code> (as a unit). This type of stroke is always 1px wide, independent of the zoom level. The feature will hopefully one day be useful for laser cutting and plotting ([https://gitlab.com/inkscape/inkscape/-/merge_requests/846 MR #846])
** Supports exporting hairlines to file formats with native hairline support (pdf/ps).
** Hairline strokes can be exported to file formats with native hairline support (PDF/PS), but this requires [https://gitlab.freedesktop.org/cairo/cairo/-/merge_requests/21 a code change in the Cairo software library], which has not been accepted (yet), so the PS/PDF hairline export feature will not yet be available in any official packages. If unavailable, a very thin line width will be used instead (1px at the "1:1 zoom" level of the output).
** Exporting hairlines to output devices or native file formats requires [https://gitlab.freedesktop.org/cairo/cairo/-/merge_requests/21 a patch to Cairo]. If unavailable, a very thin line width will be used instead.
** In other SVG renderers, hairlines will be handled via non-scaling stroke with a stroke width of 1px.
** In other SVG renderers, these will be handled via non-scaling stroke with a stroke width of 1px.
** Export to PNG and rendering on canvas will use a line width of 1px.
** Export to PNG and rendering on canvas will use a line width of 1px.
[https://gitlab.com/inkscape/inkscape/-/merge_requests/846 MR 846]
* The '''Miter maximum''' has been increased to 100000 ([https://gitlab.com/inkscape/inkscape/-/commit/88b1c1abb30437743a408644855616d3ad Commit 69dc16])
* Stock markers use SVG 2.0 context-stroke to automatically take on the stroke color of the object ([https://gitlab.com/inkscape/inkscape/-/merge_requests/2009 MR #2009]). If SVG 1.1 compatibility is needed, the setting for marker colors in <code>Edit → Preferences → Input/Output → SVG export</code> can be activated and SVG 1.1 compatibility can be activated in the 'Save as' dialog.


[[File:InkscapeHairlines.gif]]
[[File:InkscapeHairlines.gif]]


* Miter maximum increased to 100000 [https://gitlab.com/inkscape/inkscape/-/commit/69dc1688b1c1abb30437743a408644855616d3ad commit]
=== Gradient Editor dialog (removed) ===


*Markers use SVG 2.0 context-stroke [https://gitlab.com/inkscape/inkscape/-/merge_requests/2009 2009]
* The legacy gradient editor (a dialog that could previously be enabled in the preferences for the gradient tool) has been removed.


==== Gradients ====
=== Text and Font dialog ===


* The legacy gradient editor (a dialog that could previously be enabled in the preferences for the gradient tool) has been removed.
* Removed the 'Close' button ([https://gitlab.com/inkscape/inkscape/-/merge_requests/2523 MR #2523])


==== 'Welcome' dialog ====
=== 'Welcome' dialog ===


A new welcome and onboarding screen was added. You can set up the look of Inkscape on a first run and select from presets of document settings.
A new welcome and onboarding screen was added. You can set up the look of Inkscape on a first run and select from presets of document settings.
Line 205: Line 201:
</gallery>
</gallery>


=== Live path effects ===
== Filters ==
* A new "Fast Crop" filter can be found at <code>Filters → Fill and transparency → Fast Crop</code> ([https://gitlab.com/inkscape/inkscape/-/merge_requests/2767 MR #2767])


==== LPE Boolean Operations ====
== Live path effects ==
This LPE no longer experimental. We improved UX you can manipulate objects on canvas how you would expect. And this LPE should be more stable


==== Automatic fill preservation for path effects ====
=== Automatic fill preservation for path effects ===


LPEs which render strokes as fills (<code>Join Type</code>, <code>Power Stroke</code>, and <code>Taper Stroke</code>) have been modified to automatically preserve the previous fill by creating a linked path when applied to an object.
LPEs which render strokes as fills (<code>Join Type</code>, <code>Power Stroke</code>, and <code>Taper Stroke</code>) have been modified to automatically preserve the previous fill by creating a linked clone with the original fill color when applied to an object.


<gallery mode="packed" heights=250px>
<gallery mode="packed" heights=250px>
Line 221: Line 217:
</gallery>
</gallery>


==== "Taper Stroke" LPE ====
=== "Boolean Operations" LPE ===


The Taper stroke LPE has been updated to include taper direction options (allowing the taper to run to one side of the path, instead of to the middle) and smoothing options for both ends of the path, allowing more interesting paths to be made in the effect. In addition, using the keybind '''Shift+click''' on the on-canvas knots allows quickly alternating between the different possible taper shapes.
* The path effect is no longer marked as experimental.
* Operands can now easily be selected and moved with the mouse.
* Improved stability
 
=== "Taper Stroke" LPE ===
 
The Taper stroke LPE has been updated to include taper direction options (allowing the taper to run to one side of the path, instead of to the middle) and smoothing options for both ends of the path, allowing more interesting paths to be made in the effect. In addition, '''Shift+click'''ing on the on-canvas handles allows quickly alternating between the different possible taper shapes.


<gallery mode="packed" heights=250px>
<gallery mode="packed" heights=250px>
Line 230: Line 232:
</gallery>
</gallery>


==== "Fill between many" LPE ====
=== "Fill between many" LPE ===


A new item '''Fill between Paths''' has been added under the Path menu to automatically create a linked fill path using the '''Fill between many''' path effect. The effect is created beneath the selected paths and automatically selected to faciliate moving the path into the correct z-order and styling it as intended. For greater efficiency, the shortcut can also be bound to a hotkey using the '''Preferences''' dialog.
A new item '''Fill between Paths''' has been added under the <code>Path</code> menu to automatically create a linked fill path using the '''Fill between many''' path effect. The effect is created beneath the selected paths and automatically selected to faciliate moving the path into the correct z-order and styling it as intended. For greater efficiency, a shortcut can also be assigned, using the '''Preferences''' dialog.


This is especially useful for filling variable-width paths created with the PowerStroke option (or other live path effects that use the fill to emulate a stroke).
This is especially useful for filling variable-width paths created with the PowerStroke option (or other live path effects that use the fill to emulate a stroke).
Line 241: Line 243:
</gallery>
</gallery>


==== "Offset" LPE ====
=== "Offset" LPE ===


The offset is faster for more complex shapes. Open paths can now have an offset that is not automatically closed [Known issue: when they don't self-intersect].
* The Offset LPE's performance was improved for more complex shapes.
* Open paths can now have an offset that is not automatically closed [Known issue: when they don't self-intersect].


==== "Slice" LPE (new) ====
=== "Slice" LPE (new) ===


This new path effect allows you to split an object into two without destroying the original (or more by stacking multiple LPEs).
This new path effect allows you to split an object into two (or more by stacking multiple LPEs), without destroying the original.
It works with groups, shapes, and paths. If you want to use it on Text, you need to use the 'Clone' LPE and apply the 'Slice' LPE on this clone.  
It works with groups, shapes, and paths. If you want to use it on Text, you need to use the 'Clone' LPE and apply the 'Slice' LPE on this clone.  
It also allows change styles to any part because each part is a separated object only linked by original shape and maybe original transforms
It also allows to change styles for the resulting parts, because each part is a separate object ([https://gitlab.com/inkscape/inkscape/-/merge_requests/2372 MR #2372])
 
[https://gitlab.com/inkscape/inkscape/-/merge_requests/2372 MR 2372]


[[File:Slice LPE 1.gif|800px|frameless]]
[[File:Slice LPE 1.gif|800px|frameless]]


==== Other LPE improvemts ====
== Import / Export ==
* Mirror symmetry alow open and closed paths [https://gitlab.com/inkscape/inkscape/-/merge_requests/2366 2366]


=== Export ===
* Inkscape can now recognize layers in SVG files exported from CorelDraw (MR [https://gitlab.com/inkscape/inkscape/-/merge_requests/2046 !2046])
* The '''Export PNG Image dialog''' now exports the PNG as soon as the button <code>Export as</code> has been clicked and a file name was selected for the file. It's no longer necessary to explicitly click on Export after choosing a file name. Clicking on <code>Export</code> will still be available to export to the file name that is currently set in the dialog.
* Use the file name extensions ''''.jpg', '.webp' or '.tiff'''' in the PNG export dialog to open the corresponding export options and export to the selected file format. In the file chooser that opens after clicking on 'Export as', there is also a dropdown menu available to choose the file format. ''''Optimized PNG'''' is available there as an additional option (as it uses the same file name extension, it's not possible to auto-detect). The export functionality is implemented using a Python extension of the new 'Raster Output' type.


* The Export PNG Image dialog now exports the PNG as soon as the button Export as has been clicked and a file name was selected for the file. It's no longer necessary to explicitly click on Export after choosing a file name.
<gallery mode="packed" heights=150px>
* There's a hidden JPG export feature now. Select 'Guess from extension' in the file type dropdown in one of the dialogs for 'Save', 'Save as' or 'Save a Copy' and use the file name extension '.jpeg' to get to the JPG export options dialog. The export functionality is implemented using a Python extension of the new 'Raster Output' type.
File:Jpg export 1.png | A warning about JPEG export
File:Jpg export 2.png | JPEG export options
File:Tiff export.png ‎ | TIFF export options
File:Webp export.png | WebP export options
File:Optimized png export 1.png | Lossless options for export as Optimized PNG
File:Optimized png export 2.png | Lossy options for export as Optimized PNG
</gallery>


=== Customization ===
== Customization ==


==== Cursors ====
=== Cursors ===


A set of SVG-based, themeable mouse cursors with HiDPI support were added.  
A set of SVG-based, themeable mouse cursors with HiDPI support were added.  
Line 276: Line 284:
</gallery>
</gallery>


==== Shortcuts ====
=== Shortcuts ===


* In <code>Edit → Preferences → Interface → Keyboard</code>, in the new '''Modifiers''' tab, you can customize keyboard shortcut modifiers for on-canvas mouse actions (for example holding <kbd>Ctrl</kbd> for scaling while keeping the object's aspect ratio can be changed to Shift) [Known issue: doesn't survive a restart]
* Keyboard shortcut files for Inkscape can now inherit from other keyboard shortcut files by using [https://en.wikipedia.org/wiki/XInclude XInclude] (MR [https://gitlab.com/inkscape/inkscape/-/merge_requests/1150 !1150])
* Illustrator keyboard shortcut map has been updated to ... <span style="color: red;">Fill me in</span>
* Illustrator keyboard shortcut map has been updated to ... <span style="color: red;">Fill me in</span>


==== Themes ====
=== Themes ===


* A contrast slider was added for finer control over any theme look at <code>Preferences → Interface → Themeing → Contrast</code> [https://gitlab.com/inkscape/inkscape/-/merge_requests/906 906]
* A contrast slider was added for finer control over any theme look at <code>Preferences → Interface → Themeing → Contrast</code> [https://gitlab.com/inkscape/inkscape/-/merge_requests/906 906]
Line 288: Line 298:
[[File:Contrast slider.gif|center]]
[[File:Contrast slider.gif|center]]


==== macOS-specific changes ====
== macOS-specific Changes ==


* New Inkscape icon ([https://gitlab.com/inkscape/inkscape/-/commit/ee58965003ca1960c20d7da276c3774166c18d42 commit ee589650])
* New Inkscape icon ([https://gitlab.com/inkscape/inkscape/-/commit/ee58965003ca1960c20d7da276c3774166c18d42 commit ee589650])
Line 295: Line 305:
* <del>This is the last release to support OS X El Capitan 10.11. Future releases will require at least macOS High Sierra 10.13 as oldest supported operating system.</del> A few hours ago I got feedback on the [https://gitlab.gnome.org/GNOME/gtk/-/issues/3592 upstream issue] which is the deciding factor here. There's hope now, so let's not make an announcement like this just yet.
* <del>This is the last release to support OS X El Capitan 10.11. Future releases will require at least macOS High Sierra 10.13 as oldest supported operating system.</del> A few hours ago I got feedback on the [https://gitlab.gnome.org/GNOME/gtk/-/issues/3592 upstream issue] which is the deciding factor here. There's hope now, so let's not make an announcement like this just yet.


=== Extensions ===
== Extensions ==


=== Command line ===
== Command line ==


* The options <span style="color:red;">x y z</span> have been added back in to preserve compatibility with legacy Inkscape command line scripts (and ImageMagick's SVG conversion)
* The options <span style="color:red;">x y z</span> have been added back in to preserve compatibility with legacy Inkscape command line scripts (and ImageMagick's SVG conversion)
* Added actions for aligning and distributing objects ([https://gitlab.com/inkscape/inkscape/-/merge_requests/2472 MR #2472])
* Shell mode: a history of commands is now remembered and can be accessed with the up and down arrow keys. [Tab ... autocompletion?]


*Added actions for aligning and distributing objects [https://gitlab.com/inkscape/inkscape/-/merge_requests/2472 2472]
== Behind the curtains ==


=== Filters ===
Inkscape developers have also worked on improving and evolving parts of Inkscape which are not directly visible to the users. Indirectly, these changes will also benefit the users, as they make it easier for developers to work with the project, and help them make fewer mistakes.
* New filter fast crop was added. [https://gitlab.com/inkscape/inkscape/-/merge_requests/2767  2767]
 
<code> Filers / Fill and transparency / Fast Crop </code>
* Documentation for developers was updated and improved continuously, helping developers better understand other people's code
* Outdated code was updated continuously, making it easier to handle the code moving forwards. This includes a continued effort to convert old C code to modern C++, removing dead code and rewriting parts of the code in a more modern way.
* Code formatting was improved continuously, improving readability of the code
* Continuous integration was updated and improved continuously, ensuring that each code change will be tested automatically and can be reviewed by bug reporters before it is included into the main line code, also keeping up with changes in GitLab, AppVeyor and other infrastructure that is used by Inkscape
* Improvements were made to the build system, so Inkscape can be built on more Linux, Windows and macOS versions, keeping up with changes in software libraries that Inkscape depends upon
* Many tests were added and improved, reducing the risk of accidental loss of functionality
* Running test versions on Windows was simplified by adding shortcuts to the top level folder: <code>Run Inkscape !.bat, Run Inkscape and create debug trace.bat, Run Inkscape with GTK Inspector.bat</code> ([https://gitlab.com/inkscape/inkscape/-/merge_requests/2884 MR #2884])


== Notable bugfixes ==
== Notable bugfixes ==
Line 314: Line 332:


* &hellip; when ... ([https://gitlab.com/inkscape/inkscape/-/issues/ #number])
* &hellip; when ... ([https://gitlab.com/inkscape/inkscape/-/issues/ #number])
* when you delete d atrubute in XML editor [https://gitlab.com/inkscape/inkscape/-/merge_requests/2722 2722]
* when deleting the <code>d</code> attribute in the XML editor ([https://gitlab.com/inkscape/inkscape/-/merge_requests/2722 MR #2722])


=== Other bug fixes ===
=== Other bug fixes ===


* The color selector's color wheel looks better now on HiDPI screens [https://gitlab.com/inkscape/inkscape/-/merge_requests/2416 MR #2416]
* @import statements in CSS sheets are now processed in the correct order, so their styles are no longer overwritten unintentionally.
* The color indicator field in the bottom left corner of the window now uses a constant width and has been cleaned up a bit [https://gitlab.com/inkscape/inkscape/-/merge_requests/2400 MR #2400]  
* The color selector's color wheel looks better now on HiDPI screens ([https://gitlab.com/inkscape/inkscape/-/merge_requests/2416 MR #2416])
* The size of the double-arrow handles in the color sliders has been increased [https://gitlab.com/inkscape/inkscape/-/merge_requests/2427 MR #2427]
* Color slider handles look better now on HiDPI screens ([https://gitlab.com/inkscape/inkscape/-/merge_requests/2733 MR #2733])
* Fix of multiple regressions and bugs with '''Stroke to path''' [https://gitlab.com/inkscape/inkscape/-/merge_requests/2410 MR #2410]
* The color indicator field in the bottom left corner of the window now uses a constant width and has been cleaned up a bit ([https://gitlab.com/inkscape/inkscape/-/merge_requests/2400 MR #2400])
* Fix of feColorMatrix filter primitive default rendering [https://gitlab.com/inkscape/inkscape/-/merge_requests/2424 MR #2424]
* The size of the double-arrow handles in the color sliders has been increased ([https://gitlab.com/inkscape/inkscape/-/merge_requests/2427 MR #2427])
* You can now just click in the color wheel to select a color [https://gitlab.com/inkscape/inkscape/-/merge_requests/2428 MR #2428]
* Fix of multiple regressions and bugs with '''Stroke to path''' ([https://gitlab.com/inkscape/inkscape/-/merge_requests/2410 MR #2410])
* Reverse order of z-order buttons to achieve more consistency [https://gitlab.com/inkscape/inkscape/-/merge_requests/2556 MR #2556 ]
* Fix of feColorMatrix filter primitive default rendering ([https://gitlab.com/inkscape/inkscape/-/merge_requests/2424 MR #2424])
* Fix reversed buttons in Arrange/Polar Coordinates [https://gitlab.com/inkscape/inkscape/-/merge_requests/2561 MR 2561]
* You can now just click in the color wheel to select a color ([https://gitlab.com/inkscape/inkscape/-/merge_requests/2428 MR #2428])
* Multiple Fixes for Selectors and CSS dialog [https://gitlab.com/inkscape/inkscape/-/merge_requests/1681 1681]
* Reverse order of z-order buttons to achieve more consistency ([https://gitlab.com/inkscape/inkscape/-/merge_requests/2556 MR #2556])
* Multiple fixes for command: Stroke to path [https://gitlab.com/inkscape/inkscape/-/merge_requests/2410 2410]
* Fix reversed buttons in Arrange / Polar Coordinates ([https://gitlab.com/inkscape/inkscape/-/merge_requests/2561 MR 2561])
* Fixed rendering of antialiasing on clipping path [https://gitlab.com/inkscape/inkscape/-/merge_requests/2401 2401]
* Multiple Fixes for Selectors and CSS dialog ([https://gitlab.com/inkscape/inkscape/-/merge_requests/1681 MR #1681])
* Fix z-order rendering issue after ungrouping [https://gitlab.com/inkscape/inkscape/-/merge_requests/2452 2452]
* Multiple fixes for command: Stroke to path ([https://gitlab.com/inkscape/inkscape/-/merge_requests/2410 MR #2410])
* Fix copying mesh gradients to new document. [https://gitlab.com/inkscape/inkscape/-/merge_requests/2362 2362]
* Fixed rendering of antialiasing on clipping path ([https://gitlab.com/inkscape/inkscape/-/merge_requests/2401 MR #2401])
* "X-Ray" mode auto disable when cursor reaches edge of canvas. [https://gitlab.com/inkscape/inkscape/-/merge_requests/2346 2346]
* Fix z-order rendering issue after ungrouping ([https://gitlab.com/inkscape/inkscape/-/merge_requests/2452 MR #2452])
* Fix Ctrl+click "Pop selected object out of group" [https://gitlab.com/inkscape/inkscape/-/merge_requests/2729 2729]
* Fix copying mesh gradients to new document ([https://gitlab.com/inkscape/inkscape/-/merge_requests/2362 MR #2362])
* "X-Ray" mode no longer disables automatically when the cursor reaches the edge of the canvas ([https://gitlab.com/inkscape/inkscape/-/merge_requests/2346 MR #2346])
* Fix Ctrl+click "Pop selected object out of group" [https://gitlab.com/inkscape/inkscape/-/merge_requests/2729 MR #2729])
* Wording and spelling improvements
* Improved colors selection of icons - This fixes multiple bugs for different Gtk themes and icon themes [https://gitlab.com/inkscape/inkscape/-/merge_requests/2845 2845]


=== Even more bug fixes ===
=== Even more bug fixes ===
Line 339: Line 361:


For a complete list, visit [https://gitlab.com/inkscape/inkscape/-/milestones/2 our GitLab issue tracker] and see the [https://gitlab.com/inkscape/inkscape/-/commits/1.0.x commit history] (all changes since DATE until release date).
For a complete list, visit [https://gitlab.com/inkscape/inkscape/-/milestones/2 our GitLab issue tracker] and see the [https://gitlab.com/inkscape/inkscape/-/commits/1.0.x commit history] (all changes since DATE until release date).
== Breaking changes / Action required ==


=== Extensions ===
=== Extensions ===


Element selections API has been improved, the API in '''10<span color="red">?</span>''' of using <code>self.svg.selected</code> is deprecated in favour of the new <code>self.svg.selection</code> interface. The previous API will continue to work for the time being but should be updated to the new API. Selection is now a type of ElementList which provides filtering, ordering and other generalised functionality, if you need an element list for example to make a bounding box, this is the way to do it.
* Element selections API has been improved, the API in '''10<span color="red">?</span>''' of using <code>self.svg.selected</code> is deprecated in favour of the new <code>self.svg.selection</code> interface. The previous API will continue to work for the time being but should be updated to the new API. Selection is now a type of ElementList which provides filtering, ordering and other generalised functionality, if you need an element list for example to make a bounding box, this is the way to do it.


== Translations ==
== Translations ==


The following UI translations received updates:
The following UI translations received updates [2021-03-03]:


* Language
* Basque
* Brazilian Portuguese
* Bulgarian
* Catalan
* Croatian
* Czech
* Danish
* Dutch
* French
* German
* Hungarian
* Icelandic
* Italian
* Korean
* Latvian
* Polish
* Simplified Chinese
* Spanish
* Traditional Chinese
* Turkish
* Ukrainian
 
The Windows installer translation was updated for [2021-03-03]:
 
* Czech


The following documentation translations received updates:
The following documentation translations received updates:


* Language
* Language
Additionally, time has been spent on improving translatability and adding hints for translators in various places.


=== Contributing to interface translations ===
=== Contributing to interface translations ===

Revision as of 17:49, 11 April 2021

Other languages:
Deutsch • ‎English • ‎español • ‎français • ‎português


Warning symbol.png These Release Notes are in Draft Status.

Important Links:



Warning symbol.png Notes:

For changes made even before the 1.0 release that aren't in 1.0, try to find out if the checked and not stroked ones here: https://gitlab.com/inkscape/inkscape/-/issues/1030 have really not been cherrypicked


Warning symbol.png Pending questions:


Release highlights

Definitely not released yet.

Inkscape 1.1 is the latest major Inkscape release that brings users many fresh new features and new functionality. The most notable changes include:

  • A Welcome dialog, where the theme can be selected, and some choices for the new document's size or file to open are available
  • A Commands palette that opens when the ? key is pressed and that allows to search and use many functions without having to use a keyboard shortcut or going through the menus
  • It is now possible to copy, cut and paste parts of paths with the Node tool
  • The dialog docking system has been rewritten, which resolves many issues with Inkscape's docked dialogs and allows you to dock dialogs on either side of the screen
  • New Outline Overlay mode that displays object outlines while also showing their real colors
  • Preferences options are now easier to find by using the new search field
  • It is no longer necessary to remember to click on 'Export' in the PNG Export dialog, as the exporting will already happen after the click on 'Save' in the file selection dialog.
  • Export as JPG, TIFF, optimized PNG and WebP directly from Inkscape

Important changes

For packagers

  • Inkscape no longer depends on GtkSpell and ASpell but on GSpell for spell checking.
  • lib2geom has been moved into its own git submodule (like the extensions), a new release is available.
  • Inkscape now ships a /share/themes folder with two custom themes that are only suitable for use with Inkscape (as a git submodule)

General user interface

Command palette

  • Pressing ? will open the new Command palette.
  • In the little overlay, a type-forward search allows you to find any available command to execute on the whole drawing or selection. The list of available commands is currently restricted to those commands that have already been converted to 'actions', as part of an ongoing effort. Additionally, it includes the option to import or open files from Inkscape's document usage history.
    • Some commands allow you to indicate parameters. A little keyboard icon will show you when the program expects a parameter (such as an angle for rotation, or a fraction for scaling). Note that the unit that is used for parameters is usually 'px', not the display unit. Some parameters require a specific format (like a comma-separated list of values for moving). The format is often indicated in the description of the command, e.g. to align selected objects to the last selected one's left side, find the 'align objects' command, then type 'left last'.
    • Some commands do nothing visible in the user interface (yet), as either
      • they only work in conjunction with other commands, such as commands that change how a file is exported, or commands that export the file. These need to be entered in order, e.g. export type ⯈ type 'png' ⯈ press Enter ⯈ press ?export file name ⯈ type a file name ⯈ press Enter ⯈ press ?export do ⯈ press Enter; export do in this example can also be used repeatedly to export the updated image to the same file name) or
      • they produce output on the command line (like commands asking for coordinates of objects), which you will only see if you have started Inkscape from the command line.
  • Press Enter to execute any command.
  • By pressing the (upwards arrow key), you enter the history mode, where you can choose between commands that you have already used.
  • To close the palette, if not using any of the commands offered, you can press ? again, or just click on the canvas.

If a keyboard shortcut is available for the selected command, it will show up in the command palette (in the form that it is saved in the keyboard shortcut file). In the settings, at Edit → Preferences → Interface: Command palette, you can select some of the info you would like the palette to display. In addition to the translated action name, it can also show the English names of the commands and the corresponding command line argument name.

This feature was added by Google Summer of Code Student Abhay Raj Singh in 2020. You can learn more about the feature's development on GitLab or in Abhay's blog entry. (UX issue #31, MR #2072)

Paste on top of selection

When pasting an object from the clipboard onto the canvas, Inkscape will now by default paste it right above the currently selected object. This feature can be disabled in Edit → Preferences → Behavior → Selecting: Paste on top of selection instead of layer-top (MR #2476, Usability test #65).

Canvas

New Display mode

  • 'Outline Overlay' display mode: In this mode, a toned down view of the drawing (not click-sensitive) is shown behind the (click-sensitive) object outlines. The opacity of the original drawing in this view mode can be set in Edit → Preferences → Rendering: Outline overlay opacity.

Handles

  • Inkscape now uses vector-based handles, which are currently hardcoded (not SVG) (MR #2334)
  • The maximum handle size has been increased, so users with HiDPI displays will be able to enlarge them to a more comfortable size from Edit → Preferences → Interface: Handle size
  • Rotation center handles have been made more visible

Handels.png

Tools

Calligraphy Tool

  • The tool now supports units for the width, with a much increased precision (up to three digits after the decimal separator, e.g. 0.005). The old, zoom-dependent width behavior is accessible with the unit '%'.
  • The entry field for 'Mass' has been moved towards left (for LTR languages) on the tool's tool controls bar, emphasizing its importance (MR #2816)

Connector tool

  • Connection lines now update in real time while objects are moved

Node tool

The node tool now allows to copy, cut and paste a selection of nodes. These nodes can be inserted into the original path, into a different path or they can be pasted as a completely new path.

Selector Tool

  • A new selection mode for the lasso/rubber-band selection was added, which can now select every object that is either within the box or that touches its boundaries. The mode can be activated by pressing the corresponding button in the Selector tool's tool controls bar. On canvas, the mode is visualized by changing the color of the selection box to dashed red line while dragging (MR #2520).

Touch rect.gif

Text Tool

  • Text-in-a-shape can now make use of justified text alignment.
  • Highlight all shapes: When editing text-in-shape or text-on-path, all shapes are highlighted, not only the first (MR #2468) and the orientation / position of the shapes is shown correctly (e.g. display rotated rectangle as being rotated).

Dialogs

General

  • Arrows on color sliders now have better visibility

Docking

Dialogs can now be docked on the left of the Inkscape window. They're now displayed as tabs, with optional label and icon. The dialog tabs can be combined to new floating docks. Tabs can be closed by middle mouse click, right-click and selecting to close, or by clicking on the x icon.

The work for this big code refactoring was undertaken by Google Summer of Code Student Valentin Ionita in 2020. You can learn more about his work on GitLab (technical documentation).

Docking demo.gif

Preferences dialog

  • The preferences dialog now features a search bar, which performs a recursive search over all the nested categories of settings:
    • press F3 or Ctrl + G for next result
    • press Shift + F3 or Ctrl + Shift+G for previous result
  • In Edit → Preferences → Imported images: Import, there is a new option that allows you to disable relative paths to linked files ("Store absolute file path for linked images", deactivated by default).
  • In Edit → Preferences → Rendering, there is a new option to Redraw while editing, which improves performance of redrawing with some faster CPUs ("Responsive", active by default, or "Conservative").
  • In Edit → Preferences → Behavior → Scrolling, the setting Mouse wheel zooms by default has been removed. This setting can now be set by disabling the modifier 'Ctrl' for Canvas zoom, and enabling it for Vertical pan instead (see section about 'Customization' below for more information).
  • The Zoom correction factor in Edit → Preferences → Interface now works correctly for other units than mm and remembers values below 100%.
  • There is an option now to adjust the number shown in the Zoom field in the bottom right corner to match the real world scale. The new option is active by default, so that, after adjusting the factor for your monitor, at 100% zoom, your document page is as large on the screen as it is in reality.

'About Inkscape' dialog

The Help → About Inkscape dialog has been rebuilt from scratch with a larger window (and image) and a tabbed interface.

  • The user-contributed About Screen artwork is now displayed much larger, as it should be!
  • Authors and translators are now featured on separate tabs.
  • A new license tab offers a brief explanation of Inkscape licensing.
  • All the tabs include calls to action or links to the official website for more information.
  • The current version of Inkscape is displayed on a button. When clicked, the full version information is copied to the clipboard, so it can be used in bug reports, for example.
  • In the bottom right corner, there is an additional small button with a little beetle on it. Clicking that button will copy extensive information about available software library versions, in addition to operating system and Inkscape version information.

Fill and Stroke

  • The stroke's width can now be set to Hairline in the dialog at Object → Fill and stroke → Stroke Style (as a unit). This type of stroke is always 1px wide, independent of the zoom level. The feature will hopefully one day be useful for laser cutting and plotting (MR #846)
    • Hairline strokes can be exported to file formats with native hairline support (PDF/PS), but this requires a code change in the Cairo software library, which has not been accepted (yet), so the PS/PDF hairline export feature will not yet be available in any official packages. If unavailable, a very thin line width will be used instead (1px at the "1:1 zoom" level of the output).
    • In other SVG renderers, hairlines will be handled via non-scaling stroke with a stroke width of 1px.
    • Export to PNG and rendering on canvas will use a line width of 1px.
  • The Miter maximum has been increased to 100000 (Commit 69dc16)
  • Stock markers use SVG 2.0 context-stroke to automatically take on the stroke color of the object (MR #2009). If SVG 1.1 compatibility is needed, the setting for marker colors in Edit → Preferences → Input/Output → SVG export can be activated and SVG 1.1 compatibility can be activated in the 'Save as' dialog.

InkscapeHairlines.gif

Gradient Editor dialog (removed)

  • The legacy gradient editor (a dialog that could previously be enabled in the preferences for the gradient tool) has been removed.

Text and Font dialog

'Welcome' dialog

A new welcome and onboarding screen was added. You can set up the look of Inkscape on a first run and select from presets of document settings. This dialog can be turned off.

Filters

  • A new "Fast Crop" filter can be found at Filters → Fill and transparency → Fast Crop (MR #2767)

Live path effects

Automatic fill preservation for path effects

LPEs which render strokes as fills (Join Type, Power Stroke, and Taper Stroke) have been modified to automatically preserve the previous fill by creating a linked clone with the original fill color when applied to an object.

"Boolean Operations" LPE

  • The path effect is no longer marked as experimental.
  • Operands can now easily be selected and moved with the mouse.
  • Improved stability

"Taper Stroke" LPE

The Taper stroke LPE has been updated to include taper direction options (allowing the taper to run to one side of the path, instead of to the middle) and smoothing options for both ends of the path, allowing more interesting paths to be made in the effect. In addition, Shift+clicking on the on-canvas handles allows quickly alternating between the different possible taper shapes.

"Fill between many" LPE

A new item Fill between Paths has been added under the Path menu to automatically create a linked fill path using the Fill between many path effect. The effect is created beneath the selected paths and automatically selected to faciliate moving the path into the correct z-order and styling it as intended. For greater efficiency, a shortcut can also be assigned, using the Preferences dialog.

This is especially useful for filling variable-width paths created with the PowerStroke option (or other live path effects that use the fill to emulate a stroke).

"Offset" LPE

  • The Offset LPE's performance was improved for more complex shapes.
  • Open paths can now have an offset that is not automatically closed [Known issue: when they don't self-intersect].

"Slice" LPE (new)

This new path effect allows you to split an object into two (or more by stacking multiple LPEs), without destroying the original. It works with groups, shapes, and paths. If you want to use it on Text, you need to use the 'Clone' LPE and apply the 'Slice' LPE on this clone. It also allows to change styles for the resulting parts, because each part is a separate object (MR #2372)

Slice LPE 1.gif

Import / Export

  • Inkscape can now recognize layers in SVG files exported from CorelDraw (MR !2046)
  • The Export PNG Image dialog now exports the PNG as soon as the button Export as has been clicked and a file name was selected for the file. It's no longer necessary to explicitly click on Export after choosing a file name. Clicking on Export will still be available to export to the file name that is currently set in the dialog.
  • Use the file name extensions '.jpg', '.webp' or '.tiff' in the PNG export dialog to open the corresponding export options and export to the selected file format. In the file chooser that opens after clicking on 'Export as', there is also a dropdown menu available to choose the file format. 'Optimized PNG' is available there as an additional option (as it uses the same file name extension, it's not possible to auto-detect). The export functionality is implemented using a Python extension of the new 'Raster Output' type.

Customization

Cursors

A set of SVG-based, themeable mouse cursors with HiDPI support were added. These new cursors are coupled with the icon themes. The default set (hicolor theme) is stored in ~inkscape\share\inkscape\icons\hicolor\cursors.

More information can be found on the SVG Cursors page.

Shortcuts

  • In Edit → Preferences → Interface → Keyboard, in the new Modifiers tab, you can customize keyboard shortcut modifiers for on-canvas mouse actions (for example holding Ctrl for scaling while keeping the object's aspect ratio can be changed to Shift) [Known issue: doesn't survive a restart]
  • Keyboard shortcut files for Inkscape can now inherit from other keyboard shortcut files by using XInclude (MR !1150)
  • Illustrator keyboard shortcut map has been updated to ... Fill me in

Themes

  • A contrast slider was added for finer control over any theme look at Preferences → Interface → Themeing → Contrast 906
  • A more compact Minwaita theme has been added
  • The win32 theme has been improved by adding some custom adjustments
Contrast slider.gif

macOS-specific Changes

  • New Inkscape icon (commit ee589650)
  • Visio files can be imported (issue #2094)
  • No longer bundle Ghostscript, effectively removing out of the box support for EPS and PS (MR #2608), information about workarounds can be found at https://gitlab.com/inkscape/inbox/-/issues/4321
  • This is the last release to support OS X El Capitan 10.11. Future releases will require at least macOS High Sierra 10.13 as oldest supported operating system. A few hours ago I got feedback on the upstream issue which is the deciding factor here. There's hope now, so let's not make an announcement like this just yet.

Extensions

Command line

  • The options x y z have been added back in to preserve compatibility with legacy Inkscape command line scripts (and ImageMagick's SVG conversion)
  • Added actions for aligning and distributing objects (MR #2472)
  • Shell mode: a history of commands is now remembered and can be accessed with the up and down arrow keys. [Tab ... autocompletion?]

Behind the curtains

Inkscape developers have also worked on improving and evolving parts of Inkscape which are not directly visible to the users. Indirectly, these changes will also benefit the users, as they make it easier for developers to work with the project, and help them make fewer mistakes.

  • Documentation for developers was updated and improved continuously, helping developers better understand other people's code
  • Outdated code was updated continuously, making it easier to handle the code moving forwards. This includes a continued effort to convert old C code to modern C++, removing dead code and rewriting parts of the code in a more modern way.
  • Code formatting was improved continuously, improving readability of the code
  • Continuous integration was updated and improved continuously, ensuring that each code change will be tested automatically and can be reviewed by bug reporters before it is included into the main line code, also keeping up with changes in GitLab, AppVeyor and other infrastructure that is used by Inkscape
  • Improvements were made to the build system, so Inkscape can be built on more Linux, Windows and macOS versions, keeping up with changes in software libraries that Inkscape depends upon
  • Many tests were added and improved, reducing the risk of accidental loss of functionality
  • Running test versions on Windows was simplified by adding shortcuts to the top level folder: Run Inkscape !.bat, Run Inkscape and create debug trace.bat, Run Inkscape with GTK Inspector.bat (MR #2884)

Notable bugfixes

Crash fixes

Fix a crash …

  • … when ... (#number)
  • when deleting the d attribute in the XML editor (MR #2722)

Other bug fixes

  • @import statements in CSS sheets are now processed in the correct order, so their styles are no longer overwritten unintentionally.
  • The color selector's color wheel looks better now on HiDPI screens (MR #2416)
  • Color slider handles look better now on HiDPI screens (MR #2733)
  • The color indicator field in the bottom left corner of the window now uses a constant width and has been cleaned up a bit (MR #2400)
  • The size of the double-arrow handles in the color sliders has been increased (MR #2427)
  • Fix of multiple regressions and bugs with Stroke to path (MR #2410)
  • Fix of feColorMatrix filter primitive default rendering (MR #2424)
  • You can now just click in the color wheel to select a color (MR #2428)
  • Reverse order of z-order buttons to achieve more consistency (MR #2556)
  • Fix reversed buttons in Arrange / Polar Coordinates (MR 2561)
  • Multiple Fixes for Selectors and CSS dialog (MR #1681)
  • Multiple fixes for command: Stroke to path (MR #2410)
  • Fixed rendering of antialiasing on clipping path (MR #2401)
  • Fix z-order rendering issue after ungrouping (MR #2452)
  • Fix copying mesh gradients to new document (MR #2362)
  • "X-Ray" mode no longer disables automatically when the cursor reaches the edge of the canvas (MR #2346)
  • Fix Ctrl+click "Pop selected object out of group" MR #2729)
  • Wording and spelling improvements
  • Improved colors selection of icons - This fixes multiple bugs for different Gtk themes and icon themes 2845

Even more bug fixes

There were even more issues fixed than those listed above, but these probably only affect a small portion of users, or are relevant for development and packaging only.

For a complete list, visit our GitLab issue tracker and see the commit history (all changes since DATE until release date).

Extensions

  • Element selections API has been improved, the API in 10? of using self.svg.selected is deprecated in favour of the new self.svg.selection interface. The previous API will continue to work for the time being but should be updated to the new API. Selection is now a type of ElementList which provides filtering, ordering and other generalised functionality, if you need an element list for example to make a bounding box, this is the way to do it.

Translations

The following UI translations received updates [2021-03-03]:

  • Basque
  • Brazilian Portuguese
  • Bulgarian
  • Catalan
  • Croatian
  • Czech
  • Danish
  • Dutch
  • French
  • German
  • Hungarian
  • Icelandic
  • Italian
  • Korean
  • Latvian
  • Polish
  • Simplified Chinese
  • Spanish
  • Traditional Chinese
  • Turkish
  • Ukrainian

The Windows installer translation was updated for [2021-03-03]:

  • Czech

The following documentation translations received updates:

  • Language

Additionally, time has been spent on improving translatability and adding hints for translators in various places.

Contributing to interface translations

Want to help with translations? Learn how to help!

Documentation

  • Some missing options were added to the man page (command line help)
  • Some missing keyboard shortcuts were added to the keyboard shortcut reference

Contributing to documentation and documentation translation

Contributions to the documentation translations, as well as improvements to its contents, are welcome at the inkscape-docs repository.

Known issues

Previous releases