Theme elements reference
A reference list of SVG elements
Last updated
A reference list of SVG elements
Last updated
As mentioned in , each theme is stored in its own sub-folder following the name of the theme.
Each theme contains the following file structure. All SVG files should be in either .svg
or .svgz
format.
If you are looking for a list of elements to start creating your Plasma Style fast, consider starting with the following recommended elements:
dialogs/background: background for Plasma widgets on the panel
widgets/arrows: arrows used in several places
widgets/background: background for Plasma widgets on the desktop
widgets/button: buttons used in several places
widgets/containment-controls: elements used for Edit Mode
widgets/panel-background: background for Plasma panels
widgets/plasmoidheading: heading and footer of Plasma widgets
widgets/tasks: task manager icons
widgets/tooltip: thumbnail shown when hovering task manager icons
This folder contains elements used for dialogs.
This file contains the generic dialog background used by Plasma widgets managed on the panel, in addition to the Add Widget pane, and KRunner.
This folder contains elements used for the generic background used for desktop widgets.
This file contains 9 overlays for icons used to indicate actions, with their respective states.
[type]-[state]
[type]
can be:
add
: icon used to add the parent icon to a selection of elements (used for instance to select files in Dolphin when you have Single Click enabled).
remove
: icon used to remove the parent icon to a selection of elements (used for instance to deselect files in Dolphin when you have Single Click enabled).
open
: icon used to initialize a tooltip (used for instance in the Folder View widget to preview the contents of a folder).
[state]
can be:
normal
hover
pressed
[size]-[state]
[size]
can be:
empty
24-24
22-22
16-16
[state]
can be:
normal
pressed
hover
focus
This file contains the icons used for an analog gauge widget (similar to a pressure gauge or fuel tank indicator).
Deprecated relic from KDE4, only used in plasma-sdk/themeexplorer.
background
: the body of the analog instrument
foreground
: the pin where the hand rotates
pointer
: the hand of the instrument
pointer-shadow
rotateminmax
: how much the hand can rotate, the width is the maximum angle in degrees the height the minimum angle
rotatecenter
label0
: the rect for the first label
label1
: the rect for the second label
Arrow icons that match the theme. Four elements should exist and have the following IDs in this SVG file:
up-arrow
right-arrow
down-arrow
left-arrow
This file contains the generic widget background used for Plasma widgets managed on the desktop or used in Edit Mode.
See the section on backgrounds above for information on the required elements in this file.
A horizontal meter that serves as a progressbar. Used, for instance, in the Battery and Brightness widget to indicate battery levels.
background
: background of the progressbar
background-[position]
: 9-piece SVG elements forming a single frame with the background
prefix, it replaces the background element if available
bar-[state]-[position]
: 9-piece SVG elements forming a single frame with the bar-active
and bar-inactive
prefixes used to replace the bar
element when available, they will be drawn tiled (repeating their pattern until they fill the available area), unless an element with ID hint-bar-stretch
exists.
[state]
can be:
active
: the colored section of the progressbar indicating active progress
inactive
: the grayed out section of the progressbar indicating remaining progress
[position]
can be:
top
topright
right
bottomright
bottom
bottomleft
left
topleft
center
label0
: <rect>
containing text to be shown at the beginning of the progressbar
label1
: <rect>
containing text to be shown at the end of the progressbar
label2
: <rect>
containing text to be shown at the middle of the progressbar
hint-bar-size
: default height of the bar, if not present the default is taken from sum of heights ofbar-inactive-top
and bar-inactive-bottom
hint-bar-stretch
: make the progressbar background element stretched rather than tiled
hint-tile-center
A little Plasma logo that can be customized by distributors as a branding element.
Contains a single element with ID brilliant
.
Used to indicate a busy state, it's a circular image that will be animated with a rotation. It is used for instance as the default animation in the Task Manager to indicate that an application is opening.
busywidget
: the main spinner
22-22-busywidget
16-16-busywidget
paused
: the paused state
hint-rotation-angle
This file contains graphical elements used for the standard button and toolbutton widgets.
[toolbutton/mask]-[state]-[position/hint]
[toolbutton]
can be:
toolbutton
: has no borders by default and only shows them when hovered, focused or pressed, so they can only be combined with these three prefixes. Used for instance for the Settings and Pin buttons of multiple Plasma widgets
empty
[mask]
can be:
mask
empty
[state]
can be:
normal
: default button
pressed
: pressed button
hover
: element that will be in the background ofthe widget, will act as a border (useful for gloweffects)
focus
: keyboard focus rectangle superimposed to the button graphics
shadow
: a shadow for the button, can be bigger than the button itself
[position]
can be:
top
topright
right
bottomright
bottom
bottomleft
left
topleft
center
[hint]
can be:
hint-top-margin
hint-right-margin
hint-bottom-margin
hint-left-margin
Two optional hints are available for the background rendering:
normal-hint-compose-over-border
pressed-hint-compose-over-border
To better visualize how the element names are composed, here is a random selection of possible example IDs for buttons and toolbuttons:
normal
topleft
normal-topleft
toolbutton
hover
bottom
toolbutton-hover-bottom
pressed
bottomright
pressed-bottomright
mask
normal
center
mask-normal-center
hover
hint-top-margin
hover-hint-top-margin
toolbutton
pressed
hint-left-margin
toolbutton-pressed-hint-left-margin
Each button/toolbutton consists of a single frame of 9 main elements for the rectangular shape and 4 extra elements for size hints. See the [Background SVG Format]({{< ref "background-svg.md" >}}) for details on handling positions and hints.
Contains a single element with ID event
.
This file contains only two elements:
radiobutton
: the ticked state of a radiobutton. The actual radio button is stored in [widgets/radiobutton.svg]({{< ref "#widgetsradiobuttonsvg" >}}) instead
checkbox
: the ticked state of a checkbox
If no checkmarks.svg
file is provided, the default style from Qt will be used instead.
This file contains the graphical elements needed to make an analog clock icon. It must have the following IDs:
ClockFace
: the background of the clock, usually containing the numbers and other background elements
HourHand
: the hour hand, pointing down in the SVG
MinuteHand
: the minute hand, pointing down in the SVG
SecondHand
: the second hand, pointing down in the SVG
HourHandShadow
, MinuteHandShadow
and SecondHandShadow
: drop shadows for the hands (optional)
HandCenterScrew
: the "pin" that holds the hands together in the center
Glass
: a final overlay which allows for things such as the appearance of glass
hint-square-clock
: if present the shape of the clock will be square rather than round
hint-[hand(shadow)]-rotation-center-offset
: the point of a hand (shadow) where it is "pinned" to the clock center, defined by the center of the hint, relative to the element position (can be outside the element)
[hand(shadow)]
: the default is "(width/2, width/2)" from top-left of the hand (shadow) element (since Plasma 5.16)
[hand(shadow)]
can be:
hourhand
hourhandshadow
minutehand
minutehandshadow
secondhand
secondhandshadow
hint-hands-shadow-offset-to-west
or hint-hands-shadows-offset-to-east
: horizontal offset of the hands shadows, default is 0 offset (since Plasma 5.16)
hint-hands-shadow-offset-to-north
or hint-hands-shadow-offset-to-south
: vertical offset of the hands shadows, default is 0 offset (since Plasma 5.16)
This file contains a set of simple icons that are meant to be shortcuts for configuration actions. Must contain the following elements:
close
: a close icon
configure
: a setup action
move
: a move action, similar to the cursor move state
size-vertical
: a vertical grab or resize action, similar to the cursor state when grabbing a separator between two panes
size-horizontal
: a horizontal grab or resize action, similar to the cursor state when grabbing a separator between two panes
size-diagonal-tl2br
: resize diagonally, usually an arrow from top-left to bottom-right
size-diagonal-tr2bl
: resize diagonally, usually an arrow from top-right to bottom-left
rotate
: a rotate action
help
: a help icon, similar to the KHelpCenter icon
maximize
: a maximize icon, not similar to the maximize window decoration
unmaximize
: an unmaximize icon, not the same as minimize
collapse
: set something in a minimized, collapsed status
restore
: restore from collapse status
status
: refers to a status of something, logging or system monitoring in general
return-to-source
: make detached extender items return to their owner applet
add
and remove
: specular actions, adding and removing for instance an item from a list
delete
: the (potentially dangerous) action of deleting something
showbackground
filter
: the icon for sorting/filtering actions
menu
: the icon for the hamburger menu
This file handles the controls used to resize the panel in Edit Mode.
Which control will be used depends on the position of the panel, namely the top, right, bottom and left edges of the screen, represented as [cardinaldirection]
:
[cardinaldirection]-[slidertype/position]
[cardinaldirection]
can be:
north
east
south
west
[slidertype]
can be:
empty
maxslider
maximum size slider
minslider
minimum size slider
offsetslider
positioning slider
[position]
can be:
top
topright
right
bottomright
bottom
bottomleft
left
topleft
center
horizontal-centerindicator
vertical-centerindicator
This file contains an icon meant to be a generic drag handle (not currently used, but available).
It also has the following elements:
hint-preferred-icon-size
: the size icons within the drag handle should get. The vertical size of the dragger is also derived from this: this size hint + the dragger's margins.
background-vertical-top
background-vertical-topright
background-vertical-topleft
This file contains a generic frame used mostly to visually group widgets together in widget containers.
[3dlook]-[position/hint]
[3dlook]
can be:
sunken
plain
raised
[position]
can be:
top
topright
right
bottomright
bottom
bottomleft
left
topleft
center
[hint]
can be:
hint-top-margin
hint-right-margin
hint-bottom-margin
hint-left-margin
This file contains a single frame that represents a glow and it is used for instance in the panel autohide/unhide hint of the Plasma Desktop.
In other words, it's simply:
[position/hint]
[position]
can be:
top
topright
right
bottomright
bottom
bottomleft
left
topleft
center
[hint]
can be:
hint-top-margin
hint-right-margin
hint-bottom-margin
hint-left-margin
Probably a relic from KDE 4.
shape[number]
[number]
can be from 1 to 32.
Probably a relic from KDE 4.
common-[type]
[type]
can be:
background
mask
content
normal-overlay
disabled-[type]
[type]
can be:
background
content
active-overlay
selected-overlay
This file contains a simple line used to separate items in layouts, it contains only two elements IDs:
vertical-line
horizontal-line
This file contains a frame SVG used to style line edits, spinboxes and other similar fields.
[state]-[position/hint]
[state]
can be:
base
: the background of the line edit
focus
: will be drawn outside the base, when the line edit has input focus
hover
: will be drawn outside the base, when the line edit is under the mouse
[position]
can be:
top
topright
right
bottomright
bottom
bottomleft
left
topleft
center
[hint]
can be:
hint-top-margin
hint-right-margin
hint-bottom-margin
hint-left-margin
This file contains an icon used for opened/clicked notifications.
[type]-[position/hint]
[type]
can be:
normal
pressed
hover
section
[position]
can be:
top
topright
right
bottomright
bottom
bottomleft
left
topleft
center
[hint]
can be:
hint-top-margin
hint-right-margin
hint-bottom-margin
hint-left-margin
hint-stretch-borders
hint-tile-center
separator
This file includes four diagonal margin elements with a triangle shape and a central fill
element.
topleft
topright
bottomright
bottomleft
fill
Intended to be used as delegate for media types.
picture-[selected]-[position/hint]
[selected]
can be:
empty
selected
[position]
can be:
top
topright
right
bottomright
bottom
bottomleft
left
topleft
center
[hint]
can be:
hint-top-margin
hint-right-margin
hint-bottom-margin
hint-left-margin
[state]-[position]
[state]
can be:
normal
hover
pressed
[position]
can be:
top
topright
right
bottomright
bottom
bottomleft
left
topleft
center
[state]-hint-[direction]-margin
[direction]
can be:
top
right
bottom
left
This file contains several elements used to represent a screen used in places such as the wallpaper configuration dialog.
[position]
[position]
can be:
top
topright
right
bottomright
bottom
bottomleft
left
topleft
center
glass
: glass reflection effect over the screen, to be overlayed on top of center
base
: a stand for the monitor
hint-stretch-borders
This file contains the elements used to design note stickers, with 10 different color variants:
[color]-notes
: colored note sticker
[color]
can be:
white
black
red
orange
yellow
green
blue
pink
translucent
translucent-light
This file contains the graphical elements used for the little rectangle screens of the Virtual Desktop Pager widgets.
It must have 3 frames with the following IDs:
[state]-[position]
[state]
can be:
normal
: all virtual desktops
active
: active virtual desktop
hover
: virtual desktop under mouse
[position]
can be:
top
topright
right
bottomright
bottom
bottomleft
left
topleft
center
And the following optional IDs:
left
right
bottom
center
hint-stretch-borders
This file contains the background image used for panels.
[position/hint]
[position]
can be:
top
topright
right
bottomright
bottom
bottomleft
left
topleft
center
[hint]
can be:
hint-top-margin
hint-right-margin
hint-bottom-margin
hint-left-margin
thick-[hint]
thick-center
shadow-[position/hint]
mask-[position/hint]
Optionally, for each of the base frames, if you want to create a different background for panels located at the top, bottom, left or right, you should create additional frames for each [cardinaldirection]
:
north
east
south
west
In other words, the available optional frames are:
[cardinaldirection]-[position/hint]
[cardinaldirection]-shadow-[position/hint]
[cardinaldirection]-mask-[position/hint]
All prefixes fallback to a no prefix version when not available.
If an element ID with prefix shadow
is available, it will be used as a drop shadow for the panel when compositing is available.
If an element called floating-center
is present, elements named floating-hint-[direction]-margin
(where direction
is one of top
, bottom
, left
or right
) set to a specific width and height can be used to specify the margins that panels should have in floating mode.
This file contains two frames following the [Background SVG Format]({{< ref "background-svg.md" >}}), in addition to a few hints:
[mask]-[position]
[mask]
can be:
empty
mask
[position]
can be:
top
topright
right
bottomright
bottom
bottomleft
left
topleft
center
hint-[direction]-margin
[direction]
can be:
top
right
bottom
left
hint-compose-over-border
hint-stretch-borders
This file contains the header and footer of a widget/notification popup.
It has 2 frames with the following prefixes:
header-[position]
: most widgets have the heading at the top
footer-[position]
: the reverse position of a header, typically in popups originating from a top panel
[position]
can be:
top
topright
right
bottomright
bottom
bottomleft
left
topleft
center
hint-top-margin
hint-right-margin
hint-bottom-margin
hint-left-margin
hint-stretch-borders
This file contains the background for plotting (graph) widgets, such as the plots in KSysGuard.
This seems to be deprecated.
This file contains four elements used to represent the different states of a radio button, two elements for additional decoration, and one hint to specify its size.
normal
: default state
checked
: checked state
hover
: hovered state
focus
: the state it will be in when using keyboard navigation, when the radio button is selected but not checked
shadow
: a shadow that be presented behind the radio button checked sign (symbol)
symbol
: the symbol to be used as a checked sign
hint-size
: the size of the whole radio button
This file contains the classical elevator
scrollbar. It must have the following prefixes:
[state]-arrow-[direction]
[state]
can be:
empty: default state
mouseover
: hovered state
sunken
: pressed state
[direction]
can be:
top
right
bottom
left
hint-scrollbar-size
: the size the scrollbar should be rendered as (the <width>
attribute will be used if vertical, <height>
if horizontal)
background-vertical-[position]
background-horizontal-[position]
[state]-slider-[position]
[position]
can be:
top
topright
right
bottomright
bottom
bottomleft
left
topleft
center
Used by Plasma::ScrollWidget, it must contain a single frame:
border-[position]
: the border used when the scrollbar is enabled
[position]
can be:
top
topright
right
bottomright
bottom
bottomleft
left
topleft
center
Used to theme sliders, it must have the following elements:
groove-[position]
: groove for the slider (since Plasma 4.8 replaces *-slider-line
)
groove-highlight-[position]
: highlight part of the groove (since Plasma 4.8 replaces *-slider-line
)
[position]
can be:
top
topright
right
bottomright
bottom
bottomleft
left
topleft
center
vertical-slider-line
: the background for vertical sliders, it indicates how much the indicator can scroll (replaced by groove-*
)
vertical-slider-handle
: the handle for vertical sliders
vertical-slider-focus
: background for the handle when it has input focus
vertical-slider-hover
: background for the handle when it is under the mouse
horizontal-slider-line
: the background for horizontal sliders (replaced by groove-*
)
horizontal-slider-handle
: the handle for horizontal sliders
horizontal-slider-focus
: background for the handle when it has input focus
horizontal-slider-hover
: background for the handle when it is under the mouse
hint-stretch-borders
This file contains graphical elements for tabbars.
This is used, for instance, in the Grouped Widget, the Applications/Places tabs of Kickoff, and in the Devices/Applications tabs of plasma-pa.
It must have 4 frames, each one for tabs in the possible orientations a tabbar can be relative to its contents or window, that is to say, the top, right, bottom and left edges of the window/plasmoid, represented as [cardinaldirection]
:
[cardinaldirection]-active-tab-[position/hint]
[cardinaldirection]
can be:
north
east
south
west
[position]
can be:
top
topright
right
bottomright
bottom
bottomleft
left
topleft
center
[hint]
can be:
hint-top-margin
hint-right-margin
hint-bottom-margin
hint-left-margin
hint-tile-center
Each task [state]
must be represented by a single frame of 9 [position]
elements. The size [hint]
can only be applied to the normal state.
Optionally, for each of the base frames, if you want to create a different background for task items located at the top, bottom, left or right edges of the panel, you should create additional frames for each [cardinaldirection]
:
panel-[cardinaldirection]
: elements for the panel toolbox.
[cardinaldirection]-[state]-[position]
: if any of the 5 states is missing, that element will be not be drawn
[cardinaldirection]
can be:
north
east
south
west
[state]
can be:
normal
: background of normal, unfocused task item
focus
: background of focused task item. It can have thicker borders that will be painted outside the task button, useful to make a glow effect
hover
: background when hovering the task item. It can have thicker borders that will be painted outside the task button, useful to make a glow effect
attention
: background when a task item is trying to get attention
minimized
: background for minimized tasks
[position]
can be:
top
topright
right
bottomright
bottom
bottomleft
left
topleft
center
normal-[hint]
[hint]
can be:
hint-top-margin
hint-right-margin
hint-bottom-margin
hint-left-margin
group-expander-[direction]
[direction]
can be:
top
right
bottom
left
hint-stretch-borders
This file contains the numbers and separators used for the Timer widget.
[number]
: the numbers in default state
[number]
can be numbers from 0 to 9
[number]_1
: the numbers in countdown state, typically with red color
separator
: the default separator (:
)
separator_1
: the default separator (:
), in countdown state
separatorB
: the dot separator (.
)
separatorB_1
: the dot separator (.
), in countdown state
separatorC
: the blank separator ( )
separatorC_1
: the blank separator ( ), in countdown state
Used in the ToolBar QML component, it can be used in custom applications in a similar way and must use a single frame without prefix.
[position]
[position]
can be:
top
topright
right
bottomright
bottom
bottomleft
left
topleft
center
hint-stretch-borders
Probably a relic from KDE 4.
[position]
mask-[position]
[position]
can be:
top
topright
right
bottomright
bottom
bottomleft
left
topleft
center
desktop-[diagonalcardinaldirection]
[diagonalcardinaldirection]
can be:
northeast
southeast
southwest
northwest
panel-[cardinaldirection]
[cardinaldirection]
can be:
north
east
south
west
hint-[direction]-[type]
[direction]
can be:
top
right
bottom
left
[type]
can be:
margin
shadow
hint-stretch-borders
hint-compose-over-border
Background for tooltips used for instance in the panel taskbar.
A standard background image for plasmoids that for their nature are bigger and with not much text. In this case a translucent background looks better.
If this file is not present, plasmoids that use this will use background.svg
instead.
Controls the background look of selections (results in KRunner, networks in network applet), it can have 4 frame of 9 parts each:
[state]-[position]
[state]
can be:
normal
hover
selected
selected+hover
.
[position]
can be:
top
topright
right
bottomright
bottom
bottomleft
left
topleft
center
hint-tile-center
The folders opaque/
, solid/
and translucent/
contain special versions of some of the theme elements that will be activated under certain conditions and preferred over the corresponding files listed above if present. Only elements that will be rendered as top level window backgrounds should be present in these folders, so the dialogs folder, plus the panel and tooltip backgrounds; the file hierarchy is the same as in the level above.
Elements in this folder are used when compositing is disabled, which can only be done in the X11 session.
Since top-level windows will be shaped according to the transparency of the SVG and window shapes don't support alpha-blending, if the SVG has rounded borders, those borders should have a shape that doesn't require anti-aliasing, like the following example.
Elements in this folder will be used when compositing is available, but elements should not be rendered transparent.
For example, if a panel is configured to use adaptive opacity and a maximized window is present, then an opaque version of the panel is used rather than a transparent version.
Elements in this folder will be used when the KWin Background Contrast effect is enabled. When it is possible to blur the background of the window, the graphics can be more transparent, keeping the window text readable.
In the folder icons/
, there are SVG files that contain scalable icons for use with application status items (for example, icons in the system tray).
Some of the most common icons:
audio.svg
battery.svg
computer.svg
configure.svg
device.svg
input.svg
media.svg
network.svg
notification.svg
preferences.svg
start.svg
system.svg
See for information on the required elements in this file.
See for information on the required elements in this file.
A vertical meter that serves as a vertical progressbar. It has the same format of .
It is proportional to the , and while it is no longer in use by Plasma, the marking can be found in the third party to represent an event happening during a certain day.
It uses the same elements as other backgrounds similarly to the , except left
, topleft
, bottomleft
, right
, topright
, bottomright
.
It must have three frames and uses the same elements as other backgrounds similarly to the , but with the following [3dlook]
prefixes:
It follows the , without prefixes.
It must have three frames and uses the same elements as other backgrounds, similarly to the , but with the following [state]
prefixes:
It must have 3 frames and uses the same elements as other backgrounds, similarly to the , but with the following [type]
prefixes:
It uses the same elements as other backgrounds, similarly to the , but with the [picture]
and [selected]
prefixes:
This file contains three frames of 9 elements, similarly to the , with each frame representing a menu state:
It contains a frame with 9 elements, similarly to the , and a few extra elements:
It follows the and must have at least one frame and at most three frames. In other words, the available base frames are:
See for information on the required elements in this file.
This file contains elements used for task item backgrounds in the panel Task Manager and follows the , with a few extras.
See , for information on the required elements in this file.
See for information on the required elements in this file.
Deprecated in Plasma 6 The use of special icons provided by the Plasma theme to be used in the system tray has been and tray icons now come from the icon theme. See for details.