2020-07-27 16:49:39 +02:00
|
|
|
|
---
|
2021-12-16 17:08:57 +01:00
|
|
|
|
icon: material/image-frame
|
2020-07-27 16:49:39 +02:00
|
|
|
|
---
|
|
|
|
|
|
|
|
|
|
# Images
|
|
|
|
|
|
|
|
|
|
While images are first-class citizens of Markdown and part of the core syntax,
|
|
|
|
|
it can be difficult to work with them. Material for MkDocs makes working with
|
2021-10-10 12:19:14 +02:00
|
|
|
|
images more comfortable, providing styles for image alignment and image
|
|
|
|
|
captions.
|
2020-07-27 16:49:39 +02:00
|
|
|
|
|
|
|
|
|
## Configuration
|
|
|
|
|
|
2021-10-10 12:19:14 +02:00
|
|
|
|
This configuration adds the ability to align images, add captions to images
|
|
|
|
|
(rendering them as figures), and mark large images for lazy-loading. Add the
|
|
|
|
|
following lines to `mkdocs.yml`:
|
2020-07-27 16:49:39 +02:00
|
|
|
|
|
|
|
|
|
``` yaml
|
|
|
|
|
markdown_extensions:
|
|
|
|
|
- attr_list
|
2021-10-10 12:19:14 +02:00
|
|
|
|
- md_in_html
|
2020-07-27 16:49:39 +02:00
|
|
|
|
```
|
|
|
|
|
|
2021-10-10 12:19:14 +02:00
|
|
|
|
See additional configuration options:
|
|
|
|
|
|
|
|
|
|
- [Attribute Lists]
|
|
|
|
|
- [Markdown in HTML]
|
|
|
|
|
|
|
|
|
|
[Attribute Lists]: ../setup/extensions/python-markdown.md#attribute-lists
|
|
|
|
|
[Markdown in HTML]: ../setup/extensions/python-markdown.md#markdown-in-html
|
2020-07-27 16:49:39 +02:00
|
|
|
|
|
2022-07-17 12:29:30 +02:00
|
|
|
|
### Lightbox
|
|
|
|
|
|
2022-09-11 19:25:40 +02:00
|
|
|
|
[:octicons-tag-24: 0.1.0][Lightbox support] ·
|
2022-07-17 12:29:30 +02:00
|
|
|
|
[:octicons-cpu-24: Plugin][glightbox]
|
|
|
|
|
|
|
|
|
|
If you want to add image zoom functionality to your documentation, the
|
|
|
|
|
[glightbox] plugin is an excellent choice, as it integrates perfectly
|
|
|
|
|
with Material for MkDocs. Install it with `pip`:
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
pip install mkdocs-glightbox
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
Then, add the following lines to `mkdocs.yml`:
|
|
|
|
|
|
|
|
|
|
``` yaml
|
|
|
|
|
plugins:
|
|
|
|
|
- glightbox
|
|
|
|
|
```
|
|
|
|
|
|
2022-07-18 12:55:50 +02:00
|
|
|
|
We recommend checking out the available
|
2022-07-17 12:29:30 +02:00
|
|
|
|
[configuration options][glightbox options].
|
|
|
|
|
|
2022-09-11 19:25:40 +02:00
|
|
|
|
[Lightbox support]: https://github.com/squidfunk/mkdocs-material/releases/tag/0.1.0
|
2022-07-17 12:29:30 +02:00
|
|
|
|
[glightbox]: https://github.com/blueswen/mkdocs-glightbox
|
|
|
|
|
[glightbox options]: https://github.com/blueswen/mkdocs-glightbox#usage
|
|
|
|
|
|
2020-07-27 16:49:39 +02:00
|
|
|
|
## Usage
|
|
|
|
|
|
|
|
|
|
### Image alignment
|
|
|
|
|
|
2021-10-10 12:19:14 +02:00
|
|
|
|
When [Attribute Lists] is enabled, images can be aligned by adding the
|
|
|
|
|
respective alignment directions via the `align` attribute, i.e. `align=left` or
|
|
|
|
|
`align=right`:
|
2020-07-27 16:49:39 +02:00
|
|
|
|
|
|
|
|
|
=== "Left"
|
|
|
|
|
|
2022-01-10 14:31:58 +01:00
|
|
|
|
``` markdown title="Image, aligned to left"
|
2021-12-13 19:32:45 +01:00
|
|
|
|
![Image title](https://dummyimage.com/600x400/eee/aaa){ align=left }
|
2020-07-27 16:49:39 +02:00
|
|
|
|
```
|
|
|
|
|
|
2022-01-10 14:31:58 +01:00
|
|
|
|
<div class="result" markdown>
|
2020-07-27 16:49:39 +02:00
|
|
|
|
|
2023-02-06 13:59:33 +01:00
|
|
|
|
![Image title](https://dummyimage.com/600x400/f5f5f5/aaaaaa?text=–%20Image%20–){ align=left width=300 }
|
2020-07-27 16:49:39 +02:00
|
|
|
|
|
|
|
|
|
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nulla et euismod
|
|
|
|
|
nulla. Curabitur feugiat, tortor non consequat finibus, justo purus auctor
|
|
|
|
|
massa, nec semper lorem quam in massa.
|
|
|
|
|
|
2022-01-10 14:31:58 +01:00
|
|
|
|
</div>
|
2020-07-27 16:49:39 +02:00
|
|
|
|
|
2022-01-10 14:31:58 +01:00
|
|
|
|
=== "Right"
|
2020-07-27 16:49:39 +02:00
|
|
|
|
|
2022-01-10 14:31:58 +01:00
|
|
|
|
``` markdown title="Image, aligned to right"
|
2021-12-13 19:32:45 +01:00
|
|
|
|
![Image title](https://dummyimage.com/600x400/eee/aaa){ align=right }
|
2020-07-27 16:49:39 +02:00
|
|
|
|
```
|
|
|
|
|
|
2022-01-10 14:31:58 +01:00
|
|
|
|
<div class="result" markdown>
|
2020-07-27 16:49:39 +02:00
|
|
|
|
|
2023-02-06 13:59:33 +01:00
|
|
|
|
![Image title](https://dummyimage.com/600x400/f5f5f5/aaaaaa?text=–%20Image%20–){ align=right width=300 }
|
2020-07-27 16:49:39 +02:00
|
|
|
|
|
|
|
|
|
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nulla et euismod
|
|
|
|
|
nulla. Curabitur feugiat, tortor non consequat finibus, justo purus auctor
|
|
|
|
|
massa, nec semper lorem quam in massa.
|
|
|
|
|
|
2022-01-10 14:31:58 +01:00
|
|
|
|
</div>
|
|
|
|
|
|
2021-10-10 12:19:14 +02:00
|
|
|
|
If there's insufficient space to render the text next to the image, the image
|
|
|
|
|
will stretch to the full width of the viewport, e.g. on mobile viewports.
|
|
|
|
|
|
|
|
|
|
??? question "Why is there no centered alignment?"
|
|
|
|
|
|
|
|
|
|
The [`align`][align] attribute doesn't allow for centered alignment, which
|
|
|
|
|
is why this option is not supported by Material for MkDocs.[^1] Instead,
|
|
|
|
|
the [image captions] syntax can be used, as captions are optional.
|
|
|
|
|
|
|
|
|
|
[^1]:
|
|
|
|
|
You might also realize that the [`align`][align] attribute has been
|
|
|
|
|
deprecated as of HTML5, so why use it anyways? The main reason is
|
|
|
|
|
portability – it's still supported by all browsers and clients, and is very
|
|
|
|
|
unlikely to be completely removed, as many older websites still use it. This
|
|
|
|
|
ensures a consistent appearance when a Markdown file with these attributes
|
|
|
|
|
is viewed outside of a website generated by Material for MkDocs.
|
2020-07-27 16:49:39 +02:00
|
|
|
|
|
2021-10-10 12:19:14 +02:00
|
|
|
|
[align]: https://developer.mozilla.org/en-US/docs/Web/HTML/Element/img#deprecated_attributes
|
|
|
|
|
[image captions]: #image-captions
|
2020-08-16 09:54:08 +02:00
|
|
|
|
|
2020-07-27 16:49:39 +02:00
|
|
|
|
### Image captions
|
|
|
|
|
|
|
|
|
|
Sadly, the Markdown syntax doesn't provide native support for image captions,
|
2022-01-10 14:31:58 +01:00
|
|
|
|
but it's always possible to use the [Markdown in HTML] extension with literal
|
|
|
|
|
`figure` and `figcaption` tags:
|
2020-07-27 16:49:39 +02:00
|
|
|
|
|
2022-01-10 14:31:58 +01:00
|
|
|
|
``` html title="Image with caption"
|
|
|
|
|
<figure markdown>
|
2021-12-13 19:32:45 +01:00
|
|
|
|
![Image title](https://dummyimage.com/600x400/){ width="300" }
|
2020-07-27 16:49:39 +02:00
|
|
|
|
<figcaption>Image caption</figcaption>
|
|
|
|
|
</figure>
|
|
|
|
|
```
|
|
|
|
|
|
2022-01-10 14:31:58 +01:00
|
|
|
|
<div class="result">
|
|
|
|
|
<figure>
|
2023-02-06 13:59:33 +01:00
|
|
|
|
<img src="https://dummyimage.com/600x400/f5f5f5/aaaaaa?text=–%20Image%20–" width="300" />
|
2022-01-10 14:31:58 +01:00
|
|
|
|
<figcaption>Image caption</figcaption>
|
|
|
|
|
</figure>
|
|
|
|
|
</div>
|
2021-10-04 23:36:31 +02:00
|
|
|
|
|
2023-08-21 19:16:16 +03:00
|
|
|
|
|
|
|
|
|
Another option is to use [Markdown captions](https://github.com/Evidlo/markdown_captions) extension
|
|
|
|
|
which converts images with alt text to \<figure\> with \<figcaption\>.
|
|
|
|
|
|
|
|
|
|
``` html title="Image with caption"
|
|
|
|
|
![Image caption](https://dummyimage.com/600x400/){ width="300" }
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
<div class="result">
|
|
|
|
|
<figure>
|
|
|
|
|
<img src="https://dummyimage.com/600x400/f5f5f5/aaaaaa?text=–%20Image%20–" width="300" />
|
|
|
|
|
<figcaption>Image caption</figcaption>
|
|
|
|
|
</figure>
|
|
|
|
|
</div>
|
|
|
|
|
|
2020-08-16 09:54:08 +02:00
|
|
|
|
### Image lazy-loading
|
|
|
|
|
|
2021-10-10 12:19:14 +02:00
|
|
|
|
Modern browsers provide [native support for lazy-loading images][lazy-loading]
|
|
|
|
|
through the `loading=lazy` directive, which degrades to eager-loading in
|
2021-10-10 19:22:13 +02:00
|
|
|
|
browsers without support:
|
2020-08-16 09:54:08 +02:00
|
|
|
|
|
2022-01-10 14:31:58 +01:00
|
|
|
|
``` markdown title="Image, lazy-loaded"
|
2021-12-13 19:32:45 +01:00
|
|
|
|
![Image title](https://dummyimage.com/600x400/){ loading=lazy }
|
2020-08-16 09:54:08 +02:00
|
|
|
|
```
|
|
|
|
|
|
2022-01-10 14:31:58 +01:00
|
|
|
|
<div class="result" markdown>
|
2023-02-06 13:59:33 +01:00
|
|
|
|
<img src="https://dummyimage.com/600x400/f5f5f5/aaaaaa?text=–%20Image%20–" width="300" />
|
2022-01-10 14:31:58 +01:00
|
|
|
|
</div>
|
|
|
|
|
|
2021-10-10 12:19:14 +02:00
|
|
|
|
[lazy-loading]: https://caniuse.com/#feat=loading-lazy-attr
|
2021-12-11 15:40:13 +01:00
|
|
|
|
|
|
|
|
|
### Light and dark mode
|
|
|
|
|
|
2023-01-01 19:17:33 +01:00
|
|
|
|
[:octicons-tag-24: 8.1.1][Light and dark mode support]
|
2021-12-11 15:40:13 +01:00
|
|
|
|
|
|
|
|
|
If you added a [color palette toggle] and want to show different images for
|
|
|
|
|
light and dark color schemes, you can append a `#only-light` or `#only-dark`
|
|
|
|
|
hash fragment to the image URL:
|
|
|
|
|
|
2022-01-10 14:31:58 +01:00
|
|
|
|
``` markdown title="Image, different for light and dark mode"
|
2021-12-13 19:32:45 +01:00
|
|
|
|
![Image title](https://dummyimage.com/600x400/f5f5f5/aaaaaa#only-light)
|
|
|
|
|
![Image title](https://dummyimage.com/600x400/21222c/d5d7e2#only-dark)
|
2021-12-11 15:40:13 +01:00
|
|
|
|
```
|
|
|
|
|
|
2022-01-10 14:31:58 +01:00
|
|
|
|
<div class="result" markdown>
|
2021-12-11 15:40:13 +01:00
|
|
|
|
|
2021-12-13 19:32:45 +01:00
|
|
|
|
![Zelda light world]{ width="300" }
|
|
|
|
|
![Zelda dark world]{ width="300" }
|
2021-12-11 15:40:13 +01:00
|
|
|
|
|
2022-01-10 14:31:58 +01:00
|
|
|
|
</div>
|
|
|
|
|
|
2023-05-12 16:51:42 +02:00
|
|
|
|
!!! warning "Requirements when using [custom color schemes]"
|
|
|
|
|
|
|
|
|
|
The built-in [color schemes] define the aforementioned hash fragments, but
|
|
|
|
|
if you're using [custom color schemes], you'll also have to add the
|
|
|
|
|
following selectors to your scheme, depending on whether it's a light or
|
|
|
|
|
dark scheme:
|
|
|
|
|
|
|
|
|
|
=== "Custom light scheme"
|
|
|
|
|
|
|
|
|
|
``` css
|
2023-06-22 15:59:22 -04:00
|
|
|
|
[data-md-color-scheme="custom-light"] img[src$="#only-dark"],
|
2023-05-12 16:51:42 +02:00
|
|
|
|
[data-md-color-scheme="custom-light"] img[src$="#gh-dark-mode-only"] {
|
|
|
|
|
display: none; /* Hide dark images in light mode */
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
=== "Custom dark scheme"
|
|
|
|
|
|
|
|
|
|
``` css
|
|
|
|
|
[data-md-color-scheme="custom-dark"] img[src$="#only-light"],
|
|
|
|
|
[data-md-color-scheme="custom-dark"] img[src$="#gh-light-mode-only"] {
|
|
|
|
|
display: none; /* Hide light images in dark mode */
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
Remember to change `#!css "custom-light"` and `#!css "custom-dark"` to the
|
|
|
|
|
name of your scheme.
|
|
|
|
|
|
2021-12-11 15:40:13 +01:00
|
|
|
|
[Light and dark mode support]: https://github.com/squidfunk/mkdocs-material/releases/tag/8.1.1
|
|
|
|
|
[color palette toggle]: ../setup/changing-the-colors.md#color-palette-toggle
|
2021-12-13 19:32:45 +01:00
|
|
|
|
[Zelda light world]: ../assets/images/zelda-light-world.png#only-light
|
|
|
|
|
[Zelda dark world]: ../assets/images/zelda-dark-world.png#only-dark
|
2023-05-12 16:51:42 +02:00
|
|
|
|
[color schemes]: ../setup/changing-the-colors.md#color-scheme
|
|
|
|
|
[custom color schemes]: ../setup/changing-the-colors.md#custom-color-schemes
|